ARM: Add instruction aliases for the Thumb2 PLD/PLDW (literal) alternate form.
authorTilmann Scheller <tilmann.scheller@googlemail.com>
Fri, 19 Jul 2013 16:18:56 +0000 (16:18 +0000)
committerTilmann Scheller <tilmann.scheller@googlemail.com>
Fri, 19 Jul 2013 16:18:56 +0000 (16:18 +0000)
See A8.8.127 in ARM DDI 0406C.b.

Related to <rdar://problem/14403733>.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@186682 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/ARM/ARMInstrThumb2.td
test/MC/ARM/basic-thumb2-instructions.s
test/MC/ARM/thumb2-pldw.s [new file with mode: 0644]

index f014e02de2c4b8971bb9933b065d1fcdfdad2f67..fdbf5ae7332a5445071ad18309990fe70c6b91fd 100644 (file)
@@ -4428,7 +4428,12 @@ def : t2InstAlias<"ldrsh${p}.w $Rt, $addr",
 def : t2InstAlias<"add${p} $Rd, pc, $imm",
                   (t2ADR rGPR:$Rd, imm0_4095:$imm, pred:$p)>;
 
-// PLI with alternate literal form.
+// PLD/PLDW/PLI with alternate literal form.
+def : t2InstAlias<"pld${p} $addr",
+                  (t2PLDpci t2ldr_pcrel_imm12:$addr, pred:$p)>;
+def : InstAlias<"pldw${p} $addr",
+                 (t2PLDWpci  t2ldr_pcrel_imm12:$addr, pred:$p)>,
+      Requires<[IsThumb2,HasV7,HasMP]>;
 def : InstAlias<"pli${p} $addr",
                  (t2PLIpci  t2ldr_pcrel_imm12:$addr, pred:$p)>,
       Requires<[IsThumb2,HasV7]>;
index 50a505e1d3c14b56f120e109551e9c95f5638b65..2bd9a133384f7f90ef597565c682d8f2115d7bee 100644 (file)
@@ -1573,6 +1573,9 @@ _func:
 @ FIXME: pld   _foo                    @ encoding: [0x9f'A',0xf8'A',A,0xf0'A']
             @   fixup A - offset: 0, value: _foo, kind: fixup_t2_ldst_pcrel_12
 
+        pld [pc,#-4095]
+@ CHECK: pld [pc, #-4095]            @ encoding: [0x1f,0xf8,0xff,0xff]
+
 
 @------------------------------------------------------------------------------
 @ PLD(register)
diff --git a/test/MC/ARM/thumb2-pldw.s b/test/MC/ARM/thumb2-pldw.s
new file mode 100644 (file)
index 0000000..7acbd39
--- /dev/null
@@ -0,0 +1,7 @@
+@ RUN: llvm-mc -triple=thumbv7-apple-darwin -mcpu=cortex-a8 -mattr=+mp -show-encoding < %s | FileCheck %s
+
+@------------------------------------------------------------------------------
+@ PLD(literal)
+@------------------------------------------------------------------------------
+        pldw [pc,#-4095]
+@ CHECK: pldw [pc, #-4095]            @ encoding: [0x3f,0xf8,0xff,0xff]