diff options
author | Jeff Law <law@redhat.com> | 1996-04-09 05:57:15 +0000 |
---|---|---|
committer | Jeff Law <law@redhat.com> | 1996-04-09 05:57:15 +0000 |
commit | 50d45d1b2f621f026868e9802e181bebe28e10b7 (patch) | |
tree | f4f261edddaf1b0b7b9ead7a204ab5ef02b81d62 /sim/h8300/compile.c | |
parent | 75eb523103bd3a750e762927d539ef90d1bdeb44 (diff) | |
download | gdb-50d45d1b2f621f026868e9802e181bebe28e10b7.zip gdb-50d45d1b2f621f026868e9802e181bebe28e10b7.tar.gz gdb-50d45d1b2f621f026868e9802e181bebe28e10b7.tar.bz2 |
* compile.c (sim_resume): Fix overflow checks for ALU insns.
So that int-compare.c passes.
Diffstat (limited to 'sim/h8300/compile.c')
-rw-r--r-- | sim/h8300/compile.c | 50 |
1 files changed, 46 insertions, 4 deletions
diff --git a/sim/h8300/compile.c b/sim/h8300/compile.c index f55249e..7892dc6 100644 --- a/sim/h8300/compile.c +++ b/sim/h8300/compile.c @@ -1508,8 +1508,22 @@ sim_resume (step, siggnal) just_flags_alu8: n = res & 0x80; nz = res & 0xff; - v = ((ea & 0x80) == (rd & 0x80)) && ((ea & 0x80) != (res & 0x80)); c = (res & 0x100); + switch (code->opcode / 4) + { + case O_ADD: + v = ((rd & 0x80) == (ea & 0x80) + && (rd & 0x80) != (res & 0x80)); + break; + case O_SUB: + case O_CMP: + v = ((rd & 0x80) != (-ea & 0x80) + && (rd & 0x80) != (res & 0x80)); + break; + case O_NEG: + v = (rd == 0x80); + break; + } goto next; alu16: @@ -1517,8 +1531,22 @@ sim_resume (step, siggnal) just_flags_alu16: n = res & 0x8000; nz = res & 0xffff; - v = ((ea & 0x8000) == (rd & 0x8000)) && ((ea & 0x8000) != (res & 0x8000)); c = (res & 0x10000); + switch (code->opcode / 4) + { + case O_ADD: + v = ((rd & 0x8000) == (ea & 0x8000) + && (rd & 0x8000) != (res & 0x8000)); + break; + case O_SUB: + case O_CMP: + v = ((rd & 0x8000) != (-ea & 0x8000) + && (rd & 0x8000) != (res & 0x8000)); + break; + case O_NEG: + v = (rd == 0x8000); + break; + } goto next; alu32: @@ -1526,8 +1554,22 @@ sim_resume (step, siggnal) just_flags_alu32: n = res & 0x80000000; nz = res & 0xffffffff; - v = ((ea & 0x80000000) == (rd & 0x80000000)) - && ((ea & 0x80000000) != (res & 0x80000000)); + switch (code->opcode / 4) + { + case O_ADD: + v = ((rd & 0x80000000) == (ea & 0x80000000) + && (rd & 0x80000000) != (res & 0x80000000)); + break; + case O_SUB: + case O_CMP: + v = ((rd & 0x80000000) != (-ea & 0x80000000) + && (rd & 0x80000000) != (res & 0x80000000)); + break; + case O_NEG: + v = (rd == 0x80000000); + break; + } + goto next; switch (code->opcode / 4) { case O_ADD: |