llvm/llvm/test/CodeGen/SystemZ/ret-addr-02.ll

; Test support for the llvm.returnaddress intrinsic with packed-stack.

; RUN: llc < %s -mtriple=s390x-linux-gnu | FileCheck %s

; The current function's return address is in the link register.
attributes #0 = { nounwind "packed-stack" "backchain" "use-soft-float"="true" }
define ptr @rt0() #0 {
entry:
; CHECK-LABEL: rt0:
; CHECK: lgr  %r2, %r14
; CHECK: br   %r14
  %0 = tail call ptr @llvm.returnaddress(i32 0)
  ret ptr %0
}

; Check the caller's return address.
define ptr @rtcaller() #0 {
entry:
; CHECK-LABEL: rtcaller:
; CHECK: lg   %r1, 152(%r15)
; CHECK  lg   %r2, 136(%r1)
; CHECK: br   %r14
  %0 = tail call ptr @llvm.returnaddress(i32 1)
  ret ptr %0
}

; Check the caller's caller's return address.
define ptr @rtcallercaller() #0 {
entry:
; CHECK-LABEL: rtcallercaller:
; CHECK: lg   %r1, 152(%r15)
; CHECK: lg   %r1, 152(%r1)
; CHECK  lg   %r2, 136(%r1)
; CHECK: br   %r14
  %0 = tail call ptr @llvm.returnaddress(i32 2)
  ret ptr %0
}

declare ptr @llvm.returnaddress(i32) nounwind readnone