Mark Wielaard edad3ab
commit 8f36c464966045b51a75144ca4c65f354082194f
Mark Wielaard edad3ab
Author: mjw <mjw@a5019735-40e9-0310-863c-91ae7b9d1cf9>
Mark Wielaard edad3ab
Date:   Tue Mar 15 15:08:01 2016 +0000
Mark Wielaard edad3ab
Mark Wielaard edad3ab
    Bug #360425 - arm64 unsupported instruction ldpsw tests.
Mark Wielaard edad3ab
    
Mark Wielaard edad3ab
    Add tests for ldpsw implementation VEX svn r3212.
Mark Wielaard edad3ab
    
Mark Wielaard edad3ab
    git-svn-id: svn://svn.valgrind.org/valgrind/trunk@15830 a5019735-40e9-0310-863c-91ae7b9d1cf9
Mark Wielaard edad3ab
Mark Wielaard edad3ab
diff --git a/none/tests/arm64/memory.c b/none/tests/arm64/memory.c
Mark Wielaard edad3ab
index cbf31fd..91949ac 100644
Mark Wielaard edad3ab
--- a/none/tests/arm64/memory.c
Mark Wielaard edad3ab
+++ b/none/tests/arm64/memory.c
Mark Wielaard edad3ab
@@ -280,6 +280,18 @@ TESTINST2_hide2("ldarb w21, [x22]", AREA_MID, x21,x22,0);
Mark Wielaard edad3ab
 
Mark Wielaard edad3ab
 ////////////////////////////////////////////////////////////////
Mark Wielaard edad3ab
 printf("STL{R,RH,RB} (entirely MISSING)\n");
Mark Wielaard edad3ab
+
Mark Wielaard edad3ab
+////////////////////////////////////////////////////////////////
Mark Wielaard edad3ab
+// TESTINST2_hide2 allows use of x28 as scratch
Mark Wielaard edad3ab
+printf("LDPSW (immediate, simm7)\n");
Mark Wielaard edad3ab
+
Mark Wielaard d387a30
+TESTINST2_hide2("ldpsw x21, x28, [x22], #-24 ; add x21,x21,x28", AREA_MID, x21,x22,0);
Mark Wielaard d387a30
+TESTINST2_hide2("ldpsw x21, x28, [x22], #-24 ; eor x21,x21,x28", AREA_MID, x21,x22,0);
Mark Wielaard d387a30
+TESTINST2_hide2("ldpsw x21, x28, [x22, #-40]! ; add x21,x21,x28", AREA_MID, x21,x22,0);
Mark Wielaard d387a30
+TESTINST2_hide2("ldpsw x21, x28, [x22, #-40]! ; eor x21,x21,x28", AREA_MID, x21,x22,0);
Mark Wielaard d387a30
+TESTINST2_hide2("ldpsw x21, x28, [x22, #-40] ; add x21,x21,x28", AREA_MID, x21,x22,0);
Mark Wielaard d387a30
+TESTINST2_hide2("ldpsw x21, x28, [x22, #-40] ; eor x21,x21,x28", AREA_MID, x21,x22,0);
Mark Wielaard d387a30
+
Mark Wielaard edad3ab
 } /* end of test_memory_old() */
Mark Wielaard edad3ab
 
Mark Wielaard edad3ab
 
Mark Wielaard edad3ab
@@ -1608,6 +1620,12 @@ MEM_TEST("prfm pstl2strm, [x5,w6,uxtw #3]", 12, 4);
Mark Wielaard edad3ab
 MEM_TEST("prfm pstl3keep, [x5,w6,sxtw #0]", 12, 4);
Mark Wielaard edad3ab
 MEM_TEST("prfm pstl3strm, [x5,w6,sxtw #3]",  12, -4);
Mark Wielaard edad3ab
 
Mark Wielaard edad3ab
+////////////////////////////////////////////////////////////////
Mark Wielaard edad3ab
+printf("LDPSW (immediate, simm7)\n");
Mark Wielaard d387a30
+MEM_TEST("ldpsw x13, x23, [x5], #-24",   0, 0);
Mark Wielaard d387a30
+MEM_TEST("ldpsw x13, x23, [x5, #-40]!",  0, 0);
Mark Wielaard d387a30
+MEM_TEST("ldpsw x13, x23, [x5, #-40]",   0, 0);
Mark Wielaard edad3ab
+
Mark Wielaard edad3ab
 } /* end of test_memory2() */
Mark Wielaard edad3ab
 
Mark Wielaard edad3ab
 ////////////////////////////////////////////////////////////////
Mark Wielaard edad3ab
diff --git a/none/tests/arm64/memory.stdout.exp b/none/tests/arm64/memory.stdout.exp
Mark Wielaard edad3ab
index eb6ec3f..be57108 100644
Mark Wielaard edad3ab
--- a/none/tests/arm64/memory.stdout.exp
Mark Wielaard edad3ab
+++ b/none/tests/arm64/memory.stdout.exp
Mark Wielaard edad3ab
@@ -98,6 +98,13 @@ ldar  w21, [x22] :: rd 00000000f3f2f1f0 rn (hidden), cin 0, nzcv 00000000
Mark Wielaard edad3ab
 ldarh w21, [x22] :: rd 000000000000f1f0 rn (hidden), cin 0, nzcv 00000000     
Mark Wielaard edad3ab
 ldarb w21, [x22] :: rd 00000000000000f0 rn (hidden), cin 0, nzcv 00000000     
Mark Wielaard edad3ab
 STL{R,RH,RB} (entirely MISSING)
Mark Wielaard edad3ab
+LDPSW (immediate, simm7)
Mark Wielaard d387a30
+ldpsw x21, x28, [x22], #-24 ; add x21,x21,x28 :: rd ffffffffebe9e7e4 rn (hidden), cin 0, nzcv 00000000     
Mark Wielaard d387a30
+ldpsw x21, x28, [x22], #-24 ; eor x21,x21,x28 :: rd 0000000004040404 rn (hidden), cin 0, nzcv 00000000     
Mark Wielaard d387a30
+ldpsw x21, x28, [x22, #-40]! ; add x21,x21,x28 :: rd ffffffff9b999794 rn (hidden), cin 0, nzcv 00000000     
Mark Wielaard d387a30
+ldpsw x21, x28, [x22, #-40]! ; eor x21,x21,x28 :: rd 0000000004040404 rn (hidden), cin 0, nzcv 00000000     
Mark Wielaard d387a30
+ldpsw x21, x28, [x22, #-40] ; add x21,x21,x28 :: rd ffffffff9b999794 rn (hidden), cin 0, nzcv 00000000     
Mark Wielaard d387a30
+ldpsw x21, x28, [x22, #-40] ; eor x21,x21,x28 :: rd 0000000004040404 rn (hidden), cin 0, nzcv 00000000     
Mark Wielaard edad3ab
 LDR,STR (immediate, uimm12)ldr  x13, [x5, #24]  with  x5 = middle_of_block+-1,  x6=0
Mark Wielaard edad3ab
   [  0]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard edad3ab
   [ 16]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard edad3ab
@@ -26258,3 +26265,94 @@ prfm pstl3strm, [x5,w6,sxtw #3]  with  x5 = middle_of_block+12,  x6=-4
Mark Wielaard d387a30
                  0  x5       (sub, base reg)
Mark Wielaard d387a30
                  0  x6       (sub, index reg)
Mark Wielaard d387a30
 
Mark Wielaard edad3ab
+LDPSW (immediate, simm7)
Mark Wielaard d387a30
+ldpsw x13, x23, [x5], #-24  with  x5 = middle_of_block+0,  x6=0
Mark Wielaard d387a30
+  [  0]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [ 16]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [ 32]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [ 48]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [ 64]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [ 80]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [ 96]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [112]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [128]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [144]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [160]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [176]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [192]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [208]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [224]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [240]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard edad3ab
+  5430cb99daf026bb  x13      (xor, xfer intreg #1)
Mark Wielaard edad3ab
+  58eb9b702726900d  x23      (xor, xfer intreg #2)
Mark Wielaard d387a30
+  0000000000000000  v17.d[0] (xor, xfer vecreg #1)
Mark Wielaard d387a30
+  0000000000000000  v17.d[1] (xor, xfer vecreg #1)
Mark Wielaard d387a30
+  0000000000000000  v18.d[0] (xor, xfer vecreg #2)
Mark Wielaard d387a30
+  0000000000000000  v18.d[1] (xor, xfer vecreg #2)
Mark Wielaard d387a30
+  0000000000000000  v19.d[0] (xor, xfer vecreg #3)
Mark Wielaard d387a30
+  0000000000000000  v19.d[1] (xor, xfer vecreg #3)
Mark Wielaard d387a30
+  0000000000000000  v20.d[0] (xor, xfer vecreg #3)
Mark Wielaard d387a30
+  0000000000000000  v20.d[1] (xor, xfer vecreg #3)
Mark Wielaard d387a30
+               -24  x5       (sub, base reg)
Mark Wielaard d387a30
+                 0  x6       (sub, index reg)
Mark Wielaard d387a30
+
Mark Wielaard d387a30
+ldpsw x13, x23, [x5, #-40]!  with  x5 = middle_of_block+0,  x6=0
Mark Wielaard d387a30
+  [  0]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [ 16]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [ 32]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [ 48]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [ 64]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [ 80]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [ 96]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [112]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [128]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [144]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [160]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [176]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [192]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [208]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [224]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [240]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard edad3ab
+  7f799c624bfa7f08  x13      (xor, xfer intreg #1)
Mark Wielaard edad3ab
+  3e7857cc51fd19f0  x23      (xor, xfer intreg #2)
Mark Wielaard d387a30
+  0000000000000000  v17.d[0] (xor, xfer vecreg #1)
Mark Wielaard d387a30
+  0000000000000000  v17.d[1] (xor, xfer vecreg #1)
Mark Wielaard d387a30
+  0000000000000000  v18.d[0] (xor, xfer vecreg #2)
Mark Wielaard d387a30
+  0000000000000000  v18.d[1] (xor, xfer vecreg #2)
Mark Wielaard d387a30
+  0000000000000000  v19.d[0] (xor, xfer vecreg #3)
Mark Wielaard d387a30
+  0000000000000000  v19.d[1] (xor, xfer vecreg #3)
Mark Wielaard d387a30
+  0000000000000000  v20.d[0] (xor, xfer vecreg #3)
Mark Wielaard d387a30
+  0000000000000000  v20.d[1] (xor, xfer vecreg #3)
Mark Wielaard d387a30
+               -40  x5       (sub, base reg)
Mark Wielaard d387a30
+                 0  x6       (sub, index reg)
Mark Wielaard d387a30
+
Mark Wielaard d387a30
+ldpsw x13, x23, [x5, #-40]  with  x5 = middle_of_block+0,  x6=0
Mark Wielaard d387a30
+  [  0]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [ 16]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [ 32]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [ 48]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [ 64]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [ 80]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [ 96]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [112]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [128]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [144]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [160]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [176]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [192]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [208]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [224]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard d387a30
+  [240]  .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. 
Mark Wielaard edad3ab
+  01ba3febe99768c0  x13      (xor, xfer intreg #1)
Mark Wielaard edad3ab
+  1cef424f7c21ff9b  x23      (xor, xfer intreg #2)
Mark Wielaard d387a30
+  0000000000000000  v17.d[0] (xor, xfer vecreg #1)
Mark Wielaard d387a30
+  0000000000000000  v17.d[1] (xor, xfer vecreg #1)
Mark Wielaard d387a30
+  0000000000000000  v18.d[0] (xor, xfer vecreg #2)
Mark Wielaard d387a30
+  0000000000000000  v18.d[1] (xor, xfer vecreg #2)
Mark Wielaard d387a30
+  0000000000000000  v19.d[0] (xor, xfer vecreg #3)
Mark Wielaard d387a30
+  0000000000000000  v19.d[1] (xor, xfer vecreg #3)
Mark Wielaard d387a30
+  0000000000000000  v20.d[0] (xor, xfer vecreg #3)
Mark Wielaard d387a30
+  0000000000000000  v20.d[1] (xor, xfer vecreg #3)
Mark Wielaard d387a30
+                 0  x5       (sub, base reg)
Mark Wielaard d387a30
+                 0  x6       (sub, index reg)
Mark Wielaard d387a30
+
Mark Wielaard edad3ab
commit c10b13cb0ec8b797124d8379b7f932f92341bd4b
Mark Wielaard edad3ab
Author: sewardj <sewardj@8f6e269a-dfd6-0310-a8e1-e2731360e62c>
Mark Wielaard edad3ab
Date:   Tue Mar 15 14:24:56 2016 +0000
Mark Wielaard edad3ab
Mark Wielaard edad3ab
    arm64: implement LDPSW.  Fixes #360425.  Initial patch+investigation by Mark Wielaard.
Mark Wielaard edad3ab
    
Mark Wielaard edad3ab
    
Mark Wielaard edad3ab
    git-svn-id: svn://svn.valgrind.org/vex/trunk@3212 8f6e269a-dfd6-0310-a8e1-e2731360e62c
Mark Wielaard edad3ab
Mark Wielaard edad3ab
diff --git a/VEX/priv/guest_arm64_toIR.c b/VEX/priv/guest_arm64_toIR.c
Mark Wielaard edad3ab
index 8da9780..d4fe1b8 100644
Mark Wielaard edad3ab
--- a/VEX/priv/guest_arm64_toIR.c
Mark Wielaard edad3ab
+++ b/VEX/priv/guest_arm64_toIR.c
Mark Wielaard edad3ab
@@ -4804,7 +4804,6 @@ Bool dis_ARM64_load_store(/*MB_OUT*/DisResult* dres, UInt insn)
Mark Wielaard edad3ab
       (at-EA)
Mark Wielaard edad3ab
       x0 101 0010 L imm7 Rt2 Rn Rt1  mmP Rt1,Rt2, [Xn|SP, #imm]
Mark Wielaard edad3ab
    */
Mark Wielaard edad3ab
-
Mark Wielaard d387a30
    UInt insn_30_23 = INSN(30,23);
Mark Wielaard d387a30
    if (insn_30_23 == BITS8(0,1,0,1,0,0,0,1) 
Mark Wielaard d387a30
        || insn_30_23 == BITS8(0,1,0,1,0,0,1,1)
Mark Wielaard edad3ab
@@ -4912,6 +4911,87 @@ Bool dis_ARM64_load_store(/*MB_OUT*/DisResult* dres, UInt insn)
Mark Wielaard d387a30
       }
Mark Wielaard edad3ab
    }
Mark Wielaard edad3ab
 
Mark Wielaard edad3ab
+   /* -------- LDPSW (immediate, simm7) (INT REGS) -------- */
Mark Wielaard edad3ab
+   /* Does 32 bit transfers which are sign extended to 64 bits.
Mark Wielaard edad3ab
+      simm7 is scaled by the (single-register) transfer size
Mark Wielaard edad3ab
+
Mark Wielaard edad3ab
+      (at-Rn-then-Rn=EA)
Mark Wielaard edad3ab
+      01 101 0001 1 imm7 Rt2 Rn Rt1  LDPSW Rt1,Rt2, [Xn|SP], #imm
Mark Wielaard edad3ab
+   
Mark Wielaard edad3ab
+      (at-EA-then-Rn=EA)
Mark Wielaard edad3ab
+      01 101 0011 1 imm7 Rt2 Rn Rt1  LDPSW Rt1,Rt2, [Xn|SP, #imm]!
Mark Wielaard edad3ab
+
Mark Wielaard edad3ab
+      (at-EA)
Mark Wielaard edad3ab
+      01 101 0010 1 imm7 Rt2 Rn Rt1  LDPSW Rt1,Rt2, [Xn|SP, #imm]
Mark Wielaard edad3ab
+   */
Mark Wielaard edad3ab
+   UInt insn_31_22 = INSN(31,22);
Mark Wielaard edad3ab
+   if (insn_31_22 == BITS10(0,1,1,0,1,0,0,0,1,1)
Mark Wielaard edad3ab
+       || insn_31_22 == BITS10(0,1,1,0,1,0,0,1,1,1)
Mark Wielaard edad3ab
+       || insn_31_22 == BITS10(0,1,1,0,1,0,0,1,0,1)) {
Mark Wielaard edad3ab
+      UInt bWBack = INSN(23,23);
Mark Wielaard edad3ab
+      UInt rT1    = INSN(4,0);
Mark Wielaard edad3ab
+      UInt rN     = INSN(9,5);
Mark Wielaard edad3ab
+      UInt rT2    = INSN(14,10);
Mark Wielaard edad3ab
+      Long simm7  = (Long)sx_to_64(INSN(21,15), 7);
Mark Wielaard edad3ab
+      if ((bWBack && (rT1 == rN || rT2 == rN) && rN != 31)
Mark Wielaard edad3ab
+          || (rT1 == rT2)) {
Mark Wielaard edad3ab
+         /* undecodable; fall through */
Mark Wielaard edad3ab
+      } else {
Mark Wielaard edad3ab
+         if (rN == 31) { /* FIXME generate stack alignment check */ }
Mark Wielaard edad3ab
+
Mark Wielaard edad3ab
+         // Compute the transfer address TA and the writeback address WA.
Mark Wielaard edad3ab
+         IRTemp tRN = newTemp(Ity_I64);
Mark Wielaard edad3ab
+         assign(tRN, getIReg64orSP(rN));
Mark Wielaard edad3ab
+         IRTemp tEA = newTemp(Ity_I64);
Mark Wielaard edad3ab
+         simm7 = 4 * simm7;
Mark Wielaard edad3ab
+         assign(tEA, binop(Iop_Add64, mkexpr(tRN), mkU64(simm7)));
Mark Wielaard edad3ab
+
Mark Wielaard edad3ab
+         IRTemp tTA = newTemp(Ity_I64);
Mark Wielaard edad3ab
+         IRTemp tWA = newTemp(Ity_I64);
Mark Wielaard edad3ab
+         switch (INSN(24,23)) {
Mark Wielaard edad3ab
+            case BITS2(0,1):
Mark Wielaard edad3ab
+               assign(tTA, mkexpr(tRN)); assign(tWA, mkexpr(tEA)); break;
Mark Wielaard edad3ab
+            case BITS2(1,1):
Mark Wielaard edad3ab
+               assign(tTA, mkexpr(tEA)); assign(tWA, mkexpr(tEA)); break;
Mark Wielaard edad3ab
+            case BITS2(1,0):
Mark Wielaard edad3ab
+               assign(tTA, mkexpr(tEA)); /* tWA is unused */ break;
Mark Wielaard edad3ab
+            default:
Mark Wielaard edad3ab
+               vassert(0); /* NOTREACHED */
Mark Wielaard edad3ab
+         }
Mark Wielaard edad3ab
+
Mark Wielaard edad3ab
+         // 32 bit load, sign extended to 64 bits
Mark Wielaard edad3ab
+         putIReg64orZR(rT1, unop(Iop_32Sto64,
Mark Wielaard edad3ab
+                                 loadLE(Ity_I32, binop(Iop_Add64,
Mark Wielaard edad3ab
+                                                       mkexpr(tTA),
Mark Wielaard edad3ab
+                                                       mkU64(0)))));
Mark Wielaard edad3ab
+         putIReg64orZR(rT2, unop(Iop_32Sto64,
Mark Wielaard edad3ab
+                                 loadLE(Ity_I32, binop(Iop_Add64,
Mark Wielaard edad3ab
+                                                       mkexpr(tTA),
Mark Wielaard edad3ab
+                                                       mkU64(4)))));
Mark Wielaard edad3ab
+         if (bWBack)
Mark Wielaard edad3ab
+            putIReg64orSP(rN, mkexpr(tEA));
Mark Wielaard edad3ab
+
Mark Wielaard edad3ab
+         const HChar* fmt_str = NULL;
Mark Wielaard edad3ab
+         switch (INSN(24,23)) {
Mark Wielaard edad3ab
+            case BITS2(0,1):
Mark Wielaard edad3ab
+               fmt_str = "ldpsw %s, %s, [%s], #%lld (at-Rn-then-Rn=EA)\n";
Mark Wielaard edad3ab
+               break;
Mark Wielaard edad3ab
+            case BITS2(1,1):
Mark Wielaard edad3ab
+               fmt_str = "ldpsw %s, %s, [%s, #%lld]! (at-EA-then-Rn=EA)\n";
Mark Wielaard edad3ab
+               break;
Mark Wielaard edad3ab
+            case BITS2(1,0):
Mark Wielaard edad3ab
+               fmt_str = "ldpsw %s, %s, [%s, #%lld] (at-Rn)\n";
Mark Wielaard edad3ab
+               break;
Mark Wielaard edad3ab
+            default:
Mark Wielaard edad3ab
+               vassert(0);
Mark Wielaard edad3ab
+         }
Mark Wielaard edad3ab
+         DIP(fmt_str, nameIReg64orZR(rT1),
Mark Wielaard edad3ab
+                      nameIReg64orZR(rT2),
Mark Wielaard edad3ab
+                      nameIReg64orSP(rN), simm7);
Mark Wielaard edad3ab
+         return True;
Mark Wielaard edad3ab
+      }
Mark Wielaard edad3ab
+   }
Mark Wielaard edad3ab
+
Mark Wielaard edad3ab
    /* ---------------- LDR (literal, int reg) ---------------- */
Mark Wielaard edad3ab
    /* 31 29      23    4
Mark Wielaard edad3ab
       00 011 000 imm19 Rt   LDR   Wt, [PC + sxTo64(imm19 << 2)]