Fix problems in setting the carry bit

This commit is contained in:
Michael Meissner 1997-03-13 20:30:50 +00:00
parent 286f83b430
commit f4b022d37c
2 changed files with 25 additions and 31 deletions

View file

@ -3,6 +3,9 @@ Thu Mar 13 10:29:04 1997 Michael Meissner <meissner@cygnus.com>
* simops.c (trace_{input,output}_func): Call flush_stdout from the
callback functions.
(OP_5F00): Ditto.
(OP_6{4,6,C,A}01): Test for post decrement on the stack pointer.
(OP_{1200,1000000,201,5FE0,1003,17001002}): Fix problems in
setting the carry bit after an add or a subtract.
Wed Feb 12 16:04:15 1997 Michael Meissner <meissner@cygnus.com>

View file

@ -605,15 +605,12 @@ void
OP_1200 ()
{
uint32 tmp;
uint32 tmp1 = (State.regs[OP[0]]) << 16 | State.regs[OP[0]+1];
uint32 tmp2 = (State.regs[OP[1]]) << 16 | State.regs[OP[1]+1];
uint32 a = (State.regs[OP[0]]) << 16 | State.regs[OP[0]+1];
uint32 b = (State.regs[OP[1]]) << 16 | State.regs[OP[1]+1];
trace_input ("add2w", OP_DREG, OP_DREG, OP_VOID);
tmp = tmp1 + tmp2;
if ( (tmp < tmp1) || (tmp < tmp2) )
State.C = 1;
else
State.C = 0;
tmp = a + b;
State.C = (tmp < a);
State.regs[OP[0]] = tmp >> 16;
State.regs[OP[0]+1] = tmp & 0xFFFF;
trace_output (OP_DREG);
@ -623,14 +620,11 @@ OP_1200 ()
void
OP_1000000 ()
{
uint16 tmp = State.regs[OP[0]];
State.regs[OP[0]] = State.regs[OP[1]] + OP[2];
uint16 tmp = State.regs[OP[1]];
State.regs[OP[0]] = tmp + OP[2];
trace_input ("add3", OP_REG_OUTPUT, OP_REG, OP_CONSTANT16);
if ( tmp > State.regs[OP[0]])
State.C = 1;
else
State.C = 0;
State.C = (State.regs[OP[0]] < tmp);
trace_output (OP_REG);
}
@ -727,12 +721,10 @@ OP_201 ()
uint tmp = State.regs[OP[0]];
if (OP[1] == 0)
OP[1] = 16;
trace_input ("addi", OP_REG, OP_CONSTANT16, OP_VOID);
State.regs[OP[0]] += OP[1];
if (tmp > State.regs[OP[0]])
State.C = 1;
else
State.C = 0;
State.C = (State.regs[OP[0]] < tmp);
trace_output (OP_REG);
}
@ -2435,12 +2427,12 @@ OP_5FE0 ()
void
OP_0 ()
{
int32 tmp;
uint16 tmp;
trace_input ("sub", OP_REG, OP_REG, OP_VOID);
tmp = (int16)State.regs[OP[0]]- (int16)State.regs[OP[1]];
State.C = (tmp & 0xffff0000) ? 1 : 0;
State.regs[OP[0]] = tmp & 0xffff;
tmp = State.regs[OP[0]] - State.regs[OP[1]];
State.C = (tmp > State.regs[OP[0]]);
State.regs[OP[0]] = tmp;
trace_output (OP_REG);
}
@ -2495,14 +2487,13 @@ OP_1003 ()
void
OP_1000 ()
{
int64 tmp;
uint32 a,b;
uint32 tmp,a,b;
trace_input ("sub2w", OP_DREG, OP_DREG, OP_VOID);
a = (int32)((State.regs[OP[0]] << 16) | State.regs[OP[0]+1]);
b = (int32)((State.regs[OP[1]] << 16) | State.regs[OP[1]+1]);
tmp = (int64)a-b;
State.C = (tmp & 0xffffffff00000000LL) ? 1 : 0;
a = (uint32)((State.regs[OP[0]] << 16) | State.regs[OP[0]+1]);
b = (uint32)((State.regs[OP[1]] << 16) | State.regs[OP[1]+1]);
tmp = a-b;
State.C = (tmp > a);
State.regs[OP[0]] = (tmp >> 16) & 0xffff;
State.regs[OP[0]+1] = tmp & 0xffff;
trace_output (OP_DREG);
@ -2598,14 +2589,14 @@ OP_17001002 ()
void
OP_1 ()
{
int32 tmp;
uint16 tmp;
if (OP[1] == 0)
OP[1] = 16;
trace_input ("subi", OP_REG, OP_CONSTANT16, OP_VOID);
tmp = (int16)State.regs[OP[0]] - OP[1];
State.C = (tmp & 0xffff0000) ? 1 : 0;
State.regs[OP[0]] = tmp & 0xffff;
tmp = State.regs[OP[0]] - OP[1];
State.C = (tmp > State.regs[OP[0]]);
State.regs[OP[0]] = tmp;
trace_output (OP_REG);
}