; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 4
; RUN: llc < %s -mtriple=s390x-ibm-zos | FileCheck %s
; The current function's return address is in the link register.
define ptr @rt0() norecurse nounwind readnone {
; CHECK-LABEL: rt0:
; CHECK: lgr 3, 7
; CHECK-NEXT: b 2(7)
entry:
%0 = tail call ptr @llvm.returnaddress(i32 0)
ret ptr %0
}
; Check the caller's return address.
define ptr @rtcaller() nounwind "backchain" {
; CHECK-LABEL: rtcaller:
; CHECK: stmg 4, 7, 2048(4)
; CHECK-NEXT: lg 1, 2048(4)
; CHECK-NEXT: lg 3, 24(1)
; CHECK-NEXT: lmg 4, 7, 2048(4)
; CHECK-NEXT: b 2(7)
entry:
%0 = tail call ptr @llvm.returnaddress(i32 1)
ret ptr %0
}
; Check the caller's caller's return address.
define ptr @rtcallercaller() nounwind "backchain" {
; CHECK-LABEL: rtcallercaller:
; CHECK: stmg 4, 7, 2048(4)
; CHECK-NEXT: lg 1, 2048(4)
; CHECK-NEXT: lg 1, 0(1)
; CHECK-NEXT: lg 3, 24(1)
; CHECK-NEXT: lmg 4, 7, 2048(4)
; CHECK-NEXT: b 2(7)
entry:
%0 = tail call ptr @llvm.returnaddress(i32 2)
ret ptr %0
}
declare ptr @llvm.returnaddress(i32) nounwind readnone