blob: fc737928319b4a9cddf4fb1197967cd2385eeeaf [file] [log] [blame]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
; RUN: llc -mtriple riscv32-unknown-elf -mattr=+experimental-xqciint,+f -o - %s \
; RUN: -verify-machineinstrs | FileCheck --check-prefix=QCI-F %s
; RUN: llc -mtriple riscv32-unknown-elf -mattr=+experimental-xqciint,+d -o - %s \
; RUN: -verify-machineinstrs | FileCheck --check-prefix=QCI-D %s
;; This tests "interrupt"="qci-nest" and "interrupt"="qci-nonest" frame lowering
;; including CFI information, and floating point registers. These tests should
;; all lack `nounwind`.
;;
;; When `+save-restore` is enabled, the codegen should be identical as these
;; calls are incompatible with the interrupt attribute because the restore is
;; tail-called.
declare void @use_i32(i32)
define void @test_nest_asm() "interrupt"="qci-nest" {
; QCI-F-LABEL: test_nest_asm:
; QCI-F: # %bb.0:
; QCI-F-NEXT: qc.c.mienter.nest
; QCI-F-NEXT: .cfi_def_cfa_offset 96
; QCI-F-NEXT: .cfi_offset ra, -16
; QCI-F-NEXT: .cfi_offset t0, -24
; QCI-F-NEXT: .cfi_offset t1, -28
; QCI-F-NEXT: .cfi_offset t2, -32
; QCI-F-NEXT: .cfi_offset s0, -8
; QCI-F-NEXT: .cfi_offset a0, -36
; QCI-F-NEXT: .cfi_offset a1, -40
; QCI-F-NEXT: .cfi_offset a2, -44
; QCI-F-NEXT: .cfi_offset a3, -48
; QCI-F-NEXT: .cfi_offset a4, -52
; QCI-F-NEXT: .cfi_offset a5, -56
; QCI-F-NEXT: .cfi_offset a6, -60
; QCI-F-NEXT: .cfi_offset a7, -64
; QCI-F-NEXT: .cfi_offset t3, -68
; QCI-F-NEXT: .cfi_offset t4, -72
; QCI-F-NEXT: .cfi_offset t5, -76
; QCI-F-NEXT: .cfi_offset t6, -80
; QCI-F-NEXT: addi sp, sp, -80
; QCI-F-NEXT: .cfi_def_cfa_offset 176
; QCI-F-NEXT: fsw ft0, 76(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft1, 72(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft2, 68(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft3, 64(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft4, 60(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft5, 56(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft6, 52(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft7, 48(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa0, 44(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa1, 40(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa2, 36(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa3, 32(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa4, 28(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa5, 24(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa6, 20(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa7, 16(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft8, 12(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft9, 8(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft10, 4(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft11, 0(sp) # 4-byte Folded Spill
; QCI-F-NEXT: .cfi_offset ft0, -100
; QCI-F-NEXT: .cfi_offset ft1, -104
; QCI-F-NEXT: .cfi_offset ft2, -108
; QCI-F-NEXT: .cfi_offset ft3, -112
; QCI-F-NEXT: .cfi_offset ft4, -116
; QCI-F-NEXT: .cfi_offset ft5, -120
; QCI-F-NEXT: .cfi_offset ft6, -124
; QCI-F-NEXT: .cfi_offset ft7, -128
; QCI-F-NEXT: .cfi_offset fa0, -132
; QCI-F-NEXT: .cfi_offset fa1, -136
; QCI-F-NEXT: .cfi_offset fa2, -140
; QCI-F-NEXT: .cfi_offset fa3, -144
; QCI-F-NEXT: .cfi_offset fa4, -148
; QCI-F-NEXT: .cfi_offset fa5, -152
; QCI-F-NEXT: .cfi_offset fa6, -156
; QCI-F-NEXT: .cfi_offset fa7, -160
; QCI-F-NEXT: .cfi_offset ft8, -164
; QCI-F-NEXT: .cfi_offset ft9, -168
; QCI-F-NEXT: .cfi_offset ft10, -172
; QCI-F-NEXT: .cfi_offset ft11, -176
; QCI-F-NEXT: li a0, 1
; QCI-F-NEXT: #APP
; QCI-F-NEXT: # a0 <- a0
; QCI-F-NEXT: #NO_APP
; QCI-F-NEXT: call use_i32
; QCI-F-NEXT: flw ft0, 76(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft1, 72(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft2, 68(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft3, 64(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft4, 60(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft5, 56(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft6, 52(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft7, 48(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa0, 44(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa1, 40(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa2, 36(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa3, 32(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa4, 28(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa5, 24(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa6, 20(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa7, 16(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft8, 12(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft9, 8(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft10, 4(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft11, 0(sp) # 4-byte Folded Reload
; QCI-F-NEXT: .cfi_restore ft0
; QCI-F-NEXT: .cfi_restore ft1
; QCI-F-NEXT: .cfi_restore ft2
; QCI-F-NEXT: .cfi_restore ft3
; QCI-F-NEXT: .cfi_restore ft4
; QCI-F-NEXT: .cfi_restore ft5
; QCI-F-NEXT: .cfi_restore ft6
; QCI-F-NEXT: .cfi_restore ft7
; QCI-F-NEXT: .cfi_restore fa0
; QCI-F-NEXT: .cfi_restore fa1
; QCI-F-NEXT: .cfi_restore fa2
; QCI-F-NEXT: .cfi_restore fa3
; QCI-F-NEXT: .cfi_restore fa4
; QCI-F-NEXT: .cfi_restore fa5
; QCI-F-NEXT: .cfi_restore fa6
; QCI-F-NEXT: .cfi_restore fa7
; QCI-F-NEXT: .cfi_restore ft8
; QCI-F-NEXT: .cfi_restore ft9
; QCI-F-NEXT: .cfi_restore ft10
; QCI-F-NEXT: .cfi_restore ft11
; QCI-F-NEXT: addi sp, sp, 80
; QCI-F-NEXT: .cfi_def_cfa_offset 96
; QCI-F-NEXT: qc.c.mileaveret
;
; QCI-D-LABEL: test_nest_asm:
; QCI-D: # %bb.0:
; QCI-D-NEXT: qc.c.mienter.nest
; QCI-D-NEXT: .cfi_def_cfa_offset 96
; QCI-D-NEXT: .cfi_offset ra, -16
; QCI-D-NEXT: .cfi_offset t0, -24
; QCI-D-NEXT: .cfi_offset t1, -28
; QCI-D-NEXT: .cfi_offset t2, -32
; QCI-D-NEXT: .cfi_offset s0, -8
; QCI-D-NEXT: .cfi_offset a0, -36
; QCI-D-NEXT: .cfi_offset a1, -40
; QCI-D-NEXT: .cfi_offset a2, -44
; QCI-D-NEXT: .cfi_offset a3, -48
; QCI-D-NEXT: .cfi_offset a4, -52
; QCI-D-NEXT: .cfi_offset a5, -56
; QCI-D-NEXT: .cfi_offset a6, -60
; QCI-D-NEXT: .cfi_offset a7, -64
; QCI-D-NEXT: .cfi_offset t3, -68
; QCI-D-NEXT: .cfi_offset t4, -72
; QCI-D-NEXT: .cfi_offset t5, -76
; QCI-D-NEXT: .cfi_offset t6, -80
; QCI-D-NEXT: addi sp, sp, -160
; QCI-D-NEXT: .cfi_def_cfa_offset 256
; QCI-D-NEXT: fsd ft0, 152(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft1, 144(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft2, 136(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft3, 128(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft4, 120(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft5, 112(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft6, 104(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft7, 96(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa0, 88(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa1, 80(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa2, 72(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa3, 64(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa4, 56(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa5, 48(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa6, 40(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa7, 32(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft8, 24(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft9, 16(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft10, 8(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft11, 0(sp) # 8-byte Folded Spill
; QCI-D-NEXT: .cfi_offset ft0, -104
; QCI-D-NEXT: .cfi_offset ft1, -112
; QCI-D-NEXT: .cfi_offset ft2, -120
; QCI-D-NEXT: .cfi_offset ft3, -128
; QCI-D-NEXT: .cfi_offset ft4, -136
; QCI-D-NEXT: .cfi_offset ft5, -144
; QCI-D-NEXT: .cfi_offset ft6, -152
; QCI-D-NEXT: .cfi_offset ft7, -160
; QCI-D-NEXT: .cfi_offset fa0, -168
; QCI-D-NEXT: .cfi_offset fa1, -176
; QCI-D-NEXT: .cfi_offset fa2, -184
; QCI-D-NEXT: .cfi_offset fa3, -192
; QCI-D-NEXT: .cfi_offset fa4, -200
; QCI-D-NEXT: .cfi_offset fa5, -208
; QCI-D-NEXT: .cfi_offset fa6, -216
; QCI-D-NEXT: .cfi_offset fa7, -224
; QCI-D-NEXT: .cfi_offset ft8, -232
; QCI-D-NEXT: .cfi_offset ft9, -240
; QCI-D-NEXT: .cfi_offset ft10, -248
; QCI-D-NEXT: .cfi_offset ft11, -256
; QCI-D-NEXT: li a0, 1
; QCI-D-NEXT: #APP
; QCI-D-NEXT: # a0 <- a0
; QCI-D-NEXT: #NO_APP
; QCI-D-NEXT: call use_i32
; QCI-D-NEXT: fld ft0, 152(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft1, 144(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft2, 136(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft3, 128(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft4, 120(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft5, 112(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft6, 104(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft7, 96(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa0, 88(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa1, 80(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa2, 72(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa3, 64(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa4, 56(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa5, 48(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa6, 40(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa7, 32(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft8, 24(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft9, 16(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft10, 8(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft11, 0(sp) # 8-byte Folded Reload
; QCI-D-NEXT: .cfi_restore ft0
; QCI-D-NEXT: .cfi_restore ft1
; QCI-D-NEXT: .cfi_restore ft2
; QCI-D-NEXT: .cfi_restore ft3
; QCI-D-NEXT: .cfi_restore ft4
; QCI-D-NEXT: .cfi_restore ft5
; QCI-D-NEXT: .cfi_restore ft6
; QCI-D-NEXT: .cfi_restore ft7
; QCI-D-NEXT: .cfi_restore fa0
; QCI-D-NEXT: .cfi_restore fa1
; QCI-D-NEXT: .cfi_restore fa2
; QCI-D-NEXT: .cfi_restore fa3
; QCI-D-NEXT: .cfi_restore fa4
; QCI-D-NEXT: .cfi_restore fa5
; QCI-D-NEXT: .cfi_restore fa6
; QCI-D-NEXT: .cfi_restore fa7
; QCI-D-NEXT: .cfi_restore ft8
; QCI-D-NEXT: .cfi_restore ft9
; QCI-D-NEXT: .cfi_restore ft10
; QCI-D-NEXT: .cfi_restore ft11
; QCI-D-NEXT: addi sp, sp, 160
; QCI-D-NEXT: .cfi_def_cfa_offset 96
; QCI-D-NEXT: qc.c.mileaveret
%1 = call i32 asm sideeffect "/* $0 <- $1 */", "=r,r"(i32 1)
call void @use_i32(i32 %1)
ret void
}
define void @test_nonest_asm() "interrupt"="qci-nonest" {
; QCI-F-LABEL: test_nonest_asm:
; QCI-F: # %bb.0:
; QCI-F-NEXT: qc.c.mienter
; QCI-F-NEXT: .cfi_def_cfa_offset 96
; QCI-F-NEXT: .cfi_offset ra, -16
; QCI-F-NEXT: .cfi_offset t0, -24
; QCI-F-NEXT: .cfi_offset t1, -28
; QCI-F-NEXT: .cfi_offset t2, -32
; QCI-F-NEXT: .cfi_offset s0, -8
; QCI-F-NEXT: .cfi_offset a0, -36
; QCI-F-NEXT: .cfi_offset a1, -40
; QCI-F-NEXT: .cfi_offset a2, -44
; QCI-F-NEXT: .cfi_offset a3, -48
; QCI-F-NEXT: .cfi_offset a4, -52
; QCI-F-NEXT: .cfi_offset a5, -56
; QCI-F-NEXT: .cfi_offset a6, -60
; QCI-F-NEXT: .cfi_offset a7, -64
; QCI-F-NEXT: .cfi_offset t3, -68
; QCI-F-NEXT: .cfi_offset t4, -72
; QCI-F-NEXT: .cfi_offset t5, -76
; QCI-F-NEXT: .cfi_offset t6, -80
; QCI-F-NEXT: addi sp, sp, -80
; QCI-F-NEXT: .cfi_def_cfa_offset 176
; QCI-F-NEXT: fsw ft0, 76(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft1, 72(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft2, 68(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft3, 64(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft4, 60(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft5, 56(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft6, 52(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft7, 48(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa0, 44(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa1, 40(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa2, 36(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa3, 32(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa4, 28(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa5, 24(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa6, 20(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa7, 16(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft8, 12(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft9, 8(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft10, 4(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft11, 0(sp) # 4-byte Folded Spill
; QCI-F-NEXT: .cfi_offset ft0, -100
; QCI-F-NEXT: .cfi_offset ft1, -104
; QCI-F-NEXT: .cfi_offset ft2, -108
; QCI-F-NEXT: .cfi_offset ft3, -112
; QCI-F-NEXT: .cfi_offset ft4, -116
; QCI-F-NEXT: .cfi_offset ft5, -120
; QCI-F-NEXT: .cfi_offset ft6, -124
; QCI-F-NEXT: .cfi_offset ft7, -128
; QCI-F-NEXT: .cfi_offset fa0, -132
; QCI-F-NEXT: .cfi_offset fa1, -136
; QCI-F-NEXT: .cfi_offset fa2, -140
; QCI-F-NEXT: .cfi_offset fa3, -144
; QCI-F-NEXT: .cfi_offset fa4, -148
; QCI-F-NEXT: .cfi_offset fa5, -152
; QCI-F-NEXT: .cfi_offset fa6, -156
; QCI-F-NEXT: .cfi_offset fa7, -160
; QCI-F-NEXT: .cfi_offset ft8, -164
; QCI-F-NEXT: .cfi_offset ft9, -168
; QCI-F-NEXT: .cfi_offset ft10, -172
; QCI-F-NEXT: .cfi_offset ft11, -176
; QCI-F-NEXT: li a0, 1
; QCI-F-NEXT: #APP
; QCI-F-NEXT: # a0 <- a0
; QCI-F-NEXT: #NO_APP
; QCI-F-NEXT: call use_i32
; QCI-F-NEXT: flw ft0, 76(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft1, 72(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft2, 68(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft3, 64(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft4, 60(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft5, 56(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft6, 52(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft7, 48(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa0, 44(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa1, 40(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa2, 36(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa3, 32(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa4, 28(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa5, 24(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa6, 20(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa7, 16(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft8, 12(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft9, 8(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft10, 4(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft11, 0(sp) # 4-byte Folded Reload
; QCI-F-NEXT: .cfi_restore ft0
; QCI-F-NEXT: .cfi_restore ft1
; QCI-F-NEXT: .cfi_restore ft2
; QCI-F-NEXT: .cfi_restore ft3
; QCI-F-NEXT: .cfi_restore ft4
; QCI-F-NEXT: .cfi_restore ft5
; QCI-F-NEXT: .cfi_restore ft6
; QCI-F-NEXT: .cfi_restore ft7
; QCI-F-NEXT: .cfi_restore fa0
; QCI-F-NEXT: .cfi_restore fa1
; QCI-F-NEXT: .cfi_restore fa2
; QCI-F-NEXT: .cfi_restore fa3
; QCI-F-NEXT: .cfi_restore fa4
; QCI-F-NEXT: .cfi_restore fa5
; QCI-F-NEXT: .cfi_restore fa6
; QCI-F-NEXT: .cfi_restore fa7
; QCI-F-NEXT: .cfi_restore ft8
; QCI-F-NEXT: .cfi_restore ft9
; QCI-F-NEXT: .cfi_restore ft10
; QCI-F-NEXT: .cfi_restore ft11
; QCI-F-NEXT: addi sp, sp, 80
; QCI-F-NEXT: .cfi_def_cfa_offset 96
; QCI-F-NEXT: qc.c.mileaveret
;
; QCI-D-LABEL: test_nonest_asm:
; QCI-D: # %bb.0:
; QCI-D-NEXT: qc.c.mienter
; QCI-D-NEXT: .cfi_def_cfa_offset 96
; QCI-D-NEXT: .cfi_offset ra, -16
; QCI-D-NEXT: .cfi_offset t0, -24
; QCI-D-NEXT: .cfi_offset t1, -28
; QCI-D-NEXT: .cfi_offset t2, -32
; QCI-D-NEXT: .cfi_offset s0, -8
; QCI-D-NEXT: .cfi_offset a0, -36
; QCI-D-NEXT: .cfi_offset a1, -40
; QCI-D-NEXT: .cfi_offset a2, -44
; QCI-D-NEXT: .cfi_offset a3, -48
; QCI-D-NEXT: .cfi_offset a4, -52
; QCI-D-NEXT: .cfi_offset a5, -56
; QCI-D-NEXT: .cfi_offset a6, -60
; QCI-D-NEXT: .cfi_offset a7, -64
; QCI-D-NEXT: .cfi_offset t3, -68
; QCI-D-NEXT: .cfi_offset t4, -72
; QCI-D-NEXT: .cfi_offset t5, -76
; QCI-D-NEXT: .cfi_offset t6, -80
; QCI-D-NEXT: addi sp, sp, -160
; QCI-D-NEXT: .cfi_def_cfa_offset 256
; QCI-D-NEXT: fsd ft0, 152(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft1, 144(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft2, 136(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft3, 128(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft4, 120(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft5, 112(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft6, 104(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft7, 96(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa0, 88(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa1, 80(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa2, 72(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa3, 64(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa4, 56(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa5, 48(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa6, 40(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa7, 32(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft8, 24(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft9, 16(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft10, 8(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft11, 0(sp) # 8-byte Folded Spill
; QCI-D-NEXT: .cfi_offset ft0, -104
; QCI-D-NEXT: .cfi_offset ft1, -112
; QCI-D-NEXT: .cfi_offset ft2, -120
; QCI-D-NEXT: .cfi_offset ft3, -128
; QCI-D-NEXT: .cfi_offset ft4, -136
; QCI-D-NEXT: .cfi_offset ft5, -144
; QCI-D-NEXT: .cfi_offset ft6, -152
; QCI-D-NEXT: .cfi_offset ft7, -160
; QCI-D-NEXT: .cfi_offset fa0, -168
; QCI-D-NEXT: .cfi_offset fa1, -176
; QCI-D-NEXT: .cfi_offset fa2, -184
; QCI-D-NEXT: .cfi_offset fa3, -192
; QCI-D-NEXT: .cfi_offset fa4, -200
; QCI-D-NEXT: .cfi_offset fa5, -208
; QCI-D-NEXT: .cfi_offset fa6, -216
; QCI-D-NEXT: .cfi_offset fa7, -224
; QCI-D-NEXT: .cfi_offset ft8, -232
; QCI-D-NEXT: .cfi_offset ft9, -240
; QCI-D-NEXT: .cfi_offset ft10, -248
; QCI-D-NEXT: .cfi_offset ft11, -256
; QCI-D-NEXT: li a0, 1
; QCI-D-NEXT: #APP
; QCI-D-NEXT: # a0 <- a0
; QCI-D-NEXT: #NO_APP
; QCI-D-NEXT: call use_i32
; QCI-D-NEXT: fld ft0, 152(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft1, 144(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft2, 136(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft3, 128(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft4, 120(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft5, 112(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft6, 104(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft7, 96(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa0, 88(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa1, 80(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa2, 72(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa3, 64(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa4, 56(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa5, 48(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa6, 40(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa7, 32(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft8, 24(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft9, 16(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft10, 8(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft11, 0(sp) # 8-byte Folded Reload
; QCI-D-NEXT: .cfi_restore ft0
; QCI-D-NEXT: .cfi_restore ft1
; QCI-D-NEXT: .cfi_restore ft2
; QCI-D-NEXT: .cfi_restore ft3
; QCI-D-NEXT: .cfi_restore ft4
; QCI-D-NEXT: .cfi_restore ft5
; QCI-D-NEXT: .cfi_restore ft6
; QCI-D-NEXT: .cfi_restore ft7
; QCI-D-NEXT: .cfi_restore fa0
; QCI-D-NEXT: .cfi_restore fa1
; QCI-D-NEXT: .cfi_restore fa2
; QCI-D-NEXT: .cfi_restore fa3
; QCI-D-NEXT: .cfi_restore fa4
; QCI-D-NEXT: .cfi_restore fa5
; QCI-D-NEXT: .cfi_restore fa6
; QCI-D-NEXT: .cfi_restore fa7
; QCI-D-NEXT: .cfi_restore ft8
; QCI-D-NEXT: .cfi_restore ft9
; QCI-D-NEXT: .cfi_restore ft10
; QCI-D-NEXT: .cfi_restore ft11
; QCI-D-NEXT: addi sp, sp, 160
; QCI-D-NEXT: .cfi_def_cfa_offset 96
; QCI-D-NEXT: qc.c.mileaveret
%1 = call i32 asm sideeffect "/* $0 <- $1 */", "=r,r"(i32 1)
call void @use_i32(i32 %1)
ret void
}
declare float @function_with_one_stack_arg(i64, i64, i64, i64, float, float, float, float, float, float, float, float, i32, float)
declare void @use_float(float)
define void @test_nest_call() "interrupt"="qci-nest" {
; QCI-F-LABEL: test_nest_call:
; QCI-F: # %bb.0:
; QCI-F-NEXT: qc.c.mienter.nest
; QCI-F-NEXT: .cfi_def_cfa_offset 96
; QCI-F-NEXT: .cfi_offset ra, -16
; QCI-F-NEXT: .cfi_offset t0, -24
; QCI-F-NEXT: .cfi_offset t1, -28
; QCI-F-NEXT: .cfi_offset t2, -32
; QCI-F-NEXT: .cfi_offset s0, -8
; QCI-F-NEXT: .cfi_offset a0, -36
; QCI-F-NEXT: .cfi_offset a1, -40
; QCI-F-NEXT: .cfi_offset a2, -44
; QCI-F-NEXT: .cfi_offset a3, -48
; QCI-F-NEXT: .cfi_offset a4, -52
; QCI-F-NEXT: .cfi_offset a5, -56
; QCI-F-NEXT: .cfi_offset a6, -60
; QCI-F-NEXT: .cfi_offset a7, -64
; QCI-F-NEXT: .cfi_offset t3, -68
; QCI-F-NEXT: .cfi_offset t4, -72
; QCI-F-NEXT: .cfi_offset t5, -76
; QCI-F-NEXT: .cfi_offset t6, -80
; QCI-F-NEXT: addi sp, sp, -96
; QCI-F-NEXT: .cfi_def_cfa_offset 192
; QCI-F-NEXT: fsw ft0, 92(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft1, 88(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft2, 84(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft3, 80(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft4, 76(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft5, 72(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft6, 68(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft7, 64(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa0, 60(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa1, 56(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa2, 52(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa3, 48(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa4, 44(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa5, 40(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa6, 36(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa7, 32(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft8, 28(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft9, 24(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft10, 20(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft11, 16(sp) # 4-byte Folded Spill
; QCI-F-NEXT: .cfi_offset ft0, -100
; QCI-F-NEXT: .cfi_offset ft1, -104
; QCI-F-NEXT: .cfi_offset ft2, -108
; QCI-F-NEXT: .cfi_offset ft3, -112
; QCI-F-NEXT: .cfi_offset ft4, -116
; QCI-F-NEXT: .cfi_offset ft5, -120
; QCI-F-NEXT: .cfi_offset ft6, -124
; QCI-F-NEXT: .cfi_offset ft7, -128
; QCI-F-NEXT: .cfi_offset fa0, -132
; QCI-F-NEXT: .cfi_offset fa1, -136
; QCI-F-NEXT: .cfi_offset fa2, -140
; QCI-F-NEXT: .cfi_offset fa3, -144
; QCI-F-NEXT: .cfi_offset fa4, -148
; QCI-F-NEXT: .cfi_offset fa5, -152
; QCI-F-NEXT: .cfi_offset fa6, -156
; QCI-F-NEXT: .cfi_offset fa7, -160
; QCI-F-NEXT: .cfi_offset ft8, -164
; QCI-F-NEXT: .cfi_offset ft9, -168
; QCI-F-NEXT: .cfi_offset ft10, -172
; QCI-F-NEXT: .cfi_offset ft11, -176
; QCI-F-NEXT: lui a7, 266496
; QCI-F-NEXT: li t0, 5
; QCI-F-NEXT: lui a0, 260096
; QCI-F-NEXT: lui a2, 262144
; QCI-F-NEXT: lui a4, 263168
; QCI-F-NEXT: lui a5, 264192
; QCI-F-NEXT: lui a1, 264704
; QCI-F-NEXT: lui a6, 265216
; QCI-F-NEXT: fmv.w.x fa0, a0
; QCI-F-NEXT: lui t1, 265728
; QCI-F-NEXT: fmv.w.x fa1, a2
; QCI-F-NEXT: lui a3, 266240
; QCI-F-NEXT: fmv.w.x fa2, a4
; QCI-F-NEXT: li a0, 1
; QCI-F-NEXT: fmv.w.x fa3, a5
; QCI-F-NEXT: li a2, 2
; QCI-F-NEXT: fmv.w.x fa4, a1
; QCI-F-NEXT: li a4, 3
; QCI-F-NEXT: fmv.w.x fa5, a6
; QCI-F-NEXT: li a6, 4
; QCI-F-NEXT: fmv.w.x fa6, t1
; QCI-F-NEXT: fmv.w.x fa7, a3
; QCI-F-NEXT: sw t0, 0(sp)
; QCI-F-NEXT: sw a7, 4(sp)
; QCI-F-NEXT: li a1, 0
; QCI-F-NEXT: li a3, 0
; QCI-F-NEXT: li a5, 0
; QCI-F-NEXT: li a7, 0
; QCI-F-NEXT: call function_with_one_stack_arg
; QCI-F-NEXT: call use_float
; QCI-F-NEXT: flw ft0, 92(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft1, 88(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft2, 84(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft3, 80(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft4, 76(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft5, 72(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft6, 68(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft7, 64(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa0, 60(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa1, 56(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa2, 52(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa3, 48(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa4, 44(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa5, 40(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa6, 36(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa7, 32(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft8, 28(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft9, 24(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft10, 20(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft11, 16(sp) # 4-byte Folded Reload
; QCI-F-NEXT: .cfi_restore ft0
; QCI-F-NEXT: .cfi_restore ft1
; QCI-F-NEXT: .cfi_restore ft2
; QCI-F-NEXT: .cfi_restore ft3
; QCI-F-NEXT: .cfi_restore ft4
; QCI-F-NEXT: .cfi_restore ft5
; QCI-F-NEXT: .cfi_restore ft6
; QCI-F-NEXT: .cfi_restore ft7
; QCI-F-NEXT: .cfi_restore fa0
; QCI-F-NEXT: .cfi_restore fa1
; QCI-F-NEXT: .cfi_restore fa2
; QCI-F-NEXT: .cfi_restore fa3
; QCI-F-NEXT: .cfi_restore fa4
; QCI-F-NEXT: .cfi_restore fa5
; QCI-F-NEXT: .cfi_restore fa6
; QCI-F-NEXT: .cfi_restore fa7
; QCI-F-NEXT: .cfi_restore ft8
; QCI-F-NEXT: .cfi_restore ft9
; QCI-F-NEXT: .cfi_restore ft10
; QCI-F-NEXT: .cfi_restore ft11
; QCI-F-NEXT: addi sp, sp, 96
; QCI-F-NEXT: .cfi_def_cfa_offset 96
; QCI-F-NEXT: qc.c.mileaveret
;
; QCI-D-LABEL: test_nest_call:
; QCI-D: # %bb.0:
; QCI-D-NEXT: qc.c.mienter.nest
; QCI-D-NEXT: .cfi_def_cfa_offset 96
; QCI-D-NEXT: .cfi_offset ra, -16
; QCI-D-NEXT: .cfi_offset t0, -24
; QCI-D-NEXT: .cfi_offset t1, -28
; QCI-D-NEXT: .cfi_offset t2, -32
; QCI-D-NEXT: .cfi_offset s0, -8
; QCI-D-NEXT: .cfi_offset a0, -36
; QCI-D-NEXT: .cfi_offset a1, -40
; QCI-D-NEXT: .cfi_offset a2, -44
; QCI-D-NEXT: .cfi_offset a3, -48
; QCI-D-NEXT: .cfi_offset a4, -52
; QCI-D-NEXT: .cfi_offset a5, -56
; QCI-D-NEXT: .cfi_offset a6, -60
; QCI-D-NEXT: .cfi_offset a7, -64
; QCI-D-NEXT: .cfi_offset t3, -68
; QCI-D-NEXT: .cfi_offset t4, -72
; QCI-D-NEXT: .cfi_offset t5, -76
; QCI-D-NEXT: .cfi_offset t6, -80
; QCI-D-NEXT: addi sp, sp, -176
; QCI-D-NEXT: .cfi_def_cfa_offset 272
; QCI-D-NEXT: fsd ft0, 168(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft1, 160(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft2, 152(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft3, 144(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft4, 136(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft5, 128(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft6, 120(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft7, 112(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa0, 104(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa1, 96(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa2, 88(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa3, 80(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa4, 72(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa5, 64(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa6, 56(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa7, 48(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft8, 40(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft9, 32(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft10, 24(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft11, 16(sp) # 8-byte Folded Spill
; QCI-D-NEXT: .cfi_offset ft0, -104
; QCI-D-NEXT: .cfi_offset ft1, -112
; QCI-D-NEXT: .cfi_offset ft2, -120
; QCI-D-NEXT: .cfi_offset ft3, -128
; QCI-D-NEXT: .cfi_offset ft4, -136
; QCI-D-NEXT: .cfi_offset ft5, -144
; QCI-D-NEXT: .cfi_offset ft6, -152
; QCI-D-NEXT: .cfi_offset ft7, -160
; QCI-D-NEXT: .cfi_offset fa0, -168
; QCI-D-NEXT: .cfi_offset fa1, -176
; QCI-D-NEXT: .cfi_offset fa2, -184
; QCI-D-NEXT: .cfi_offset fa3, -192
; QCI-D-NEXT: .cfi_offset fa4, -200
; QCI-D-NEXT: .cfi_offset fa5, -208
; QCI-D-NEXT: .cfi_offset fa6, -216
; QCI-D-NEXT: .cfi_offset fa7, -224
; QCI-D-NEXT: .cfi_offset ft8, -232
; QCI-D-NEXT: .cfi_offset ft9, -240
; QCI-D-NEXT: .cfi_offset ft10, -248
; QCI-D-NEXT: .cfi_offset ft11, -256
; QCI-D-NEXT: lui a7, 266496
; QCI-D-NEXT: li t0, 5
; QCI-D-NEXT: lui a0, 260096
; QCI-D-NEXT: lui a2, 262144
; QCI-D-NEXT: lui a4, 263168
; QCI-D-NEXT: lui a5, 264192
; QCI-D-NEXT: lui a1, 264704
; QCI-D-NEXT: lui a6, 265216
; QCI-D-NEXT: fmv.w.x fa0, a0
; QCI-D-NEXT: lui t1, 265728
; QCI-D-NEXT: fmv.w.x fa1, a2
; QCI-D-NEXT: lui a3, 266240
; QCI-D-NEXT: fmv.w.x fa2, a4
; QCI-D-NEXT: li a0, 1
; QCI-D-NEXT: fmv.w.x fa3, a5
; QCI-D-NEXT: li a2, 2
; QCI-D-NEXT: fmv.w.x fa4, a1
; QCI-D-NEXT: li a4, 3
; QCI-D-NEXT: fmv.w.x fa5, a6
; QCI-D-NEXT: li a6, 4
; QCI-D-NEXT: fmv.w.x fa6, t1
; QCI-D-NEXT: fmv.w.x fa7, a3
; QCI-D-NEXT: sw t0, 0(sp)
; QCI-D-NEXT: sw a7, 4(sp)
; QCI-D-NEXT: li a1, 0
; QCI-D-NEXT: li a3, 0
; QCI-D-NEXT: li a5, 0
; QCI-D-NEXT: li a7, 0
; QCI-D-NEXT: call function_with_one_stack_arg
; QCI-D-NEXT: call use_float
; QCI-D-NEXT: fld ft0, 168(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft1, 160(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft2, 152(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft3, 144(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft4, 136(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft5, 128(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft6, 120(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft7, 112(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa0, 104(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa1, 96(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa2, 88(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa3, 80(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa4, 72(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa5, 64(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa6, 56(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa7, 48(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft8, 40(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft9, 32(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft10, 24(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft11, 16(sp) # 8-byte Folded Reload
; QCI-D-NEXT: .cfi_restore ft0
; QCI-D-NEXT: .cfi_restore ft1
; QCI-D-NEXT: .cfi_restore ft2
; QCI-D-NEXT: .cfi_restore ft3
; QCI-D-NEXT: .cfi_restore ft4
; QCI-D-NEXT: .cfi_restore ft5
; QCI-D-NEXT: .cfi_restore ft6
; QCI-D-NEXT: .cfi_restore ft7
; QCI-D-NEXT: .cfi_restore fa0
; QCI-D-NEXT: .cfi_restore fa1
; QCI-D-NEXT: .cfi_restore fa2
; QCI-D-NEXT: .cfi_restore fa3
; QCI-D-NEXT: .cfi_restore fa4
; QCI-D-NEXT: .cfi_restore fa5
; QCI-D-NEXT: .cfi_restore fa6
; QCI-D-NEXT: .cfi_restore fa7
; QCI-D-NEXT: .cfi_restore ft8
; QCI-D-NEXT: .cfi_restore ft9
; QCI-D-NEXT: .cfi_restore ft10
; QCI-D-NEXT: .cfi_restore ft11
; QCI-D-NEXT: addi sp, sp, 176
; QCI-D-NEXT: .cfi_def_cfa_offset 96
; QCI-D-NEXT: qc.c.mileaveret
%1 = call float @function_with_one_stack_arg(i64 1, i64 2, i64 3, i64 4, float 1.0, float 2.0, float 3.0, float 4.0, float 5.0, float 6.0, float 7.0, float 8.0, i32 5, float 9.0)
call void @use_float(float %1)
ret void
}
define void @test_nonest_call() "interrupt"="qci-nonest" {
; QCI-F-LABEL: test_nonest_call:
; QCI-F: # %bb.0:
; QCI-F-NEXT: qc.c.mienter
; QCI-F-NEXT: .cfi_def_cfa_offset 96
; QCI-F-NEXT: .cfi_offset ra, -16
; QCI-F-NEXT: .cfi_offset t0, -24
; QCI-F-NEXT: .cfi_offset t1, -28
; QCI-F-NEXT: .cfi_offset t2, -32
; QCI-F-NEXT: .cfi_offset s0, -8
; QCI-F-NEXT: .cfi_offset a0, -36
; QCI-F-NEXT: .cfi_offset a1, -40
; QCI-F-NEXT: .cfi_offset a2, -44
; QCI-F-NEXT: .cfi_offset a3, -48
; QCI-F-NEXT: .cfi_offset a4, -52
; QCI-F-NEXT: .cfi_offset a5, -56
; QCI-F-NEXT: .cfi_offset a6, -60
; QCI-F-NEXT: .cfi_offset a7, -64
; QCI-F-NEXT: .cfi_offset t3, -68
; QCI-F-NEXT: .cfi_offset t4, -72
; QCI-F-NEXT: .cfi_offset t5, -76
; QCI-F-NEXT: .cfi_offset t6, -80
; QCI-F-NEXT: addi sp, sp, -96
; QCI-F-NEXT: .cfi_def_cfa_offset 192
; QCI-F-NEXT: fsw ft0, 92(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft1, 88(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft2, 84(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft3, 80(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft4, 76(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft5, 72(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft6, 68(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft7, 64(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa0, 60(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa1, 56(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa2, 52(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa3, 48(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa4, 44(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa5, 40(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa6, 36(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa7, 32(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft8, 28(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft9, 24(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft10, 20(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft11, 16(sp) # 4-byte Folded Spill
; QCI-F-NEXT: .cfi_offset ft0, -100
; QCI-F-NEXT: .cfi_offset ft1, -104
; QCI-F-NEXT: .cfi_offset ft2, -108
; QCI-F-NEXT: .cfi_offset ft3, -112
; QCI-F-NEXT: .cfi_offset ft4, -116
; QCI-F-NEXT: .cfi_offset ft5, -120
; QCI-F-NEXT: .cfi_offset ft6, -124
; QCI-F-NEXT: .cfi_offset ft7, -128
; QCI-F-NEXT: .cfi_offset fa0, -132
; QCI-F-NEXT: .cfi_offset fa1, -136
; QCI-F-NEXT: .cfi_offset fa2, -140
; QCI-F-NEXT: .cfi_offset fa3, -144
; QCI-F-NEXT: .cfi_offset fa4, -148
; QCI-F-NEXT: .cfi_offset fa5, -152
; QCI-F-NEXT: .cfi_offset fa6, -156
; QCI-F-NEXT: .cfi_offset fa7, -160
; QCI-F-NEXT: .cfi_offset ft8, -164
; QCI-F-NEXT: .cfi_offset ft9, -168
; QCI-F-NEXT: .cfi_offset ft10, -172
; QCI-F-NEXT: .cfi_offset ft11, -176
; QCI-F-NEXT: lui a7, 266496
; QCI-F-NEXT: li t0, 5
; QCI-F-NEXT: lui a0, 260096
; QCI-F-NEXT: lui a2, 262144
; QCI-F-NEXT: lui a4, 263168
; QCI-F-NEXT: lui a5, 264192
; QCI-F-NEXT: lui a1, 264704
; QCI-F-NEXT: lui a6, 265216
; QCI-F-NEXT: fmv.w.x fa0, a0
; QCI-F-NEXT: lui t1, 265728
; QCI-F-NEXT: fmv.w.x fa1, a2
; QCI-F-NEXT: lui a3, 266240
; QCI-F-NEXT: fmv.w.x fa2, a4
; QCI-F-NEXT: li a0, 1
; QCI-F-NEXT: fmv.w.x fa3, a5
; QCI-F-NEXT: li a2, 2
; QCI-F-NEXT: fmv.w.x fa4, a1
; QCI-F-NEXT: li a4, 3
; QCI-F-NEXT: fmv.w.x fa5, a6
; QCI-F-NEXT: li a6, 4
; QCI-F-NEXT: fmv.w.x fa6, t1
; QCI-F-NEXT: fmv.w.x fa7, a3
; QCI-F-NEXT: sw t0, 0(sp)
; QCI-F-NEXT: sw a7, 4(sp)
; QCI-F-NEXT: li a1, 0
; QCI-F-NEXT: li a3, 0
; QCI-F-NEXT: li a5, 0
; QCI-F-NEXT: li a7, 0
; QCI-F-NEXT: call function_with_one_stack_arg
; QCI-F-NEXT: call use_float
; QCI-F-NEXT: flw ft0, 92(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft1, 88(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft2, 84(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft3, 80(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft4, 76(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft5, 72(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft6, 68(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft7, 64(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa0, 60(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa1, 56(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa2, 52(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa3, 48(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa4, 44(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa5, 40(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa6, 36(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa7, 32(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft8, 28(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft9, 24(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft10, 20(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft11, 16(sp) # 4-byte Folded Reload
; QCI-F-NEXT: .cfi_restore ft0
; QCI-F-NEXT: .cfi_restore ft1
; QCI-F-NEXT: .cfi_restore ft2
; QCI-F-NEXT: .cfi_restore ft3
; QCI-F-NEXT: .cfi_restore ft4
; QCI-F-NEXT: .cfi_restore ft5
; QCI-F-NEXT: .cfi_restore ft6
; QCI-F-NEXT: .cfi_restore ft7
; QCI-F-NEXT: .cfi_restore fa0
; QCI-F-NEXT: .cfi_restore fa1
; QCI-F-NEXT: .cfi_restore fa2
; QCI-F-NEXT: .cfi_restore fa3
; QCI-F-NEXT: .cfi_restore fa4
; QCI-F-NEXT: .cfi_restore fa5
; QCI-F-NEXT: .cfi_restore fa6
; QCI-F-NEXT: .cfi_restore fa7
; QCI-F-NEXT: .cfi_restore ft8
; QCI-F-NEXT: .cfi_restore ft9
; QCI-F-NEXT: .cfi_restore ft10
; QCI-F-NEXT: .cfi_restore ft11
; QCI-F-NEXT: addi sp, sp, 96
; QCI-F-NEXT: .cfi_def_cfa_offset 96
; QCI-F-NEXT: qc.c.mileaveret
;
; QCI-D-LABEL: test_nonest_call:
; QCI-D: # %bb.0:
; QCI-D-NEXT: qc.c.mienter
; QCI-D-NEXT: .cfi_def_cfa_offset 96
; QCI-D-NEXT: .cfi_offset ra, -16
; QCI-D-NEXT: .cfi_offset t0, -24
; QCI-D-NEXT: .cfi_offset t1, -28
; QCI-D-NEXT: .cfi_offset t2, -32
; QCI-D-NEXT: .cfi_offset s0, -8
; QCI-D-NEXT: .cfi_offset a0, -36
; QCI-D-NEXT: .cfi_offset a1, -40
; QCI-D-NEXT: .cfi_offset a2, -44
; QCI-D-NEXT: .cfi_offset a3, -48
; QCI-D-NEXT: .cfi_offset a4, -52
; QCI-D-NEXT: .cfi_offset a5, -56
; QCI-D-NEXT: .cfi_offset a6, -60
; QCI-D-NEXT: .cfi_offset a7, -64
; QCI-D-NEXT: .cfi_offset t3, -68
; QCI-D-NEXT: .cfi_offset t4, -72
; QCI-D-NEXT: .cfi_offset t5, -76
; QCI-D-NEXT: .cfi_offset t6, -80
; QCI-D-NEXT: addi sp, sp, -176
; QCI-D-NEXT: .cfi_def_cfa_offset 272
; QCI-D-NEXT: fsd ft0, 168(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft1, 160(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft2, 152(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft3, 144(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft4, 136(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft5, 128(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft6, 120(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft7, 112(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa0, 104(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa1, 96(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa2, 88(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa3, 80(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa4, 72(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa5, 64(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa6, 56(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa7, 48(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft8, 40(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft9, 32(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft10, 24(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft11, 16(sp) # 8-byte Folded Spill
; QCI-D-NEXT: .cfi_offset ft0, -104
; QCI-D-NEXT: .cfi_offset ft1, -112
; QCI-D-NEXT: .cfi_offset ft2, -120
; QCI-D-NEXT: .cfi_offset ft3, -128
; QCI-D-NEXT: .cfi_offset ft4, -136
; QCI-D-NEXT: .cfi_offset ft5, -144
; QCI-D-NEXT: .cfi_offset ft6, -152
; QCI-D-NEXT: .cfi_offset ft7, -160
; QCI-D-NEXT: .cfi_offset fa0, -168
; QCI-D-NEXT: .cfi_offset fa1, -176
; QCI-D-NEXT: .cfi_offset fa2, -184
; QCI-D-NEXT: .cfi_offset fa3, -192
; QCI-D-NEXT: .cfi_offset fa4, -200
; QCI-D-NEXT: .cfi_offset fa5, -208
; QCI-D-NEXT: .cfi_offset fa6, -216
; QCI-D-NEXT: .cfi_offset fa7, -224
; QCI-D-NEXT: .cfi_offset ft8, -232
; QCI-D-NEXT: .cfi_offset ft9, -240
; QCI-D-NEXT: .cfi_offset ft10, -248
; QCI-D-NEXT: .cfi_offset ft11, -256
; QCI-D-NEXT: lui a7, 266496
; QCI-D-NEXT: li t0, 5
; QCI-D-NEXT: lui a0, 260096
; QCI-D-NEXT: lui a2, 262144
; QCI-D-NEXT: lui a4, 263168
; QCI-D-NEXT: lui a5, 264192
; QCI-D-NEXT: lui a1, 264704
; QCI-D-NEXT: lui a6, 265216
; QCI-D-NEXT: fmv.w.x fa0, a0
; QCI-D-NEXT: lui t1, 265728
; QCI-D-NEXT: fmv.w.x fa1, a2
; QCI-D-NEXT: lui a3, 266240
; QCI-D-NEXT: fmv.w.x fa2, a4
; QCI-D-NEXT: li a0, 1
; QCI-D-NEXT: fmv.w.x fa3, a5
; QCI-D-NEXT: li a2, 2
; QCI-D-NEXT: fmv.w.x fa4, a1
; QCI-D-NEXT: li a4, 3
; QCI-D-NEXT: fmv.w.x fa5, a6
; QCI-D-NEXT: li a6, 4
; QCI-D-NEXT: fmv.w.x fa6, t1
; QCI-D-NEXT: fmv.w.x fa7, a3
; QCI-D-NEXT: sw t0, 0(sp)
; QCI-D-NEXT: sw a7, 4(sp)
; QCI-D-NEXT: li a1, 0
; QCI-D-NEXT: li a3, 0
; QCI-D-NEXT: li a5, 0
; QCI-D-NEXT: li a7, 0
; QCI-D-NEXT: call function_with_one_stack_arg
; QCI-D-NEXT: call use_float
; QCI-D-NEXT: fld ft0, 168(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft1, 160(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft2, 152(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft3, 144(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft4, 136(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft5, 128(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft6, 120(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft7, 112(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa0, 104(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa1, 96(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa2, 88(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa3, 80(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa4, 72(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa5, 64(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa6, 56(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa7, 48(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft8, 40(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft9, 32(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft10, 24(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft11, 16(sp) # 8-byte Folded Reload
; QCI-D-NEXT: .cfi_restore ft0
; QCI-D-NEXT: .cfi_restore ft1
; QCI-D-NEXT: .cfi_restore ft2
; QCI-D-NEXT: .cfi_restore ft3
; QCI-D-NEXT: .cfi_restore ft4
; QCI-D-NEXT: .cfi_restore ft5
; QCI-D-NEXT: .cfi_restore ft6
; QCI-D-NEXT: .cfi_restore ft7
; QCI-D-NEXT: .cfi_restore fa0
; QCI-D-NEXT: .cfi_restore fa1
; QCI-D-NEXT: .cfi_restore fa2
; QCI-D-NEXT: .cfi_restore fa3
; QCI-D-NEXT: .cfi_restore fa4
; QCI-D-NEXT: .cfi_restore fa5
; QCI-D-NEXT: .cfi_restore fa6
; QCI-D-NEXT: .cfi_restore fa7
; QCI-D-NEXT: .cfi_restore ft8
; QCI-D-NEXT: .cfi_restore ft9
; QCI-D-NEXT: .cfi_restore ft10
; QCI-D-NEXT: .cfi_restore ft11
; QCI-D-NEXT: addi sp, sp, 176
; QCI-D-NEXT: .cfi_def_cfa_offset 96
; QCI-D-NEXT: qc.c.mileaveret
%1 = call float @function_with_one_stack_arg(i64 1, i64 2, i64 3, i64 4, float 1.0, float 2.0, float 3.0, float 4.0, float 5.0, float 6.0, float 7.0, float 8.0, i32 5, float 9.0)
call void @use_float(float %1)
ret void
}
@var = global [32 x i32] zeroinitializer
define void @test_spill_nest() "interrupt"="qci-nest" {
; QCI-F-LABEL: test_spill_nest:
; QCI-F: # %bb.0:
; QCI-F-NEXT: qc.c.mienter.nest
; QCI-F-NEXT: .cfi_def_cfa_offset 96
; QCI-F-NEXT: .cfi_offset ra, -16
; QCI-F-NEXT: .cfi_offset t0, -24
; QCI-F-NEXT: .cfi_offset t1, -28
; QCI-F-NEXT: .cfi_offset t2, -32
; QCI-F-NEXT: .cfi_offset s0, -8
; QCI-F-NEXT: .cfi_offset a0, -36
; QCI-F-NEXT: .cfi_offset a1, -40
; QCI-F-NEXT: .cfi_offset a2, -44
; QCI-F-NEXT: .cfi_offset a3, -48
; QCI-F-NEXT: .cfi_offset a4, -52
; QCI-F-NEXT: .cfi_offset a5, -56
; QCI-F-NEXT: .cfi_offset a6, -60
; QCI-F-NEXT: .cfi_offset a7, -64
; QCI-F-NEXT: .cfi_offset t3, -68
; QCI-F-NEXT: .cfi_offset t4, -72
; QCI-F-NEXT: .cfi_offset t5, -76
; QCI-F-NEXT: .cfi_offset t6, -80
; QCI-F-NEXT: addi sp, sp, -80
; QCI-F-NEXT: .cfi_def_cfa_offset 176
; QCI-F-NEXT: sw s1, 76(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s2, 72(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s3, 68(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s4, 64(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s5, 60(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s6, 56(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s7, 52(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s8, 48(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s9, 44(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s10, 40(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s11, 36(sp) # 4-byte Folded Spill
; QCI-F-NEXT: .cfi_offset s1, -100
; QCI-F-NEXT: .cfi_offset s2, -104
; QCI-F-NEXT: .cfi_offset s3, -108
; QCI-F-NEXT: .cfi_offset s4, -112
; QCI-F-NEXT: .cfi_offset s5, -116
; QCI-F-NEXT: .cfi_offset s6, -120
; QCI-F-NEXT: .cfi_offset s7, -124
; QCI-F-NEXT: .cfi_offset s8, -128
; QCI-F-NEXT: .cfi_offset s9, -132
; QCI-F-NEXT: .cfi_offset s10, -136
; QCI-F-NEXT: .cfi_offset s11, -140
; QCI-F-NEXT: lui t0, %hi(var)
; QCI-F-NEXT: lw a0, %lo(var)(t0)
; QCI-F-NEXT: sw a0, 32(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, %lo(var+4)(t0)
; QCI-F-NEXT: sw a0, 28(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, %lo(var+8)(t0)
; QCI-F-NEXT: sw a0, 24(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, %lo(var+12)(t0)
; QCI-F-NEXT: sw a0, 20(sp) # 4-byte Folded Spill
; QCI-F-NEXT: addi a5, t0, %lo(var)
; QCI-F-NEXT: lw a0, 16(a5)
; QCI-F-NEXT: sw a0, 16(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 20(a5)
; QCI-F-NEXT: sw a0, 12(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw t4, 24(a5)
; QCI-F-NEXT: lw t5, 28(a5)
; QCI-F-NEXT: lw t6, 32(a5)
; QCI-F-NEXT: lw s2, 36(a5)
; QCI-F-NEXT: lw s3, 40(a5)
; QCI-F-NEXT: lw s4, 44(a5)
; QCI-F-NEXT: lw s5, 48(a5)
; QCI-F-NEXT: lw s6, 52(a5)
; QCI-F-NEXT: lw s7, 56(a5)
; QCI-F-NEXT: lw s8, 60(a5)
; QCI-F-NEXT: lw s9, 64(a5)
; QCI-F-NEXT: lw s10, 68(a5)
; QCI-F-NEXT: lw s11, 72(a5)
; QCI-F-NEXT: lw ra, 76(a5)
; QCI-F-NEXT: lw s1, 80(a5)
; QCI-F-NEXT: lw t3, 84(a5)
; QCI-F-NEXT: lw t2, 88(a5)
; QCI-F-NEXT: lw t1, 92(a5)
; QCI-F-NEXT: lw a7, 112(a5)
; QCI-F-NEXT: lw s0, 116(a5)
; QCI-F-NEXT: lw a3, 120(a5)
; QCI-F-NEXT: lw a0, 124(a5)
; QCI-F-NEXT: lw a6, 96(a5)
; QCI-F-NEXT: lw a4, 100(a5)
; QCI-F-NEXT: lw a2, 104(a5)
; QCI-F-NEXT: lw a1, 108(a5)
; QCI-F-NEXT: sw a0, 124(a5)
; QCI-F-NEXT: sw a3, 120(a5)
; QCI-F-NEXT: sw s0, 116(a5)
; QCI-F-NEXT: sw a7, 112(a5)
; QCI-F-NEXT: sw a1, 108(a5)
; QCI-F-NEXT: sw a2, 104(a5)
; QCI-F-NEXT: sw a4, 100(a5)
; QCI-F-NEXT: sw a6, 96(a5)
; QCI-F-NEXT: sw t1, 92(a5)
; QCI-F-NEXT: sw t2, 88(a5)
; QCI-F-NEXT: sw t3, 84(a5)
; QCI-F-NEXT: sw s1, 80(a5)
; QCI-F-NEXT: sw ra, 76(a5)
; QCI-F-NEXT: sw s11, 72(a5)
; QCI-F-NEXT: sw s10, 68(a5)
; QCI-F-NEXT: sw s9, 64(a5)
; QCI-F-NEXT: sw s8, 60(a5)
; QCI-F-NEXT: sw s7, 56(a5)
; QCI-F-NEXT: sw s6, 52(a5)
; QCI-F-NEXT: sw s5, 48(a5)
; QCI-F-NEXT: sw s4, 44(a5)
; QCI-F-NEXT: sw s3, 40(a5)
; QCI-F-NEXT: sw s2, 36(a5)
; QCI-F-NEXT: sw t6, 32(a5)
; QCI-F-NEXT: sw t5, 28(a5)
; QCI-F-NEXT: sw t4, 24(a5)
; QCI-F-NEXT: lw a0, 12(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 20(a5)
; QCI-F-NEXT: lw a0, 16(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 16(a5)
; QCI-F-NEXT: lw a0, 20(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, %lo(var+12)(t0)
; QCI-F-NEXT: lw a0, 24(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, %lo(var+8)(t0)
; QCI-F-NEXT: lw a0, 28(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, %lo(var+4)(t0)
; QCI-F-NEXT: lw a0, 32(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, %lo(var)(t0)
; QCI-F-NEXT: lw s1, 76(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s2, 72(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s3, 68(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s4, 64(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s5, 60(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s6, 56(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s7, 52(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s8, 48(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s9, 44(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s10, 40(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s11, 36(sp) # 4-byte Folded Reload
; QCI-F-NEXT: .cfi_restore s1
; QCI-F-NEXT: .cfi_restore s2
; QCI-F-NEXT: .cfi_restore s3
; QCI-F-NEXT: .cfi_restore s4
; QCI-F-NEXT: .cfi_restore s5
; QCI-F-NEXT: .cfi_restore s6
; QCI-F-NEXT: .cfi_restore s7
; QCI-F-NEXT: .cfi_restore s8
; QCI-F-NEXT: .cfi_restore s9
; QCI-F-NEXT: .cfi_restore s10
; QCI-F-NEXT: .cfi_restore s11
; QCI-F-NEXT: addi sp, sp, 80
; QCI-F-NEXT: .cfi_def_cfa_offset 96
; QCI-F-NEXT: qc.c.mileaveret
;
; QCI-D-LABEL: test_spill_nest:
; QCI-D: # %bb.0:
; QCI-D-NEXT: qc.c.mienter.nest
; QCI-D-NEXT: .cfi_def_cfa_offset 96
; QCI-D-NEXT: .cfi_offset ra, -16
; QCI-D-NEXT: .cfi_offset t0, -24
; QCI-D-NEXT: .cfi_offset t1, -28
; QCI-D-NEXT: .cfi_offset t2, -32
; QCI-D-NEXT: .cfi_offset s0, -8
; QCI-D-NEXT: .cfi_offset a0, -36
; QCI-D-NEXT: .cfi_offset a1, -40
; QCI-D-NEXT: .cfi_offset a2, -44
; QCI-D-NEXT: .cfi_offset a3, -48
; QCI-D-NEXT: .cfi_offset a4, -52
; QCI-D-NEXT: .cfi_offset a5, -56
; QCI-D-NEXT: .cfi_offset a6, -60
; QCI-D-NEXT: .cfi_offset a7, -64
; QCI-D-NEXT: .cfi_offset t3, -68
; QCI-D-NEXT: .cfi_offset t4, -72
; QCI-D-NEXT: .cfi_offset t5, -76
; QCI-D-NEXT: .cfi_offset t6, -80
; QCI-D-NEXT: addi sp, sp, -80
; QCI-D-NEXT: .cfi_def_cfa_offset 176
; QCI-D-NEXT: sw s1, 76(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s2, 72(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s3, 68(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s4, 64(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s5, 60(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s6, 56(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s7, 52(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s8, 48(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s9, 44(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s10, 40(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s11, 36(sp) # 4-byte Folded Spill
; QCI-D-NEXT: .cfi_offset s1, -100
; QCI-D-NEXT: .cfi_offset s2, -104
; QCI-D-NEXT: .cfi_offset s3, -108
; QCI-D-NEXT: .cfi_offset s4, -112
; QCI-D-NEXT: .cfi_offset s5, -116
; QCI-D-NEXT: .cfi_offset s6, -120
; QCI-D-NEXT: .cfi_offset s7, -124
; QCI-D-NEXT: .cfi_offset s8, -128
; QCI-D-NEXT: .cfi_offset s9, -132
; QCI-D-NEXT: .cfi_offset s10, -136
; QCI-D-NEXT: .cfi_offset s11, -140
; QCI-D-NEXT: lui t0, %hi(var)
; QCI-D-NEXT: lw a0, %lo(var)(t0)
; QCI-D-NEXT: sw a0, 32(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, %lo(var+4)(t0)
; QCI-D-NEXT: sw a0, 28(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, %lo(var+8)(t0)
; QCI-D-NEXT: sw a0, 24(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, %lo(var+12)(t0)
; QCI-D-NEXT: sw a0, 20(sp) # 4-byte Folded Spill
; QCI-D-NEXT: addi a5, t0, %lo(var)
; QCI-D-NEXT: lw a0, 16(a5)
; QCI-D-NEXT: sw a0, 16(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 20(a5)
; QCI-D-NEXT: sw a0, 12(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw t4, 24(a5)
; QCI-D-NEXT: lw t5, 28(a5)
; QCI-D-NEXT: lw t6, 32(a5)
; QCI-D-NEXT: lw s2, 36(a5)
; QCI-D-NEXT: lw s3, 40(a5)
; QCI-D-NEXT: lw s4, 44(a5)
; QCI-D-NEXT: lw s5, 48(a5)
; QCI-D-NEXT: lw s6, 52(a5)
; QCI-D-NEXT: lw s7, 56(a5)
; QCI-D-NEXT: lw s8, 60(a5)
; QCI-D-NEXT: lw s9, 64(a5)
; QCI-D-NEXT: lw s10, 68(a5)
; QCI-D-NEXT: lw s11, 72(a5)
; QCI-D-NEXT: lw ra, 76(a5)
; QCI-D-NEXT: lw s1, 80(a5)
; QCI-D-NEXT: lw t3, 84(a5)
; QCI-D-NEXT: lw t2, 88(a5)
; QCI-D-NEXT: lw t1, 92(a5)
; QCI-D-NEXT: lw a7, 112(a5)
; QCI-D-NEXT: lw s0, 116(a5)
; QCI-D-NEXT: lw a3, 120(a5)
; QCI-D-NEXT: lw a0, 124(a5)
; QCI-D-NEXT: lw a6, 96(a5)
; QCI-D-NEXT: lw a4, 100(a5)
; QCI-D-NEXT: lw a2, 104(a5)
; QCI-D-NEXT: lw a1, 108(a5)
; QCI-D-NEXT: sw a0, 124(a5)
; QCI-D-NEXT: sw a3, 120(a5)
; QCI-D-NEXT: sw s0, 116(a5)
; QCI-D-NEXT: sw a7, 112(a5)
; QCI-D-NEXT: sw a1, 108(a5)
; QCI-D-NEXT: sw a2, 104(a5)
; QCI-D-NEXT: sw a4, 100(a5)
; QCI-D-NEXT: sw a6, 96(a5)
; QCI-D-NEXT: sw t1, 92(a5)
; QCI-D-NEXT: sw t2, 88(a5)
; QCI-D-NEXT: sw t3, 84(a5)
; QCI-D-NEXT: sw s1, 80(a5)
; QCI-D-NEXT: sw ra, 76(a5)
; QCI-D-NEXT: sw s11, 72(a5)
; QCI-D-NEXT: sw s10, 68(a5)
; QCI-D-NEXT: sw s9, 64(a5)
; QCI-D-NEXT: sw s8, 60(a5)
; QCI-D-NEXT: sw s7, 56(a5)
; QCI-D-NEXT: sw s6, 52(a5)
; QCI-D-NEXT: sw s5, 48(a5)
; QCI-D-NEXT: sw s4, 44(a5)
; QCI-D-NEXT: sw s3, 40(a5)
; QCI-D-NEXT: sw s2, 36(a5)
; QCI-D-NEXT: sw t6, 32(a5)
; QCI-D-NEXT: sw t5, 28(a5)
; QCI-D-NEXT: sw t4, 24(a5)
; QCI-D-NEXT: lw a0, 12(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 20(a5)
; QCI-D-NEXT: lw a0, 16(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 16(a5)
; QCI-D-NEXT: lw a0, 20(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, %lo(var+12)(t0)
; QCI-D-NEXT: lw a0, 24(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, %lo(var+8)(t0)
; QCI-D-NEXT: lw a0, 28(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, %lo(var+4)(t0)
; QCI-D-NEXT: lw a0, 32(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, %lo(var)(t0)
; QCI-D-NEXT: lw s1, 76(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s2, 72(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s3, 68(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s4, 64(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s5, 60(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s6, 56(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s7, 52(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s8, 48(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s9, 44(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s10, 40(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s11, 36(sp) # 4-byte Folded Reload
; QCI-D-NEXT: .cfi_restore s1
; QCI-D-NEXT: .cfi_restore s2
; QCI-D-NEXT: .cfi_restore s3
; QCI-D-NEXT: .cfi_restore s4
; QCI-D-NEXT: .cfi_restore s5
; QCI-D-NEXT: .cfi_restore s6
; QCI-D-NEXT: .cfi_restore s7
; QCI-D-NEXT: .cfi_restore s8
; QCI-D-NEXT: .cfi_restore s9
; QCI-D-NEXT: .cfi_restore s10
; QCI-D-NEXT: .cfi_restore s11
; QCI-D-NEXT: addi sp, sp, 80
; QCI-D-NEXT: .cfi_def_cfa_offset 96
; QCI-D-NEXT: qc.c.mileaveret
%1 = load [32 x i32], ptr @var
store volatile [32 x i32] %1, ptr @var
ret void
}
define void @test_spill_nonest() "interrupt"="qci-nonest" {
; QCI-F-LABEL: test_spill_nonest:
; QCI-F: # %bb.0:
; QCI-F-NEXT: qc.c.mienter
; QCI-F-NEXT: .cfi_def_cfa_offset 96
; QCI-F-NEXT: .cfi_offset ra, -16
; QCI-F-NEXT: .cfi_offset t0, -24
; QCI-F-NEXT: .cfi_offset t1, -28
; QCI-F-NEXT: .cfi_offset t2, -32
; QCI-F-NEXT: .cfi_offset s0, -8
; QCI-F-NEXT: .cfi_offset a0, -36
; QCI-F-NEXT: .cfi_offset a1, -40
; QCI-F-NEXT: .cfi_offset a2, -44
; QCI-F-NEXT: .cfi_offset a3, -48
; QCI-F-NEXT: .cfi_offset a4, -52
; QCI-F-NEXT: .cfi_offset a5, -56
; QCI-F-NEXT: .cfi_offset a6, -60
; QCI-F-NEXT: .cfi_offset a7, -64
; QCI-F-NEXT: .cfi_offset t3, -68
; QCI-F-NEXT: .cfi_offset t4, -72
; QCI-F-NEXT: .cfi_offset t5, -76
; QCI-F-NEXT: .cfi_offset t6, -80
; QCI-F-NEXT: addi sp, sp, -80
; QCI-F-NEXT: .cfi_def_cfa_offset 176
; QCI-F-NEXT: sw s1, 76(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s2, 72(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s3, 68(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s4, 64(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s5, 60(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s6, 56(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s7, 52(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s8, 48(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s9, 44(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s10, 40(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s11, 36(sp) # 4-byte Folded Spill
; QCI-F-NEXT: .cfi_offset s1, -100
; QCI-F-NEXT: .cfi_offset s2, -104
; QCI-F-NEXT: .cfi_offset s3, -108
; QCI-F-NEXT: .cfi_offset s4, -112
; QCI-F-NEXT: .cfi_offset s5, -116
; QCI-F-NEXT: .cfi_offset s6, -120
; QCI-F-NEXT: .cfi_offset s7, -124
; QCI-F-NEXT: .cfi_offset s8, -128
; QCI-F-NEXT: .cfi_offset s9, -132
; QCI-F-NEXT: .cfi_offset s10, -136
; QCI-F-NEXT: .cfi_offset s11, -140
; QCI-F-NEXT: lui t0, %hi(var)
; QCI-F-NEXT: lw a0, %lo(var)(t0)
; QCI-F-NEXT: sw a0, 32(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, %lo(var+4)(t0)
; QCI-F-NEXT: sw a0, 28(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, %lo(var+8)(t0)
; QCI-F-NEXT: sw a0, 24(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, %lo(var+12)(t0)
; QCI-F-NEXT: sw a0, 20(sp) # 4-byte Folded Spill
; QCI-F-NEXT: addi a5, t0, %lo(var)
; QCI-F-NEXT: lw a0, 16(a5)
; QCI-F-NEXT: sw a0, 16(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 20(a5)
; QCI-F-NEXT: sw a0, 12(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw t4, 24(a5)
; QCI-F-NEXT: lw t5, 28(a5)
; QCI-F-NEXT: lw t6, 32(a5)
; QCI-F-NEXT: lw s2, 36(a5)
; QCI-F-NEXT: lw s3, 40(a5)
; QCI-F-NEXT: lw s4, 44(a5)
; QCI-F-NEXT: lw s5, 48(a5)
; QCI-F-NEXT: lw s6, 52(a5)
; QCI-F-NEXT: lw s7, 56(a5)
; QCI-F-NEXT: lw s8, 60(a5)
; QCI-F-NEXT: lw s9, 64(a5)
; QCI-F-NEXT: lw s10, 68(a5)
; QCI-F-NEXT: lw s11, 72(a5)
; QCI-F-NEXT: lw ra, 76(a5)
; QCI-F-NEXT: lw s1, 80(a5)
; QCI-F-NEXT: lw t3, 84(a5)
; QCI-F-NEXT: lw t2, 88(a5)
; QCI-F-NEXT: lw t1, 92(a5)
; QCI-F-NEXT: lw a7, 112(a5)
; QCI-F-NEXT: lw s0, 116(a5)
; QCI-F-NEXT: lw a3, 120(a5)
; QCI-F-NEXT: lw a0, 124(a5)
; QCI-F-NEXT: lw a6, 96(a5)
; QCI-F-NEXT: lw a4, 100(a5)
; QCI-F-NEXT: lw a2, 104(a5)
; QCI-F-NEXT: lw a1, 108(a5)
; QCI-F-NEXT: sw a0, 124(a5)
; QCI-F-NEXT: sw a3, 120(a5)
; QCI-F-NEXT: sw s0, 116(a5)
; QCI-F-NEXT: sw a7, 112(a5)
; QCI-F-NEXT: sw a1, 108(a5)
; QCI-F-NEXT: sw a2, 104(a5)
; QCI-F-NEXT: sw a4, 100(a5)
; QCI-F-NEXT: sw a6, 96(a5)
; QCI-F-NEXT: sw t1, 92(a5)
; QCI-F-NEXT: sw t2, 88(a5)
; QCI-F-NEXT: sw t3, 84(a5)
; QCI-F-NEXT: sw s1, 80(a5)
; QCI-F-NEXT: sw ra, 76(a5)
; QCI-F-NEXT: sw s11, 72(a5)
; QCI-F-NEXT: sw s10, 68(a5)
; QCI-F-NEXT: sw s9, 64(a5)
; QCI-F-NEXT: sw s8, 60(a5)
; QCI-F-NEXT: sw s7, 56(a5)
; QCI-F-NEXT: sw s6, 52(a5)
; QCI-F-NEXT: sw s5, 48(a5)
; QCI-F-NEXT: sw s4, 44(a5)
; QCI-F-NEXT: sw s3, 40(a5)
; QCI-F-NEXT: sw s2, 36(a5)
; QCI-F-NEXT: sw t6, 32(a5)
; QCI-F-NEXT: sw t5, 28(a5)
; QCI-F-NEXT: sw t4, 24(a5)
; QCI-F-NEXT: lw a0, 12(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 20(a5)
; QCI-F-NEXT: lw a0, 16(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 16(a5)
; QCI-F-NEXT: lw a0, 20(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, %lo(var+12)(t0)
; QCI-F-NEXT: lw a0, 24(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, %lo(var+8)(t0)
; QCI-F-NEXT: lw a0, 28(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, %lo(var+4)(t0)
; QCI-F-NEXT: lw a0, 32(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, %lo(var)(t0)
; QCI-F-NEXT: lw s1, 76(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s2, 72(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s3, 68(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s4, 64(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s5, 60(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s6, 56(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s7, 52(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s8, 48(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s9, 44(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s10, 40(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s11, 36(sp) # 4-byte Folded Reload
; QCI-F-NEXT: .cfi_restore s1
; QCI-F-NEXT: .cfi_restore s2
; QCI-F-NEXT: .cfi_restore s3
; QCI-F-NEXT: .cfi_restore s4
; QCI-F-NEXT: .cfi_restore s5
; QCI-F-NEXT: .cfi_restore s6
; QCI-F-NEXT: .cfi_restore s7
; QCI-F-NEXT: .cfi_restore s8
; QCI-F-NEXT: .cfi_restore s9
; QCI-F-NEXT: .cfi_restore s10
; QCI-F-NEXT: .cfi_restore s11
; QCI-F-NEXT: addi sp, sp, 80
; QCI-F-NEXT: .cfi_def_cfa_offset 96
; QCI-F-NEXT: qc.c.mileaveret
;
; QCI-D-LABEL: test_spill_nonest:
; QCI-D: # %bb.0:
; QCI-D-NEXT: qc.c.mienter
; QCI-D-NEXT: .cfi_def_cfa_offset 96
; QCI-D-NEXT: .cfi_offset ra, -16
; QCI-D-NEXT: .cfi_offset t0, -24
; QCI-D-NEXT: .cfi_offset t1, -28
; QCI-D-NEXT: .cfi_offset t2, -32
; QCI-D-NEXT: .cfi_offset s0, -8
; QCI-D-NEXT: .cfi_offset a0, -36
; QCI-D-NEXT: .cfi_offset a1, -40
; QCI-D-NEXT: .cfi_offset a2, -44
; QCI-D-NEXT: .cfi_offset a3, -48
; QCI-D-NEXT: .cfi_offset a4, -52
; QCI-D-NEXT: .cfi_offset a5, -56
; QCI-D-NEXT: .cfi_offset a6, -60
; QCI-D-NEXT: .cfi_offset a7, -64
; QCI-D-NEXT: .cfi_offset t3, -68
; QCI-D-NEXT: .cfi_offset t4, -72
; QCI-D-NEXT: .cfi_offset t5, -76
; QCI-D-NEXT: .cfi_offset t6, -80
; QCI-D-NEXT: addi sp, sp, -80
; QCI-D-NEXT: .cfi_def_cfa_offset 176
; QCI-D-NEXT: sw s1, 76(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s2, 72(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s3, 68(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s4, 64(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s5, 60(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s6, 56(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s7, 52(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s8, 48(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s9, 44(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s10, 40(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s11, 36(sp) # 4-byte Folded Spill
; QCI-D-NEXT: .cfi_offset s1, -100
; QCI-D-NEXT: .cfi_offset s2, -104
; QCI-D-NEXT: .cfi_offset s3, -108
; QCI-D-NEXT: .cfi_offset s4, -112
; QCI-D-NEXT: .cfi_offset s5, -116
; QCI-D-NEXT: .cfi_offset s6, -120
; QCI-D-NEXT: .cfi_offset s7, -124
; QCI-D-NEXT: .cfi_offset s8, -128
; QCI-D-NEXT: .cfi_offset s9, -132
; QCI-D-NEXT: .cfi_offset s10, -136
; QCI-D-NEXT: .cfi_offset s11, -140
; QCI-D-NEXT: lui t0, %hi(var)
; QCI-D-NEXT: lw a0, %lo(var)(t0)
; QCI-D-NEXT: sw a0, 32(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, %lo(var+4)(t0)
; QCI-D-NEXT: sw a0, 28(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, %lo(var+8)(t0)
; QCI-D-NEXT: sw a0, 24(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, %lo(var+12)(t0)
; QCI-D-NEXT: sw a0, 20(sp) # 4-byte Folded Spill
; QCI-D-NEXT: addi a5, t0, %lo(var)
; QCI-D-NEXT: lw a0, 16(a5)
; QCI-D-NEXT: sw a0, 16(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 20(a5)
; QCI-D-NEXT: sw a0, 12(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw t4, 24(a5)
; QCI-D-NEXT: lw t5, 28(a5)
; QCI-D-NEXT: lw t6, 32(a5)
; QCI-D-NEXT: lw s2, 36(a5)
; QCI-D-NEXT: lw s3, 40(a5)
; QCI-D-NEXT: lw s4, 44(a5)
; QCI-D-NEXT: lw s5, 48(a5)
; QCI-D-NEXT: lw s6, 52(a5)
; QCI-D-NEXT: lw s7, 56(a5)
; QCI-D-NEXT: lw s8, 60(a5)
; QCI-D-NEXT: lw s9, 64(a5)
; QCI-D-NEXT: lw s10, 68(a5)
; QCI-D-NEXT: lw s11, 72(a5)
; QCI-D-NEXT: lw ra, 76(a5)
; QCI-D-NEXT: lw s1, 80(a5)
; QCI-D-NEXT: lw t3, 84(a5)
; QCI-D-NEXT: lw t2, 88(a5)
; QCI-D-NEXT: lw t1, 92(a5)
; QCI-D-NEXT: lw a7, 112(a5)
; QCI-D-NEXT: lw s0, 116(a5)
; QCI-D-NEXT: lw a3, 120(a5)
; QCI-D-NEXT: lw a0, 124(a5)
; QCI-D-NEXT: lw a6, 96(a5)
; QCI-D-NEXT: lw a4, 100(a5)
; QCI-D-NEXT: lw a2, 104(a5)
; QCI-D-NEXT: lw a1, 108(a5)
; QCI-D-NEXT: sw a0, 124(a5)
; QCI-D-NEXT: sw a3, 120(a5)
; QCI-D-NEXT: sw s0, 116(a5)
; QCI-D-NEXT: sw a7, 112(a5)
; QCI-D-NEXT: sw a1, 108(a5)
; QCI-D-NEXT: sw a2, 104(a5)
; QCI-D-NEXT: sw a4, 100(a5)
; QCI-D-NEXT: sw a6, 96(a5)
; QCI-D-NEXT: sw t1, 92(a5)
; QCI-D-NEXT: sw t2, 88(a5)
; QCI-D-NEXT: sw t3, 84(a5)
; QCI-D-NEXT: sw s1, 80(a5)
; QCI-D-NEXT: sw ra, 76(a5)
; QCI-D-NEXT: sw s11, 72(a5)
; QCI-D-NEXT: sw s10, 68(a5)
; QCI-D-NEXT: sw s9, 64(a5)
; QCI-D-NEXT: sw s8, 60(a5)
; QCI-D-NEXT: sw s7, 56(a5)
; QCI-D-NEXT: sw s6, 52(a5)
; QCI-D-NEXT: sw s5, 48(a5)
; QCI-D-NEXT: sw s4, 44(a5)
; QCI-D-NEXT: sw s3, 40(a5)
; QCI-D-NEXT: sw s2, 36(a5)
; QCI-D-NEXT: sw t6, 32(a5)
; QCI-D-NEXT: sw t5, 28(a5)
; QCI-D-NEXT: sw t4, 24(a5)
; QCI-D-NEXT: lw a0, 12(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 20(a5)
; QCI-D-NEXT: lw a0, 16(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 16(a5)
; QCI-D-NEXT: lw a0, 20(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, %lo(var+12)(t0)
; QCI-D-NEXT: lw a0, 24(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, %lo(var+8)(t0)
; QCI-D-NEXT: lw a0, 28(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, %lo(var+4)(t0)
; QCI-D-NEXT: lw a0, 32(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, %lo(var)(t0)
; QCI-D-NEXT: lw s1, 76(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s2, 72(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s3, 68(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s4, 64(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s5, 60(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s6, 56(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s7, 52(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s8, 48(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s9, 44(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s10, 40(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s11, 36(sp) # 4-byte Folded Reload
; QCI-D-NEXT: .cfi_restore s1
; QCI-D-NEXT: .cfi_restore s2
; QCI-D-NEXT: .cfi_restore s3
; QCI-D-NEXT: .cfi_restore s4
; QCI-D-NEXT: .cfi_restore s5
; QCI-D-NEXT: .cfi_restore s6
; QCI-D-NEXT: .cfi_restore s7
; QCI-D-NEXT: .cfi_restore s8
; QCI-D-NEXT: .cfi_restore s9
; QCI-D-NEXT: .cfi_restore s10
; QCI-D-NEXT: .cfi_restore s11
; QCI-D-NEXT: addi sp, sp, 80
; QCI-D-NEXT: .cfi_def_cfa_offset 96
; QCI-D-NEXT: qc.c.mileaveret
%1 = load [32 x i32], ptr @var
store volatile [32 x i32] %1, ptr @var
ret void
}
define void @test_spill_call_nest() "interrupt"="qci-nest" {
; QCI-F-LABEL: test_spill_call_nest:
; QCI-F: # %bb.0:
; QCI-F-NEXT: qc.c.mienter.nest
; QCI-F-NEXT: .cfi_def_cfa_offset 96
; QCI-F-NEXT: .cfi_offset ra, -16
; QCI-F-NEXT: .cfi_offset t0, -24
; QCI-F-NEXT: .cfi_offset t1, -28
; QCI-F-NEXT: .cfi_offset t2, -32
; QCI-F-NEXT: .cfi_offset s0, -8
; QCI-F-NEXT: .cfi_offset a0, -36
; QCI-F-NEXT: .cfi_offset a1, -40
; QCI-F-NEXT: .cfi_offset a2, -44
; QCI-F-NEXT: .cfi_offset a3, -48
; QCI-F-NEXT: .cfi_offset a4, -52
; QCI-F-NEXT: .cfi_offset a5, -56
; QCI-F-NEXT: .cfi_offset a6, -60
; QCI-F-NEXT: .cfi_offset a7, -64
; QCI-F-NEXT: .cfi_offset t3, -68
; QCI-F-NEXT: .cfi_offset t4, -72
; QCI-F-NEXT: .cfi_offset t5, -76
; QCI-F-NEXT: .cfi_offset t6, -80
; QCI-F-NEXT: addi sp, sp, -224
; QCI-F-NEXT: .cfi_def_cfa_offset 320
; QCI-F-NEXT: sw s1, 220(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s2, 216(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s3, 212(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s4, 208(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s5, 204(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s6, 200(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s7, 196(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s8, 192(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s9, 188(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s10, 184(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s11, 180(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft0, 176(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft1, 172(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft2, 168(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft3, 164(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft4, 160(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft5, 156(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft6, 152(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft7, 148(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa0, 144(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa1, 140(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa2, 136(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa3, 132(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa4, 128(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa5, 124(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa6, 120(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa7, 116(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft8, 112(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft9, 108(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft10, 104(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft11, 100(sp) # 4-byte Folded Spill
; QCI-F-NEXT: .cfi_offset s1, -100
; QCI-F-NEXT: .cfi_offset s2, -104
; QCI-F-NEXT: .cfi_offset s3, -108
; QCI-F-NEXT: .cfi_offset s4, -112
; QCI-F-NEXT: .cfi_offset s5, -116
; QCI-F-NEXT: .cfi_offset s6, -120
; QCI-F-NEXT: .cfi_offset s7, -124
; QCI-F-NEXT: .cfi_offset s8, -128
; QCI-F-NEXT: .cfi_offset s9, -132
; QCI-F-NEXT: .cfi_offset s10, -136
; QCI-F-NEXT: .cfi_offset s11, -140
; QCI-F-NEXT: .cfi_offset ft0, -144
; QCI-F-NEXT: .cfi_offset ft1, -148
; QCI-F-NEXT: .cfi_offset ft2, -152
; QCI-F-NEXT: .cfi_offset ft3, -156
; QCI-F-NEXT: .cfi_offset ft4, -160
; QCI-F-NEXT: .cfi_offset ft5, -164
; QCI-F-NEXT: .cfi_offset ft6, -168
; QCI-F-NEXT: .cfi_offset ft7, -172
; QCI-F-NEXT: .cfi_offset fa0, -176
; QCI-F-NEXT: .cfi_offset fa1, -180
; QCI-F-NEXT: .cfi_offset fa2, -184
; QCI-F-NEXT: .cfi_offset fa3, -188
; QCI-F-NEXT: .cfi_offset fa4, -192
; QCI-F-NEXT: .cfi_offset fa5, -196
; QCI-F-NEXT: .cfi_offset fa6, -200
; QCI-F-NEXT: .cfi_offset fa7, -204
; QCI-F-NEXT: .cfi_offset ft8, -208
; QCI-F-NEXT: .cfi_offset ft9, -212
; QCI-F-NEXT: .cfi_offset ft10, -216
; QCI-F-NEXT: .cfi_offset ft11, -220
; QCI-F-NEXT: lui s0, %hi(var)
; QCI-F-NEXT: lw a0, %lo(var)(s0)
; QCI-F-NEXT: sw a0, 96(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, %lo(var+4)(s0)
; QCI-F-NEXT: sw a0, 92(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, %lo(var+8)(s0)
; QCI-F-NEXT: sw a0, 88(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, %lo(var+12)(s0)
; QCI-F-NEXT: sw a0, 84(sp) # 4-byte Folded Spill
; QCI-F-NEXT: addi s1, s0, %lo(var)
; QCI-F-NEXT: lw a0, 16(s1)
; QCI-F-NEXT: sw a0, 80(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 20(s1)
; QCI-F-NEXT: sw a0, 76(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 24(s1)
; QCI-F-NEXT: sw a0, 72(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 28(s1)
; QCI-F-NEXT: sw a0, 68(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 32(s1)
; QCI-F-NEXT: sw a0, 64(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 36(s1)
; QCI-F-NEXT: sw a0, 60(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 40(s1)
; QCI-F-NEXT: sw a0, 56(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 44(s1)
; QCI-F-NEXT: sw a0, 52(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 48(s1)
; QCI-F-NEXT: sw a0, 48(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 52(s1)
; QCI-F-NEXT: sw a0, 44(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 56(s1)
; QCI-F-NEXT: sw a0, 40(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 60(s1)
; QCI-F-NEXT: sw a0, 36(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 64(s1)
; QCI-F-NEXT: sw a0, 32(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 68(s1)
; QCI-F-NEXT: sw a0, 28(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 72(s1)
; QCI-F-NEXT: sw a0, 24(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 76(s1)
; QCI-F-NEXT: sw a0, 20(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 80(s1)
; QCI-F-NEXT: sw a0, 16(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 84(s1)
; QCI-F-NEXT: sw a0, 12(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw s4, 88(s1)
; QCI-F-NEXT: lw s5, 92(s1)
; QCI-F-NEXT: lw s6, 96(s1)
; QCI-F-NEXT: lw s7, 100(s1)
; QCI-F-NEXT: lw s8, 104(s1)
; QCI-F-NEXT: lw s9, 108(s1)
; QCI-F-NEXT: lw s10, 112(s1)
; QCI-F-NEXT: lw s11, 116(s1)
; QCI-F-NEXT: lw s2, 120(s1)
; QCI-F-NEXT: lw s3, 124(s1)
; QCI-F-NEXT: lui a7, 266496
; QCI-F-NEXT: li t0, 5
; QCI-F-NEXT: lui a0, 260096
; QCI-F-NEXT: lui a2, 262144
; QCI-F-NEXT: lui a4, 263168
; QCI-F-NEXT: lui a5, 264192
; QCI-F-NEXT: lui a1, 264704
; QCI-F-NEXT: lui a6, 265216
; QCI-F-NEXT: fmv.w.x fa0, a0
; QCI-F-NEXT: lui t1, 265728
; QCI-F-NEXT: fmv.w.x fa1, a2
; QCI-F-NEXT: lui a3, 266240
; QCI-F-NEXT: fmv.w.x fa2, a4
; QCI-F-NEXT: li a0, 1
; QCI-F-NEXT: fmv.w.x fa3, a5
; QCI-F-NEXT: li a2, 2
; QCI-F-NEXT: fmv.w.x fa4, a1
; QCI-F-NEXT: li a4, 3
; QCI-F-NEXT: fmv.w.x fa5, a6
; QCI-F-NEXT: li a6, 4
; QCI-F-NEXT: fmv.w.x fa6, t1
; QCI-F-NEXT: fmv.w.x fa7, a3
; QCI-F-NEXT: sw t0, 0(sp)
; QCI-F-NEXT: sw a7, 4(sp)
; QCI-F-NEXT: li a1, 0
; QCI-F-NEXT: li a3, 0
; QCI-F-NEXT: li a5, 0
; QCI-F-NEXT: li a7, 0
; QCI-F-NEXT: call function_with_one_stack_arg
; QCI-F-NEXT: call use_float
; QCI-F-NEXT: sw s3, 124(s1)
; QCI-F-NEXT: sw s2, 120(s1)
; QCI-F-NEXT: sw s11, 116(s1)
; QCI-F-NEXT: sw s10, 112(s1)
; QCI-F-NEXT: sw s9, 108(s1)
; QCI-F-NEXT: sw s8, 104(s1)
; QCI-F-NEXT: sw s7, 100(s1)
; QCI-F-NEXT: sw s6, 96(s1)
; QCI-F-NEXT: sw s5, 92(s1)
; QCI-F-NEXT: sw s4, 88(s1)
; QCI-F-NEXT: lw a0, 12(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 84(s1)
; QCI-F-NEXT: lw a0, 16(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 80(s1)
; QCI-F-NEXT: lw a0, 20(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 76(s1)
; QCI-F-NEXT: lw a0, 24(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 72(s1)
; QCI-F-NEXT: lw a0, 28(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 68(s1)
; QCI-F-NEXT: lw a0, 32(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 64(s1)
; QCI-F-NEXT: lw a0, 36(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 60(s1)
; QCI-F-NEXT: lw a0, 40(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 56(s1)
; QCI-F-NEXT: lw a0, 44(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 52(s1)
; QCI-F-NEXT: lw a0, 48(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 48(s1)
; QCI-F-NEXT: lw a0, 52(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 44(s1)
; QCI-F-NEXT: lw a0, 56(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 40(s1)
; QCI-F-NEXT: lw a0, 60(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 36(s1)
; QCI-F-NEXT: lw a0, 64(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 32(s1)
; QCI-F-NEXT: lw a0, 68(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 28(s1)
; QCI-F-NEXT: lw a0, 72(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 24(s1)
; QCI-F-NEXT: lw a0, 76(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 20(s1)
; QCI-F-NEXT: lw a0, 80(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 16(s1)
; QCI-F-NEXT: lw a0, 84(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, %lo(var+12)(s0)
; QCI-F-NEXT: lw a0, 88(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, %lo(var+8)(s0)
; QCI-F-NEXT: lw a0, 92(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, %lo(var+4)(s0)
; QCI-F-NEXT: lw a0, 96(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, %lo(var)(s0)
; QCI-F-NEXT: lw s1, 220(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s2, 216(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s3, 212(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s4, 208(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s5, 204(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s6, 200(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s7, 196(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s8, 192(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s9, 188(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s10, 184(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s11, 180(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft0, 176(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft1, 172(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft2, 168(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft3, 164(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft4, 160(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft5, 156(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft6, 152(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft7, 148(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa0, 144(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa1, 140(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa2, 136(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa3, 132(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa4, 128(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa5, 124(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa6, 120(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa7, 116(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft8, 112(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft9, 108(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft10, 104(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft11, 100(sp) # 4-byte Folded Reload
; QCI-F-NEXT: .cfi_restore s1
; QCI-F-NEXT: .cfi_restore s2
; QCI-F-NEXT: .cfi_restore s3
; QCI-F-NEXT: .cfi_restore s4
; QCI-F-NEXT: .cfi_restore s5
; QCI-F-NEXT: .cfi_restore s6
; QCI-F-NEXT: .cfi_restore s7
; QCI-F-NEXT: .cfi_restore s8
; QCI-F-NEXT: .cfi_restore s9
; QCI-F-NEXT: .cfi_restore s10
; QCI-F-NEXT: .cfi_restore s11
; QCI-F-NEXT: .cfi_restore ft0
; QCI-F-NEXT: .cfi_restore ft1
; QCI-F-NEXT: .cfi_restore ft2
; QCI-F-NEXT: .cfi_restore ft3
; QCI-F-NEXT: .cfi_restore ft4
; QCI-F-NEXT: .cfi_restore ft5
; QCI-F-NEXT: .cfi_restore ft6
; QCI-F-NEXT: .cfi_restore ft7
; QCI-F-NEXT: .cfi_restore fa0
; QCI-F-NEXT: .cfi_restore fa1
; QCI-F-NEXT: .cfi_restore fa2
; QCI-F-NEXT: .cfi_restore fa3
; QCI-F-NEXT: .cfi_restore fa4
; QCI-F-NEXT: .cfi_restore fa5
; QCI-F-NEXT: .cfi_restore fa6
; QCI-F-NEXT: .cfi_restore fa7
; QCI-F-NEXT: .cfi_restore ft8
; QCI-F-NEXT: .cfi_restore ft9
; QCI-F-NEXT: .cfi_restore ft10
; QCI-F-NEXT: .cfi_restore ft11
; QCI-F-NEXT: addi sp, sp, 224
; QCI-F-NEXT: .cfi_def_cfa_offset 96
; QCI-F-NEXT: qc.c.mileaveret
;
; QCI-D-LABEL: test_spill_call_nest:
; QCI-D: # %bb.0:
; QCI-D-NEXT: qc.c.mienter.nest
; QCI-D-NEXT: .cfi_def_cfa_offset 96
; QCI-D-NEXT: .cfi_offset ra, -16
; QCI-D-NEXT: .cfi_offset t0, -24
; QCI-D-NEXT: .cfi_offset t1, -28
; QCI-D-NEXT: .cfi_offset t2, -32
; QCI-D-NEXT: .cfi_offset s0, -8
; QCI-D-NEXT: .cfi_offset a0, -36
; QCI-D-NEXT: .cfi_offset a1, -40
; QCI-D-NEXT: .cfi_offset a2, -44
; QCI-D-NEXT: .cfi_offset a3, -48
; QCI-D-NEXT: .cfi_offset a4, -52
; QCI-D-NEXT: .cfi_offset a5, -56
; QCI-D-NEXT: .cfi_offset a6, -60
; QCI-D-NEXT: .cfi_offset a7, -64
; QCI-D-NEXT: .cfi_offset t3, -68
; QCI-D-NEXT: .cfi_offset t4, -72
; QCI-D-NEXT: .cfi_offset t5, -76
; QCI-D-NEXT: .cfi_offset t6, -80
; QCI-D-NEXT: addi sp, sp, -304
; QCI-D-NEXT: .cfi_def_cfa_offset 400
; QCI-D-NEXT: sw s1, 300(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s2, 296(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s3, 292(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s4, 288(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s5, 284(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s6, 280(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s7, 276(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s8, 272(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s9, 268(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s10, 264(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s11, 260(sp) # 4-byte Folded Spill
; QCI-D-NEXT: fsd ft0, 248(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft1, 240(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft2, 232(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft3, 224(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft4, 216(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft5, 208(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft6, 200(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft7, 192(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa0, 184(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa1, 176(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa2, 168(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa3, 160(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa4, 152(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa5, 144(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa6, 136(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa7, 128(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft8, 120(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft9, 112(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft10, 104(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft11, 96(sp) # 8-byte Folded Spill
; QCI-D-NEXT: .cfi_offset s1, -100
; QCI-D-NEXT: .cfi_offset s2, -104
; QCI-D-NEXT: .cfi_offset s3, -108
; QCI-D-NEXT: .cfi_offset s4, -112
; QCI-D-NEXT: .cfi_offset s5, -116
; QCI-D-NEXT: .cfi_offset s6, -120
; QCI-D-NEXT: .cfi_offset s7, -124
; QCI-D-NEXT: .cfi_offset s8, -128
; QCI-D-NEXT: .cfi_offset s9, -132
; QCI-D-NEXT: .cfi_offset s10, -136
; QCI-D-NEXT: .cfi_offset s11, -140
; QCI-D-NEXT: .cfi_offset ft0, -152
; QCI-D-NEXT: .cfi_offset ft1, -160
; QCI-D-NEXT: .cfi_offset ft2, -168
; QCI-D-NEXT: .cfi_offset ft3, -176
; QCI-D-NEXT: .cfi_offset ft4, -184
; QCI-D-NEXT: .cfi_offset ft5, -192
; QCI-D-NEXT: .cfi_offset ft6, -200
; QCI-D-NEXT: .cfi_offset ft7, -208
; QCI-D-NEXT: .cfi_offset fa0, -216
; QCI-D-NEXT: .cfi_offset fa1, -224
; QCI-D-NEXT: .cfi_offset fa2, -232
; QCI-D-NEXT: .cfi_offset fa3, -240
; QCI-D-NEXT: .cfi_offset fa4, -248
; QCI-D-NEXT: .cfi_offset fa5, -256
; QCI-D-NEXT: .cfi_offset fa6, -264
; QCI-D-NEXT: .cfi_offset fa7, -272
; QCI-D-NEXT: .cfi_offset ft8, -280
; QCI-D-NEXT: .cfi_offset ft9, -288
; QCI-D-NEXT: .cfi_offset ft10, -296
; QCI-D-NEXT: .cfi_offset ft11, -304
; QCI-D-NEXT: lui s0, %hi(var)
; QCI-D-NEXT: lw a0, %lo(var)(s0)
; QCI-D-NEXT: sw a0, 92(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, %lo(var+4)(s0)
; QCI-D-NEXT: sw a0, 88(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, %lo(var+8)(s0)
; QCI-D-NEXT: sw a0, 84(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, %lo(var+12)(s0)
; QCI-D-NEXT: sw a0, 80(sp) # 4-byte Folded Spill
; QCI-D-NEXT: addi s1, s0, %lo(var)
; QCI-D-NEXT: lw a0, 16(s1)
; QCI-D-NEXT: sw a0, 76(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 20(s1)
; QCI-D-NEXT: sw a0, 72(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 24(s1)
; QCI-D-NEXT: sw a0, 68(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 28(s1)
; QCI-D-NEXT: sw a0, 64(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 32(s1)
; QCI-D-NEXT: sw a0, 60(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 36(s1)
; QCI-D-NEXT: sw a0, 56(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 40(s1)
; QCI-D-NEXT: sw a0, 52(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 44(s1)
; QCI-D-NEXT: sw a0, 48(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 48(s1)
; QCI-D-NEXT: sw a0, 44(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 52(s1)
; QCI-D-NEXT: sw a0, 40(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 56(s1)
; QCI-D-NEXT: sw a0, 36(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 60(s1)
; QCI-D-NEXT: sw a0, 32(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 64(s1)
; QCI-D-NEXT: sw a0, 28(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 68(s1)
; QCI-D-NEXT: sw a0, 24(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 72(s1)
; QCI-D-NEXT: sw a0, 20(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 76(s1)
; QCI-D-NEXT: sw a0, 16(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 80(s1)
; QCI-D-NEXT: sw a0, 12(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 84(s1)
; QCI-D-NEXT: sw a0, 8(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw s4, 88(s1)
; QCI-D-NEXT: lw s5, 92(s1)
; QCI-D-NEXT: lw s6, 96(s1)
; QCI-D-NEXT: lw s7, 100(s1)
; QCI-D-NEXT: lw s8, 104(s1)
; QCI-D-NEXT: lw s9, 108(s1)
; QCI-D-NEXT: lw s10, 112(s1)
; QCI-D-NEXT: lw s11, 116(s1)
; QCI-D-NEXT: lw s2, 120(s1)
; QCI-D-NEXT: lw s3, 124(s1)
; QCI-D-NEXT: lui a7, 266496
; QCI-D-NEXT: li t0, 5
; QCI-D-NEXT: lui a0, 260096
; QCI-D-NEXT: lui a2, 262144
; QCI-D-NEXT: lui a4, 263168
; QCI-D-NEXT: lui a5, 264192
; QCI-D-NEXT: lui a1, 264704
; QCI-D-NEXT: lui a6, 265216
; QCI-D-NEXT: fmv.w.x fa0, a0
; QCI-D-NEXT: lui t1, 265728
; QCI-D-NEXT: fmv.w.x fa1, a2
; QCI-D-NEXT: lui a3, 266240
; QCI-D-NEXT: fmv.w.x fa2, a4
; QCI-D-NEXT: li a0, 1
; QCI-D-NEXT: fmv.w.x fa3, a5
; QCI-D-NEXT: li a2, 2
; QCI-D-NEXT: fmv.w.x fa4, a1
; QCI-D-NEXT: li a4, 3
; QCI-D-NEXT: fmv.w.x fa5, a6
; QCI-D-NEXT: li a6, 4
; QCI-D-NEXT: fmv.w.x fa6, t1
; QCI-D-NEXT: fmv.w.x fa7, a3
; QCI-D-NEXT: sw t0, 0(sp)
; QCI-D-NEXT: sw a7, 4(sp)
; QCI-D-NEXT: li a1, 0
; QCI-D-NEXT: li a3, 0
; QCI-D-NEXT: li a5, 0
; QCI-D-NEXT: li a7, 0
; QCI-D-NEXT: call function_with_one_stack_arg
; QCI-D-NEXT: call use_float
; QCI-D-NEXT: sw s3, 124(s1)
; QCI-D-NEXT: sw s2, 120(s1)
; QCI-D-NEXT: sw s11, 116(s1)
; QCI-D-NEXT: sw s10, 112(s1)
; QCI-D-NEXT: sw s9, 108(s1)
; QCI-D-NEXT: sw s8, 104(s1)
; QCI-D-NEXT: sw s7, 100(s1)
; QCI-D-NEXT: sw s6, 96(s1)
; QCI-D-NEXT: sw s5, 92(s1)
; QCI-D-NEXT: sw s4, 88(s1)
; QCI-D-NEXT: lw a0, 8(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 84(s1)
; QCI-D-NEXT: lw a0, 12(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 80(s1)
; QCI-D-NEXT: lw a0, 16(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 76(s1)
; QCI-D-NEXT: lw a0, 20(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 72(s1)
; QCI-D-NEXT: lw a0, 24(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 68(s1)
; QCI-D-NEXT: lw a0, 28(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 64(s1)
; QCI-D-NEXT: lw a0, 32(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 60(s1)
; QCI-D-NEXT: lw a0, 36(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 56(s1)
; QCI-D-NEXT: lw a0, 40(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 52(s1)
; QCI-D-NEXT: lw a0, 44(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 48(s1)
; QCI-D-NEXT: lw a0, 48(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 44(s1)
; QCI-D-NEXT: lw a0, 52(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 40(s1)
; QCI-D-NEXT: lw a0, 56(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 36(s1)
; QCI-D-NEXT: lw a0, 60(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 32(s1)
; QCI-D-NEXT: lw a0, 64(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 28(s1)
; QCI-D-NEXT: lw a0, 68(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 24(s1)
; QCI-D-NEXT: lw a0, 72(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 20(s1)
; QCI-D-NEXT: lw a0, 76(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 16(s1)
; QCI-D-NEXT: lw a0, 80(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, %lo(var+12)(s0)
; QCI-D-NEXT: lw a0, 84(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, %lo(var+8)(s0)
; QCI-D-NEXT: lw a0, 88(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, %lo(var+4)(s0)
; QCI-D-NEXT: lw a0, 92(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, %lo(var)(s0)
; QCI-D-NEXT: lw s1, 300(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s2, 296(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s3, 292(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s4, 288(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s5, 284(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s6, 280(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s7, 276(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s8, 272(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s9, 268(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s10, 264(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s11, 260(sp) # 4-byte Folded Reload
; QCI-D-NEXT: fld ft0, 248(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft1, 240(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft2, 232(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft3, 224(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft4, 216(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft5, 208(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft6, 200(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft7, 192(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa0, 184(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa1, 176(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa2, 168(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa3, 160(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa4, 152(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa5, 144(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa6, 136(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa7, 128(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft8, 120(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft9, 112(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft10, 104(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft11, 96(sp) # 8-byte Folded Reload
; QCI-D-NEXT: .cfi_restore s1
; QCI-D-NEXT: .cfi_restore s2
; QCI-D-NEXT: .cfi_restore s3
; QCI-D-NEXT: .cfi_restore s4
; QCI-D-NEXT: .cfi_restore s5
; QCI-D-NEXT: .cfi_restore s6
; QCI-D-NEXT: .cfi_restore s7
; QCI-D-NEXT: .cfi_restore s8
; QCI-D-NEXT: .cfi_restore s9
; QCI-D-NEXT: .cfi_restore s10
; QCI-D-NEXT: .cfi_restore s11
; QCI-D-NEXT: .cfi_restore ft0
; QCI-D-NEXT: .cfi_restore ft1
; QCI-D-NEXT: .cfi_restore ft2
; QCI-D-NEXT: .cfi_restore ft3
; QCI-D-NEXT: .cfi_restore ft4
; QCI-D-NEXT: .cfi_restore ft5
; QCI-D-NEXT: .cfi_restore ft6
; QCI-D-NEXT: .cfi_restore ft7
; QCI-D-NEXT: .cfi_restore fa0
; QCI-D-NEXT: .cfi_restore fa1
; QCI-D-NEXT: .cfi_restore fa2
; QCI-D-NEXT: .cfi_restore fa3
; QCI-D-NEXT: .cfi_restore fa4
; QCI-D-NEXT: .cfi_restore fa5
; QCI-D-NEXT: .cfi_restore fa6
; QCI-D-NEXT: .cfi_restore fa7
; QCI-D-NEXT: .cfi_restore ft8
; QCI-D-NEXT: .cfi_restore ft9
; QCI-D-NEXT: .cfi_restore ft10
; QCI-D-NEXT: .cfi_restore ft11
; QCI-D-NEXT: addi sp, sp, 304
; QCI-D-NEXT: .cfi_def_cfa_offset 96
; QCI-D-NEXT: qc.c.mileaveret
%1 = load [32 x i32], ptr @var
%2 = call float @function_with_one_stack_arg(i64 1, i64 2, i64 3, i64 4, float 1.0, float 2.0, float 3.0, float 4.0, float 5.0, float 6.0, float 7.0, float 8.0, i32 5, float 9.0)
call void @use_float(float %2)
store volatile [32 x i32] %1, ptr @var
ret void
}
define void @test_spill_call_nonest() "interrupt"="qci-nonest" {
; QCI-F-LABEL: test_spill_call_nonest:
; QCI-F: # %bb.0:
; QCI-F-NEXT: qc.c.mienter
; QCI-F-NEXT: .cfi_def_cfa_offset 96
; QCI-F-NEXT: .cfi_offset ra, -16
; QCI-F-NEXT: .cfi_offset t0, -24
; QCI-F-NEXT: .cfi_offset t1, -28
; QCI-F-NEXT: .cfi_offset t2, -32
; QCI-F-NEXT: .cfi_offset s0, -8
; QCI-F-NEXT: .cfi_offset a0, -36
; QCI-F-NEXT: .cfi_offset a1, -40
; QCI-F-NEXT: .cfi_offset a2, -44
; QCI-F-NEXT: .cfi_offset a3, -48
; QCI-F-NEXT: .cfi_offset a4, -52
; QCI-F-NEXT: .cfi_offset a5, -56
; QCI-F-NEXT: .cfi_offset a6, -60
; QCI-F-NEXT: .cfi_offset a7, -64
; QCI-F-NEXT: .cfi_offset t3, -68
; QCI-F-NEXT: .cfi_offset t4, -72
; QCI-F-NEXT: .cfi_offset t5, -76
; QCI-F-NEXT: .cfi_offset t6, -80
; QCI-F-NEXT: addi sp, sp, -224
; QCI-F-NEXT: .cfi_def_cfa_offset 320
; QCI-F-NEXT: sw s1, 220(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s2, 216(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s3, 212(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s4, 208(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s5, 204(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s6, 200(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s7, 196(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s8, 192(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s9, 188(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s10, 184(sp) # 4-byte Folded Spill
; QCI-F-NEXT: sw s11, 180(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft0, 176(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft1, 172(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft2, 168(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft3, 164(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft4, 160(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft5, 156(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft6, 152(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft7, 148(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa0, 144(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa1, 140(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa2, 136(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa3, 132(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa4, 128(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa5, 124(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa6, 120(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw fa7, 116(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft8, 112(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft9, 108(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft10, 104(sp) # 4-byte Folded Spill
; QCI-F-NEXT: fsw ft11, 100(sp) # 4-byte Folded Spill
; QCI-F-NEXT: .cfi_offset s1, -100
; QCI-F-NEXT: .cfi_offset s2, -104
; QCI-F-NEXT: .cfi_offset s3, -108
; QCI-F-NEXT: .cfi_offset s4, -112
; QCI-F-NEXT: .cfi_offset s5, -116
; QCI-F-NEXT: .cfi_offset s6, -120
; QCI-F-NEXT: .cfi_offset s7, -124
; QCI-F-NEXT: .cfi_offset s8, -128
; QCI-F-NEXT: .cfi_offset s9, -132
; QCI-F-NEXT: .cfi_offset s10, -136
; QCI-F-NEXT: .cfi_offset s11, -140
; QCI-F-NEXT: .cfi_offset ft0, -144
; QCI-F-NEXT: .cfi_offset ft1, -148
; QCI-F-NEXT: .cfi_offset ft2, -152
; QCI-F-NEXT: .cfi_offset ft3, -156
; QCI-F-NEXT: .cfi_offset ft4, -160
; QCI-F-NEXT: .cfi_offset ft5, -164
; QCI-F-NEXT: .cfi_offset ft6, -168
; QCI-F-NEXT: .cfi_offset ft7, -172
; QCI-F-NEXT: .cfi_offset fa0, -176
; QCI-F-NEXT: .cfi_offset fa1, -180
; QCI-F-NEXT: .cfi_offset fa2, -184
; QCI-F-NEXT: .cfi_offset fa3, -188
; QCI-F-NEXT: .cfi_offset fa4, -192
; QCI-F-NEXT: .cfi_offset fa5, -196
; QCI-F-NEXT: .cfi_offset fa6, -200
; QCI-F-NEXT: .cfi_offset fa7, -204
; QCI-F-NEXT: .cfi_offset ft8, -208
; QCI-F-NEXT: .cfi_offset ft9, -212
; QCI-F-NEXT: .cfi_offset ft10, -216
; QCI-F-NEXT: .cfi_offset ft11, -220
; QCI-F-NEXT: lui s0, %hi(var)
; QCI-F-NEXT: lw a0, %lo(var)(s0)
; QCI-F-NEXT: sw a0, 96(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, %lo(var+4)(s0)
; QCI-F-NEXT: sw a0, 92(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, %lo(var+8)(s0)
; QCI-F-NEXT: sw a0, 88(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, %lo(var+12)(s0)
; QCI-F-NEXT: sw a0, 84(sp) # 4-byte Folded Spill
; QCI-F-NEXT: addi s1, s0, %lo(var)
; QCI-F-NEXT: lw a0, 16(s1)
; QCI-F-NEXT: sw a0, 80(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 20(s1)
; QCI-F-NEXT: sw a0, 76(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 24(s1)
; QCI-F-NEXT: sw a0, 72(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 28(s1)
; QCI-F-NEXT: sw a0, 68(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 32(s1)
; QCI-F-NEXT: sw a0, 64(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 36(s1)
; QCI-F-NEXT: sw a0, 60(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 40(s1)
; QCI-F-NEXT: sw a0, 56(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 44(s1)
; QCI-F-NEXT: sw a0, 52(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 48(s1)
; QCI-F-NEXT: sw a0, 48(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 52(s1)
; QCI-F-NEXT: sw a0, 44(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 56(s1)
; QCI-F-NEXT: sw a0, 40(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 60(s1)
; QCI-F-NEXT: sw a0, 36(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 64(s1)
; QCI-F-NEXT: sw a0, 32(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 68(s1)
; QCI-F-NEXT: sw a0, 28(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 72(s1)
; QCI-F-NEXT: sw a0, 24(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 76(s1)
; QCI-F-NEXT: sw a0, 20(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 80(s1)
; QCI-F-NEXT: sw a0, 16(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw a0, 84(s1)
; QCI-F-NEXT: sw a0, 12(sp) # 4-byte Folded Spill
; QCI-F-NEXT: lw s4, 88(s1)
; QCI-F-NEXT: lw s5, 92(s1)
; QCI-F-NEXT: lw s6, 96(s1)
; QCI-F-NEXT: lw s7, 100(s1)
; QCI-F-NEXT: lw s8, 104(s1)
; QCI-F-NEXT: lw s9, 108(s1)
; QCI-F-NEXT: lw s10, 112(s1)
; QCI-F-NEXT: lw s11, 116(s1)
; QCI-F-NEXT: lw s2, 120(s1)
; QCI-F-NEXT: lw s3, 124(s1)
; QCI-F-NEXT: lui a7, 266496
; QCI-F-NEXT: li t0, 5
; QCI-F-NEXT: lui a0, 260096
; QCI-F-NEXT: lui a2, 262144
; QCI-F-NEXT: lui a4, 263168
; QCI-F-NEXT: lui a5, 264192
; QCI-F-NEXT: lui a1, 264704
; QCI-F-NEXT: lui a6, 265216
; QCI-F-NEXT: fmv.w.x fa0, a0
; QCI-F-NEXT: lui t1, 265728
; QCI-F-NEXT: fmv.w.x fa1, a2
; QCI-F-NEXT: lui a3, 266240
; QCI-F-NEXT: fmv.w.x fa2, a4
; QCI-F-NEXT: li a0, 1
; QCI-F-NEXT: fmv.w.x fa3, a5
; QCI-F-NEXT: li a2, 2
; QCI-F-NEXT: fmv.w.x fa4, a1
; QCI-F-NEXT: li a4, 3
; QCI-F-NEXT: fmv.w.x fa5, a6
; QCI-F-NEXT: li a6, 4
; QCI-F-NEXT: fmv.w.x fa6, t1
; QCI-F-NEXT: fmv.w.x fa7, a3
; QCI-F-NEXT: sw t0, 0(sp)
; QCI-F-NEXT: sw a7, 4(sp)
; QCI-F-NEXT: li a1, 0
; QCI-F-NEXT: li a3, 0
; QCI-F-NEXT: li a5, 0
; QCI-F-NEXT: li a7, 0
; QCI-F-NEXT: call function_with_one_stack_arg
; QCI-F-NEXT: call use_float
; QCI-F-NEXT: sw s3, 124(s1)
; QCI-F-NEXT: sw s2, 120(s1)
; QCI-F-NEXT: sw s11, 116(s1)
; QCI-F-NEXT: sw s10, 112(s1)
; QCI-F-NEXT: sw s9, 108(s1)
; QCI-F-NEXT: sw s8, 104(s1)
; QCI-F-NEXT: sw s7, 100(s1)
; QCI-F-NEXT: sw s6, 96(s1)
; QCI-F-NEXT: sw s5, 92(s1)
; QCI-F-NEXT: sw s4, 88(s1)
; QCI-F-NEXT: lw a0, 12(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 84(s1)
; QCI-F-NEXT: lw a0, 16(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 80(s1)
; QCI-F-NEXT: lw a0, 20(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 76(s1)
; QCI-F-NEXT: lw a0, 24(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 72(s1)
; QCI-F-NEXT: lw a0, 28(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 68(s1)
; QCI-F-NEXT: lw a0, 32(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 64(s1)
; QCI-F-NEXT: lw a0, 36(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 60(s1)
; QCI-F-NEXT: lw a0, 40(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 56(s1)
; QCI-F-NEXT: lw a0, 44(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 52(s1)
; QCI-F-NEXT: lw a0, 48(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 48(s1)
; QCI-F-NEXT: lw a0, 52(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 44(s1)
; QCI-F-NEXT: lw a0, 56(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 40(s1)
; QCI-F-NEXT: lw a0, 60(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 36(s1)
; QCI-F-NEXT: lw a0, 64(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 32(s1)
; QCI-F-NEXT: lw a0, 68(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 28(s1)
; QCI-F-NEXT: lw a0, 72(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 24(s1)
; QCI-F-NEXT: lw a0, 76(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 20(s1)
; QCI-F-NEXT: lw a0, 80(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, 16(s1)
; QCI-F-NEXT: lw a0, 84(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, %lo(var+12)(s0)
; QCI-F-NEXT: lw a0, 88(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, %lo(var+8)(s0)
; QCI-F-NEXT: lw a0, 92(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, %lo(var+4)(s0)
; QCI-F-NEXT: lw a0, 96(sp) # 4-byte Folded Reload
; QCI-F-NEXT: sw a0, %lo(var)(s0)
; QCI-F-NEXT: lw s1, 220(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s2, 216(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s3, 212(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s4, 208(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s5, 204(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s6, 200(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s7, 196(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s8, 192(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s9, 188(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s10, 184(sp) # 4-byte Folded Reload
; QCI-F-NEXT: lw s11, 180(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft0, 176(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft1, 172(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft2, 168(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft3, 164(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft4, 160(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft5, 156(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft6, 152(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft7, 148(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa0, 144(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa1, 140(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa2, 136(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa3, 132(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa4, 128(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa5, 124(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa6, 120(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw fa7, 116(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft8, 112(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft9, 108(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft10, 104(sp) # 4-byte Folded Reload
; QCI-F-NEXT: flw ft11, 100(sp) # 4-byte Folded Reload
; QCI-F-NEXT: .cfi_restore s1
; QCI-F-NEXT: .cfi_restore s2
; QCI-F-NEXT: .cfi_restore s3
; QCI-F-NEXT: .cfi_restore s4
; QCI-F-NEXT: .cfi_restore s5
; QCI-F-NEXT: .cfi_restore s6
; QCI-F-NEXT: .cfi_restore s7
; QCI-F-NEXT: .cfi_restore s8
; QCI-F-NEXT: .cfi_restore s9
; QCI-F-NEXT: .cfi_restore s10
; QCI-F-NEXT: .cfi_restore s11
; QCI-F-NEXT: .cfi_restore ft0
; QCI-F-NEXT: .cfi_restore ft1
; QCI-F-NEXT: .cfi_restore ft2
; QCI-F-NEXT: .cfi_restore ft3
; QCI-F-NEXT: .cfi_restore ft4
; QCI-F-NEXT: .cfi_restore ft5
; QCI-F-NEXT: .cfi_restore ft6
; QCI-F-NEXT: .cfi_restore ft7
; QCI-F-NEXT: .cfi_restore fa0
; QCI-F-NEXT: .cfi_restore fa1
; QCI-F-NEXT: .cfi_restore fa2
; QCI-F-NEXT: .cfi_restore fa3
; QCI-F-NEXT: .cfi_restore fa4
; QCI-F-NEXT: .cfi_restore fa5
; QCI-F-NEXT: .cfi_restore fa6
; QCI-F-NEXT: .cfi_restore fa7
; QCI-F-NEXT: .cfi_restore ft8
; QCI-F-NEXT: .cfi_restore ft9
; QCI-F-NEXT: .cfi_restore ft10
; QCI-F-NEXT: .cfi_restore ft11
; QCI-F-NEXT: addi sp, sp, 224
; QCI-F-NEXT: .cfi_def_cfa_offset 96
; QCI-F-NEXT: qc.c.mileaveret
;
; QCI-D-LABEL: test_spill_call_nonest:
; QCI-D: # %bb.0:
; QCI-D-NEXT: qc.c.mienter
; QCI-D-NEXT: .cfi_def_cfa_offset 96
; QCI-D-NEXT: .cfi_offset ra, -16
; QCI-D-NEXT: .cfi_offset t0, -24
; QCI-D-NEXT: .cfi_offset t1, -28
; QCI-D-NEXT: .cfi_offset t2, -32
; QCI-D-NEXT: .cfi_offset s0, -8
; QCI-D-NEXT: .cfi_offset a0, -36
; QCI-D-NEXT: .cfi_offset a1, -40
; QCI-D-NEXT: .cfi_offset a2, -44
; QCI-D-NEXT: .cfi_offset a3, -48
; QCI-D-NEXT: .cfi_offset a4, -52
; QCI-D-NEXT: .cfi_offset a5, -56
; QCI-D-NEXT: .cfi_offset a6, -60
; QCI-D-NEXT: .cfi_offset a7, -64
; QCI-D-NEXT: .cfi_offset t3, -68
; QCI-D-NEXT: .cfi_offset t4, -72
; QCI-D-NEXT: .cfi_offset t5, -76
; QCI-D-NEXT: .cfi_offset t6, -80
; QCI-D-NEXT: addi sp, sp, -304
; QCI-D-NEXT: .cfi_def_cfa_offset 400
; QCI-D-NEXT: sw s1, 300(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s2, 296(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s3, 292(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s4, 288(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s5, 284(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s6, 280(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s7, 276(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s8, 272(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s9, 268(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s10, 264(sp) # 4-byte Folded Spill
; QCI-D-NEXT: sw s11, 260(sp) # 4-byte Folded Spill
; QCI-D-NEXT: fsd ft0, 248(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft1, 240(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft2, 232(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft3, 224(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft4, 216(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft5, 208(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft6, 200(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft7, 192(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa0, 184(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa1, 176(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa2, 168(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa3, 160(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa4, 152(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa5, 144(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa6, 136(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd fa7, 128(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft8, 120(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft9, 112(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft10, 104(sp) # 8-byte Folded Spill
; QCI-D-NEXT: fsd ft11, 96(sp) # 8-byte Folded Spill
; QCI-D-NEXT: .cfi_offset s1, -100
; QCI-D-NEXT: .cfi_offset s2, -104
; QCI-D-NEXT: .cfi_offset s3, -108
; QCI-D-NEXT: .cfi_offset s4, -112
; QCI-D-NEXT: .cfi_offset s5, -116
; QCI-D-NEXT: .cfi_offset s6, -120
; QCI-D-NEXT: .cfi_offset s7, -124
; QCI-D-NEXT: .cfi_offset s8, -128
; QCI-D-NEXT: .cfi_offset s9, -132
; QCI-D-NEXT: .cfi_offset s10, -136
; QCI-D-NEXT: .cfi_offset s11, -140
; QCI-D-NEXT: .cfi_offset ft0, -152
; QCI-D-NEXT: .cfi_offset ft1, -160
; QCI-D-NEXT: .cfi_offset ft2, -168
; QCI-D-NEXT: .cfi_offset ft3, -176
; QCI-D-NEXT: .cfi_offset ft4, -184
; QCI-D-NEXT: .cfi_offset ft5, -192
; QCI-D-NEXT: .cfi_offset ft6, -200
; QCI-D-NEXT: .cfi_offset ft7, -208
; QCI-D-NEXT: .cfi_offset fa0, -216
; QCI-D-NEXT: .cfi_offset fa1, -224
; QCI-D-NEXT: .cfi_offset fa2, -232
; QCI-D-NEXT: .cfi_offset fa3, -240
; QCI-D-NEXT: .cfi_offset fa4, -248
; QCI-D-NEXT: .cfi_offset fa5, -256
; QCI-D-NEXT: .cfi_offset fa6, -264
; QCI-D-NEXT: .cfi_offset fa7, -272
; QCI-D-NEXT: .cfi_offset ft8, -280
; QCI-D-NEXT: .cfi_offset ft9, -288
; QCI-D-NEXT: .cfi_offset ft10, -296
; QCI-D-NEXT: .cfi_offset ft11, -304
; QCI-D-NEXT: lui s0, %hi(var)
; QCI-D-NEXT: lw a0, %lo(var)(s0)
; QCI-D-NEXT: sw a0, 92(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, %lo(var+4)(s0)
; QCI-D-NEXT: sw a0, 88(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, %lo(var+8)(s0)
; QCI-D-NEXT: sw a0, 84(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, %lo(var+12)(s0)
; QCI-D-NEXT: sw a0, 80(sp) # 4-byte Folded Spill
; QCI-D-NEXT: addi s1, s0, %lo(var)
; QCI-D-NEXT: lw a0, 16(s1)
; QCI-D-NEXT: sw a0, 76(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 20(s1)
; QCI-D-NEXT: sw a0, 72(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 24(s1)
; QCI-D-NEXT: sw a0, 68(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 28(s1)
; QCI-D-NEXT: sw a0, 64(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 32(s1)
; QCI-D-NEXT: sw a0, 60(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 36(s1)
; QCI-D-NEXT: sw a0, 56(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 40(s1)
; QCI-D-NEXT: sw a0, 52(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 44(s1)
; QCI-D-NEXT: sw a0, 48(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 48(s1)
; QCI-D-NEXT: sw a0, 44(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 52(s1)
; QCI-D-NEXT: sw a0, 40(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 56(s1)
; QCI-D-NEXT: sw a0, 36(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 60(s1)
; QCI-D-NEXT: sw a0, 32(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 64(s1)
; QCI-D-NEXT: sw a0, 28(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 68(s1)
; QCI-D-NEXT: sw a0, 24(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 72(s1)
; QCI-D-NEXT: sw a0, 20(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 76(s1)
; QCI-D-NEXT: sw a0, 16(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 80(s1)
; QCI-D-NEXT: sw a0, 12(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw a0, 84(s1)
; QCI-D-NEXT: sw a0, 8(sp) # 4-byte Folded Spill
; QCI-D-NEXT: lw s4, 88(s1)
; QCI-D-NEXT: lw s5, 92(s1)
; QCI-D-NEXT: lw s6, 96(s1)
; QCI-D-NEXT: lw s7, 100(s1)
; QCI-D-NEXT: lw s8, 104(s1)
; QCI-D-NEXT: lw s9, 108(s1)
; QCI-D-NEXT: lw s10, 112(s1)
; QCI-D-NEXT: lw s11, 116(s1)
; QCI-D-NEXT: lw s2, 120(s1)
; QCI-D-NEXT: lw s3, 124(s1)
; QCI-D-NEXT: lui a7, 266496
; QCI-D-NEXT: li t0, 5
; QCI-D-NEXT: lui a0, 260096
; QCI-D-NEXT: lui a2, 262144
; QCI-D-NEXT: lui a4, 263168
; QCI-D-NEXT: lui a5, 264192
; QCI-D-NEXT: lui a1, 264704
; QCI-D-NEXT: lui a6, 265216
; QCI-D-NEXT: fmv.w.x fa0, a0
; QCI-D-NEXT: lui t1, 265728
; QCI-D-NEXT: fmv.w.x fa1, a2
; QCI-D-NEXT: lui a3, 266240
; QCI-D-NEXT: fmv.w.x fa2, a4
; QCI-D-NEXT: li a0, 1
; QCI-D-NEXT: fmv.w.x fa3, a5
; QCI-D-NEXT: li a2, 2
; QCI-D-NEXT: fmv.w.x fa4, a1
; QCI-D-NEXT: li a4, 3
; QCI-D-NEXT: fmv.w.x fa5, a6
; QCI-D-NEXT: li a6, 4
; QCI-D-NEXT: fmv.w.x fa6, t1
; QCI-D-NEXT: fmv.w.x fa7, a3
; QCI-D-NEXT: sw t0, 0(sp)
; QCI-D-NEXT: sw a7, 4(sp)
; QCI-D-NEXT: li a1, 0
; QCI-D-NEXT: li a3, 0
; QCI-D-NEXT: li a5, 0
; QCI-D-NEXT: li a7, 0
; QCI-D-NEXT: call function_with_one_stack_arg
; QCI-D-NEXT: call use_float
; QCI-D-NEXT: sw s3, 124(s1)
; QCI-D-NEXT: sw s2, 120(s1)
; QCI-D-NEXT: sw s11, 116(s1)
; QCI-D-NEXT: sw s10, 112(s1)
; QCI-D-NEXT: sw s9, 108(s1)
; QCI-D-NEXT: sw s8, 104(s1)
; QCI-D-NEXT: sw s7, 100(s1)
; QCI-D-NEXT: sw s6, 96(s1)
; QCI-D-NEXT: sw s5, 92(s1)
; QCI-D-NEXT: sw s4, 88(s1)
; QCI-D-NEXT: lw a0, 8(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 84(s1)
; QCI-D-NEXT: lw a0, 12(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 80(s1)
; QCI-D-NEXT: lw a0, 16(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 76(s1)
; QCI-D-NEXT: lw a0, 20(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 72(s1)
; QCI-D-NEXT: lw a0, 24(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 68(s1)
; QCI-D-NEXT: lw a0, 28(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 64(s1)
; QCI-D-NEXT: lw a0, 32(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 60(s1)
; QCI-D-NEXT: lw a0, 36(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 56(s1)
; QCI-D-NEXT: lw a0, 40(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 52(s1)
; QCI-D-NEXT: lw a0, 44(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 48(s1)
; QCI-D-NEXT: lw a0, 48(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 44(s1)
; QCI-D-NEXT: lw a0, 52(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 40(s1)
; QCI-D-NEXT: lw a0, 56(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 36(s1)
; QCI-D-NEXT: lw a0, 60(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 32(s1)
; QCI-D-NEXT: lw a0, 64(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 28(s1)
; QCI-D-NEXT: lw a0, 68(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 24(s1)
; QCI-D-NEXT: lw a0, 72(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 20(s1)
; QCI-D-NEXT: lw a0, 76(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, 16(s1)
; QCI-D-NEXT: lw a0, 80(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, %lo(var+12)(s0)
; QCI-D-NEXT: lw a0, 84(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, %lo(var+8)(s0)
; QCI-D-NEXT: lw a0, 88(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, %lo(var+4)(s0)
; QCI-D-NEXT: lw a0, 92(sp) # 4-byte Folded Reload
; QCI-D-NEXT: sw a0, %lo(var)(s0)
; QCI-D-NEXT: lw s1, 300(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s2, 296(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s3, 292(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s4, 288(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s5, 284(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s6, 280(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s7, 276(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s8, 272(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s9, 268(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s10, 264(sp) # 4-byte Folded Reload
; QCI-D-NEXT: lw s11, 260(sp) # 4-byte Folded Reload
; QCI-D-NEXT: fld ft0, 248(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft1, 240(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft2, 232(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft3, 224(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft4, 216(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft5, 208(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft6, 200(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft7, 192(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa0, 184(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa1, 176(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa2, 168(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa3, 160(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa4, 152(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa5, 144(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa6, 136(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld fa7, 128(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft8, 120(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft9, 112(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft10, 104(sp) # 8-byte Folded Reload
; QCI-D-NEXT: fld ft11, 96(sp) # 8-byte Folded Reload
; QCI-D-NEXT: .cfi_restore s1
; QCI-D-NEXT: .cfi_restore s2
; QCI-D-NEXT: .cfi_restore s3
; QCI-D-NEXT: .cfi_restore s4
; QCI-D-NEXT: .cfi_restore s5
; QCI-D-NEXT: .cfi_restore s6
; QCI-D-NEXT: .cfi_restore s7
; QCI-D-NEXT: .cfi_restore s8
; QCI-D-NEXT: .cfi_restore s9
; QCI-D-NEXT: .cfi_restore s10
; QCI-D-NEXT: .cfi_restore s11
; QCI-D-NEXT: .cfi_restore ft0
; QCI-D-NEXT: .cfi_restore ft1
; QCI-D-NEXT: .cfi_restore ft2
; QCI-D-NEXT: .cfi_restore ft3
; QCI-D-NEXT: .cfi_restore ft4
; QCI-D-NEXT: .cfi_restore ft5
; QCI-D-NEXT: .cfi_restore ft6
; QCI-D-NEXT: .cfi_restore ft7
; QCI-D-NEXT: .cfi_restore fa0
; QCI-D-NEXT: .cfi_restore fa1
; QCI-D-NEXT: .cfi_restore fa2
; QCI-D-NEXT: .cfi_restore fa3
; QCI-D-NEXT: .cfi_restore fa4
; QCI-D-NEXT: .cfi_restore fa5
; QCI-D-NEXT: .cfi_restore fa6
; QCI-D-NEXT: .cfi_restore fa7
; QCI-D-NEXT: .cfi_restore ft8
; QCI-D-NEXT: .cfi_restore ft9
; QCI-D-NEXT: .cfi_restore ft10
; QCI-D-NEXT: .cfi_restore ft11
; QCI-D-NEXT: addi sp, sp, 304
; QCI-D-NEXT: .cfi_def_cfa_offset 96
; QCI-D-NEXT: qc.c.mileaveret
%1 = load [32 x i32], ptr @var
%2 = call float @function_with_one_stack_arg(i64 1, i64 2, i64 3, i64 4, float 1.0, float 2.0, float 3.0, float 4.0, float 5.0, float 6.0, float 7.0, float 8.0, i32 5, float 9.0)
call void @use_float(float %2)
store volatile [32 x i32] %1, ptr @var
ret void
}