
This patch adds CFI instructions in the function epilogue. Before patch: addi sp, s0, -32 ld ra, 24(sp) # 8-byte Folded Reload ld s0, 16(sp) # 8-byte Folded Reload ld s1, 8(sp) # 8-byte Folded Reload addi sp, sp, 32 ret After patch: addi sp, s0, -32 .cfi_def_cfa sp, 32 ld ra, 24(sp) # 8-byte Folded Reload ld s0, 16(sp) # 8-byte Folded Reload ld s1, 8(sp) # 8-byte Folded Reload .cfi_restore ra .cfi_restore s0 .cfi_restore s1 addi sp, sp, 32 .cfi_def_cfa_offset 0 ret This functionality is already present in `riscv-gcc`, but it’s not in `clang` and this slightly impairs the `lldb` debugging experience, e.g. backtrace.
615 lines
20 KiB
LLVM
615 lines
20 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
|
; RUN: llc -mtriple=riscv32 -verify-machineinstrs < %s \
|
|
; RUN: | FileCheck %s -check-prefixes=RV32,RV32I
|
|
; RUN: llc -mtriple=riscv32 -verify-machineinstrs -mattr=+zba < %s \
|
|
; RUN: | FileCheck %s -check-prefixes=RV32,RV32ZBA
|
|
; RUN: llc -mtriple=riscv64 -verify-machineinstrs < %s \
|
|
; RUN: | FileCheck %s -check-prefixes=RV64,RV64I
|
|
; RUN: llc -mtriple=riscv64 -verify-machineinstrs -mattr=+zba < %s \
|
|
; RUN: | FileCheck %s -check-prefixes=RV64,RV64ZBA
|
|
|
|
declare void @callee(ptr)
|
|
|
|
define void @frame_16b() {
|
|
; RV32-LABEL: frame_16b:
|
|
; RV32: # %bb.0:
|
|
; RV32-NEXT: addi sp, sp, -16
|
|
; RV32-NEXT: .cfi_def_cfa_offset 16
|
|
; RV32-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
|
|
; RV32-NEXT: .cfi_offset ra, -4
|
|
; RV32-NEXT: li a0, 0
|
|
; RV32-NEXT: call callee
|
|
; RV32-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
|
|
; RV32-NEXT: .cfi_restore ra
|
|
; RV32-NEXT: addi sp, sp, 16
|
|
; RV32-NEXT: .cfi_def_cfa_offset 0
|
|
; RV32-NEXT: ret
|
|
;
|
|
; RV64-LABEL: frame_16b:
|
|
; RV64: # %bb.0:
|
|
; RV64-NEXT: addi sp, sp, -16
|
|
; RV64-NEXT: .cfi_def_cfa_offset 16
|
|
; RV64-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
|
|
; RV64-NEXT: .cfi_offset ra, -8
|
|
; RV64-NEXT: li a0, 0
|
|
; RV64-NEXT: call callee
|
|
; RV64-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
|
|
; RV64-NEXT: .cfi_restore ra
|
|
; RV64-NEXT: addi sp, sp, 16
|
|
; RV64-NEXT: .cfi_def_cfa_offset 0
|
|
; RV64-NEXT: ret
|
|
call void @callee(ptr null)
|
|
ret void
|
|
}
|
|
|
|
define void @frame_1024b() {
|
|
; RV32-LABEL: frame_1024b:
|
|
; RV32: # %bb.0:
|
|
; RV32-NEXT: addi sp, sp, -1024
|
|
; RV32-NEXT: .cfi_def_cfa_offset 1024
|
|
; RV32-NEXT: sw ra, 1020(sp) # 4-byte Folded Spill
|
|
; RV32-NEXT: .cfi_offset ra, -4
|
|
; RV32-NEXT: addi a0, sp, 12
|
|
; RV32-NEXT: call callee
|
|
; RV32-NEXT: lw ra, 1020(sp) # 4-byte Folded Reload
|
|
; RV32-NEXT: .cfi_restore ra
|
|
; RV32-NEXT: addi sp, sp, 1024
|
|
; RV32-NEXT: .cfi_def_cfa_offset 0
|
|
; RV32-NEXT: ret
|
|
;
|
|
; RV64-LABEL: frame_1024b:
|
|
; RV64: # %bb.0:
|
|
; RV64-NEXT: addi sp, sp, -1024
|
|
; RV64-NEXT: .cfi_def_cfa_offset 1024
|
|
; RV64-NEXT: sd ra, 1016(sp) # 8-byte Folded Spill
|
|
; RV64-NEXT: .cfi_offset ra, -8
|
|
; RV64-NEXT: addi a0, sp, 8
|
|
; RV64-NEXT: call callee
|
|
; RV64-NEXT: ld ra, 1016(sp) # 8-byte Folded Reload
|
|
; RV64-NEXT: .cfi_restore ra
|
|
; RV64-NEXT: addi sp, sp, 1024
|
|
; RV64-NEXT: .cfi_def_cfa_offset 0
|
|
; RV64-NEXT: ret
|
|
%a = alloca [1008 x i8]
|
|
call void @callee(ptr %a)
|
|
ret void
|
|
}
|
|
|
|
define void @frame_2048b() {
|
|
; RV32-LABEL: frame_2048b:
|
|
; RV32: # %bb.0:
|
|
; RV32-NEXT: addi sp, sp, -2032
|
|
; RV32-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32-NEXT: sw ra, 2028(sp) # 4-byte Folded Spill
|
|
; RV32-NEXT: .cfi_offset ra, -4
|
|
; RV32-NEXT: addi sp, sp, -16
|
|
; RV32-NEXT: .cfi_def_cfa_offset 2048
|
|
; RV32-NEXT: addi a0, sp, 12
|
|
; RV32-NEXT: call callee
|
|
; RV32-NEXT: addi sp, sp, 16
|
|
; RV32-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32-NEXT: lw ra, 2028(sp) # 4-byte Folded Reload
|
|
; RV32-NEXT: .cfi_restore ra
|
|
; RV32-NEXT: addi sp, sp, 2032
|
|
; RV32-NEXT: .cfi_def_cfa_offset 0
|
|
; RV32-NEXT: ret
|
|
;
|
|
; RV64-LABEL: frame_2048b:
|
|
; RV64: # %bb.0:
|
|
; RV64-NEXT: addi sp, sp, -2032
|
|
; RV64-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64-NEXT: sd ra, 2024(sp) # 8-byte Folded Spill
|
|
; RV64-NEXT: .cfi_offset ra, -8
|
|
; RV64-NEXT: addi sp, sp, -16
|
|
; RV64-NEXT: .cfi_def_cfa_offset 2048
|
|
; RV64-NEXT: addi a0, sp, 8
|
|
; RV64-NEXT: call callee
|
|
; RV64-NEXT: addi sp, sp, 16
|
|
; RV64-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64-NEXT: ld ra, 2024(sp) # 8-byte Folded Reload
|
|
; RV64-NEXT: .cfi_restore ra
|
|
; RV64-NEXT: addi sp, sp, 2032
|
|
; RV64-NEXT: .cfi_def_cfa_offset 0
|
|
; RV64-NEXT: ret
|
|
%a = alloca [2032 x i8]
|
|
call void @callee(ptr %a)
|
|
ret void
|
|
}
|
|
|
|
define void @frame_4096b() {
|
|
; RV32-LABEL: frame_4096b:
|
|
; RV32: # %bb.0:
|
|
; RV32-NEXT: addi sp, sp, -2032
|
|
; RV32-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32-NEXT: sw ra, 2028(sp) # 4-byte Folded Spill
|
|
; RV32-NEXT: .cfi_offset ra, -4
|
|
; RV32-NEXT: addi sp, sp, -2048
|
|
; RV32-NEXT: addi sp, sp, -16
|
|
; RV32-NEXT: .cfi_def_cfa_offset 4096
|
|
; RV32-NEXT: addi a0, sp, 12
|
|
; RV32-NEXT: call callee
|
|
; RV32-NEXT: addi sp, sp, 2032
|
|
; RV32-NEXT: addi sp, sp, 32
|
|
; RV32-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32-NEXT: lw ra, 2028(sp) # 4-byte Folded Reload
|
|
; RV32-NEXT: .cfi_restore ra
|
|
; RV32-NEXT: addi sp, sp, 2032
|
|
; RV32-NEXT: .cfi_def_cfa_offset 0
|
|
; RV32-NEXT: ret
|
|
;
|
|
; RV64-LABEL: frame_4096b:
|
|
; RV64: # %bb.0:
|
|
; RV64-NEXT: addi sp, sp, -2032
|
|
; RV64-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64-NEXT: sd ra, 2024(sp) # 8-byte Folded Spill
|
|
; RV64-NEXT: .cfi_offset ra, -8
|
|
; RV64-NEXT: addi sp, sp, -2048
|
|
; RV64-NEXT: addi sp, sp, -16
|
|
; RV64-NEXT: .cfi_def_cfa_offset 4096
|
|
; RV64-NEXT: addi a0, sp, 8
|
|
; RV64-NEXT: call callee
|
|
; RV64-NEXT: addi sp, sp, 2032
|
|
; RV64-NEXT: addi sp, sp, 32
|
|
; RV64-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64-NEXT: ld ra, 2024(sp) # 8-byte Folded Reload
|
|
; RV64-NEXT: .cfi_restore ra
|
|
; RV64-NEXT: addi sp, sp, 2032
|
|
; RV64-NEXT: .cfi_def_cfa_offset 0
|
|
; RV64-NEXT: ret
|
|
%a = alloca [4080 x i8]
|
|
call void @callee(ptr %a)
|
|
ret void
|
|
}
|
|
|
|
;; 2^12-16+2032
|
|
define void @frame_4kb() {
|
|
; RV32-LABEL: frame_4kb:
|
|
; RV32: # %bb.0:
|
|
; RV32-NEXT: addi sp, sp, -2032
|
|
; RV32-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32-NEXT: sw ra, 2028(sp) # 4-byte Folded Spill
|
|
; RV32-NEXT: .cfi_offset ra, -4
|
|
; RV32-NEXT: lui a0, 1
|
|
; RV32-NEXT: sub sp, sp, a0
|
|
; RV32-NEXT: .cfi_def_cfa_offset 6128
|
|
; RV32-NEXT: addi a0, sp, 12
|
|
; RV32-NEXT: call callee
|
|
; RV32-NEXT: lui a0, 1
|
|
; RV32-NEXT: add sp, sp, a0
|
|
; RV32-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32-NEXT: lw ra, 2028(sp) # 4-byte Folded Reload
|
|
; RV32-NEXT: .cfi_restore ra
|
|
; RV32-NEXT: addi sp, sp, 2032
|
|
; RV32-NEXT: .cfi_def_cfa_offset 0
|
|
; RV32-NEXT: ret
|
|
;
|
|
; RV64-LABEL: frame_4kb:
|
|
; RV64: # %bb.0:
|
|
; RV64-NEXT: addi sp, sp, -2032
|
|
; RV64-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64-NEXT: sd ra, 2024(sp) # 8-byte Folded Spill
|
|
; RV64-NEXT: .cfi_offset ra, -8
|
|
; RV64-NEXT: lui a0, 1
|
|
; RV64-NEXT: sub sp, sp, a0
|
|
; RV64-NEXT: .cfi_def_cfa_offset 6128
|
|
; RV64-NEXT: addi a0, sp, 8
|
|
; RV64-NEXT: call callee
|
|
; RV64-NEXT: lui a0, 1
|
|
; RV64-NEXT: add sp, sp, a0
|
|
; RV64-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64-NEXT: ld ra, 2024(sp) # 8-byte Folded Reload
|
|
; RV64-NEXT: .cfi_restore ra
|
|
; RV64-NEXT: addi sp, sp, 2032
|
|
; RV64-NEXT: .cfi_def_cfa_offset 0
|
|
; RV64-NEXT: ret
|
|
%a = alloca [6112 x i8]
|
|
call void @callee(ptr %a)
|
|
ret void
|
|
}
|
|
|
|
define void @frame_4kb_offset_128() {
|
|
; RV32I-LABEL: frame_4kb_offset_128:
|
|
; RV32I: # %bb.0:
|
|
; RV32I-NEXT: addi sp, sp, -2032
|
|
; RV32I-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32I-NEXT: sw ra, 2028(sp) # 4-byte Folded Spill
|
|
; RV32I-NEXT: .cfi_offset ra, -4
|
|
; RV32I-NEXT: lui a0, 1
|
|
; RV32I-NEXT: addi a0, a0, 128
|
|
; RV32I-NEXT: sub sp, sp, a0
|
|
; RV32I-NEXT: .cfi_def_cfa_offset 6256
|
|
; RV32I-NEXT: addi a0, sp, 12
|
|
; RV32I-NEXT: call callee
|
|
; RV32I-NEXT: lui a0, 1
|
|
; RV32I-NEXT: addi a0, a0, 128
|
|
; RV32I-NEXT: add sp, sp, a0
|
|
; RV32I-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32I-NEXT: lw ra, 2028(sp) # 4-byte Folded Reload
|
|
; RV32I-NEXT: .cfi_restore ra
|
|
; RV32I-NEXT: addi sp, sp, 2032
|
|
; RV32I-NEXT: .cfi_def_cfa_offset 0
|
|
; RV32I-NEXT: ret
|
|
;
|
|
; RV32ZBA-LABEL: frame_4kb_offset_128:
|
|
; RV32ZBA: # %bb.0:
|
|
; RV32ZBA-NEXT: addi sp, sp, -2032
|
|
; RV32ZBA-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32ZBA-NEXT: sw ra, 2028(sp) # 4-byte Folded Spill
|
|
; RV32ZBA-NEXT: .cfi_offset ra, -4
|
|
; RV32ZBA-NEXT: li a0, -528
|
|
; RV32ZBA-NEXT: sh3add sp, a0, sp
|
|
; RV32ZBA-NEXT: .cfi_def_cfa_offset 6256
|
|
; RV32ZBA-NEXT: addi a0, sp, 12
|
|
; RV32ZBA-NEXT: call callee
|
|
; RV32ZBA-NEXT: li a0, 528
|
|
; RV32ZBA-NEXT: sh3add sp, a0, sp
|
|
; RV32ZBA-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32ZBA-NEXT: lw ra, 2028(sp) # 4-byte Folded Reload
|
|
; RV32ZBA-NEXT: .cfi_restore ra
|
|
; RV32ZBA-NEXT: addi sp, sp, 2032
|
|
; RV32ZBA-NEXT: .cfi_def_cfa_offset 0
|
|
; RV32ZBA-NEXT: ret
|
|
;
|
|
; RV64I-LABEL: frame_4kb_offset_128:
|
|
; RV64I: # %bb.0:
|
|
; RV64I-NEXT: addi sp, sp, -2032
|
|
; RV64I-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64I-NEXT: sd ra, 2024(sp) # 8-byte Folded Spill
|
|
; RV64I-NEXT: .cfi_offset ra, -8
|
|
; RV64I-NEXT: lui a0, 1
|
|
; RV64I-NEXT: addiw a0, a0, 128
|
|
; RV64I-NEXT: sub sp, sp, a0
|
|
; RV64I-NEXT: .cfi_def_cfa_offset 6256
|
|
; RV64I-NEXT: addi a0, sp, 8
|
|
; RV64I-NEXT: call callee
|
|
; RV64I-NEXT: lui a0, 1
|
|
; RV64I-NEXT: addiw a0, a0, 128
|
|
; RV64I-NEXT: add sp, sp, a0
|
|
; RV64I-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64I-NEXT: ld ra, 2024(sp) # 8-byte Folded Reload
|
|
; RV64I-NEXT: .cfi_restore ra
|
|
; RV64I-NEXT: addi sp, sp, 2032
|
|
; RV64I-NEXT: .cfi_def_cfa_offset 0
|
|
; RV64I-NEXT: ret
|
|
;
|
|
; RV64ZBA-LABEL: frame_4kb_offset_128:
|
|
; RV64ZBA: # %bb.0:
|
|
; RV64ZBA-NEXT: addi sp, sp, -2032
|
|
; RV64ZBA-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64ZBA-NEXT: sd ra, 2024(sp) # 8-byte Folded Spill
|
|
; RV64ZBA-NEXT: .cfi_offset ra, -8
|
|
; RV64ZBA-NEXT: li a0, -528
|
|
; RV64ZBA-NEXT: sh3add sp, a0, sp
|
|
; RV64ZBA-NEXT: .cfi_def_cfa_offset 6256
|
|
; RV64ZBA-NEXT: addi a0, sp, 8
|
|
; RV64ZBA-NEXT: call callee
|
|
; RV64ZBA-NEXT: li a0, 528
|
|
; RV64ZBA-NEXT: sh3add sp, a0, sp
|
|
; RV64ZBA-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64ZBA-NEXT: ld ra, 2024(sp) # 8-byte Folded Reload
|
|
; RV64ZBA-NEXT: .cfi_restore ra
|
|
; RV64ZBA-NEXT: addi sp, sp, 2032
|
|
; RV64ZBA-NEXT: .cfi_def_cfa_offset 0
|
|
; RV64ZBA-NEXT: ret
|
|
%a = alloca [6240 x i8]
|
|
call void @callee(ptr %a)
|
|
ret void
|
|
}
|
|
|
|
|
|
;; 2^13-16+2032
|
|
define void @frame_8kb() {
|
|
; RV32-LABEL: frame_8kb:
|
|
; RV32: # %bb.0:
|
|
; RV32-NEXT: addi sp, sp, -2032
|
|
; RV32-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32-NEXT: sw ra, 2028(sp) # 4-byte Folded Spill
|
|
; RV32-NEXT: .cfi_offset ra, -4
|
|
; RV32-NEXT: lui a0, 2
|
|
; RV32-NEXT: sub sp, sp, a0
|
|
; RV32-NEXT: .cfi_def_cfa_offset 10224
|
|
; RV32-NEXT: addi a0, sp, 12
|
|
; RV32-NEXT: call callee
|
|
; RV32-NEXT: lui a0, 2
|
|
; RV32-NEXT: add sp, sp, a0
|
|
; RV32-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32-NEXT: lw ra, 2028(sp) # 4-byte Folded Reload
|
|
; RV32-NEXT: .cfi_restore ra
|
|
; RV32-NEXT: addi sp, sp, 2032
|
|
; RV32-NEXT: .cfi_def_cfa_offset 0
|
|
; RV32-NEXT: ret
|
|
;
|
|
; RV64-LABEL: frame_8kb:
|
|
; RV64: # %bb.0:
|
|
; RV64-NEXT: addi sp, sp, -2032
|
|
; RV64-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64-NEXT: sd ra, 2024(sp) # 8-byte Folded Spill
|
|
; RV64-NEXT: .cfi_offset ra, -8
|
|
; RV64-NEXT: lui a0, 2
|
|
; RV64-NEXT: sub sp, sp, a0
|
|
; RV64-NEXT: .cfi_def_cfa_offset 10224
|
|
; RV64-NEXT: addi a0, sp, 8
|
|
; RV64-NEXT: call callee
|
|
; RV64-NEXT: lui a0, 2
|
|
; RV64-NEXT: add sp, sp, a0
|
|
; RV64-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64-NEXT: ld ra, 2024(sp) # 8-byte Folded Reload
|
|
; RV64-NEXT: .cfi_restore ra
|
|
; RV64-NEXT: addi sp, sp, 2032
|
|
; RV64-NEXT: .cfi_def_cfa_offset 0
|
|
; RV64-NEXT: ret
|
|
%a = alloca [10208 x i8]
|
|
call void @callee(ptr %a)
|
|
ret void
|
|
}
|
|
|
|
define void @frame_8kb_offset_128() {
|
|
; RV32I-LABEL: frame_8kb_offset_128:
|
|
; RV32I: # %bb.0:
|
|
; RV32I-NEXT: addi sp, sp, -2032
|
|
; RV32I-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32I-NEXT: sw ra, 2028(sp) # 4-byte Folded Spill
|
|
; RV32I-NEXT: .cfi_offset ra, -4
|
|
; RV32I-NEXT: lui a0, 2
|
|
; RV32I-NEXT: addi a0, a0, 128
|
|
; RV32I-NEXT: sub sp, sp, a0
|
|
; RV32I-NEXT: .cfi_def_cfa_offset 10352
|
|
; RV32I-NEXT: addi a0, sp, 12
|
|
; RV32I-NEXT: call callee
|
|
; RV32I-NEXT: lui a0, 2
|
|
; RV32I-NEXT: addi a0, a0, 128
|
|
; RV32I-NEXT: add sp, sp, a0
|
|
; RV32I-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32I-NEXT: lw ra, 2028(sp) # 4-byte Folded Reload
|
|
; RV32I-NEXT: .cfi_restore ra
|
|
; RV32I-NEXT: addi sp, sp, 2032
|
|
; RV32I-NEXT: .cfi_def_cfa_offset 0
|
|
; RV32I-NEXT: ret
|
|
;
|
|
; RV32ZBA-LABEL: frame_8kb_offset_128:
|
|
; RV32ZBA: # %bb.0:
|
|
; RV32ZBA-NEXT: addi sp, sp, -2032
|
|
; RV32ZBA-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32ZBA-NEXT: sw ra, 2028(sp) # 4-byte Folded Spill
|
|
; RV32ZBA-NEXT: .cfi_offset ra, -4
|
|
; RV32ZBA-NEXT: li a0, -1040
|
|
; RV32ZBA-NEXT: sh3add sp, a0, sp
|
|
; RV32ZBA-NEXT: .cfi_def_cfa_offset 10352
|
|
; RV32ZBA-NEXT: addi a0, sp, 12
|
|
; RV32ZBA-NEXT: call callee
|
|
; RV32ZBA-NEXT: li a0, 1040
|
|
; RV32ZBA-NEXT: sh3add sp, a0, sp
|
|
; RV32ZBA-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32ZBA-NEXT: lw ra, 2028(sp) # 4-byte Folded Reload
|
|
; RV32ZBA-NEXT: .cfi_restore ra
|
|
; RV32ZBA-NEXT: addi sp, sp, 2032
|
|
; RV32ZBA-NEXT: .cfi_def_cfa_offset 0
|
|
; RV32ZBA-NEXT: ret
|
|
;
|
|
; RV64I-LABEL: frame_8kb_offset_128:
|
|
; RV64I: # %bb.0:
|
|
; RV64I-NEXT: addi sp, sp, -2032
|
|
; RV64I-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64I-NEXT: sd ra, 2024(sp) # 8-byte Folded Spill
|
|
; RV64I-NEXT: .cfi_offset ra, -8
|
|
; RV64I-NEXT: lui a0, 2
|
|
; RV64I-NEXT: addiw a0, a0, 128
|
|
; RV64I-NEXT: sub sp, sp, a0
|
|
; RV64I-NEXT: .cfi_def_cfa_offset 10352
|
|
; RV64I-NEXT: addi a0, sp, 8
|
|
; RV64I-NEXT: call callee
|
|
; RV64I-NEXT: lui a0, 2
|
|
; RV64I-NEXT: addiw a0, a0, 128
|
|
; RV64I-NEXT: add sp, sp, a0
|
|
; RV64I-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64I-NEXT: ld ra, 2024(sp) # 8-byte Folded Reload
|
|
; RV64I-NEXT: .cfi_restore ra
|
|
; RV64I-NEXT: addi sp, sp, 2032
|
|
; RV64I-NEXT: .cfi_def_cfa_offset 0
|
|
; RV64I-NEXT: ret
|
|
;
|
|
; RV64ZBA-LABEL: frame_8kb_offset_128:
|
|
; RV64ZBA: # %bb.0:
|
|
; RV64ZBA-NEXT: addi sp, sp, -2032
|
|
; RV64ZBA-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64ZBA-NEXT: sd ra, 2024(sp) # 8-byte Folded Spill
|
|
; RV64ZBA-NEXT: .cfi_offset ra, -8
|
|
; RV64ZBA-NEXT: li a0, -1040
|
|
; RV64ZBA-NEXT: sh3add sp, a0, sp
|
|
; RV64ZBA-NEXT: .cfi_def_cfa_offset 10352
|
|
; RV64ZBA-NEXT: addi a0, sp, 8
|
|
; RV64ZBA-NEXT: call callee
|
|
; RV64ZBA-NEXT: li a0, 1040
|
|
; RV64ZBA-NEXT: sh3add sp, a0, sp
|
|
; RV64ZBA-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64ZBA-NEXT: ld ra, 2024(sp) # 8-byte Folded Reload
|
|
; RV64ZBA-NEXT: .cfi_restore ra
|
|
; RV64ZBA-NEXT: addi sp, sp, 2032
|
|
; RV64ZBA-NEXT: .cfi_def_cfa_offset 0
|
|
; RV64ZBA-NEXT: ret
|
|
%a = alloca [10336 x i8]
|
|
call void @callee(ptr %a)
|
|
ret void
|
|
}
|
|
|
|
define void @frame_16kb_minus_80() {
|
|
; RV32I-LABEL: frame_16kb_minus_80:
|
|
; RV32I: # %bb.0:
|
|
; RV32I-NEXT: addi sp, sp, -2032
|
|
; RV32I-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32I-NEXT: sw ra, 2028(sp) # 4-byte Folded Spill
|
|
; RV32I-NEXT: .cfi_offset ra, -4
|
|
; RV32I-NEXT: lui a0, 4
|
|
; RV32I-NEXT: addi a0, a0, -80
|
|
; RV32I-NEXT: sub sp, sp, a0
|
|
; RV32I-NEXT: .cfi_def_cfa_offset 18336
|
|
; RV32I-NEXT: addi a0, sp, 12
|
|
; RV32I-NEXT: call callee
|
|
; RV32I-NEXT: lui a0, 4
|
|
; RV32I-NEXT: addi a0, a0, -80
|
|
; RV32I-NEXT: add sp, sp, a0
|
|
; RV32I-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32I-NEXT: lw ra, 2028(sp) # 4-byte Folded Reload
|
|
; RV32I-NEXT: .cfi_restore ra
|
|
; RV32I-NEXT: addi sp, sp, 2032
|
|
; RV32I-NEXT: .cfi_def_cfa_offset 0
|
|
; RV32I-NEXT: ret
|
|
;
|
|
; RV32ZBA-LABEL: frame_16kb_minus_80:
|
|
; RV32ZBA: # %bb.0:
|
|
; RV32ZBA-NEXT: addi sp, sp, -2032
|
|
; RV32ZBA-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32ZBA-NEXT: sw ra, 2028(sp) # 4-byte Folded Spill
|
|
; RV32ZBA-NEXT: .cfi_offset ra, -4
|
|
; RV32ZBA-NEXT: li a0, -2038
|
|
; RV32ZBA-NEXT: sh3add sp, a0, sp
|
|
; RV32ZBA-NEXT: .cfi_def_cfa_offset 18336
|
|
; RV32ZBA-NEXT: addi a0, sp, 12
|
|
; RV32ZBA-NEXT: call callee
|
|
; RV32ZBA-NEXT: li a0, 2038
|
|
; RV32ZBA-NEXT: sh3add sp, a0, sp
|
|
; RV32ZBA-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32ZBA-NEXT: lw ra, 2028(sp) # 4-byte Folded Reload
|
|
; RV32ZBA-NEXT: .cfi_restore ra
|
|
; RV32ZBA-NEXT: addi sp, sp, 2032
|
|
; RV32ZBA-NEXT: .cfi_def_cfa_offset 0
|
|
; RV32ZBA-NEXT: ret
|
|
;
|
|
; RV64I-LABEL: frame_16kb_minus_80:
|
|
; RV64I: # %bb.0:
|
|
; RV64I-NEXT: addi sp, sp, -2032
|
|
; RV64I-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64I-NEXT: sd ra, 2024(sp) # 8-byte Folded Spill
|
|
; RV64I-NEXT: .cfi_offset ra, -8
|
|
; RV64I-NEXT: lui a0, 4
|
|
; RV64I-NEXT: addiw a0, a0, -80
|
|
; RV64I-NEXT: sub sp, sp, a0
|
|
; RV64I-NEXT: .cfi_def_cfa_offset 18336
|
|
; RV64I-NEXT: addi a0, sp, 8
|
|
; RV64I-NEXT: call callee
|
|
; RV64I-NEXT: lui a0, 4
|
|
; RV64I-NEXT: addiw a0, a0, -80
|
|
; RV64I-NEXT: add sp, sp, a0
|
|
; RV64I-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64I-NEXT: ld ra, 2024(sp) # 8-byte Folded Reload
|
|
; RV64I-NEXT: .cfi_restore ra
|
|
; RV64I-NEXT: addi sp, sp, 2032
|
|
; RV64I-NEXT: .cfi_def_cfa_offset 0
|
|
; RV64I-NEXT: ret
|
|
;
|
|
; RV64ZBA-LABEL: frame_16kb_minus_80:
|
|
; RV64ZBA: # %bb.0:
|
|
; RV64ZBA-NEXT: addi sp, sp, -2032
|
|
; RV64ZBA-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64ZBA-NEXT: sd ra, 2024(sp) # 8-byte Folded Spill
|
|
; RV64ZBA-NEXT: .cfi_offset ra, -8
|
|
; RV64ZBA-NEXT: li a0, -2038
|
|
; RV64ZBA-NEXT: sh3add sp, a0, sp
|
|
; RV64ZBA-NEXT: .cfi_def_cfa_offset 18336
|
|
; RV64ZBA-NEXT: addi a0, sp, 8
|
|
; RV64ZBA-NEXT: call callee
|
|
; RV64ZBA-NEXT: li a0, 2038
|
|
; RV64ZBA-NEXT: sh3add sp, a0, sp
|
|
; RV64ZBA-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64ZBA-NEXT: ld ra, 2024(sp) # 8-byte Folded Reload
|
|
; RV64ZBA-NEXT: .cfi_restore ra
|
|
; RV64ZBA-NEXT: addi sp, sp, 2032
|
|
; RV64ZBA-NEXT: .cfi_def_cfa_offset 0
|
|
; RV64ZBA-NEXT: ret
|
|
%a = alloca [18320 x i8]
|
|
call void @callee(ptr %a)
|
|
ret void
|
|
}
|
|
|
|
;; 2^14-16+2032
|
|
define void @frame_16kb() {
|
|
; RV32-LABEL: frame_16kb:
|
|
; RV32: # %bb.0:
|
|
; RV32-NEXT: addi sp, sp, -2032
|
|
; RV32-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32-NEXT: sw ra, 2028(sp) # 4-byte Folded Spill
|
|
; RV32-NEXT: .cfi_offset ra, -4
|
|
; RV32-NEXT: lui a0, 4
|
|
; RV32-NEXT: sub sp, sp, a0
|
|
; RV32-NEXT: .cfi_def_cfa_offset 18416
|
|
; RV32-NEXT: addi a0, sp, 12
|
|
; RV32-NEXT: call callee
|
|
; RV32-NEXT: lui a0, 4
|
|
; RV32-NEXT: add sp, sp, a0
|
|
; RV32-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32-NEXT: lw ra, 2028(sp) # 4-byte Folded Reload
|
|
; RV32-NEXT: .cfi_restore ra
|
|
; RV32-NEXT: addi sp, sp, 2032
|
|
; RV32-NEXT: .cfi_def_cfa_offset 0
|
|
; RV32-NEXT: ret
|
|
;
|
|
; RV64-LABEL: frame_16kb:
|
|
; RV64: # %bb.0:
|
|
; RV64-NEXT: addi sp, sp, -2032
|
|
; RV64-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64-NEXT: sd ra, 2024(sp) # 8-byte Folded Spill
|
|
; RV64-NEXT: .cfi_offset ra, -8
|
|
; RV64-NEXT: lui a0, 4
|
|
; RV64-NEXT: sub sp, sp, a0
|
|
; RV64-NEXT: .cfi_def_cfa_offset 18416
|
|
; RV64-NEXT: addi a0, sp, 8
|
|
; RV64-NEXT: call callee
|
|
; RV64-NEXT: lui a0, 4
|
|
; RV64-NEXT: add sp, sp, a0
|
|
; RV64-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64-NEXT: ld ra, 2024(sp) # 8-byte Folded Reload
|
|
; RV64-NEXT: .cfi_restore ra
|
|
; RV64-NEXT: addi sp, sp, 2032
|
|
; RV64-NEXT: .cfi_def_cfa_offset 0
|
|
; RV64-NEXT: ret
|
|
%a = alloca [18400 x i8]
|
|
call void @callee(ptr %a)
|
|
ret void
|
|
}
|
|
|
|
;; 2^15-16+2032
|
|
define void @frame_32kb() {
|
|
; RV32-LABEL: frame_32kb:
|
|
; RV32: # %bb.0:
|
|
; RV32-NEXT: addi sp, sp, -2032
|
|
; RV32-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32-NEXT: sw ra, 2028(sp) # 4-byte Folded Spill
|
|
; RV32-NEXT: .cfi_offset ra, -4
|
|
; RV32-NEXT: lui a0, 8
|
|
; RV32-NEXT: sub sp, sp, a0
|
|
; RV32-NEXT: .cfi_def_cfa_offset 34800
|
|
; RV32-NEXT: addi a0, sp, 12
|
|
; RV32-NEXT: call callee
|
|
; RV32-NEXT: lui a0, 8
|
|
; RV32-NEXT: add sp, sp, a0
|
|
; RV32-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV32-NEXT: lw ra, 2028(sp) # 4-byte Folded Reload
|
|
; RV32-NEXT: .cfi_restore ra
|
|
; RV32-NEXT: addi sp, sp, 2032
|
|
; RV32-NEXT: .cfi_def_cfa_offset 0
|
|
; RV32-NEXT: ret
|
|
;
|
|
; RV64-LABEL: frame_32kb:
|
|
; RV64: # %bb.0:
|
|
; RV64-NEXT: addi sp, sp, -2032
|
|
; RV64-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64-NEXT: sd ra, 2024(sp) # 8-byte Folded Spill
|
|
; RV64-NEXT: .cfi_offset ra, -8
|
|
; RV64-NEXT: lui a0, 8
|
|
; RV64-NEXT: sub sp, sp, a0
|
|
; RV64-NEXT: .cfi_def_cfa_offset 34800
|
|
; RV64-NEXT: addi a0, sp, 8
|
|
; RV64-NEXT: call callee
|
|
; RV64-NEXT: lui a0, 8
|
|
; RV64-NEXT: add sp, sp, a0
|
|
; RV64-NEXT: .cfi_def_cfa_offset 2032
|
|
; RV64-NEXT: ld ra, 2024(sp) # 8-byte Folded Reload
|
|
; RV64-NEXT: .cfi_restore ra
|
|
; RV64-NEXT: addi sp, sp, 2032
|
|
; RV64-NEXT: .cfi_def_cfa_offset 0
|
|
; RV64-NEXT: ret
|
|
%a = alloca [34784 x i8]
|
|
call void @callee(ptr %a)
|
|
ret void
|
|
}
|