summaryrefslogtreecommitdiffstats
path: root/llvm/test/CodeGen
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2009-11-01 03:25:03 +0000
committerChris Lattner <sabre@nondot.org>2009-11-01 03:25:03 +0000
commit50ba5c3dc2f02eb603fd41311c8f18abc1370e87 (patch)
treec0920b9d4a473b95dfc088d3e4be1746d0978353 /llvm/test/CodeGen
parent4578f8ea07c020aff5936501033d09672ac2b69e (diff)
downloadbcm5719-llvm-50ba5c3dc2f02eb603fd41311c8f18abc1370e87.tar.gz
bcm5719-llvm-50ba5c3dc2f02eb603fd41311c8f18abc1370e87.zip
improve x86 codegen support for blockaddress. We now compile
the testcase into: _test1: ## @test1 ## BB#0: ## %entry leaq L_test1_bb6(%rip), %rax jmpq *%rax L_test1_bb: ## Address Taken LBB1_1: ## %bb movb $1, %al ret L_test1_bb6: ## Address Taken LBB1_2: ## %bb6 movb $2, %al ret Note, it is very very strange that BlockAddressSDNode doesn't carry around TargetFlags. Dan, please fix this. llvm-svn: 85703
Diffstat (limited to 'llvm/test/CodeGen')
-rw-r--r--llvm/test/CodeGen/X86/x86-64-jumps.ll16
1 files changed, 16 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/X86/x86-64-jumps.ll b/llvm/test/CodeGen/X86/x86-64-jumps.ll
new file mode 100644
index 00000000000..5ed6a23ef87
--- /dev/null
+++ b/llvm/test/CodeGen/X86/x86-64-jumps.ll
@@ -0,0 +1,16 @@
+; RUN: llc < %s
+target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128"
+target triple = "x86_64-apple-darwin10.0"
+
+define i8 @test1() nounwind ssp {
+entry:
+ %0 = select i1 undef, i8* blockaddress(@test1, %bb), i8* blockaddress(@test1, %bb6) ; <i8*> [#uses=1]
+ indirectbr i8* %0, [label %bb, label %bb6]
+
+bb: ; preds = %entry
+ ret i8 1
+
+bb6: ; preds = %entry
+ ret i8 2
+}
+
OpenPOWER on IntegriCloud