From: Gabe Black Date: Wed, 2 Jun 2010 17:58:06 +0000 (-0500) Subject: ARM: Decode the SADD8 and SADD16 instructions. X-Git-Tag: stable_2012_02_02~1277 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=bcf0454864b32dfc196585963d1a554149420acc;p=gem5.git ARM: Decode the SADD8 and SADD16 instructions. --- diff --git a/src/arch/arm/isa/formats/data.isa b/src/arch/arm/isa/formats/data.isa index dc78a5770..28fb50194 100644 --- a/src/arch/arm/isa/formats/data.isa +++ b/src/arch/arm/isa/formats/data.isa @@ -234,7 +234,7 @@ def format ArmParallelAddSubtract() {{ case 0x1: switch (op2) { case 0x0: - return new WarnUnimplemented("sadd16", machInst); + return new Sadd16RegCc(machInst, rd, rn, rm, 0, LSL); case 0x1: return new WarnUnimplemented("sasx", machInst); case 0x2: @@ -242,7 +242,7 @@ def format ArmParallelAddSubtract() {{ case 0x3: return new WarnUnimplemented("ssub16", machInst); case 0x4: - return new WarnUnimplemented("sadd8", machInst); + return new Sadd8RegCc(machInst, rd, rn, rm, 0, LSL); case 0x7: return new WarnUnimplemented("ssub8", machInst); } @@ -542,11 +542,16 @@ def format Thumb32DataProcReg() {{ if (bits(op2, 2) == 0x0) { const uint32_t op1 = bits(machInst, 22, 20); const uint32_t op2 = bits(machInst, 5, 4); + const IntRegIndex rd = + (IntRegIndex)(uint32_t)bits(machInst, 11, 8); + const IntRegIndex rm = + (IntRegIndex)(uint32_t)bits(machInst, 3, 0); switch (op2) { case 0x0: switch (op1) { case 0x1: - return new WarnUnimplemented("sadd16", machInst); + return new Sadd16RegCc(machInst, rd, + rn, rm, 0, LSL); case 0x2: return new WarnUnimplemented("sasx", machInst); case 0x6: @@ -554,39 +559,26 @@ def format Thumb32DataProcReg() {{ case 0x5: return new WarnUnimplemented("ssub16", machInst); case 0x0: - return new WarnUnimplemented("sadd8", machInst); + return new Sadd8RegCc(machInst, rd, + rn, rm, 0, LSL); case 0x4: return new WarnUnimplemented("ssub8", machInst); } break; case 0x1: - { - IntRegIndex rn = - (IntRegIndex)(uint32_t)bits(machInst, 19, 16); - IntRegIndex rd = - (IntRegIndex)(uint32_t)bits(machInst, 11, 8); - IntRegIndex rm = - (IntRegIndex)(uint32_t)bits(machInst, 3, 0); - switch (op1) { - case 0x1: - return new Qadd16Reg(machInst, rd, - rn, rm, 0, LSL); - case 0x2: - return new QasxReg(machInst, rd, - rn, rm, 0, LSL); - case 0x6: - return new QsaxReg(machInst, rd, - rn, rm, 0, LSL); - case 0x5: - return new Qsub16Reg(machInst, rd, - rn, rm, 0, LSL); - case 0x0: - return new Qsub8Reg(machInst, rd, - rn, rm, 0, LSL); - case 0x4: - return new Qsub8Reg(machInst, rd, - rn, rm, 0, LSL); - } + switch (op1) { + case 0x1: + return new Qadd16Reg(machInst, rd, rn, rm, 0, LSL); + case 0x2: + return new QasxReg(machInst, rd, rn, rm, 0, LSL); + case 0x6: + return new QsaxReg(machInst, rd, rn, rm, 0, LSL); + case 0x5: + return new Qsub16Reg(machInst, rd, rn, rm, 0, LSL); + case 0x0: + return new Qadd8Reg(machInst, rd, rn, rm, 0, LSL); + case 0x4: + return new Qsub8Reg(machInst, rd, rn, rm, 0, LSL); } break; case 0x2: