
Add reloc_unsign_bits() to fix others sop_pop relocs overflow check. Then add over/underflow tests for relocs B*, SOP_POP* and PCREL20_S2. bfd/ChangeLog: * bfd/elfxx-loongarch.c: Add reloc_unsign_bits(). ld/ChangeLog: * ld/testsuite/ld-loongarch-elf/ld-loongarch-elf.exp: Add tests. * ld/testsuite/ld-loongarch-elf/abi1_max_imm.dd: New test. * ld/testsuite/ld-loongarch-elf/abi1_max_imm.s: New test. * ld/testsuite/ld-loongarch-elf/abi1_sops.s: New test. * ld/testsuite/ld-loongarch-elf/abi2_max_imm.s: New test. * ld/testsuite/ld-loongarch-elf/abi2_overflows.s: New test. * ld/testsuite/ld-loongarch-elf/max_imm_b16.d: New test. * ld/testsuite/ld-loongarch-elf/max_imm_b21.d: New test. * ld/testsuite/ld-loongarch-elf/max_imm_b26.d: New test. * ld/testsuite/ld-loongarch-elf/max_imm_pcrel20.d: New test. * ld/testsuite/ld-loongarch-elf/overflow_b16.d: New test. * ld/testsuite/ld-loongarch-elf/overflow_b21.d: New test. * ld/testsuite/ld-loongarch-elf/overflow_b26.d: New test. * ld/testsuite/ld-loongarch-elf/overflow_pcrel20.d: New test. * ld/testsuite/ld-loongarch-elf/overflow_s_0_10_10_16_s2.d: New test. * ld/testsuite/ld-loongarch-elf/overflow_s_0_5_10_16_s2.d: New test. * ld/testsuite/ld-loongarch-elf/overflow_s_10_12.d: New test. * ld/testsuite/ld-loongarch-elf/overflow_s_10_16.d: New test. * ld/testsuite/ld-loongarch-elf/overflow_s_10_16_s2.d: New test. * ld/testsuite/ld-loongarch-elf/overflow_s_10_5.d: New test. * ld/testsuite/ld-loongarch-elf/overflow_s_5_20.d: New test. * ld/testsuite/ld-loongarch-elf/overflow_u.d: New test. * ld/testsuite/ld-loongarch-elf/overflow_u_10_12.d: New test. * ld/testsuite/ld-loongarch-elf/underflow_b16.d: New test. * ld/testsuite/ld-loongarch-elf/underflow_b21.d: New test. * ld/testsuite/ld-loongarch-elf/underflow_b26.d: New test. * ld/testsuite/ld-loongarch-elf/underflow_pcrel20.d: New test. * ld/testsuite/ld-loongarch-elf/underflow_s_0_10_10_16_s2.d: New test. * ld/testsuite/ld-loongarch-elf/underflow_s_0_5_10_16_s2.d: New test. * ld/testsuite/ld-loongarch-elf/underflow_s_10_12.d: New test. * ld/testsuite/ld-loongarch-elf/underflow_s_10_16.d: New test. * ld/testsuite/ld-loongarch-elf/underflow_s_10_16_s2.d: New test. * ld/testsuite/ld-loongarch-elf/underflow_s_10_5.d: New test. * ld/testsuite/ld-loongarch-elf/underflow_s_5_20.d: New test.
43 lines
1.3 KiB
ArmAsm
43 lines
1.3 KiB
ArmAsm
.macro sign_check reloc_sym reloc_name reloc_bits
|
|
.ifdef \reloc_sym
|
|
.ifdef overflow
|
|
.reloc 0, R_LARCH_SOP_PUSH_ABSOLUTE, 1 << (\reloc_bits - 1)
|
|
.reloc 0, \reloc_name
|
|
.else
|
|
.reloc 0, R_LARCH_SOP_PUSH_ABSOLUTE, -(1 << (\reloc_bits - 1)) - 1
|
|
.reloc 0, \reloc_name
|
|
.endif
|
|
.word 0
|
|
.endif
|
|
.endm
|
|
|
|
.macro sign_check_s2 reloc_sym reloc_name reloc_bits
|
|
.ifdef \reloc_sym
|
|
.ifdef overflow
|
|
.reloc 0, R_LARCH_SOP_PUSH_ABSOLUTE, (1 << (\reloc_bits - 1)) << 2
|
|
.reloc 0, \reloc_name
|
|
.else
|
|
.reloc 0, R_LARCH_SOP_PUSH_ABSOLUTE, (-(1 << (\reloc_bits - 1)) - 1) << 2
|
|
.reloc 0, \reloc_name
|
|
.endif
|
|
.word 0
|
|
.endif
|
|
.endm
|
|
|
|
.macro unsign_check reloc_sym reloc_name reloc_bits
|
|
.ifdef \reloc_sym
|
|
.reloc 0, R_LARCH_SOP_PUSH_ABSOLUTE, 1 << \reloc_bits
|
|
.reloc 0, \reloc_name
|
|
.word 0
|
|
.endif
|
|
.endm
|
|
|
|
sign_check s_10_5 R_LARCH_SOP_POP_32_S_10_5 5
|
|
sign_check s_10_12 R_LARCH_SOP_POP_32_S_10_12 12
|
|
sign_check s_10_16 R_LARCH_SOP_POP_32_S_10_16 16
|
|
sign_check_s2 s_10_16_s2 R_LARCH_SOP_POP_32_S_10_16_S2 16
|
|
sign_check_s2 s_0_5_10_16_s2 R_LARCH_SOP_POP_32_S_0_5_10_16_S2 21
|
|
sign_check_s2 s_0_10_10_16_s2 R_LARCH_SOP_POP_32_S_0_10_10_16_S2 26
|
|
sign_check s_5_20 R_LARCH_SOP_POP_32_S_5_20 20
|
|
unsign_check u_10_12 R_LARCH_SOP_POP_32_U_10_12 12
|
|
unsign_check u R_LARCH_SOP_POP_32_U 32
|