mirror of https://gitee.com/openkylin/qemu.git
target-mips: fix bad shifts in {dextp|dextpdp}
Fixed issues in the MIPSDSP64 instructions dextp and dextpdp. Shifting can go out of 32 bit range. https://bugs.launchpad.net/qemu/+bug/1631625 Reported-by: Thomas Huth <thuth@redhat.com> Reported-by: Jia Liu <proljc@gmail.com> Signed-off-by: Yongbok Kim <yongbok.kim@imgtec.com> Reviewed-by: Thomas Huth <thuth@redhat.com>
This commit is contained in:
parent
b5a587b613
commit
e6e2784cac
|
@ -3477,7 +3477,7 @@ target_ulong helper_dextp(target_ulong ac, target_ulong size, CPUMIPSState *env)
|
||||||
|
|
||||||
if (sub >= -1) {
|
if (sub >= -1) {
|
||||||
temp = (tempB << (64 - len)) | (tempA >> len);
|
temp = (tempB << (64 - len)) | (tempA >> len);
|
||||||
temp = temp & ((0x01 << (size + 1)) - 1);
|
temp = temp & ((1ULL << (size + 1)) - 1);
|
||||||
set_DSPControl_efi(0, env);
|
set_DSPControl_efi(0, env);
|
||||||
} else {
|
} else {
|
||||||
set_DSPControl_efi(1, env);
|
set_DSPControl_efi(1, env);
|
||||||
|
@ -3506,7 +3506,7 @@ target_ulong helper_dextpdp(target_ulong ac, target_ulong size,
|
||||||
|
|
||||||
if (sub >= -1) {
|
if (sub >= -1) {
|
||||||
temp = (tempB << (64 - len)) | (tempA >> len);
|
temp = (tempB << (64 - len)) | (tempA >> len);
|
||||||
temp = temp & ((0x01 << (size + 1)) - 1);
|
temp = temp & ((1ULL << (size + 1)) - 1);
|
||||||
set_DSPControl_pos(sub, env);
|
set_DSPControl_pos(sub, env);
|
||||||
set_DSPControl_efi(0, env);
|
set_DSPControl_efi(0, env);
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in New Issue