aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Target/ARM/ARMInstrThumb.td
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2009-11-04 00:00:39 +0000
committerEvan Cheng <evan.cheng@apple.com>2009-11-04 00:00:39 +0000
commit7883fa942ff004b9c441ff9126a9d57b29d22a5e (patch)
tree94570ffe561abd08da3fa4c77deeed70094d144f /lib/Target/ARM/ARMInstrThumb.td
parent233a60ec40b41027ff429e2f2c27fa2be762f2e9 (diff)
downloadexternal_llvm-7883fa942ff004b9c441ff9126a9d57b29d22a5e.zip
external_llvm-7883fa942ff004b9c441ff9126a9d57b29d22a5e.tar.gz
external_llvm-7883fa942ff004b9c441ff9126a9d57b29d22a5e.tar.bz2
Use ldr.n to workaround a darwin assembler bug.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@85980 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/ARM/ARMInstrThumb.td')
-rw-r--r--lib/Target/ARM/ARMInstrThumb.td3
1 files changed, 2 insertions, 1 deletions
diff --git a/lib/Target/ARM/ARMInstrThumb.td b/lib/Target/ARM/ARMInstrThumb.td
index d353334..ba68f8f 100644
--- a/lib/Target/ARM/ARMInstrThumb.td
+++ b/lib/Target/ARM/ARMInstrThumb.td
@@ -326,9 +326,10 @@ def tRestore : T1pIs<(outs tGPR:$dst), (ins t_addrmode_sp:$addr), IIC_iLoadi,
"ldr", "\t$dst, $addr", []>;
// Load tconstpool
+// FIXME: Use ldr.n to work around a Darwin assembler bug.
let canFoldAsLoad = 1 in
def tLDRpci : T1pIs<(outs tGPR:$dst), (ins i32imm:$addr), IIC_iLoadi,
- "ldr", "\t$dst, $addr",
+ "ldr.n", "\t$dst, $addr",
[(set tGPR:$dst, (load (ARMWrapper tconstpool:$addr)))]>;
// Special LDR for loads from non-pc-relative constpools.