summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJakob Stoklund Olesen <stoklund@2pi.dk>2013-05-19 19:14:24 +0000
committerJakob Stoklund Olesen <stoklund@2pi.dk>2013-05-19 19:14:24 +0000
commitead983cec99c2025614f2374e895a963f7a17bc7 (patch)
tree3af32baf5052bb55223b89299403fd0f5c76179e
parent826df14d7274ed8e637dcbd8e4bb3d8b89f7d175 (diff)
downloadbcm5719-llvm-ead983cec99c2025614f2374e895a963f7a17bc7.tar.gz
bcm5719-llvm-ead983cec99c2025614f2374e895a963f7a17bc7.zip
Handle i64 FrameIndex nodes in SPARC v9 mode.
llvm-svn: 182216
-rw-r--r--llvm/lib/Target/Sparc/SparcInstrInfo.td2
-rw-r--r--llvm/test/CodeGen/SPARC/64bit.ll10
2 files changed, 11 insertions, 1 deletions
diff --git a/llvm/lib/Target/Sparc/SparcInstrInfo.td b/llvm/lib/Target/Sparc/SparcInstrInfo.td
index baefb0642d4..740390f3f56 100644
--- a/llvm/lib/Target/Sparc/SparcInstrInfo.td
+++ b/llvm/lib/Target/Sparc/SparcInstrInfo.td
@@ -463,7 +463,7 @@ defm ADD : F3_12<"add", 0b000000, add>;
def LEA_ADDri : F3_2<2, 0b000000,
(outs IntRegs:$dst), (ins MEMri:$addr),
"add ${addr:arith}, $dst",
- [(set i32:$dst, ADDRri:$addr)]>;
+ [(set iPTR:$dst, ADDRri:$addr)]>;
let Defs = [ICC] in
defm ADDCC : F3_12<"addcc", 0b010000, addc>;
diff --git a/llvm/test/CodeGen/SPARC/64bit.ll b/llvm/test/CodeGen/SPARC/64bit.ll
index 2bbf7deb168..37dcea9891d 100644
--- a/llvm/test/CodeGen/SPARC/64bit.ll
+++ b/llvm/test/CodeGen/SPARC/64bit.ll
@@ -181,3 +181,13 @@ define i64 @unsigned_divide(i64 %a, i64 %b) {
%r = udiv i64 %a, %b
ret i64 %r
}
+
+define void @access_fi() {
+entry:
+ %b = alloca [32 x i8], align 1
+ %arraydecay = getelementptr inbounds [32 x i8]* %b, i64 0, i64 0
+ call void @g(i8* %arraydecay) #2
+ ret void
+}
+
+declare void @g(i8*)
OpenPOWER on IntegriCloud