https://sourceware.org/bugzilla/show_bug.cgi?id=22318

--- Comment #6 from cvs-commit at gcc dot gnu.org <cvs-commit at gcc dot 
gnu.org> ---
The master branch has been updated by H.J. Lu <h...@sourceware.org>:

https://sourceware.org/git/gitweb.cgi?p=binutils-gdb.git;h=3cba8b6c93ab8c573ba4678255df11486de61c54

commit 3cba8b6c93ab8c573ba4678255df11486de61c54
Author: H.J. Lu <hjl.to...@gmail.com>
Date:   Thu Apr 5 15:31:41 2018 -0700

    Use dlsym to check if libdl is needed for plugin

    config/plugins.m4 has

     if test "$plugins" = "yes"; then
        AC_SEARCH_LIBS([dlopen], [dl])
      fi

    Plugin uses dlsym, but libasan.so only intercepts dlopen, not dlsym:

    [hjl@gnu-tools-1 binutils-text]$ nm -D /lib64/libasan.so.4| grep " dl"
    0000000000038580 W dlclose
                     U dl_iterate_phdr
    000000000004dc50 W dlopen
                     U dlsym
                     U dlvsym
    [hjl@gnu-tools-1 binutils-text]$

    Testing dlopen for libdl leads to false negative when -fsanitize=address
    is used.  It results in link failure:

    ../bfd/.libs/libbfd.a(plugin.o): undefined reference to symbol
'dlsym@@GLIBC_2.16'

    dlsym should be used to check if libdl is needed for plugin.

    bfd/

        PR gas/22318
        * configure: Regenerated.

    binutils/

        PR gas/22318
        * configure: Regenerated.

    gas/

        PR gas/22318
        * configure: Regenerated.

    gprof/

        PR gas/22318
        * configure: Regenerated.

    ld/

        PR gas/22318
        * configure: Regenerated.

-- 
You are receiving this mail because:
You are on the CC list for the bug.
_______________________________________________
bug-binutils mailing list
bug-binutils@gnu.org
https://lists.gnu.org/mailman/listinfo/bug-binutils

Reply via email to