summaryrefslogtreecommitdiffstats
path: root/llvm/test/CodeGen/Thumb2
diff options
context:
space:
mode:
authorJim Grosbach <grosbach@apple.com>2013-02-19 18:55:36 +0000
committerJim Grosbach <grosbach@apple.com>2013-02-19 18:55:36 +0000
commit3fa275e6f76a5b7fc24c341a58aa10f8da987e92 (patch)
tree0b93923adefcb9e5cacd8ec867718ade3de1fecb /llvm/test/CodeGen/Thumb2
parent7e28db019a4ecba0a3f13e4c5d424b4a7d641e5c (diff)
downloadbcm5719-llvm-3fa275e6f76a5b7fc24c341a58aa10f8da987e92.tar.gz
bcm5719-llvm-3fa275e6f76a5b7fc24c341a58aa10f8da987e92.zip
ARM: Allocation hints must make sure to be in the alloc order.
When creating an allocation hint for a register pair, make sure the hint for the physical register reference is still in the allocation order. rdar://13240556 llvm-svn: 175541
Diffstat (limited to 'llvm/test/CodeGen/Thumb2')
-rw-r--r--llvm/test/CodeGen/Thumb2/2013-02-19-tail-call-register-hint.ll53
1 files changed, 53 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/Thumb2/2013-02-19-tail-call-register-hint.ll b/llvm/test/CodeGen/Thumb2/2013-02-19-tail-call-register-hint.ll
new file mode 100644
index 00000000000..502b138f65c
--- /dev/null
+++ b/llvm/test/CodeGen/Thumb2/2013-02-19-tail-call-register-hint.ll
@@ -0,0 +1,53 @@
+; RUN: llc < %s -mtriple=thumbv7s-apple-ios6.0.0 -verify-machineinstrs
+
+; Check to make sure the tail-call return at the end doesn't use a
+; callee-saved register. Register hinting from t2LDRDri was getting this
+; wrong. The intervening call will force allocation to try a high register
+; first, so the hint will attempt to fire, but must be rejected due to
+; not being in the allocation order for the tcGPR register class.
+; The machine instruction verifier will make sure that all actually worked
+; out the way it's supposed to.
+
+%"myclass" = type { %struct.foo }
+%struct.foo = type { i32, [40 x i8] }
+
+define hidden void @func(i8* %Data) nounwind ssp {
+ %1 = getelementptr inbounds i8* %Data, i32 12
+ %2 = bitcast i8* %1 to %"myclass"*
+ tail call void @abc(%"myclass"* %2) nounwind
+ tail call void @def(%"myclass"* %2) nounwind
+ %3 = getelementptr inbounds i8* %Data, i32 8
+ %4 = bitcast i8* %3 to i8**
+ %5 = load i8** %4, align 4, !tbaa !0
+ tail call void @ghi(i8* %5) nounwind
+ %6 = bitcast i8* %Data to void (i8*)**
+ %7 = load void (i8*)** %6, align 4, !tbaa !0
+ %8 = getelementptr inbounds i8* %Data, i32 4
+ %9 = bitcast i8* %8 to i8**
+ %10 = load i8** %9, align 4, !tbaa !0
+ %11 = icmp eq i8* %Data, null
+ br i1 %11, label %14, label %12
+
+; <label>:12 ; preds = %0
+ %13 = tail call %"myclass"* @jkl(%"myclass"* %2) nounwind
+ tail call void @mno(i8* %Data) nounwind
+ br label %14
+
+; <label>:14 ; preds = %12, %0
+ tail call void %7(i8* %10) nounwind
+ ret void
+}
+
+declare void @mno(i8*)
+
+declare void @def(%"myclass"*)
+
+declare void @abc(%"myclass"*)
+
+declare void @ghi(i8*)
+
+declare %"myclass"* @jkl(%"myclass"*) nounwind
+
+!0 = metadata !{metadata !"any pointer", metadata !1}
+!1 = metadata !{metadata !"omnipotent char", metadata !2}
+!2 = metadata !{metadata !"Simple C/C++ TBAA"}
OpenPOWER on IntegriCloud