From: Gabe Black Date: Wed, 2 Jun 2010 17:58:05 +0000 (-0500) Subject: ARM: Make LDM that loads the PC perform an interworking branch. X-Git-Tag: stable_2012_02_02~1286 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=57443a2144c6f446c7b7a3de7389ae794d591330;p=gem5.git ARM: Make LDM that loads the PC perform an interworking branch. --- diff --git a/src/arch/arm/isa/insts/macromem.isa b/src/arch/arm/isa/insts/macromem.isa index 474e4fab0..13eb70b39 100644 --- a/src/arch/arm/isa/insts/macromem.isa +++ b/src/arch/arm/isa/insts/macromem.isa @@ -53,7 +53,7 @@ let {{ let {{ microLdrUopIop = InstObjParams('ldr_uop', 'MicroLdrUop', 'MicroMemOp', - {'memacc_code': 'Ra = Mem;', + {'memacc_code': 'IWRa = Mem;', 'ea_code': 'EA = Rb + (up ? imm : -imm);', 'predicate_test': predicateTest}, ['IsMicroop']) diff --git a/src/arch/arm/isa/operands.isa b/src/arch/arm/isa/operands.isa index c507864b6..c845acc94 100644 --- a/src/arch/arm/isa/operands.isa +++ b/src/arch/arm/isa/operands.isa @@ -129,6 +129,8 @@ def operands {{ #Register fields for microops 'Ra' : ('IntReg', 'uw', 'ura', 'IsInteger', 11, maybePCRead, maybePCWrite), + 'IWRa' : ('IntReg', 'uw', 'ura', 'IsInteger', 11, + maybePCRead, maybeIWPCWrite), 'Fa' : ('FloatReg', 'sf', 'ura', 'IsFloating', 11), 'Rb' : ('IntReg', 'uw', 'urb', 'IsInteger', 12, maybePCRead, maybePCWrite),