1
0
Fork 0
forked from suyu/suyu

Merge pull request #298 from lioncash/flags

armemu: Unset GE flags for UADD8 if results are < 0x100
This commit is contained in:
bunnei 2014-12-17 22:06:27 -05:00
commit 797efbde1a

View file

@ -5958,11 +5958,29 @@ L_stm_s_takeabort:
b2 = ((u8)(from >> 8) + (u8)(to >> 8)); b2 = ((u8)(from >> 8) + (u8)(to >> 8));
b3 = ((u8)(from >> 16) + (u8)(to >> 16)); b3 = ((u8)(from >> 16) + (u8)(to >> 16));
b4 = ((u8)(from >> 24) + (u8)(to >> 24)); b4 = ((u8)(from >> 24) + (u8)(to >> 24));
if (b1 & 0xffffff00) state->Cpsr |= (1 << 16);
if (b2 & 0xffffff00) state->Cpsr |= (1 << 17); if (b1 & 0xffffff00)
if (b3 & 0xffffff00) state->Cpsr |= (1 << 18); state->Cpsr |= (1 << 16);
if (b4 & 0xffffff00) state->Cpsr |= (1 << 19); else
state->Cpsr &= ~(1 << 16);
if (b2 & 0xffffff00)
state->Cpsr |= (1 << 17);
else
state->Cpsr &= ~(1 << 17);
if (b3 & 0xffffff00)
state->Cpsr |= (1 << 18);
else
state->Cpsr &= ~(1 << 18);
if (b4 & 0xffffff00)
state->Cpsr |= (1 << 19);
else
state->Cpsr &= ~(1 << 19);
} }
state->Reg[rd] = (u32)(b1 | (b2 & 0xff) << 8 | (b3 & 0xff) << 16 | (b4 & 0xff) << 24); state->Reg[rd] = (u32)(b1 | (b2 & 0xff) << 8 | (b3 & 0xff) << 16 | (b4 & 0xff) << 24);
return 1; return 1;
} }