+2018-04-09 Maciej W. Rozycki <macro@mips.com>
+
+ * testsuite/binutils-all/strip-14.d: New test.
+ * testsuite/binutils-all/strip-14rel.s: New test source.
+ * testsuite/binutils-all/strip-14rela.s: New test source.
+ * testsuite/binutils-all/strip-14mips64.s: New test source.
+ * testsuite/binutils-all/objcopy.exp: Run the new test.
+
2018-04-06 Tom Tromey <tom@tromey.com>
* dwarf.c (read_and_display_attr_value): Add missing DW_LANG
set reloc_format rela
}
run_dump_test "strip-13" [list [list source strip-13${reloc_format}.s]]
+ # Select a relocation number that corresponds to one actually
+ # supported by the target and ABI being tested.
+ if { [istarget "aarch64*-*"] } {
+ set reloc 259
+ } elseif { [istarget "ia64*-*"] \
+ || [istarget "m32r*-*"] \
+ || [istarget "v850*-*"] } {
+ set reloc 50
+ } else {
+ set reloc 1
+ }
+ run_dump_test "strip-14" [list \
+ [list source strip-14${reloc_format}.s] \
+ [list as "--defsym RELOC=${reloc}"] \
+ [list as [expr {[is_elf64 tmpdir/bintest.o] \
+ ? "--defsym ELF64=1" : ""}]]]
# This requires STB_GNU_UNIQUE support with OSABI set to GNU.
if { [supports_gnu_unique] } {
--- /dev/null
+#PROG: strip
+#strip: -g
+#error: \A[^\n]*: relocation 0 has invalid symbol index 1048560\Z
+#not-target: rx-*
+# The RX targets do not complain about bad relocs, unless they are
+# actually used
+# (which is what should really happen with the other targets...)
--- /dev/null
+ .text
+foo:
+ .dc.l 0x12345678
+
+ .section .rela.text
+ .dc.a 0
+ .dc.l 0x000ffff0
+ .dc.b 0, 0, 0, RELOC
+ .dc.a 0x00000001
+
+ .dc.a 0
+ .dc.l 0
+ .dc.b 0, 0, 0, 0
+ .dc.a 0
--- /dev/null
+ .text
+foo:
+ .dc.l 0x12345678
+
+ .section .rel.text
+ .ifdef ELF64
+
+ .dc.a 0
+ .dc.a 0x000ffff000000000 + RELOC
+
+ .dc.a 0
+ .dc.a 0
+ .else
+
+ # Some targets, such as `m68hc11-*', use 16-bit addresses.
+ # With them `.dc.a' emits 16-bit quantities, so we need to use
+ # `.dc.l' for 32-bit relocation data.
+ .dc.l 0
+ .dc.l 0x0ffff000 + RELOC
+
+ .dc.l 0
+ .dc.l 0
+ .endif
--- /dev/null
+ .text
+foo:
+ .dc.l 0x12345678
+
+ .section .rela.text
+ .ifdef ELF64
+
+ .dc.a 0
+ .dc.a 0x000ffff000000000 + RELOC
+ .dc.a 0x0000000000000001
+
+ .dc.a 0
+ .dc.a 0
+ .dc.a 0
+ .else
+
+ # Some targets, such as `h8300-*' or `ip2k-*', use 16-bit addresses.
+ # With them `.dc.a' emits 16-bit quantities, so we need to use
+ # `.dc.l' for 32-bit relocation data.
+ .dc.l 0
+ .dc.l 0x0ffff000 + RELOC
+ .dc.l 0x00000001
+
+ .dc.l 0
+ .dc.l 0
+ .dc.l 0
+ .endif