blob: 02507f19cf9b3ac047f0c917c5c21ba4c32640de [file]
.macro sign_check reloc_name reloc_bits
.reloc off, R_LARCH_SOP_PUSH_ABSOLUTE, (1 << (\reloc_bits - 1)) - 1
.reloc off, \reloc_name
.word 0
.set off, off + 4
.reloc off, R_LARCH_SOP_PUSH_ABSOLUTE, -(1 << (\reloc_bits - 1))
.reloc off, \reloc_name
.word 0
.set off, off + 4
.endm
.macro sign_check_s2 reloc_name reloc_bits
.reloc off, R_LARCH_SOP_PUSH_ABSOLUTE, ((1 << (\reloc_bits - 1)) - 1) << 2
.reloc off, \reloc_name
.word 0
.set off, off + 4
.reloc off, R_LARCH_SOP_PUSH_ABSOLUTE, (-(1 << (\reloc_bits - 1))) << 2
.reloc off, \reloc_name
.word 0
.set off, off + 4
.endm
.macro unsign_check reloc_name reloc_bits
.reloc off, R_LARCH_SOP_PUSH_ABSOLUTE, (1 << \reloc_bits) - 1
.reloc off, \reloc_name
.word 0
.set off, off + 4
.endm
.set off, 0
sign_check R_LARCH_SOP_POP_32_S_10_5 5
sign_check R_LARCH_SOP_POP_32_S_10_12 12
sign_check R_LARCH_SOP_POP_32_S_10_16 16
sign_check_s2 R_LARCH_SOP_POP_32_S_10_16_S2 16
sign_check_s2 R_LARCH_SOP_POP_32_S_0_5_10_16_S2 21
sign_check_s2 R_LARCH_SOP_POP_32_S_0_10_10_16_S2 26
sign_check R_LARCH_SOP_POP_32_S_5_20 20
unsign_check R_LARCH_SOP_POP_32_U_10_12 12
unsign_check R_LARCH_SOP_POP_32_U 32