blob: 46fb7c3ef1926a7f022c9907ae5ad3a825cd924a [file] [log] [blame]
Evan Chenga6bff982010-01-30 01:22:00 +00001; RUN: llc < %s -march=x86 -asm-verbose=false | FileCheck %s -check-prefix=32
2; RUN: llc < %s -march=x86-64 -asm-verbose=false | FileCheck %s -check-prefix=64
Evan Chengb1712452010-01-27 06:25:16 +00003
Evan Cheng7096ae42010-01-29 06:45:59 +00004define void @t1(i32 %x) nounwind ssp {
Evan Chengb1712452010-01-27 06:25:16 +00005entry:
Evan Chenga6bff982010-01-30 01:22:00 +00006; 32: t1:
7; 32: jmp {{_?}}foo
8
9; 64: t1:
10; 64: jmp {{_?}}foo
Evan Chengb1712452010-01-27 06:25:16 +000011 tail call void @foo() nounwind
12 ret void
13}
14
15declare void @foo()
Evan Cheng7096ae42010-01-29 06:45:59 +000016
17define void @t2() nounwind ssp {
18entry:
Evan Chenga6bff982010-01-30 01:22:00 +000019; 32: t2:
20; 32: jmp {{_?}}foo2
21
22; 64: t2:
23; 64: jmp {{_?}}foo2
Evan Cheng7096ae42010-01-29 06:45:59 +000024 %0 = tail call i32 @foo2() nounwind
25 ret void
26}
27
28declare i32 @foo2()
29
30define void @t3() nounwind ssp {
31entry:
Evan Chenga6bff982010-01-30 01:22:00 +000032; 32: t3:
33; 32: jmp {{_?}}foo3
34
35; 64: t3:
36; 64: jmp {{_?}}foo3
Evan Cheng7096ae42010-01-29 06:45:59 +000037 %0 = tail call i32 @foo3() nounwind
38 ret void
39}
40
41declare i32 @foo3()
Evan Chenga6bff982010-01-30 01:22:00 +000042
43define void @t4(void (i32)* nocapture %x) nounwind ssp {
44entry:
45; 32: t4:
46; 32: call *
47; FIXME: gcc can generate a tailcall for this. But it's tricky.
48
49; 64: t4:
50; 64-NOT: call
51; 64: jmpq *
52 tail call void %x(i32 0) nounwind
53 ret void
54}
55
56define void @t5(void ()* nocapture %x) nounwind ssp {
57entry:
58; 32: t5:
59; 32-NOT: call
60; 32: jmpl *
61
62; 64: t5:
63; 64-NOT: call
64; 64: jmpq *
65 tail call void %x() nounwind
66 ret void
67}
Evan Cheng843bd692010-01-31 06:44:49 +000068
69define i32 @t6(i32 %x) nounwind ssp {
70entry:
71; 32: t6:
72; 32: call {{_?}}t6
73; 32: call {{_?}}bar
74
75; 64: t6:
Evan Cheng0a4fd462010-02-01 02:13:39 +000076; 64: jmp {{_?}}t6
Evan Cheng843bd692010-01-31 06:44:49 +000077; 64: jmp {{_?}}bar
78 %0 = icmp slt i32 %x, 10
79 br i1 %0, label %bb, label %bb1
80
81bb:
82 %1 = add nsw i32 %x, -1
83 %2 = tail call i32 @t6(i32 %1) nounwind ssp
84 ret i32 %2
85
86bb1:
87 %3 = tail call i32 @bar(i32 %x) nounwind
88 ret i32 %3
89}
90
91declare i32 @bar(i32)
Evan Chengb2c92902010-02-02 02:22:50 +000092
93define i32 @t7(i32 %a, i32 %b, i32 %c) nounwind ssp {
94entry:
95; 32: t7:
96; 32: jmp {{_?}}bar2
97
98; 64: t7:
99; 64: jmp {{_?}}bar2
100 %0 = tail call i32 @bar2(i32 %a, i32 %b, i32 %c) nounwind
101 ret i32 %0
102}
103
104declare i32 @bar2(i32, i32, i32)
Evan Cheng86809cc2010-02-03 03:28:02 +0000105
106define signext i16 @t8() nounwind ssp {
107entry:
108; 32: t8:
Evan Cheng1f2fda92010-02-04 06:47:24 +0000109; 32: call {{_?}}bar3
Evan Cheng86809cc2010-02-03 03:28:02 +0000110
111; 64: t8:
Evan Cheng1f2fda92010-02-04 06:47:24 +0000112; 64: callq {{_?}}bar3
Evan Cheng86809cc2010-02-03 03:28:02 +0000113 %0 = tail call signext i16 @bar3() nounwind ; <i16> [#uses=1]
114 ret i16 %0
115}
116
117declare signext i16 @bar3()
118
119define signext i16 @t9(i32 (i32)* nocapture %x) nounwind ssp {
120entry:
121; 32: t9:
122; 32: call *
123
124; 64: t9:
125; 64: callq *
126 %0 = bitcast i32 (i32)* %x to i16 (i32)*
127 %1 = tail call signext i16 %0(i32 0) nounwind
128 ret i16 %1
129}
Evan Chengfebc8162010-02-03 03:55:59 +0000130
131define void @t10() nounwind ssp {
132entry:
133; 32: t10:
134; 32: call
135
136; 64: t10:
137; 64: callq
138 %0 = tail call i32 @foo4() noreturn nounwind
139 unreachable
140}
141
142declare i32 @foo4()