summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorBill Wendling <isanbard@gmail.com>2010-11-30 00:18:30 +0000
committerBill Wendling <isanbard@gmail.com>2010-11-30 00:18:30 +0000
commit85a8a72d85782cedba82b67c5ff033428cf34bd4 (patch)
treef59916daf7747e6681549f61261e3d353a5cf5d6 /llvm/lib
parente22c7322b807f77dfc9497c34462e2c8af7fd91b (diff)
downloadbcm5719-llvm-85a8a72d85782cedba82b67c5ff033428cf34bd4.tar.gz
bcm5719-llvm-85a8a72d85782cedba82b67c5ff033428cf34bd4.zip
Add some encoding for the adr instruction. Labels still need to be finished.
llvm-svn: 120365
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Target/ARM/ARMInstrThumb.td22
1 files changed, 16 insertions, 6 deletions
diff --git a/llvm/lib/Target/ARM/ARMInstrThumb.td b/llvm/lib/Target/ARM/ARMInstrThumb.td
index 4a2a199a3b4..0fac0daa0ef 100644
--- a/llvm/lib/Target/ARM/ARMInstrThumb.td
+++ b/llvm/lib/Target/ARM/ARMInstrThumb.td
@@ -1241,14 +1241,24 @@ def tMOVCCi : T1pIt<(outs tGPR:$dst), (ins tGPR:$lhs, i32imm:$rhs), IIC_iCMOVi,
// tLEApcrel - Load a pc-relative address into a register without offending the
// assembler.
let neverHasSideEffects = 1, isReMaterializable = 1 in
-def tLEApcrel : T1I<(outs tGPR:$dst), (ins i32imm:$label, pred:$p), IIC_iALUi,
- "adr${p}\t$dst, #$label", []>,
- T1Encoding<{1,0,1,0,0,?}>; // A6.2 & A8.6.10
+def tLEApcrel : T1I<(outs tGPR:$Rd), (ins i32imm:$label, pred:$p), IIC_iALUi,
+ "adr${p}\t$Rd, #$label", []>,
+ T1Encoding<{1,0,1,0,0,?}> {
+ // A6.2 & A8.6.10
+ bits<3> Rd;
+ let Inst{10-8} = Rd;
+ // FIXME: Add label encoding/fixup
+}
-def tLEApcrelJT : T1I<(outs tGPR:$dst),
+def tLEApcrelJT : T1I<(outs tGPR:$Rd),
(ins i32imm:$label, nohash_imm:$id, pred:$p),
- IIC_iALUi, "adr${p}\t$dst, #${label}_${id}", []>,
- T1Encoding<{1,0,1,0,0,?}>; // A6.2 & A8.6.10
+ IIC_iALUi, "adr${p}\t$Rd, #${label}_${id}", []>,
+ T1Encoding<{1,0,1,0,0,?}> {
+ // A6.2 & A8.6.10
+ bits<3> Rd;
+ let Inst{10-8} = Rd;
+ // FIXME: Add label encoding/fixup
+}
//===----------------------------------------------------------------------===//
// TLS Instructions
OpenPOWER on IntegriCloud