summaryrefslogtreecommitdiff
path: root/src/arch/arm/isa/formats
diff options
context:
space:
mode:
authorGabe Black <gblack@eecs.umich.edu>2010-06-02 12:58:07 -0500
committerGabe Black <gblack@eecs.umich.edu>2010-06-02 12:58:07 -0500
commit952253483b85bee25f8ef23cc147fade2bf0c00f (patch)
tree7b23d11210a8e379022933f5b15eb16e1f30e37f /src/arch/arm/isa/formats
parentf7f75ad053b492897ffc76808541dc40f2239aed (diff)
downloadgem5-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.isa54
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 = '''
{