]> git.ipfire.org Git - thirdparty/valgrind.git/commitdiff
Implement MOVUPS -- move from G (xmm) to E (mem or xmm) [UNVERIFIED]
authorJulian Seward <jseward@acm.org>
Thu, 25 Aug 2005 21:34:24 +0000 (21:34 +0000)
committerJulian Seward <jseward@acm.org>
Thu, 25 Aug 2005 21:34:24 +0000 (21:34 +0000)
git-svn-id: svn://svn.valgrind.org/vex/trunk@1362

VEX/priv/guest-x86/toIR.c

index 201282a0600f74cabd86f7e0f3ffed96e74d1db9..ebc81c4d93b8d330fb626df7e091cbf4f38f7e8d 100644 (file)
@@ -7501,15 +7501,17 @@ DisResult disInstr_X86_WRK (
    }
 
    /* 0F 29 = MOVAPS -- move from G (xmm) to E (mem or xmm). */
-   if (sz == 4 && insn[0] == 0x0F && insn[1] == 0x29) {
+   /* 0F 11 = MOVUPS -- move from G (xmm) to E (mem or xmm). */
+   if (sz == 4 && insn[0] == 0x0F 
+       && (insn[1] == 0x29 || insn[1] == 0x11)) {
       modrm = getIByte(delta+2);
       if (epartIsReg(modrm)) {
          /* fall through; awaiting test case */
       } else {
          addr = disAMode ( &alen, sorb, delta+2, dis_buf );
          storeLE( mkexpr(addr), getXMMReg(gregOfRM(modrm)) );
-         DIP("movaps %s,%s\n", nameXMMReg(gregOfRM(modrm)),
-                               dis_buf );
+         DIP("mov[ua]ps %s,%s\n", nameXMMReg(gregOfRM(modrm)),
+                                  dis_buf );
          delta += 2+alen;
          goto decode_success;
       }