1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124
|
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
; Test setjmp store jmp_buf
; Return address in slot 2.
; Backchain value is stored in slot 3 for -mbackchain option.
; Stack Pointer in slot 4.
; Clobber %r6-%r15, %f8-%f15.
; RUN: llc < %s -verify-machineinstrs -mtriple=s390x-linux-gnu | FileCheck %s
declare i32 @llvm.eh.sjlj.setjmp(ptr)
@buf = global [20 x ptr] zeroinitializer, align 8
define void @foo() {
; CHECK-LABEL: foo:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r6, %r15, 48(%r15)
; CHECK-NEXT: .cfi_offset %r6, -112
; CHECK-NEXT: .cfi_offset %r7, -104
; CHECK-NEXT: .cfi_offset %r8, -96
; CHECK-NEXT: .cfi_offset %r9, -88
; CHECK-NEXT: .cfi_offset %r10, -80
; CHECK-NEXT: .cfi_offset %r11, -72
; CHECK-NEXT: .cfi_offset %r12, -64
; CHECK-NEXT: .cfi_offset %r13, -56
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: aghi %r15, -64
; CHECK-NEXT: .cfi_def_cfa_offset 224
; CHECK-NEXT: std %f8, 56(%r15) # 8-byte Folded Spill
; CHECK-NEXT: std %f9, 48(%r15) # 8-byte Folded Spill
; CHECK-NEXT: std %f10, 40(%r15) # 8-byte Folded Spill
; CHECK-NEXT: std %f11, 32(%r15) # 8-byte Folded Spill
; CHECK-NEXT: std %f12, 24(%r15) # 8-byte Folded Spill
; CHECK-NEXT: std %f13, 16(%r15) # 8-byte Folded Spill
; CHECK-NEXT: std %f14, 8(%r15) # 8-byte Folded Spill
; CHECK-NEXT: std %f15, 0(%r15) # 8-byte Folded Spill
; CHECK-NEXT: .cfi_offset %f8, -168
; CHECK-NEXT: .cfi_offset %f9, -176
; CHECK-NEXT: .cfi_offset %f10, -184
; CHECK-NEXT: .cfi_offset %f11, -192
; CHECK-NEXT: .cfi_offset %f12, -200
; CHECK-NEXT: .cfi_offset %f13, -208
; CHECK-NEXT: .cfi_offset %f14, -216
; CHECK-NEXT: .cfi_offset %f15, -224
; CHECK-NEXT: lgrl %r1, buf@GOT
; CHECK-NEXT: larl %r0, .LBB0_1
; CHECK-NEXT: stg %r0, 8(%r1)
; CHECK-NEXT: stg %r15, 24(%r1)
; CHECK-NEXT: .LBB0_1: # Block address taken
; CHECK-NEXT: # %entry
; CHECK-NEXT: .LBB0_2: # %entry
; CHECK-NEXT: ld %f8, 56(%r15) # 8-byte Folded Reload
; CHECK-NEXT: ld %f9, 48(%r15) # 8-byte Folded Reload
; CHECK-NEXT: ld %f10, 40(%r15) # 8-byte Folded Reload
; CHECK-NEXT: ld %f11, 32(%r15) # 8-byte Folded Reload
; CHECK-NEXT: ld %f12, 24(%r15) # 8-byte Folded Reload
; CHECK-NEXT: ld %f13, 16(%r15) # 8-byte Folded Reload
; CHECK-NEXT: ld %f14, 8(%r15) # 8-byte Folded Reload
; CHECK-NEXT: ld %f15, 0(%r15) # 8-byte Folded Reload
; CHECK-NEXT: lmg %r6, %r15, 112(%r15)
; CHECK-NEXT: br %r14
entry:
%0 = tail call i32 @llvm.eh.sjlj.setjmp(ptr nonnull @buf)
ret void
}
define void @foo1() "backchain" {
; CHECK-LABEL: foo1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: stmg %r6, %r15, 48(%r15)
; CHECK-NEXT: .cfi_offset %r6, -112
; CHECK-NEXT: .cfi_offset %r7, -104
; CHECK-NEXT: .cfi_offset %r8, -96
; CHECK-NEXT: .cfi_offset %r9, -88
; CHECK-NEXT: .cfi_offset %r10, -80
; CHECK-NEXT: .cfi_offset %r11, -72
; CHECK-NEXT: .cfi_offset %r12, -64
; CHECK-NEXT: .cfi_offset %r13, -56
; CHECK-NEXT: .cfi_offset %r14, -48
; CHECK-NEXT: .cfi_offset %r15, -40
; CHECK-NEXT: lgr %r1, %r15
; CHECK-NEXT: aghi %r15, -64
; CHECK-NEXT: .cfi_def_cfa_offset 224
; CHECK-NEXT: stg %r1, 0(%r15)
; CHECK-NEXT: std %f8, 56(%r15) # 8-byte Folded Spill
; CHECK-NEXT: std %f9, 48(%r15) # 8-byte Folded Spill
; CHECK-NEXT: std %f10, 40(%r15) # 8-byte Folded Spill
; CHECK-NEXT: std %f11, 32(%r15) # 8-byte Folded Spill
; CHECK-NEXT: std %f12, 24(%r15) # 8-byte Folded Spill
; CHECK-NEXT: std %f13, 16(%r15) # 8-byte Folded Spill
; CHECK-NEXT: std %f14, 8(%r15) # 8-byte Folded Spill
; CHECK-NEXT: std %f15, 0(%r15) # 8-byte Folded Spill
; CHECK-NEXT: .cfi_offset %f8, -168
; CHECK-NEXT: .cfi_offset %f9, -176
; CHECK-NEXT: .cfi_offset %f10, -184
; CHECK-NEXT: .cfi_offset %f11, -192
; CHECK-NEXT: .cfi_offset %f12, -200
; CHECK-NEXT: .cfi_offset %f13, -208
; CHECK-NEXT: .cfi_offset %f14, -216
; CHECK-NEXT: .cfi_offset %f15, -224
; CHECK-NEXT: lgrl %r1, buf@GOT
; CHECK-NEXT: larl %r0, .LBB1_1
; CHECK-NEXT: stg %r0, 8(%r1)
; CHECK-NEXT: stg %r15, 24(%r1)
; CHECK-NEXT: lg %r0, 0(%r15)
; CHECK-NEXT: stg %r0, 16(%r1)
; CHECK-NEXT: .LBB1_1: # Block address taken
; CHECK-NEXT: # %entry
; CHECK-NEXT: .LBB1_2: # %entry
; CHECK-NEXT: ld %f8, 56(%r15) # 8-byte Folded Reload
; CHECK-NEXT: ld %f9, 48(%r15) # 8-byte Folded Reload
; CHECK-NEXT: ld %f10, 40(%r15) # 8-byte Folded Reload
; CHECK-NEXT: ld %f11, 32(%r15) # 8-byte Folded Reload
; CHECK-NEXT: ld %f12, 24(%r15) # 8-byte Folded Reload
; CHECK-NEXT: ld %f13, 16(%r15) # 8-byte Folded Reload
; CHECK-NEXT: ld %f14, 8(%r15) # 8-byte Folded Reload
; CHECK-NEXT: ld %f15, 0(%r15) # 8-byte Folded Reload
; CHECK-NEXT: lmg %r6, %r15, 112(%r15)
; CHECK-NEXT: br %r14
entry:
%0 = tail call i32 @llvm.eh.sjlj.setjmp(ptr nonnull @buf)
ret void
}
|