mirror of
https://github.com/dingusdev/dingusppc.git
synced 2025-01-26 10:33:01 +00:00
poweropcodes: Fix sllq.
Test bit 26 of rB instead of using >= 0x20 to determine which operation to perform. Since the mask is not complicated, we don't need to use power_rot_mask.
This commit is contained in:
parent
e1f31a2da3
commit
e8273ecc61
@ -458,14 +458,11 @@ template <field_rc rec>
|
|||||||
void dppc_interpreter::power_sllq() {
|
void dppc_interpreter::power_sllq() {
|
||||||
ppc_grab_regssab(ppc_cur_instruction);
|
ppc_grab_regssab(ppc_cur_instruction);
|
||||||
unsigned rot_sh = ppc_result_b & 0x1F;
|
unsigned rot_sh = ppc_result_b & 0x1F;
|
||||||
uint32_t r = ((ppc_result_d << rot_sh) | (ppc_result_d >> (32 - rot_sh)));
|
|
||||||
uint32_t mask = power_rot_mask(0, 31 - rot_sh);
|
|
||||||
|
|
||||||
if (ppc_result_b >= 0x20) {
|
if (ppc_result_b & 0x20) {
|
||||||
ppc_result_a = (ppc_state.spr[SPR::MQ] & mask);
|
ppc_result_a = ppc_state.spr[SPR::MQ] & (-1U << rot_sh);
|
||||||
}
|
} else {
|
||||||
else {
|
ppc_result_a = ((ppc_result_d << rot_sh) | (ppc_state.spr[SPR::MQ] & ((1 << rot_sh) - 1)));
|
||||||
ppc_result_a = ((r & mask) | (ppc_state.spr[SPR::MQ] & ~mask));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (rec)
|
if (rec)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user