# RUN: llvm-mc --triple=loongarch64 < %s --show-encoding \ # RUN: | FileCheck --check-prefixes=INSTR,FIXUP %s # RUN: llvm-mc --filetype=obj --triple=loongarch64 < %s \ # RUN: | llvm-readobj -r - | FileCheck --check-prefix=RELOC %s ## Check prefixes: ## RELOC - Check the relocation in the object. ## FIXUP - Check the fixup on the instruction. ## INSTR - Check the instruction is handled properly by the ASMPrinter. .long foo # RELOC: R_LARCH_32 foo .quad foo # RELOC: R_LARCH_64 foo bne $t1, $t2, %b16(foo) # RELOC: R_LARCH_B16 # INSTR: bne $t1, $t2, %b16(foo) # FIXUP: fixup A - offset: 0, value: %b16(foo), kind: fixup_loongarch_b16 bnez $t1, %b21(foo) # RELOC: R_LARCH_B21 # INSTR: bnez $t1, %b21(foo) # FIXUP: fixup A - offset: 0, value: %b21(foo), kind: fixup_loongarch_b21 bl %plt(foo) # RELOC: R_LARCH_B26 # INSTR: bl %plt(foo) # FIXUP: fixup A - offset: 0, value: %plt(foo), kind: fixup_loongarch_b26 bl foo # RELOC: R_LARCH_B26 # INSTR: bl foo # FIXUP: fixup A - offset: 0, value: foo, kind: fixup_loongarch_b26 lu12i.w $t1, %abs_hi20(foo) # RELOC: R_LARCH_ABS_HI20 foo 0x0 # INSTR: lu12i.w $t1, %abs_hi20(foo) # FIXUP: fixup A - offset: 0, value: %abs_hi20(foo), kind: fixup_loongarch_abs_hi20 ori $t1, $t1, %abs_lo12(foo) # RELOC: R_LARCH_ABS_LO12 foo 0x0 # INSTR: ori $t1, $t1, %abs_lo12(foo) # FIXUP: fixup A - offset: 0, value: %abs_lo12(foo), kind: fixup_loongarch_abs_lo12 lu32i.d $t1, %abs64_lo20(foo) # RELOC: R_LARCH_ABS64_LO20 foo 0x0 # INSTR: lu32i.d $t1, %abs64_lo20(foo) # FIXUP: fixup A - offset: 0, value: %abs64_lo20(foo), kind: fixup_loongarch_abs64_lo20 lu52i.d $t1, $t1, %abs64_hi12(foo) # RELOC: R_LARCH_ABS64_HI12 foo 0x0 # INSTR: lu52i.d $t1, $t1, %abs64_hi12(foo) # FIXUP: fixup A - offset: 0, value: %abs64_hi12(foo), kind: fixup_loongarch_abs64_hi12 pcalau12i $t1, %pc_hi20(foo) # RELOC: R_LARCH_PCALA_HI20 foo 0x0 # INSTR: pcalau12i $t1, %pc_hi20(foo) # FIXUP: fixup A - offset: 0, value: %pc_hi20(foo), kind: FK_NONE pcalau12i $t1, %pc_hi20(foo+4) # RELOC: R_LARCH_PCALA_HI20 foo 0x4 # INSTR: pcalau12i $t1, %pc_hi20(foo+4) # FIXUP: fixup A - offset: 0, value: %pc_hi20(foo+4), kind: FK_NONE addi.d $t1, $t1, %pc_lo12(foo) # RELOC: R_LARCH_PCALA_LO12 foo 0x0 # INSTR: addi.d $t1, $t1, %pc_lo12(foo) # FIXUP: fixup A - offset: 0, value: %pc_lo12(foo), kind: FK_NONE addi.d $t1, $t1, %pc_lo12(foo+4) # RELOC: R_LARCH_PCALA_LO12 foo 0x4 # INSTR: addi.d $t1, $t1, %pc_lo12(foo+4) # FIXUP: fixup A - offset: 0, value: %pc_lo12(foo+4), kind: FK_NONE jirl $zero, $t1, %pc_lo12(foo) # RELOC: R_LARCH_PCALA_LO12 foo 0x0 # INSTR: jirl $zero, $t1, %pc_lo12(foo) # FIXUP: fixup A - offset: 0, value: %pc_lo12(foo), kind: FK_NONE st.b $t1, $a2, %pc_lo12(foo) # RELOC: R_LARCH_PCALA_LO12 foo 0x0 # INSTR: st.b $t1, $a2, %pc_lo12(foo) # FIXUP: fixup A - offset: 0, value: %pc_lo12(foo), kind: FK_NONE st.b $t1, $a2, %pc_lo12(foo+4) # RELOC: R_LARCH_PCALA_LO12 foo 0x4 # INSTR: st.b $t1, $a2, %pc_lo12(foo+4) # FIXUP: fixup A - offset: 0, value: %pc_lo12(foo+4), kind: FK_NONE lu32i.d $t1, %pc64_lo20(foo) # RELOC: R_LARCH_PCALA64_LO20 foo 0x0 # INSTR: lu32i.d $t1, %pc64_lo20(foo) # FIXUP: fixup A - offset: 0, value: %pc64_lo20(foo), kind: FK_NONE lu52i.d $t1, $t1, %pc64_hi12(foo) # RELOC: R_LARCH_PCALA64_HI12 foo 0x0 # INSTR: lu52i.d $t1, $t1, %pc64_hi12(foo) # FIXUP: fixup A - offset: 0, value: %pc64_hi12(foo), kind: FK_NONE pcalau12i $t1, %got_pc_hi20(foo) # RELOC: R_LARCH_GOT_PC_HI20 foo 0x0 # INSTR: pcalau12i $t1, %got_pc_hi20(foo) # FIXUP: fixup A - offset: 0, value: %got_pc_hi20(foo), kind: FK_NONE ld.d $t1, $a2, %got_pc_lo12(foo) # RELOC: R_LARCH_GOT_PC_LO12 foo 0x0 # INSTR: ld.d $t1, $a2, %got_pc_lo12(foo) # FIXUP: fixup A - offset: 0, value: %got_pc_lo12(foo), kind: FK_NONE lu32i.d $t1, %got64_pc_lo20(foo) # RELOC: R_LARCH_GOT64_PC_LO20 foo 0x0 # INSTR: lu32i.d $t1, %got64_pc_lo20(foo) # FIXUP: fixup A - offset: 0, value: %got64_pc_lo20(foo), kind: FK_NONE lu52i.d $t1, $t1, %got64_pc_hi12(foo) # RELOC: R_LARCH_GOT64_PC_HI12 foo 0x0 # INSTR: lu52i.d $t1, $t1, %got64_pc_hi12(foo) # FIXUP: fixup A - offset: 0, value: %got64_pc_hi12(foo), kind: FK_NONE lu12i.w $t1, %got_hi20(foo) # RELOC: R_LARCH_GOT_HI20 foo 0x0 # INSTR: lu12i.w $t1, %got_hi20(foo) # FIXUP: fixup A - offset: 0, value: %got_hi20(foo), kind: FK_NONE ori $t1, $a2, %got_lo12(foo) # RELOC: R_LARCH_GOT_LO12 foo 0x0 # INSTR: ori $t1, $a2, %got_lo12(foo) # FIXUP: fixup A - offset: 0, value: %got_lo12(foo), kind: FK_NONE lu32i.d $t1, %got64_lo20(foo) # RELOC: R_LARCH_GOT64_LO20 foo 0x0 # INSTR: lu32i.d $t1, %got64_lo20(foo) # FIXUP: fixup A - offset: 0, value: %got64_lo20(foo), kind: FK_NONE lu52i.d $t1, $t1, %got64_hi12(foo) # RELOC: R_LARCH_GOT64_HI12 foo 0x0 # INSTR: lu52i.d $t1, $t1, %got64_hi12(foo) # FIXUP: fixup A - offset: 0, value: %got64_hi12(foo), kind: FK_NONE lu12i.w $t1, %le_hi20(foo) # RELOC: R_LARCH_TLS_LE_HI20 foo 0x0 # INSTR: lu12i.w $t1, %le_hi20(foo) # FIXUP: fixup A - offset: 0, value: %le_hi20(foo), kind: fixup_loongarch_tls_le_hi20 ori $t1, $a2, %le_lo12(foo) # RELOC: R_LARCH_TLS_LE_LO12 foo 0x0 # INSTR: ori $t1, $a2, %le_lo12(foo) # FIXUP: fixup A - offset: 0, value: %le_lo12(foo), kind: fixup_loongarch_tls_le_lo12 lu32i.d $t1, %le64_lo20(foo) # RELOC: R_LARCH_TLS_LE64_LO20 foo 0x0 # INSTR: lu32i.d $t1, %le64_lo20(foo) # FIXUP: fixup A - offset: 0, value: %le64_lo20(foo), kind: fixup_loongarch_tls_le64_lo20 lu52i.d $t1, $t1, %le64_hi12(foo) # RELOC: R_LARCH_TLS_LE64_HI12 foo 0x0 # INSTR: lu52i.d $t1, $t1, %le64_hi12(foo) # FIXUP: fixup A - offset: 0, value: %le64_hi12(foo), kind: fixup_loongarch_tls_le64_hi12 pcalau12i $t1, %ie_pc_hi20(foo) # RELOC: R_LARCH_TLS_IE_PC_HI20 foo 0x0 # INSTR: pcalau12i $t1, %ie_pc_hi20(foo) # FIXUP: fixup A - offset: 0, value: %ie_pc_hi20(foo), kind: FK_NONE ld.d $t1, $a2, %ie_pc_lo12(foo) # RELOC: R_LARCH_TLS_IE_PC_LO12 foo 0x0 # INSTR: ld.d $t1, $a2, %ie_pc_lo12(foo) # FIXUP: fixup A - offset: 0, value: %ie_pc_lo12(foo), kind: FK_NONE lu32i.d $t1, %ie64_pc_lo20(foo) # RELOC: R_LARCH_TLS_IE64_PC_LO20 foo 0x0 # INSTR: lu32i.d $t1, %ie64_pc_lo20(foo) # FIXUP: fixup A - offset: 0, value: %ie64_pc_lo20(foo), kind: FK_NONE lu52i.d $t1, $t1, %ie64_pc_hi12(foo) # RELOC: R_LARCH_TLS_IE64_PC_HI12 foo 0x0 # INSTR: lu52i.d $t1, $t1, %ie64_pc_hi12(foo) # FIXUP: fixup A - offset: 0, value: %ie64_pc_hi12(foo), kind: FK_NONE lu12i.w $t1, %ie_hi20(foo) # RELOC: R_LARCH_TLS_IE_HI20 foo 0x0 # INSTR: lu12i.w $t1, %ie_hi20(foo) # FIXUP: fixup A - offset: 0, value: %ie_hi20(foo), kind: FK_NONE ori $t1, $a2, %ie_lo12(foo) # RELOC: R_LARCH_TLS_IE_LO12 foo 0x0 # INSTR: ori $t1, $a2, %ie_lo12(foo) # FIXUP: fixup A - offset: 0, value: %ie_lo12(foo), kind: FK_NONE lu32i.d $t1, %ie64_lo20(foo) # RELOC: R_LARCH_TLS_IE64_LO20 foo 0x0 # INSTR: lu32i.d $t1, %ie64_lo20(foo) # FIXUP: fixup A - offset: 0, value: %ie64_lo20(foo), kind: FK_NONE lu52i.d $t1, $t1, %ie64_hi12(foo) # RELOC: R_LARCH_TLS_IE64_HI12 foo 0x0 # INSTR: lu52i.d $t1, $t1, %ie64_hi12(foo) # FIXUP: fixup A - offset: 0, value: %ie64_hi12(foo), kind: FK_NONE pcalau12i $t1, %ld_pc_hi20(foo) # RELOC: R_LARCH_TLS_LD_PC_HI20 foo 0x0 # INSTR: pcalau12i $t1, %ld_pc_hi20(foo) # FIXUP: fixup A - offset: 0, value: %ld_pc_hi20(foo), kind: FK_NONE lu12i.w $t1, %ld_hi20(foo) # RELOC: R_LARCH_TLS_LD_HI20 foo 0x0 # INSTR: lu12i.w $t1, %ld_hi20(foo) # FIXUP: fixup A - offset: 0, value: %ld_hi20(foo), kind: FK_NONE pcalau12i $t1, %gd_pc_hi20(foo) # RELOC: R_LARCH_TLS_GD_PC_HI20 foo 0x0 # INSTR: pcalau12i $t1, %gd_pc_hi20(foo) # FIXUP: fixup A - offset: 0, value: %gd_pc_hi20(foo), kind: FK_NONE lu12i.w $t1, %gd_hi20(foo) # RELOC: R_LARCH_TLS_GD_HI20 foo 0x0 # INSTR: lu12i.w $t1, %gd_hi20(foo) # FIXUP: fixup A - offset: 0, value: %gd_hi20(foo), kind: FK_NONE pcaddu18i $t1, %call36(foo) # RELOC: R_LARCH_CALL36 foo 0x0 # INSTR: pcaddu18i $t1, %call36(foo) # FIXUP: fixup A - offset: 0, value: %call36(foo), kind: FK_NONE