[lldb] Make sure Blocks always have a parent (#117683)
[llvm-project.git] / llvm / test / CodeGen / SystemZ / zos-frameaddr.ll
blobf0a8a67041d12f0138c0e64973fb23ff0d0331b1
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 4
2 ; RUN: llc < %s -mtriple=s390x-ibm-zos | FileCheck --check-prefix=CHECK %s
4 ; The current function's frame address is the address of
5 ; the optional back chain slot.
6 define ptr @fp0() nounwind {
7 ; CHECK-LABEL: fp0:
8 ; CHECK:         la 3,2048(4)
9 ; CHECK-NEXT:    b 2(7)
10 entry:
11   %0 = tail call ptr @llvm.frameaddress(i32 0)
12   ret ptr %0
15 ; Check that the frame address is correct in a presence
16 ; of a stack frame.
17 define ptr @fp0f() nounwind {
18 ; CHECK-LABEL: fp0f:
19 ; CHECK:         stmg 6,7,1904(4)
20 ; CHECK-NEXT:    aghi 4,-160
21 ; CHECK-NEXT:    la 3,2048(4)
22 ; CHECK-NEXT:    lg 7,2072(4)
23 ; CHECK-NEXT:    aghi 4,160
24 ; CHECK-NEXT:    b 2(7)
25 entry:
26   %0 = alloca i64, align 8
27   %1 = tail call ptr @llvm.frameaddress(i32 0)
28   ret ptr %1
31 ; Check the caller's frame address.
32 define ptr @fpcaller() nounwind "backchain" {
33 ; CHECK-LABEL: fpcaller:
34 ; CHECK:         stmg 4,7,2048(4)
35 ; CHECK-NEXT:    lg 3,2048(4)
36 ; CHECK-NEXT:    lmg 4,7,2048(4)
37 ; CHECK-NEXT:    b 2(7)
38 entry:
39   %0 = tail call ptr @llvm.frameaddress(i32 1)
40   ret ptr %0
43 ; Check the caller's frame address.
44 define ptr @fpcallercaller() nounwind "backchain" {
45 ; CHECK-LABEL: fpcallercaller:
46 ; CHECK:         stmg 4,7,2048(4)
47 ; CHECK-NEXT:    lg 1,2048(4)
48 ; CHECK-NEXT:    lg 3,0(1)
49 ; CHECK-NEXT:    lmg 4,7,2048(4)
50 ; CHECK-NEXT:    b 2(7)
51 entry:
52   %0 = tail call ptr @llvm.frameaddress(i32 2)
53   ret ptr %0
56 declare ptr @llvm.frameaddress(i32) nounwind readnone