mirror of
https://github.com/Lime3DS/Lime3DS.git
synced 2024-11-02 00:15:06 +01:00
dyncom: Correct SXTAB16 and SXTB16
This commit is contained in:
parent
2889372e47
commit
b125388152
@ -3928,13 +3928,13 @@ SXTB16_INST : {
|
||||
if (inst_cream->Rn == 15) {
|
||||
u32 lo = (u32)(s8)rm_val;
|
||||
u32 hi = (u32)(s8)(rm_val >> 16);
|
||||
RD = (lo | (hi << 16));
|
||||
RD = (lo & 0xFFFF) | (hi << 16);
|
||||
}
|
||||
// SXTAB16
|
||||
else {
|
||||
u32 lo = (rn_val & 0xFFFF) + (u32)(s8)(rm_val & 0xFF);
|
||||
u32 hi = ((rn_val >> 16) & 0xFFFF) + (u32)(s8)((rm_val >> 16) & 0xFF);
|
||||
RD = (lo | (hi << 16));
|
||||
u32 lo = rn_val + (u32)(s8)(rm_val & 0xFF);
|
||||
u32 hi = (rn_val >> 16) + (u32)(s8)((rm_val >> 16) & 0xFF);
|
||||
RD = (lo & 0xFFFF) | (hi << 16);
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user