diff options
Diffstat (limited to 'ld/testsuite/ld-x86-64')
-rw-r--r-- | ld/testsuite/ld-x86-64/dwarfreloc.exp | 58 | ||||
-rw-r--r-- | ld/testsuite/ld-x86-64/largecomm-1.s | 3 | ||||
-rw-r--r-- | ld/testsuite/ld-x86-64/largecomm-1a.d | 8 | ||||
-rw-r--r-- | ld/testsuite/ld-x86-64/largecomm-1b.d | 8 | ||||
-rw-r--r-- | ld/testsuite/ld-x86-64/largecomm-1c.d | 8 | ||||
-rw-r--r-- | ld/testsuite/ld-x86-64/largecomm-1d.d | 8 | ||||
-rw-r--r-- | ld/testsuite/ld-x86-64/largecomm-1e.d | 8 | ||||
-rw-r--r-- | ld/testsuite/ld-x86-64/largecomm-1f.d | 8 | ||||
-rw-r--r-- | ld/testsuite/ld-x86-64/pr19645.d | 13 | ||||
-rw-r--r-- | ld/testsuite/ld-x86-64/pr19645.s | 6 | ||||
-rw-r--r-- | ld/testsuite/ld-x86-64/x86-64.exp | 7 |
11 files changed, 125 insertions, 10 deletions
diff --git a/ld/testsuite/ld-x86-64/dwarfreloc.exp b/ld/testsuite/ld-x86-64/dwarfreloc.exp index afe5f6c..959ae9c 100644 --- a/ld/testsuite/ld-x86-64/dwarfreloc.exp +++ b/ld/testsuite/ld-x86-64/dwarfreloc.exp @@ -41,18 +41,31 @@ if { !([istarget "x86_64-*-elf*"] } set build_tests_ld { - {"Build dwarfreloc1x.o" - "-r" "" "" - {dwarfreloc1.s} {} "dwarfreloc1x.o"} - {"Build dwarfreloc2.o" - "-r" "" "" - {dwarfreloc2.s} {} "dwarfreloc2x.o"} + {"Build dwarfreloc1xa.o" + "-r" "" "--elf-stt-common=no" + {dwarfreloc1.s} {} "dwarfreloc1xa.o"} + {"Build dwarfreloc1xb.o" + "-r" "" "--elf-stt-common=yes" + {dwarfreloc1.s} {} "dwarfreloc1xb.o"} + {"Build dwarfreloc2a.o" + "-r" "" "--elf-stt-common=no" + {dwarfreloc2.s} {} "dwarfreloc2xa.o"} + {"Build dwarfreloc2b.o" + "-r" "" "--elf-stt-common=yes" + {dwarfreloc2.s} {} "dwarfreloc2xb.o"} } run_ld_link_tests $build_tests_ld -set testname "Link dwarfreloc1x.o and dwarfreloc2x.o to dwarfreloc.o" -if [ld_simple_link $ld "tmpdir/dwarfreloc.o" "-r tmpdir/dwarfreloc1x.o tmpdir/dwarfreloc2x.o"] { +set testname "Link dwarfreloc1xa.o and dwarfreloc2xa.o to dwarfreloca.o" +if [ld_simple_link $ld "tmpdir/dwarfreloca.o" "-r tmpdir/dwarfreloc1xa.o tmpdir/dwarfreloc2xa.o"] { + pass $testname +} else { + fail $testname +} + +set testname "Link dwarfreloc1xb.o and dwarfreloc2xb.o to dwarfrelocb.o" +if [ld_simple_link $ld "tmpdir/dwarfrelocb.o" "-r tmpdir/dwarfreloc1xb.o tmpdir/dwarfreloc2xb.o"] { pass $testname } else { fail $testname @@ -61,9 +74,34 @@ if [ld_simple_link $ld "tmpdir/dwarfreloc.o" "-r tmpdir/dwarfreloc1x.o tmpdir/dw # The code is copied from `ld-lib.exp'. We cannot use the functions there as # they expect source (.s or .c) files while we to check a `ld -r' output (.o). -set testname "Check dwarfreloc.o readelf" +set testname "Check dwarfreloca.o readelf" +set dumpfile "dwarfreloc.rd" +set cmd "$READELF --debug-dump=info tmpdir/dwarfreloca.o" +set status [remote_exec host [concat sh -c [list "$cmd >dump.out 2>ld.stderr"]] "" "/dev/null"] +send_log "$cmd\n" +remote_upload host "ld.stderr" +set comp_output [prune_warnings [file_contents "ld.stderr"]] +remote_file host delete "ld.stderr" +remote_file build delete "ld.stderr" + +if ![string match "" $comp_output] then { + send_log "$comp_output\n" + fail $testname +} else { + remote_upload host "dump.out" + if { [regexp_diff "dump.out" "$srcdir/$subdir/$dumpfile"] } then { + verbose "output is [file_contents "dump.out"]" 2 + fail $testname + } else { + pass $testname + } + remote_file build delete "dump.out" + remote_file host delete "dump.out" +} + +set testname "Check dwarfrelocb.o readelf" set dumpfile "dwarfreloc.rd" -set cmd "$READELF --debug-dump=info tmpdir/dwarfreloc.o" +set cmd "$READELF --debug-dump=info tmpdir/dwarfrelocb.o" set status [remote_exec host [concat sh -c [list "$cmd >dump.out 2>ld.stderr"]] "" "/dev/null"] send_log "$cmd\n" remote_upload host "ld.stderr" diff --git a/ld/testsuite/ld-x86-64/largecomm-1.s b/ld/testsuite/ld-x86-64/largecomm-1.s new file mode 100644 index 0000000..cfadc4f --- /dev/null +++ b/ld/testsuite/ld-x86-64/largecomm-1.s @@ -0,0 +1,3 @@ + .data + .dc.a foobar + .largecomm foobar,30,4 diff --git a/ld/testsuite/ld-x86-64/largecomm-1a.d b/ld/testsuite/ld-x86-64/largecomm-1a.d new file mode 100644 index 0000000..63462bf --- /dev/null +++ b/ld/testsuite/ld-x86-64/largecomm-1a.d @@ -0,0 +1,8 @@ +#source: largecomm-1.s +#as: --elf-stt-common=yes +#ld: -r +#readelf: -s -W + +#... + +[0-9]+: +0+4 +30 +COMMON +GLOBAL +DEFAULT +LARGE_COM +foobar +#pass diff --git a/ld/testsuite/ld-x86-64/largecomm-1b.d b/ld/testsuite/ld-x86-64/largecomm-1b.d new file mode 100644 index 0000000..8f62d0d --- /dev/null +++ b/ld/testsuite/ld-x86-64/largecomm-1b.d @@ -0,0 +1,8 @@ +#source: largecomm-1.s +#as: --elf-stt-common=no +#ld: -r +#readelf: -s -W + +#... + +[0-9]+: +0+4 +30 +OBJECT +GLOBAL +DEFAULT +LARGE_COM +foobar +#pass diff --git a/ld/testsuite/ld-x86-64/largecomm-1c.d b/ld/testsuite/ld-x86-64/largecomm-1c.d new file mode 100644 index 0000000..7e6a8cc --- /dev/null +++ b/ld/testsuite/ld-x86-64/largecomm-1c.d @@ -0,0 +1,8 @@ +#source: largecomm-1.s +#as: --elf-stt-common=yes +#ld: -r -z nocommon +#readelf: -s -W + +#... + +[0-9]+: +0+4 +30 +OBJECT +GLOBAL +DEFAULT +LARGE_COM +foobar +#pass diff --git a/ld/testsuite/ld-x86-64/largecomm-1d.d b/ld/testsuite/ld-x86-64/largecomm-1d.d new file mode 100644 index 0000000..4025e7b --- /dev/null +++ b/ld/testsuite/ld-x86-64/largecomm-1d.d @@ -0,0 +1,8 @@ +#source: largecomm-1.s +#as: --elf-stt-common=yes +#ld: -r -z common +#readelf: -s -W + +#... + +[0-9]+: +0+4 +30 +COMMON +GLOBAL +DEFAULT +LARGE_COM +foobar +#pass diff --git a/ld/testsuite/ld-x86-64/largecomm-1e.d b/ld/testsuite/ld-x86-64/largecomm-1e.d new file mode 100644 index 0000000..b1a3a03 --- /dev/null +++ b/ld/testsuite/ld-x86-64/largecomm-1e.d @@ -0,0 +1,8 @@ +#source: largecomm-1.s +#as: --elf-stt-common=no +#ld: -r -z common +#readelf: -s -W + +#... + +[0-9]+: +0+4 +30 +COMMON +GLOBAL +DEFAULT +LARGE_COM +foobar +#pass diff --git a/ld/testsuite/ld-x86-64/largecomm-1f.d b/ld/testsuite/ld-x86-64/largecomm-1f.d new file mode 100644 index 0000000..3b5bd92 --- /dev/null +++ b/ld/testsuite/ld-x86-64/largecomm-1f.d @@ -0,0 +1,8 @@ +#source: largecomm-1.s +#as: --elf-stt-common=no +#ld: -r -z nocommon +#readelf: -s -W + +#... + +[0-9]+: +0+4 +30 +OBJECT +GLOBAL +DEFAULT +LARGE_COM +foobar +#pass diff --git a/ld/testsuite/ld-x86-64/pr19645.d b/ld/testsuite/ld-x86-64/pr19645.d new file mode 100644 index 0000000..9445fda --- /dev/null +++ b/ld/testsuite/ld-x86-64/pr19645.d @@ -0,0 +1,13 @@ +#as: --64 --elf-stt-common=yes +#ld: -shared -Bsymbolic-functions -melf_x86_64 +#readelf: -r --wide --dyn-syms + +Relocation section '.rela.dyn' at offset 0x[0-9a-f]+ contains 1 entries: + +Offset +Info +Type +Symbol's Value +Symbol's Name \+ Addend +[0-9a-f]+ +[0-9a-f]+ +R_X86_64_GLOB_DAT +[0-9a-f]+ +foobar \+ 0 + +Symbol table '.dynsym' contains [0-9]+ entries: + +Num: +Value +Size +Type +Bind +Vis +Ndx +Name +#... + +[0-9]+: +[0-9a-f]+ +30 +OBJECT +GLOBAL +DEFAULT +[0-9]+ foobar +#pass diff --git a/ld/testsuite/ld-x86-64/pr19645.s b/ld/testsuite/ld-x86-64/pr19645.s new file mode 100644 index 0000000..88331ed --- /dev/null +++ b/ld/testsuite/ld-x86-64/pr19645.s @@ -0,0 +1,6 @@ + .text + .global bar + .type bar,"function" +bar: + movq foobar@GOTPCREL(%rip), %rax + .comm foobar,30,4 diff --git a/ld/testsuite/ld-x86-64/x86-64.exp b/ld/testsuite/ld-x86-64/x86-64.exp index 214b08b..5a3b24f 100644 --- a/ld/testsuite/ld-x86-64/x86-64.exp +++ b/ld/testsuite/ld-x86-64/x86-64.exp @@ -239,6 +239,12 @@ run_dump_test "pr14215" run_dump_test "pr14207" run_dump_test "gotplt1" run_dump_test "pie1" +run_dump_test "largecomm-1a" +run_dump_test "largecomm-1b" +run_dump_test "largecomm-1c" +run_dump_test "largecomm-1d" +run_dump_test "largecomm-1e" +run_dump_test "largecomm-1f" if { ![istarget "x86_64-*-linux*"] && ![istarget "x86_64-*-nacl*"]} { return @@ -375,6 +381,7 @@ run_dump_test "pr19636-2i" run_dump_test "pr19636-3a" run_dump_test "pr19636-3b" run_dump_test "pr19636-3c" +run_dump_test "pr19645" proc undefined_weak {cflags ldflags} { set testname "Undefined weak symbol" |