summaryrefslogtreecommitdiff
path: root/ld/testsuite
diff options
context:
space:
mode:
authorH.J. Lu <hjl.tools@gmail.com>2013-02-16 17:54:35 +0000
committerH.J. Lu <hjl.tools@gmail.com>2013-02-16 17:54:35 +0000
commit000458d5b04ef11d19dbc5eda3f33eaba3fa3a71 (patch)
tree3ddbf7976f409c3a89528fc5e5e56bdf16bb636c /ld/testsuite
parentd69670d501f1b6a4d587f6108b1a462ace4cc376 (diff)
downloadbinutils-redhat-000458d5b04ef11d19dbc5eda3f33eaba3fa3a71.tar.gz
Don't add DT_NEEDED for references from the dummy bfd
bfd/ PR ld/15146 * elflink.c (elf_link_add_object_symbols): Don't add DT_NEEDED for references from the dummy bfd. ld/ PR ld/15146 * plugin.c (plugin_notice): Replace the undefined dummy bfd with the real one. ld/testsuite/ PR ld/15146 * ld-plugin/pr15146.d: New file. * ld-plugin/pr15146a.c: Likewise. * ld-plugin/pr15146b.c: Likewise. * ld-plugin/pr15146c.c: Likewise. * ld-plugin/pr15146d.c: Likewise. * ld-plugin/lto.exp: Add tests for PR ld/15146.
Diffstat (limited to 'ld/testsuite')
-rw-r--r--ld/testsuite/ChangeLog11
-rw-r--r--ld/testsuite/ld-plugin/lto.exp25
-rw-r--r--ld/testsuite/ld-plugin/pr15146.d4
-rw-r--r--ld/testsuite/ld-plugin/pr15146a.c13
-rw-r--r--ld/testsuite/ld-plugin/pr15146b.c1
-rw-r--r--ld/testsuite/ld-plugin/pr15146d.c7
6 files changed, 61 insertions, 0 deletions
diff --git a/ld/testsuite/ChangeLog b/ld/testsuite/ChangeLog
index dd7ee337f7..0e5eda476e 100644
--- a/ld/testsuite/ChangeLog
+++ b/ld/testsuite/ChangeLog
@@ -1,3 +1,14 @@
+2013-02-16 H.J. Lu <hongjiu.lu@intel.com>
+
+ PR ld/15146
+ * ld-plugin/pr15146.d: New file.
+ * ld-plugin/pr15146a.c: Likewise.
+ * ld-plugin/pr15146b.c: Likewise.
+ * ld-plugin/pr15146c.c: Likewise.
+ * ld-plugin/pr15146d.c: Likewise.
+
+ * ld-plugin/lto.exp: Add tests for PR ld/15146.
+
2013-02-15 Markos Chandras <markos.chandras@imgtec.com>
* ld-metag/pcrel.d: Fix the expected disassembler
diff --git a/ld/testsuite/ld-plugin/lto.exp b/ld/testsuite/ld-plugin/lto.exp
index 365b98800a..269dde7d2a 100644
--- a/ld/testsuite/ld-plugin/lto.exp
+++ b/ld/testsuite/ld-plugin/lto.exp
@@ -180,6 +180,24 @@ set lto_link_elf_tests {
{"PR ld/13244"
"-shared -O2 -fPIC -flto -fuse-linker-plugin -nostdlib" "-O2 -fno-early-inlining -flto"
{pr13244.c} {{"readelf" {-s --wide} "pr13244.d"}} "pr13244.so" "c"}
+ {"Build libpr15146a.a"
+ "" "-flto -O2"
+ {pr15146a.c} {} "lib15146a.a"}
+ {"Build pr15146b.so"
+ "-shared" "-O2 -fpic"
+ {pr15146b.c} {} "pr15146b.so" "c"}
+ {"Build pr15146c.so"
+ "-shared tmpdir/pr15146b.so" "-O2 -fpic"
+ {pr15146c.c} {} "pr15146c.so" "c"}
+ {"PR ld/15146 (1)"
+ "-O2 -flto -fuse-linker-plugin -Wl,-rpath-link,. -Wl,--no-copy-dt-needed-entries tmpdir/pr15146a.o tmpdir/pr15146c.so" ""
+ {dummy.c} {{"readelf" {-d} "pr15146.d"}} "pr15146a.exe"}
+ {"Build libpr15146d.a"
+ "" "-flto -O2"
+ {pr15146d.c} {} "lib15146d.a"}
+ {"Build libpr15146d.a"
+ "" "-flto -O2"
+ {pr15146d.c} {} "lib15146d.a"}
}
# Check final symbols in executables.
@@ -269,6 +287,13 @@ run_cc_link_tests $lto_link_tests
if { [is_elf_format]
&& [run_host_cmd_yesno $CC "-shared -fPIC $srcdir/$subdir/dummy.c -o tmpdir/t.so"] } {
run_cc_link_tests $lto_link_elf_tests
+ set testname "PR ld/15146 (2)"
+ set exec_output [run_host_cmd "$CC" "$gcc_gas_flag $gcc_ld_flag -O2 -flto -fuse-linker-plugin -Wl,-rpath-link,. -Wl,--no-copy-dt-needed-entries tmpdir/pr15146d.o tmpdir/pr15146c.so"]
+ if { [ regexp "ltrans.o: undefined reference to symbol 'xxx'" $exec_output ] } {
+ pass $testname
+ } {
+ fail $testname
+ }
}
set testname "Build liblto-11.a"
diff --git a/ld/testsuite/ld-plugin/pr15146.d b/ld/testsuite/ld-plugin/pr15146.d
new file mode 100644
index 0000000000..48d4b85446
--- /dev/null
+++ b/ld/testsuite/ld-plugin/pr15146.d
@@ -0,0 +1,4 @@
+#failif
+#...
+ +0x[0-9a-f]+ +\(NEEDED\) +Shared library: +\[.*pr15146b.so\]
+#...
diff --git a/ld/testsuite/ld-plugin/pr15146a.c b/ld/testsuite/ld-plugin/pr15146a.c
new file mode 100644
index 0000000000..a22860af5b
--- /dev/null
+++ b/ld/testsuite/ld-plugin/pr15146a.c
@@ -0,0 +1,13 @@
+extern int xxx;
+
+int
+bar (void)
+{
+ return xxx;
+}
+
+int
+main ()
+{
+ return 0;
+}
diff --git a/ld/testsuite/ld-plugin/pr15146b.c b/ld/testsuite/ld-plugin/pr15146b.c
new file mode 100644
index 0000000000..90eb21ea55
--- /dev/null
+++ b/ld/testsuite/ld-plugin/pr15146b.c
@@ -0,0 +1 @@
+int xxx = 3;
diff --git a/ld/testsuite/ld-plugin/pr15146d.c b/ld/testsuite/ld-plugin/pr15146d.c
new file mode 100644
index 0000000000..ba1e0abfa6
--- /dev/null
+++ b/ld/testsuite/ld-plugin/pr15146d.c
@@ -0,0 +1,7 @@
+extern int xxx;
+
+int
+main ()
+{
+ return xxx;
+}