diff options
author | Gabe Black <gblack@eecs.umich.edu> | 2010-06-02 12:58:07 -0500 |
---|---|---|
committer | Gabe Black <gblack@eecs.umich.edu> | 2010-06-02 12:58:07 -0500 |
commit | 952253483b85bee25f8ef23cc147fade2bf0c00f (patch) | |
tree | 7b23d11210a8e379022933f5b15eb16e1f30e37f /src/arch/arm/isa/formats | |
parent | f7f75ad053b492897ffc76808541dc40f2239aed (diff) | |
download | gem5-952253483b85bee25f8ef23cc147fade2bf0c00f.tar.xz |
ARM: Rearrange the load/store double/exclusive, table branch thumb decoding.
Diffstat (limited to 'src/arch/arm/isa/formats')
-rw-r--r-- | src/arch/arm/isa/formats/mem.isa | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/src/arch/arm/isa/formats/mem.isa b/src/arch/arm/isa/formats/mem.isa index 2ea45733b..209f62af4 100644 --- a/src/arch/arm/isa/formats/mem.isa +++ b/src/arch/arm/isa/formats/mem.isa @@ -235,6 +235,60 @@ def format ArmSyncMem() {{ ''' }}; +def format Thumb32LdrStrDExTbh() {{ + decode_block = ''' + { + const uint32_t op1 = bits(machInst, 24, 23); + const uint32_t op2 = bits(machInst, 21, 20); + const uint32_t op3 = bits(machInst, 7, 4); + const IntRegIndex rn = (IntRegIndex)(uint32_t)bits(machInst, 19, 16); + if (bits(op1, 1) == 0 && bits(op2, 1) == 0) { + if (op1 == 0) { + if (op2 == 0) { + return new WarnUnimplemented("strex", machInst); + } else { + return new WarnUnimplemented("ldrex", machInst); + } + } else { + if (op2 == 0) { + switch (op3) { + case 0x4: + return new WarnUnimplemented("strexb", machInst); + case 0x5: + return new WarnUnimplemented("strexh", machInst); + case 0x7: + return new WarnUnimplemented("strexd", machInst); + default: + return new Unknown(machInst); + } + } else { + switch (op3) { + case 0x0: + return new WarnUnimplemented("tbb", machInst); + case 0x1: + return new WarnUnimplemented("tbh", machInst); + case 0x4: + return new WarnUnimplemented("ldrexb", machInst); + case 0x5: + return new WarnUnimplemented("ldrexh", machInst); + case 0x7: + return new WarnUnimplemented("ldrexd", machInst); + default: + return new Unknown(machInst); + } + } + } + } else { + if (bits(op2, 0) == 0) { + return new WarnUnimplemented("strd", machInst); + } else { + return new WarnUnimplemented("ldrd", machInst); + } + } + } + ''' +}}; + def format Thumb32LoadWord() {{ decode = ''' { |