| ; RUN: llc -march=sparc -O0 <%s |
| ; RUN: llc -march=sparc <%s | FileCheck %s --check-prefix=V8 |
| ; RUN: llc -march=sparcv9 <%s | FileCheck %s --check-prefix=V9 |
| |
| ; V8-LABEL: test |
| ; V8: save %sp |
| ; V8: call foo |
| ; V8-NEXT: nop |
| ; V8: call bar |
| ; V8-NEXT: nop |
| ; V8: ret |
| ; V8-NEXT: restore |
| |
| ; V9-LABEL: test |
| ; V9: save %sp |
| ; V9: call foo |
| ; V9-NEXT: nop |
| ; V9: call bar |
| ; V9-NEXT: nop |
| ; V9: ret |
| ; V9-NEXT: restore |
| |
| define void @test() nounwind { |
| entry: |
| %0 = tail call i32 (...) @foo() nounwind |
| tail call void (...) @bar() nounwind |
| ret void |
| } |
| |
| declare i32 @foo(...) |
| |
| declare void @bar(...) |
| |
| |
| ; V8-LABEL: test_tail_call_with_return |
| ; V8: save %sp |
| ; V8: call foo |
| ; V8-NEXT: nop |
| ; V8: ret |
| ; V8-NEXT: restore %g0, %o0, %o0 |
| |
| ; V9-LABEL: test_tail_call_with_return |
| ; V9: save %sp |
| ; V9: call foo |
| ; V9-NEXT: nop |
| ; V9: ret |
| ; V9-NEXT: restore %g0, %o0, %o0 |
| |
| define i32 @test_tail_call_with_return() nounwind { |
| entry: |
| %0 = tail call i32 (...) @foo() nounwind |
| ret i32 %0 |
| } |