diff options
Diffstat (limited to 'sim/v850')
-rw-r--r-- | sim/v850/ChangeLog | 3 | ||||
-rw-r--r-- | sim/v850/simops.c | 128 |
2 files changed, 101 insertions, 30 deletions
diff --git a/sim/v850/ChangeLog b/sim/v850/ChangeLog index 9b1ad58..a026e1f 100644 --- a/sim/v850/ChangeLog +++ b/sim/v850/ChangeLog @@ -1,5 +1,8 @@ Thu Aug 29 13:53:29 1996 Jeffrey A Law (law@cygnus.com) + * simops.c: Add condition code handling to shift insns. + Fix minor typos in condition code handling for other insns. + * Makefile.in: Fix typo. * simops.c: Add condition code handling to "sub" "subr" and "divh" instructions. diff --git a/sim/v850/simops.c b/sim/v850/simops.c index 0bcdabe..b06c124 100644 --- a/sim/v850/simops.c +++ b/sim/v850/simops.c @@ -429,66 +429,136 @@ OP_80 () { } -/* sar zero_extend(imm5),reg1 - - XXX condition codes. */ +/* sar zero_extend(imm5),reg1 */ void OP_2A0 () { - int temp = State.regs[OP[1]]; + unsigned int op0, op1, result, z, s, cy, ov; - temp >>= (OP[0] & 0x1f); + op0 = OP[0] & 0x1f; + op1 = State.regs[OP[1]]; + result = (signed)op1 >> op0; - State.regs[OP[1]] = temp; -} + /* Compute the condition codes. */ + z = (result == 0); + s = (result & 0x80000000); + cy = (op1 & (1 << (op0 - 1))); -/* sar reg1, reg2 + /* Store the result and condition codes. */ + State.regs[OP[1]] = result; + State.psw &= ~(PSW_Z | PSW_S | PSW_OV | PSW_CY); + State.psw |= ((z ? PSW_Z : 0) | (s ? PSW_S : 0) + | (cy ? PSW_CY : 0) | (ov ? PSW_OV : 0)); +} - XXX condition codes. */ +/* sar reg1, reg2 */ void OP_A007E0 () { - int temp = State.regs[OP[1]]; + unsigned int op0, op1, result, z, s, cy, ov; - temp >>= (State.regs[OP[0]] & 0x1f); + op0 = State.regs[OP[0]] & 0x1f; + op1 = State.regs[OP[1]]; + result = (signed)op1 >> op0; - State.regs[OP[1]] = temp; -} + /* Compute the condition codes. */ + z = (result == 0); + s = (result & 0x80000000); + cy = (op1 & (1 << (op0 - 1))); -/* shl zero_extend(imm5),reg1 + /* Store the result and condition codes. */ + State.regs[OP[1]] = result; + State.psw &= ~(PSW_Z | PSW_S | PSW_OV | PSW_CY); + State.psw |= ((z ? PSW_Z : 0) | (s ? PSW_S : 0) + | (cy ? PSW_CY : 0)); +} - XXX condition codes. */ +/* shl zero_extend(imm5),reg1 */ void OP_2C0 () { - State.regs[OP[1]] <<= (OP[0] & 0x1f); -} + unsigned int op0, op1, result, z, s, cy, ov; + + op0 = OP[0] & 0x1f; + op1 = State.regs[OP[1]]; + result = op1 << op0; + + /* Compute the condition codes. */ + z = (result == 0); + s = (result & 0x80000000); + cy = (op1 & (1 << (32 - op0))); -/* shl reg1, reg2 + /* Store the result and condition codes. */ + State.regs[OP[1]] = result; + State.psw &= ~(PSW_Z | PSW_S | PSW_OV | PSW_CY); + State.psw |= ((z ? PSW_Z : 0) | (s ? PSW_S : 0) + | (cy ? PSW_CY : 0)); +} - XXX condition codes. */ +/* shl reg1, reg2 */ void OP_C007E0 () { - State.regs[OP[1]] <<= (State.regs[OP[0]] & 0x1f); -} + unsigned int op0, op1, result, z, s, cy, ov; -/* shr zero_extend(imm5),reg1 + op0 = State.regs[OP[0]] & 0x1f; + op1 = State.regs[OP[1]]; + result = op1 << op0; + + /* Compute the condition codes. */ + z = (result == 0); + s = (result & 0x80000000); + cy = (op1 & (1 << (32 - op0))); + + /* Store the result and condition codes. */ + State.regs[OP[1]] = result; + State.psw &= ~(PSW_Z | PSW_S | PSW_OV | PSW_CY); + State.psw |= ((z ? PSW_Z : 0) | (s ? PSW_S : 0) + | (cy ? PSW_CY : 0)); +} - XXX condition codes. */ +/* shr zero_extend(imm5),reg1 */ void OP_280 () { - State.regs[OP[1]] >>= (OP[0] & 0x1f); -} + unsigned int op0, op1, result, z, s, cy, ov; -/* shr reg1, reg2 + op0 = OP[0] & 0x1f; + op1 = State.regs[OP[1]]; + result = op1 >> op0; - XXX condition codes. */ + /* Compute the condition codes. */ + z = (result == 0); + s = (result & 0x80000000); + cy = (op1 & (1 << (op0 - 1))); + + /* Store the result and condition codes. */ + State.regs[OP[1]] = result; + State.psw &= ~(PSW_Z | PSW_S | PSW_OV | PSW_CY); + State.psw |= ((z ? PSW_Z : 0) | (s ? PSW_S : 0) + | (cy ? PSW_CY : 0)); +} + +/* shr reg1, reg2 */ void OP_8007E0 () { - State.regs[OP[1]] >>= (State.regs[OP[0]] & 0x1f); + unsigned int op0, op1, result, z, s, cy, ov; + + op0 = State.regs[OP[0]] & 0x1f; + op1 = State.regs[OP[1]]; + result = op1 >> op0; + + /* Compute the condition codes. */ + z = (result == 0); + s = (result & 0x80000000); + cy = (op1 & (1 << (op0 - 1))); + + /* Store the result and condition codes. */ + State.regs[OP[1]] = result; + State.psw &= ~(PSW_Z | PSW_S | PSW_OV | PSW_CY); + State.psw |= ((z ? PSW_Z : 0) | (s ? PSW_S : 0) + | (cy ? PSW_CY : 0)); } void @@ -545,7 +615,6 @@ OP_680 () State.regs[OP[2]] = result; State.psw &= ~(PSW_Z | PSW_S | PSW_OV); State.psw |= ((z ? PSW_Z : 0) | (s ? PSW_S : 0)); - State.psw |= (z ? PSW_Z : 0); } /* and reg, reg */ @@ -627,7 +696,6 @@ OP_6A0 () State.regs[OP[2]] = result; State.psw &= ~(PSW_Z | PSW_S | PSW_OV); State.psw |= ((z ? PSW_Z : 0) | (s ? PSW_S : 0)); - State.psw |= (z ? PSW_Z : 0); } /* not reg1, reg2 */ |