This patch adds support for PC-relative address materialization using pcadd-class relocations, covering the HI20/LO12 pair and their GOT and TLS variants (IE, LD, GD, and DESC). Link: https://gcc.gnu.org/pipermail/gcc-patches/2025-December/703312.html
108 lines
4.6 KiB
LLVM
108 lines
4.6 KiB
LLVM
; 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: .Lpcadd_hi0:
|
|
; LINUX32-NEXT: pcaddu12i $fp, %pcadd_hi20(__stack_chk_guard)
|
|
; LINUX32-NEXT: ld.w $a0, $fp, %pcadd_lo12(.Lpcadd_hi0)
|
|
; LINUX32-NEXT: st.w $a0, $sp, 4
|
|
; LINUX32-NEXT: addi.w $a0, $sp, 0
|
|
; LINUX32-NEXT: bl capture
|
|
; LINUX32-NEXT: ld.w $a0, $fp, %pcadd_lo12(.Lpcadd_hi0)
|
|
; 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: .Lpcadd_hi0:
|
|
; OPENBSD32-NEXT: pcaddu12i $fp, %pcadd_hi20(__guard_local)
|
|
; OPENBSD32-NEXT: ld.w $a0, $fp, %pcadd_lo12(.Lpcadd_hi0)
|
|
; OPENBSD32-NEXT: st.w $a0, $sp, 4
|
|
; OPENBSD32-NEXT: addi.w $a0, $sp, 0
|
|
; OPENBSD32-NEXT: bl capture
|
|
; OPENBSD32-NEXT: ld.w $a0, $fp, %pcadd_lo12(.Lpcadd_hi0)
|
|
; 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: .Lpcadd_hi1:
|
|
; OPENBSD32-NEXT: pcaddu12i $a0, %pcadd_hi20(.LSSH)
|
|
; OPENBSD32-NEXT: addi.w $a0, $a0, %pcadd_lo12(.Lpcadd_hi1)
|
|
; 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)
|