From d023c380db01abd7f6f2a53edecca09488b53982 Mon Sep 17 00:00:00 2001 From: "H.J. Lu" Date: Fri, 8 Jan 2010 03:03:16 +0000 Subject: [PATCH] Fix PR ld/11138 bfd/ 2010-01-07 H.J. Lu PR ld/11138 * elflink.c (elf_link_check_versioned_symbol): Don't abort if a symbol referenced by DSO is is defined in a non-shared object and forced local. ld/testsuite/ 2010-01-07 H.J. Lu PR ld/11138 * ld-elf/pr11138-1.c: New. * ld-elf/pr11138-1.map: Likewise. * ld-elf/pr11138-2.c: Likewise. * ld-elf/pr11138-2.map: Likewise. * ld-elf/pr11138.out: Likewise. * ld-elf/shared.exp (build_tests): Add libpr11138-1.so and libpr11138-2.o. (run_tests): Add 2 tests for PR ld/11138. --- bfd/ChangeLog | 7 +++++++ bfd/elflink.c | 8 ++++++-- ld/testsuite/ChangeLog | 13 +++++++++++++ ld/testsuite/ld-elf/pr11138-1.c | 13 +++++++++++++ ld/testsuite/ld-elf/pr11138-1.map | 4 ++++ ld/testsuite/ld-elf/pr11138-2.c | 17 +++++++++++++++++ ld/testsuite/ld-elf/pr11138-2.map | 4 ++++ ld/testsuite/ld-elf/pr11138.out | 2 ++ ld/testsuite/ld-elf/shared.exp | 12 ++++++++++++ 9 files changed, 78 insertions(+), 2 deletions(-) create mode 100644 ld/testsuite/ld-elf/pr11138-1.c create mode 100644 ld/testsuite/ld-elf/pr11138-1.map create mode 100644 ld/testsuite/ld-elf/pr11138-2.c create mode 100644 ld/testsuite/ld-elf/pr11138-2.map create mode 100644 ld/testsuite/ld-elf/pr11138.out diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 0f2e0e4..b9a32c4 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,5 +1,12 @@ 2010-01-07 H.J. Lu + PR ld/11138 + * elflink.c (elf_link_check_versioned_symbol): Don't abort if + a symbol referenced by DSO is is defined in a non-shared object + and forced local. + +2010-01-07 H.J. Lu + PR ld/11133 * elflink.c (_bfd_elf_gc_mark_hook): Check section XXX for undefined __start_XXX/__stop_XXX in all input files and set diff --git a/bfd/elflink.c b/bfd/elflink.c index f9f804d..24d8702 100644 --- a/bfd/elflink.c +++ b/bfd/elflink.c @@ -8492,10 +8492,14 @@ elf_link_check_versioned_symbol (struct bfd_link_info *info, _bfd_elf_swap_versym_in (input, ever, &iver); - if ((iver.vs_vers & VERSYM_HIDDEN) == 0) + if ((iver.vs_vers & VERSYM_HIDDEN) == 0 + && !(h->def_regular + && h->forced_local)) { /* If we have a non-hidden versioned sym, then it should - have provided a definition for the undefined sym. */ + have provided a definition for the undefined sym unless + it is defined in a non-shared object and forced local. + */ abort (); } diff --git a/ld/testsuite/ChangeLog b/ld/testsuite/ChangeLog index 220a6d9..24ab471 100644 --- a/ld/testsuite/ChangeLog +++ b/ld/testsuite/ChangeLog @@ -1,5 +1,18 @@ 2010-01-07 H.J. Lu + PR ld/11138 + * ld-elf/pr11138-1.c: New. + * ld-elf/pr11138-1.map: Likewise. + * ld-elf/pr11138-2.c: Likewise. + * ld-elf/pr11138-2.map: Likewise. + * ld-elf/pr11138.out: Likewise. + + * ld-elf/shared.exp (build_tests): Add libpr11138-1.so and + libpr11138-2.o. + (run_tests): Add 2 tests for PR ld/11138. + +2010-01-07 H.J. Lu + PR ld/11133 * ld-gc/gc.exp: Run start. diff --git a/ld/testsuite/ld-elf/pr11138-1.c b/ld/testsuite/ld-elf/pr11138-1.c new file mode 100644 index 0000000..2aab815 --- /dev/null +++ b/ld/testsuite/ld-elf/pr11138-1.c @@ -0,0 +1,13 @@ +#include + +void +bar (void) +{ + printf ("DSO bar\n"); +} + +void +foo (void) +{ + bar (); +} diff --git a/ld/testsuite/ld-elf/pr11138-1.map b/ld/testsuite/ld-elf/pr11138-1.map new file mode 100644 index 0000000..8676b1f --- /dev/null +++ b/ld/testsuite/ld-elf/pr11138-1.map @@ -0,0 +1,4 @@ +VERS_1 { + global: bar; foo; + local: *; +}; diff --git a/ld/testsuite/ld-elf/pr11138-2.c b/ld/testsuite/ld-elf/pr11138-2.c new file mode 100644 index 0000000..ccca280 --- /dev/null +++ b/ld/testsuite/ld-elf/pr11138-2.c @@ -0,0 +1,17 @@ +#include + +extern void foo (void); + +void +bar (void) +{ + printf ("MAIN bar\n"); +} + +int +main (void) +{ + bar (); + foo (); + return 0; +} diff --git a/ld/testsuite/ld-elf/pr11138-2.map b/ld/testsuite/ld-elf/pr11138-2.map new file mode 100644 index 0000000..1f8fb15 --- /dev/null +++ b/ld/testsuite/ld-elf/pr11138-2.map @@ -0,0 +1,4 @@ +{ + global: main; + local: *; +}; diff --git a/ld/testsuite/ld-elf/pr11138.out b/ld/testsuite/ld-elf/pr11138.out new file mode 100644 index 0000000..6dbdc49 --- /dev/null +++ b/ld/testsuite/ld-elf/pr11138.out @@ -0,0 +1,2 @@ +MAIN bar +DSO bar diff --git a/ld/testsuite/ld-elf/shared.exp b/ld/testsuite/ld-elf/shared.exp index 3128e05..d0c3478 100644 --- a/ld/testsuite/ld-elf/shared.exp +++ b/ld/testsuite/ld-elf/shared.exp @@ -148,6 +148,12 @@ set build_tests { {"Build libpr9679.so" "-shared" "-fPIC -O0" {pr9679-1.c pr9679-2.c} {{readelf {-s} pr9679.rd}} "libpr9679.so"} + {"Build libpr11138-1.so" + "-shared -Wl,--version-script=pr11138-1.map" "-fPIC" + {pr11138-1.c} {} "libpr11138-1.so"} + {"Build libpr11138-2.o" + "-r -nostdlib" "" + {pr11138-2.c} {} "libpr11138-2.o"} } set run_tests { @@ -266,6 +272,12 @@ set run_tests { {"Run with comm1.o libfunc1.so" "tmpdir/comm1.o tmpdir/libfunc1.so" "" {dummy.c} "comm1" "pass.out"} + {"Run with pr11138-2.c libpr11138-1.so" + "--version-script=pr11138-2.map tmpdir/pr11138-2.o tmpdir/libpr11138-1.so" "" + {dummy.c} "pr11138a" "pr11138.out"} + {"Run with libpr11138-1.so pr11138-2.c" + "--version-script=pr11138-2.map tmpdir/libpr11138-1.so tmpdir/pr11138-2.o" "" + {dummy.c} "pr11138b" "pr11138.out"} } run_cc_link_tests $build_tests -- 2.7.4