aboutsummaryrefslogtreecommitdiff
path: root/ld/testsuite/ld-elf/indirect5.map
diff options
context:
space:
mode:
authorAlan Modra <amodra@gmail.com>2017-04-17 18:33:52 +0930
committerAlan Modra <amodra@gmail.com>2017-04-17 23:14:37 +0930
commitc5d37467b152fe98f02ac1ff8188e32ecd0def95 (patch)
tree46caf31ba379349fdf89ea75c9841ebad7b44ee9 /ld/testsuite/ld-elf/indirect5.map
parentc661778cb6b406d5b55fbf22ff88fbc85ee3f4c2 (diff)
downloadgdb-c5d37467b152fe98f02ac1ff8188e32ecd0def95.zip
gdb-c5d37467b152fe98f02ac1ff8188e32ecd0def95.tar.gz
gdb-c5d37467b152fe98f02ac1ff8188e32ecd0def95.tar.bz2
Undo dynamic symbol state after regular object sym type mismatch
We already handle the case of an object file first defining a symbol that a later shared library also defines where the symbol types are incompatible. This patch handles the reverse, when a later object file defines an incompatible symbol defined by an earlier shared library. bfd/ * elflink.c (_bfd_elf_merge_symbol): Undo dynamic linking state when a regular object file defines a symbol with incompatible type to that defined by an earlier shared lib. ld/ * testsuite/ld-elf/indirect5a.c, * testsuite/ld-elf/indirect5b.c, * testsuite/ld-elf/indirect5.map, * testsuite/ld-elf/indirect5.out: New test. * testsuite/ld-elf/indirect6a.c: Likewise. * testsuite/ld-elf/indirect.exp (check_dynamic_syms): New proc. Run new tests and check dynsyms.
Diffstat (limited to 'ld/testsuite/ld-elf/indirect5.map')
-rw-r--r--ld/testsuite/ld-elf/indirect5.map6
1 files changed, 6 insertions, 0 deletions
diff --git a/ld/testsuite/ld-elf/indirect5.map b/ld/testsuite/ld-elf/indirect5.map
new file mode 100644
index 0000000..f62b414
--- /dev/null
+++ b/ld/testsuite/ld-elf/indirect5.map
@@ -0,0 +1,6 @@
+FOO
+{
+global:
+ foo;
+ bar;
+};