binutils-gdb/ld/testsuite/ld-mips-elf/unaligned-jalx-addend-mips16-1.d
Maciej W. Rozycki bc27bb0573 MIPS/BFD: Include the addend in JALX's target alignment verification
On RELA targets the addend can affect JALX target's alignment, so only
verify it once the whole relocation calculation has completed.

	bfd/
	* elfxx-mips.c (mips_elf_calculate_relocation) <R_MIPS16_26>
	<R_MIPS_26, R_MICROMIPS_26_S1>: Include the addend in JALX's
	target alignment verification.

	ld/
	* testsuite/ld-mips-elf/unaligned-jalx-addend-0.d: New test.
	* testsuite/ld-mips-elf/unaligned-jalx-addend-1.d: New test.
	* testsuite/ld-mips-elf/unaligned-jalx-addend-mips16-0.d: New
	test.
	* testsuite/ld-mips-elf/unaligned-jalx-addend-mips16-1.d: New
	test.
	* testsuite/ld-mips-elf/unaligned-jalx-addend-micromips-0.d: New
	test.
	* testsuite/ld-mips-elf/unaligned-jalx-addend-micromips-1.d: New
	test.
	* testsuite/ld-mips-elf/unaligned-jalx-addend-0.s: New test
	source.
	* testsuite/ld-mips-elf/unaligned-jalx-addend-1.s: New test
	source.
	* testsuite/ld-mips-elf/mips-elf.exp: Run the new tests.
2016-05-27 22:31:29 +01:00

31 lines
1.5 KiB
Makefile

#name: MIPS16 JALX to unaligned symbol with addend 1
#source: unaligned-jalx-addend-1.s -mips16
#source: unaligned-insn.s
#as: -EB -n32 -march=from-abi
#ld: -EB -Ttext 0x1c000000 -e 0x1c000000
#objdump: -dr --prefix-addresses --show-raw-insn
#error: \A[^\n]*: In function `foo':\n
#error: \(\.text\+0x[0-9a-f]+\): JALX to a non-word-aligned address\n
#error: [^\n]*: In function `foo':\n
#error: \(\.text\+0x[0-9a-f]+\): JALX to a non-word-aligned address\n
#error: [^\n]*: In function `foo':\n
#error: \(\.text\+0x[0-9a-f]+\): JALX to a non-word-aligned address\n
#error: [^\n]*: In function `foo':\n
#error: \(\.text\+0x[0-9a-f]+\): JALX to a non-word-aligned address\n
#error: [^\n]*: In function `foo':\n
#error: \(\.text\+0x[0-9a-f]+\): JALX to a non-word-aligned address\n
#error: [^\n]*: In function `foo':\n
#error: \(\.text\+0x[0-9a-f]+\): JALX to a non-word-aligned address\n
#error: [^\n]*: In function `foo':\n
#error: \(\.text\+0x[0-9a-f]+\): JALX to a non-word-aligned address\n
#error: [^\n]*: In function `foo':\n
#error: \(\.text\+0x[0-9a-f]+\): JALX to a non-word-aligned address\n
#error: [^\n]*: In function `foo':\n
#error: \(\.text\+0x[0-9a-f]+\): JALX to a non-word-aligned address\n
#error: [^\n]*: In function `foo':\n
#error: \(\.text\+0x[0-9a-f]+\): JALX to a non-word-aligned address\n
#error: [^\n]*: In function `foo':\n
#error: \(\.text\+0x[0-9a-f]+\): JALX to a non-word-aligned address\n
#error: [^\n]*: In function `foo':\n
#error: \(\.text\+0x[0-9a-f]+\): JALX to a non-word-aligned address\Z