diff options
author | Gabe Black <gblack@eecs.umich.edu> | 2010-06-02 12:58:11 -0500 |
---|---|---|
committer | Gabe Black <gblack@eecs.umich.edu> | 2010-06-02 12:58:11 -0500 |
commit | eb1447302d03f1cbd88870f185310eef3f2db054 (patch) | |
tree | d082b47b115697b969ffe622bc740d3b2fedbe0e /src/arch/arm/isa/formats/mem.isa | |
parent | bb6fea91da7c5436d26d6b93f22b2dd5cd6287ba (diff) | |
download | gem5-eb1447302d03f1cbd88870f185310eef3f2db054.tar.xz |
ARM: Decode the SRS instruction.
Diffstat (limited to 'src/arch/arm/isa/formats/mem.isa')
-rw-r--r-- | src/arch/arm/isa/formats/mem.isa | 25 |
1 files changed, 21 insertions, 4 deletions
diff --git a/src/arch/arm/isa/formats/mem.isa b/src/arch/arm/isa/formats/mem.isa index 15a4a5c4f..aa8bbf55e 100644 --- a/src/arch/arm/isa/formats/mem.isa +++ b/src/arch/arm/isa/formats/mem.isa @@ -263,10 +263,10 @@ def format ArmSyncMem() {{ def format Thumb32SrsRfe() {{ decode_block = ''' { + const bool wb = (bits(machInst, 21) == 1); + const bool add = (bits(machInst, 24, 23) == 0x3); if (bits(machInst, 20) == 1) { - const bool add = (bits(machInst, 24, 23) == 0x3); // post == add - const bool wb = (bits(machInst, 21) == 1); const IntRegIndex rn = (IntRegIndex)(uint32_t)bits(machInst, 19, 16); if (!add && !wb) { @@ -279,14 +279,31 @@ def format Thumb32SrsRfe() {{ return new %(rfe_uw)s(machInst, rn, RfeOp::IncrementAfter, wb); } } else { - return new WarnUnimplemented("srs", machInst); + const uint32_t mode = bits(machInst, 4, 0); + if (!add && !wb) { + return new %(srs)s(machInst, mode, + SrsOp::DecrementBefore, wb); + } else if (add && !wb) { + return new %(srs_u)s(machInst, mode, + SrsOp::IncrementAfter, wb); + } else if (!add && wb) { + return new %(srs_w)s(machInst, mode, + SrsOp::DecrementBefore, wb); + } else { + return new %(srs_uw)s(machInst, mode, + SrsOp::IncrementAfter, wb); + } } } ''' % { "rfe" : "RFE_" + loadImmClassName(False, False, False, 8), "rfe_u" : "RFE_" + loadImmClassName(True, True, False, 8), "rfe_w" : "RFE_" + loadImmClassName(False, False, True, 8), - "rfe_uw" : "RFE_" + loadImmClassName(True, True, True, 8) + "rfe_uw" : "RFE_" + loadImmClassName(True, True, True, 8), + "srs" : "SRS_" + storeImmClassName(False, False, False, 8), + "srs_u" : "SRS_" + storeImmClassName(True, True, False, 8), + "srs_w" : "SRS_" + storeImmClassName(False, False, True, 8), + "srs_uw" : "SRS_" + storeImmClassName(True, True, True, 8) } }}; |