[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Xen-changelog] [qemu-xen master] target-mips: fix bad shifts in {dextp|dextpdp}



commit e6e2784cacd4cfec149a7690976b9ff15e541c4d
Author:     Yongbok Kim <yongbok.kim@xxxxxxxxxx>
AuthorDate: Wed Nov 30 15:25:04 2016 +0000
Commit:     Yongbok Kim <yongbok.kim@xxxxxxxxxx>
CommitDate: Sun Dec 4 00:57:06 2016 +0000

    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@xxxxxxxxxx>
    Reported-by: Jia Liu <proljc@xxxxxxxxx>
    Signed-off-by: Yongbok Kim <yongbok.kim@xxxxxxxxxx>
    Reviewed-by: Thomas Huth <thuth@xxxxxxxxxx>
---
 target-mips/dsp_helper.c | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/target-mips/dsp_helper.c b/target-mips/dsp_helper.c
index df7d220..dc70793 100644
--- a/target-mips/dsp_helper.c
+++ b/target-mips/dsp_helper.c
@@ -3477,7 +3477,7 @@ target_ulong helper_dextp(target_ulong ac, target_ulong 
size, CPUMIPSState *env)
 
     if (sub >= -1) {
         temp = (tempB << (64 - len)) | (tempA >> len);
-        temp = temp & ((0x01 << (size + 1)) - 1);
+        temp = temp & ((1ULL << (size + 1)) - 1);
         set_DSPControl_efi(0, env);
     } else {
         set_DSPControl_efi(1, env);
@@ -3506,7 +3506,7 @@ target_ulong helper_dextpdp(target_ulong ac, target_ulong 
size,
 
     if (sub >= -1) {
         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_efi(0, env);
     } else {
--
generated by git-patchbot for /home/xen/git/qemu-xen.git#master

_______________________________________________
Xen-changelog mailing list
Xen-changelog@xxxxxxxxxxxxx
https://lists.xenproject.org/xen-changelog

 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.