aboutsummaryrefslogtreecommitdiff
path: root/sim/h8300/compile.c
diff options
context:
space:
mode:
authorJeff Law <law@redhat.com>1996-04-09 05:57:15 +0000
committerJeff Law <law@redhat.com>1996-04-09 05:57:15 +0000
commit50d45d1b2f621f026868e9802e181bebe28e10b7 (patch)
treef4f261edddaf1b0b7b9ead7a204ab5ef02b81d62 /sim/h8300/compile.c
parent75eb523103bd3a750e762927d539ef90d1bdeb44 (diff)
downloadgdb-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.c50
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: