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