; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 4 ; RUN: llc < %s -mtriple=s390x-ibm-zos | FileCheck --check-prefix=CHECK %s ; The current function's frame address is the address of ; the optional back chain slot. define ptr @fp0() nounwind { ; CHECK-LABEL: fp0: ; CHECK: la 3,2048(4) ; CHECK-NEXT: b 2(7) entry: %0 = tail call ptr @llvm.frameaddress(i32 0) ret ptr %0 } ; Check that the frame address is correct in a presence ; of a stack frame. define ptr @fp0f() nounwind { ; CHECK-LABEL: fp0f: ; CHECK: stmg 6,7,1904(4) ; CHECK-NEXT: aghi 4,-160 ; CHECK-NEXT: la 3,2048(4) ; CHECK-NEXT: lg 7,2072(4) ; CHECK-NEXT: aghi 4,160 ; CHECK-NEXT: b 2(7) entry: %0 = alloca i64, align 8 %1 = tail call ptr @llvm.frameaddress(i32 0) ret ptr %1 } ; Check the caller's frame address. define ptr @fpcaller() nounwind "backchain" { ; CHECK-LABEL: fpcaller: ; CHECK: stmg 4,7,2048(4) ; CHECK-NEXT: lg 3,2048(4) ; CHECK-NEXT: lmg 4,7,2048(4) ; CHECK-NEXT: b 2(7) entry: %0 = tail call ptr @llvm.frameaddress(i32 1) ret ptr %0 } ; Check the caller's frame address. define ptr @fpcallercaller() nounwind "backchain" { ; CHECK-LABEL: fpcallercaller: ; CHECK: stmg 4,7,2048(4) ; CHECK-NEXT: lg 1,2048(4) ; CHECK-NEXT: lg 3,0(1) ; CHECK-NEXT: lmg 4,7,2048(4) ; CHECK-NEXT: b 2(7) entry: %0 = tail call ptr @llvm.frameaddress(i32 2) ret ptr %0 } declare ptr @llvm.frameaddress(i32) nounwind readnone