summaryrefslogtreecommitdiffstats
path: root/llvm/test/CodeGen/Thumb2/large-stack.ll
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2009-07-28 05:48:47 +0000
committerEvan Cheng <evan.cheng@apple.com>2009-07-28 05:48:47 +0000
commit780748d565b189968c172451d6bb843e673a887c (patch)
treebae7e9bfb8057b9a72baab927e04980f05c68afc /llvm/test/CodeGen/Thumb2/large-stack.ll
parent7be52a817999ded3ab10d853db1612904c01b8c6 (diff)
downloadbcm5719-llvm-780748d565b189968c172451d6bb843e673a887c.tar.gz
bcm5719-llvm-780748d565b189968c172451d6bb843e673a887c.zip
- More refactoring. This gets rid of all of the getOpcode calls.
- This change also makes it possible to switch between ARM / Thumb on a per-function basis. - Fixed thumb2 routine which expand reg + arbitrary immediate. It was using using ARM so_imm logic. - Use movw and movt to do reg + imm when profitable. - Other code clean ups and minor optimizations. llvm-svn: 77300
Diffstat (limited to 'llvm/test/CodeGen/Thumb2/large-stack.ll')
-rw-r--r--llvm/test/CodeGen/Thumb2/large-stack.ll28
1 files changed, 28 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/Thumb2/large-stack.ll b/llvm/test/CodeGen/Thumb2/large-stack.ll
new file mode 100644
index 00000000000..60604f020ff
--- /dev/null
+++ b/llvm/test/CodeGen/Thumb2/large-stack.ll
@@ -0,0 +1,28 @@
+; RUN: llvm-as < %s | llc -march=thumb -mattr=+thumb2 | FileCheck %s
+
+define void @test1() {
+; CHECK: test1:
+; CHECK: sub.w sp, sp, #256
+ %tmp = alloca [ 64 x i32 ] , align 4
+ ret void
+}
+
+define void @test2() {
+; CHECK: test2:
+; CHECK: sub.w sp, sp, #4160
+; CHECK: sub.w sp, sp, #8
+ %tmp = alloca [ 4168 x i8 ] , align 4
+ ret void
+}
+
+define i32 @test3() {
+; CHECK: test3:
+; CHECK: sub.w sp, sp, #805306368
+; CHECK: sub.w sp, sp, #16
+ %retval = alloca i32, align 4
+ %tmp = alloca i32, align 4
+ %a = alloca [805306369 x i8], align 16
+ store i32 0, i32* %tmp
+ %tmp1 = load i32* %tmp
+ ret i32 %tmp1
+}
OpenPOWER on IntegriCloud