blob: ea4569e198d02f539f95cb45a106e04598f449fd [file] [log] [blame]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
; RUN: llc -mtriple=loongarch32-linux-gnu < %s | FileCheck -check-prefix=LINUX32 %s
; RUN: llc -mtriple=loongarch64-linux-gnu < %s | FileCheck -check-prefix=LINUX64 %s
; RUN: llc -mtriple=loongarch32-unknown-openbsd < %s | FileCheck -check-prefix=OPENBSD32 %s
; RUN: llc -mtriple=loongarch64-unknown-openbsd < %s | FileCheck -check-prefix=OPENBSD64 %s
define void @func() sspreq nounwind {
; LINUX32-LABEL: func:
; LINUX32: # %bb.0:
; LINUX32-NEXT: addi.w $sp, $sp, -16
; LINUX32-NEXT: st.w $ra, $sp, 12 # 4-byte Folded Spill
; LINUX32-NEXT: st.w $fp, $sp, 8 # 4-byte Folded Spill
; LINUX32-NEXT: pcalau12i $fp, %pc_hi20(__stack_chk_guard)
; LINUX32-NEXT: ld.w $a0, $fp, %pc_lo12(__stack_chk_guard)
; LINUX32-NEXT: st.w $a0, $sp, 4
; LINUX32-NEXT: addi.w $a0, $sp, 0
; LINUX32-NEXT: bl capture
; LINUX32-NEXT: ld.w $a0, $fp, %pc_lo12(__stack_chk_guard)
; LINUX32-NEXT: ld.w $a1, $sp, 4
; LINUX32-NEXT: bne $a0, $a1, .LBB0_2
; LINUX32-NEXT: # %bb.1:
; LINUX32-NEXT: ld.w $fp, $sp, 8 # 4-byte Folded Reload
; LINUX32-NEXT: ld.w $ra, $sp, 12 # 4-byte Folded Reload
; LINUX32-NEXT: addi.w $sp, $sp, 16
; LINUX32-NEXT: ret
; LINUX32-NEXT: .LBB0_2:
; LINUX32-NEXT: bl __stack_chk_fail
;
; LINUX64-LABEL: func:
; LINUX64: # %bb.0:
; LINUX64-NEXT: addi.d $sp, $sp, -32
; LINUX64-NEXT: st.d $ra, $sp, 24 # 8-byte Folded Spill
; LINUX64-NEXT: st.d $fp, $sp, 16 # 8-byte Folded Spill
; LINUX64-NEXT: pcalau12i $fp, %pc_hi20(__stack_chk_guard)
; LINUX64-NEXT: ld.d $a0, $fp, %pc_lo12(__stack_chk_guard)
; LINUX64-NEXT: st.d $a0, $sp, 8
; LINUX64-NEXT: addi.d $a0, $sp, 4
; LINUX64-NEXT: pcaddu18i $ra, %call36(capture)
; LINUX64-NEXT: jirl $ra, $ra, 0
; LINUX64-NEXT: ld.d $a0, $fp, %pc_lo12(__stack_chk_guard)
; LINUX64-NEXT: ld.d $a1, $sp, 8
; LINUX64-NEXT: bne $a0, $a1, .LBB0_2
; LINUX64-NEXT: # %bb.1:
; LINUX64-NEXT: ld.d $fp, $sp, 16 # 8-byte Folded Reload
; LINUX64-NEXT: ld.d $ra, $sp, 24 # 8-byte Folded Reload
; LINUX64-NEXT: addi.d $sp, $sp, 32
; LINUX64-NEXT: ret
; LINUX64-NEXT: .LBB0_2:
; LINUX64-NEXT: pcaddu18i $ra, %call36(__stack_chk_fail)
; LINUX64-NEXT: jirl $ra, $ra, 0
;
; OPENBSD32-LABEL: func:
; OPENBSD32: # %bb.0:
; OPENBSD32-NEXT: addi.w $sp, $sp, -16
; OPENBSD32-NEXT: st.w $ra, $sp, 12 # 4-byte Folded Spill
; OPENBSD32-NEXT: st.w $fp, $sp, 8 # 4-byte Folded Spill
; OPENBSD32-NEXT: pcalau12i $fp, %pc_hi20(__guard_local)
; OPENBSD32-NEXT: ld.w $a0, $fp, %pc_lo12(__guard_local)
; OPENBSD32-NEXT: st.w $a0, $sp, 4
; OPENBSD32-NEXT: addi.w $a0, $sp, 0
; OPENBSD32-NEXT: bl capture
; OPENBSD32-NEXT: ld.w $a0, $fp, %pc_lo12(__guard_local)
; OPENBSD32-NEXT: ld.w $a1, $sp, 4
; OPENBSD32-NEXT: bne $a0, $a1, .LBB0_2
; OPENBSD32-NEXT: # %bb.1: # %SP_return
; OPENBSD32-NEXT: ld.w $fp, $sp, 8 # 4-byte Folded Reload
; OPENBSD32-NEXT: ld.w $ra, $sp, 12 # 4-byte Folded Reload
; OPENBSD32-NEXT: addi.w $sp, $sp, 16
; OPENBSD32-NEXT: ret
; OPENBSD32-NEXT: .LBB0_2: # %CallStackCheckFailBlk
; OPENBSD32-NEXT: pcalau12i $a0, %pc_hi20(.LSSH)
; OPENBSD32-NEXT: addi.w $a0, $a0, %pc_lo12(.LSSH)
; OPENBSD32-NEXT: bl __stack_smash_handler
;
; OPENBSD64-LABEL: func:
; OPENBSD64: # %bb.0:
; OPENBSD64-NEXT: addi.d $sp, $sp, -32
; OPENBSD64-NEXT: st.d $ra, $sp, 24 # 8-byte Folded Spill
; OPENBSD64-NEXT: st.d $fp, $sp, 16 # 8-byte Folded Spill
; OPENBSD64-NEXT: pcalau12i $fp, %pc_hi20(__guard_local)
; OPENBSD64-NEXT: ld.d $a0, $fp, %pc_lo12(__guard_local)
; OPENBSD64-NEXT: st.d $a0, $sp, 8
; OPENBSD64-NEXT: addi.d $a0, $sp, 4
; OPENBSD64-NEXT: pcaddu18i $ra, %call36(capture)
; OPENBSD64-NEXT: jirl $ra, $ra, 0
; OPENBSD64-NEXT: ld.d $a0, $fp, %pc_lo12(__guard_local)
; OPENBSD64-NEXT: ld.d $a1, $sp, 8
; OPENBSD64-NEXT: bne $a0, $a1, .LBB0_2
; OPENBSD64-NEXT: # %bb.1: # %SP_return
; OPENBSD64-NEXT: ld.d $fp, $sp, 16 # 8-byte Folded Reload
; OPENBSD64-NEXT: ld.d $ra, $sp, 24 # 8-byte Folded Reload
; OPENBSD64-NEXT: addi.d $sp, $sp, 32
; OPENBSD64-NEXT: ret
; OPENBSD64-NEXT: .LBB0_2: # %CallStackCheckFailBlk
; OPENBSD64-NEXT: pcalau12i $a0, %pc_hi20(.LSSH)
; OPENBSD64-NEXT: addi.d $a0, $a0, %pc_lo12(.LSSH)
; OPENBSD64-NEXT: pcaddu18i $ra, %call36(__stack_smash_handler)
; OPENBSD64-NEXT: jirl $ra, $ra, 0
%alloca = alloca i32, align 4
call void @capture(ptr %alloca)
ret void
}
declare void @capture(ptr)