[InstCombine] Signed saturation patterns
[llvm-core.git] / test / CodeGen / SPARC / 2011-01-11-Call.ll
blob8097e49ad3f7b885a757db3d47603b7b58ab8711
1 ; RUN: llc -march=sparc -O0 <%s
2 ; RUN: llc -march=sparc   <%s | FileCheck %s --check-prefix=V8
3 ; RUN: llc -march=sparcv9 <%s | FileCheck %s --check-prefix=V9
5 ; V8-LABEL: test
6 ; V8:       save %sp
7 ; V8:       call foo
8 ; V8-NEXT:  nop
9 ; V8:       call bar
10 ; V8-NEXT:  nop
11 ; V8:       ret
12 ; V8-NEXT:  restore
14 ; V9-LABEL: test
15 ; V9:       save %sp
16 ; V9:       call foo
17 ; V9-NEXT:  nop
18 ; V9:       call bar
19 ; V9-NEXT:  nop
20 ; V9:       ret
21 ; V9-NEXT:  restore
23 define void @test() nounwind {
24 entry:
25  %0 = tail call i32 (...) @foo() nounwind
26  tail call void (...) @bar() nounwind
27  ret void
30 declare i32 @foo(...)
32 declare void @bar(...)
35 ; V8-LABEL: test_tail_call_with_return
36 ; V8:       save %sp
37 ; V8:       call foo
38 ; V8-NEXT:  nop
39 ; V8:       ret
40 ; V8-NEXT:  restore %g0, %o0, %o0
42 ; V9-LABEL: test_tail_call_with_return
43 ; V9:       save %sp
44 ; V9:       call foo
45 ; V9-NEXT:  nop
46 ; V9:       ret
47 ; V9-NEXT:  restore %g0, %o0, %o0
49 define i32 @test_tail_call_with_return() nounwind {
50 entry:
51  %0 = tail call i32 (...) @foo() nounwind
52  ret i32 %0