; 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 Spill ; CHECK-NEXT: std %f9, 48(%r15) # 8-byte Spill ; CHECK-NEXT: std %f10, 40(%r15) # 8-byte Spill ; CHECK-NEXT: std %f11, 32(%r15) # 8-byte Spill ; CHECK-NEXT: std %f12, 24(%r15) # 8-byte Spill ; CHECK-NEXT: std %f13, 16(%r15) # 8-byte Spill ; CHECK-NEXT: std %f14, 8(%r15) # 8-byte Spill ; CHECK-NEXT: std %f15, 0(%r15) # 8-byte 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 Reload ; CHECK-NEXT: ld %f9, 48(%r15) # 8-byte Reload ; CHECK-NEXT: ld %f10, 40(%r15) # 8-byte Reload ; CHECK-NEXT: ld %f11, 32(%r15) # 8-byte Reload ; CHECK-NEXT: ld %f12, 24(%r15) # 8-byte Reload ; CHECK-NEXT: ld %f13, 16(%r15) # 8-byte Reload ; CHECK-NEXT: ld %f14, 8(%r15) # 8-byte Reload ; CHECK-NEXT: ld %f15, 0(%r15) # 8-byte 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 Spill ; CHECK-NEXT: std %f9, 48(%r15) # 8-byte Spill ; CHECK-NEXT: std %f10, 40(%r15) # 8-byte Spill ; CHECK-NEXT: std %f11, 32(%r15) # 8-byte Spill ; CHECK-NEXT: std %f12, 24(%r15) # 8-byte Spill ; CHECK-NEXT: std %f13, 16(%r15) # 8-byte Spill ; CHECK-NEXT: std %f14, 8(%r15) # 8-byte Spill ; CHECK-NEXT: std %f15, 0(%r15) # 8-byte 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 Reload ; CHECK-NEXT: ld %f9, 48(%r15) # 8-byte Reload ; CHECK-NEXT: ld %f10, 40(%r15) # 8-byte Reload ; CHECK-NEXT: ld %f11, 32(%r15) # 8-byte Reload ; CHECK-NEXT: ld %f12, 24(%r15) # 8-byte Reload ; CHECK-NEXT: ld %f13, 16(%r15) # 8-byte Reload ; CHECK-NEXT: ld %f14, 8(%r15) # 8-byte Reload ; CHECK-NEXT: ld %f15, 0(%r15) # 8-byte 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 }