; 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
}