mirror of
https://github.com/zeromq/libzmq.git
synced 2025-01-07 09:48:07 +01:00
Problem: libtool -export-symbols-regexp seems to leak weak symbols
Solution: go back to using -Wl,--version-script. Use ax_check_vscript.m4 from the autoconf-archive to detect support on multiple platforms (eg Solaris ld(1) -M). libtool -export-symbols-regexp used ld(1) --retain-symbols-file under the hood, the latter lets some C++ weak symbols make their way into the dynamic symbols table, along with the zmq_* interface. The reason for such behavior is unknown to me.
This commit is contained in:
parent
546f8e7205
commit
687c75858e
@ -298,7 +298,9 @@ endif
|
|||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
src_libzmq_la_LDFLAGS += -export-symbols-regex '^zmq_.*'
|
if HAVE_VSCRIPT_COMPLEX
|
||||||
|
src_libzmq_la_LDFLAGS += $(VSCRIPT_LDFLAGS),$(srcdir)/src/libzmq.vers
|
||||||
|
endif
|
||||||
|
|
||||||
src_libzmq_la_CPPFLAGS = $(CODE_COVERAGE_CPPFLAGS) $(LIBUNWIND_CFLAGS)
|
src_libzmq_la_CPPFLAGS = $(CODE_COVERAGE_CPPFLAGS) $(LIBUNWIND_CFLAGS)
|
||||||
src_libzmq_la_CFLAGS = $(CODE_COVERAGE_CFLAGS) $(LIBUNWIND_CFLAGS)
|
src_libzmq_la_CFLAGS = $(CODE_COVERAGE_CFLAGS) $(LIBUNWIND_CFLAGS)
|
||||||
@ -1046,6 +1048,7 @@ EXTRA_DIST = \
|
|||||||
version.sh \
|
version.sh \
|
||||||
src/libzmq.pc.cmake.in \
|
src/libzmq.pc.cmake.in \
|
||||||
ci_build.sh \
|
ci_build.sh \
|
||||||
|
src/libzmq.vers \
|
||||||
src/version.rc.in \
|
src/version.rc.in \
|
||||||
tests/CMakeLists.txt \
|
tests/CMakeLists.txt \
|
||||||
unittests/CMakeLists.txt \
|
unittests/CMakeLists.txt \
|
||||||
|
@ -18,6 +18,7 @@ m4_include([m4/ax_check_compile_flag.m4])
|
|||||||
m4_include([m4/ax_cxx_compile_stdcxx_11.m4])
|
m4_include([m4/ax_cxx_compile_stdcxx_11.m4])
|
||||||
m4_include([m4/ax_code_coverage.m4])
|
m4_include([m4/ax_code_coverage.m4])
|
||||||
m4_include([m4/ax_valgrind_check.m4])
|
m4_include([m4/ax_valgrind_check.m4])
|
||||||
|
m4_include([m4/ax_check_vscript.m4])
|
||||||
m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])
|
m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])
|
||||||
|
|
||||||
# This lets us use PACKAGE_VERSION in Makefiles
|
# This lets us use PACKAGE_VERSION in Makefiles
|
||||||
@ -75,6 +76,7 @@ LIBZMQ_CONFIG_LIBTOOL
|
|||||||
AC_LIBTOOL_WIN32_DLL
|
AC_LIBTOOL_WIN32_DLL
|
||||||
AC_PROG_LIBTOOL
|
AC_PROG_LIBTOOL
|
||||||
AX_VALGRIND_CHECK
|
AX_VALGRIND_CHECK
|
||||||
|
AX_CHECK_VSCRIPT
|
||||||
|
|
||||||
AC_ARG_ENABLE([force-CXX98-compat],
|
AC_ARG_ENABLE([force-CXX98-compat],
|
||||||
[AS_HELP_STRING([--enable-force-CXX98-compat], [force C++98 build [default=disabled]])])
|
[AS_HELP_STRING([--enable-force-CXX98-compat], [force C++98 build [default=disabled]])])
|
||||||
|
142
m4/ax_check_vscript.m4
Normal file
142
m4/ax_check_vscript.m4
Normal file
@ -0,0 +1,142 @@
|
|||||||
|
# ===========================================================================
|
||||||
|
# https://www.gnu.org/software/autoconf-archive/ax_check_vscript.html
|
||||||
|
# ===========================================================================
|
||||||
|
#
|
||||||
|
# SYNOPSIS
|
||||||
|
#
|
||||||
|
# AX_CHECK_VSCRIPT
|
||||||
|
#
|
||||||
|
# DESCRIPTION
|
||||||
|
#
|
||||||
|
# Check whether the linker supports version scripts. Version scripts are
|
||||||
|
# used when building shared libraries to bind symbols to version nodes
|
||||||
|
# (helping to detect incompatibilities) or to limit the visibility of
|
||||||
|
# non-public symbols.
|
||||||
|
#
|
||||||
|
# Output:
|
||||||
|
#
|
||||||
|
# If version scripts are supported, VSCRIPT_LDFLAGS will contain the
|
||||||
|
# appropriate flag to pass to the linker. On GNU systems this would
|
||||||
|
# typically be "-Wl,--version-script", and on Solaris it would typically
|
||||||
|
# be "-Wl,-M".
|
||||||
|
#
|
||||||
|
# Two Automake conditionals are also set:
|
||||||
|
#
|
||||||
|
# HAVE_VSCRIPT is true if the linker supports version scripts with
|
||||||
|
# entries that use simple wildcards, like "local: *".
|
||||||
|
#
|
||||||
|
# HAVE_VSCRIPT_COMPLEX is true if the linker supports version scripts with
|
||||||
|
# pattern matching wildcards, like "global: Java_*".
|
||||||
|
#
|
||||||
|
# On systems that do not support symbol versioning, such as Mac OS X, both
|
||||||
|
# conditionals will be false. They will also be false if the user passes
|
||||||
|
# "--disable-symvers" on the configure command line.
|
||||||
|
#
|
||||||
|
# Example:
|
||||||
|
#
|
||||||
|
# configure.ac:
|
||||||
|
#
|
||||||
|
# AX_CHECK_VSCRIPT
|
||||||
|
#
|
||||||
|
# Makefile.am:
|
||||||
|
#
|
||||||
|
# if HAVE_VSCRIPT
|
||||||
|
# libfoo_la_LDFLAGS += $(VSCRIPT_LDFLAGS),@srcdir@/libfoo.map
|
||||||
|
# endif
|
||||||
|
#
|
||||||
|
# if HAVE_VSCRIPT_COMPLEX
|
||||||
|
# libbar_la_LDFLAGS += $(VSCRIPT_LDFLAGS),@srcdir@/libbar.map
|
||||||
|
# endif
|
||||||
|
#
|
||||||
|
# LICENSE
|
||||||
|
#
|
||||||
|
# Copyright (c) 2014 Kevin Cernekee <cernekee@gmail.com>
|
||||||
|
#
|
||||||
|
# Copying and distribution of this file, with or without modification, are
|
||||||
|
# permitted in any medium without royalty provided the copyright notice
|
||||||
|
# and this notice are preserved. This file is offered as-is, without any
|
||||||
|
# warranty.
|
||||||
|
|
||||||
|
#serial 2
|
||||||
|
|
||||||
|
# _AX_CHECK_VSCRIPT(flag, global-sym, action-if-link-succeeds, [junk-file=no])
|
||||||
|
AC_DEFUN([_AX_CHECK_VSCRIPT], [
|
||||||
|
AC_LANG_PUSH([C])
|
||||||
|
ax_check_vscript_save_flags="$LDFLAGS"
|
||||||
|
echo "V1 { global: $2; local: *; };" > conftest.map
|
||||||
|
AS_IF([test x$4 = xyes], [
|
||||||
|
echo "{" >> conftest.map
|
||||||
|
])
|
||||||
|
LDFLAGS="$LDFLAGS -Wl,$1,conftest.map"
|
||||||
|
AC_LINK_IFELSE([AC_LANG_PROGRAM([[int show, hide;]], [])], [$3])
|
||||||
|
LDFLAGS="$ax_check_vscript_save_flags"
|
||||||
|
rm -f conftest.map
|
||||||
|
AC_LANG_POP([C])
|
||||||
|
]) dnl _AX_CHECK_VSCRIPT
|
||||||
|
|
||||||
|
AC_DEFUN([AX_CHECK_VSCRIPT], [
|
||||||
|
|
||||||
|
AC_ARG_ENABLE([symvers],
|
||||||
|
AS_HELP_STRING([--disable-symvers],
|
||||||
|
[disable library symbol versioning [default=auto]]),
|
||||||
|
[want_symvers=$enableval],
|
||||||
|
[want_symvers=yes]
|
||||||
|
)
|
||||||
|
|
||||||
|
AS_IF([test x$want_symvers = xyes], [
|
||||||
|
|
||||||
|
dnl First test --version-script and -M with a simple wildcard.
|
||||||
|
|
||||||
|
AC_CACHE_CHECK([linker version script flag], ax_cv_check_vscript_flag, [
|
||||||
|
ax_cv_check_vscript_flag=unsupported
|
||||||
|
_AX_CHECK_VSCRIPT([--version-script], [show], [
|
||||||
|
ax_cv_check_vscript_flag=--version-script
|
||||||
|
])
|
||||||
|
AS_IF([test x$ax_cv_check_vscript_flag = xunsupported], [
|
||||||
|
_AX_CHECK_VSCRIPT([-M], [show], [ax_cv_check_vscript_flag=-M])
|
||||||
|
])
|
||||||
|
|
||||||
|
dnl The linker may interpret -M (no argument) as "produce a load map."
|
||||||
|
dnl If "-M conftest.map" doesn't fail when conftest.map contains
|
||||||
|
dnl obvious syntax errors, assume this is the case.
|
||||||
|
|
||||||
|
AS_IF([test x$ax_cv_check_vscript_flag != xunsupported], [
|
||||||
|
_AX_CHECK_VSCRIPT([$ax_cv_check_vscript_flag], [show],
|
||||||
|
[ax_cv_check_vscript_flag=unsupported], [yes])
|
||||||
|
])
|
||||||
|
])
|
||||||
|
|
||||||
|
dnl If the simple wildcard worked, retest with a complex wildcard.
|
||||||
|
|
||||||
|
AS_IF([test x$ax_cv_check_vscript_flag != xunsupported], [
|
||||||
|
ax_check_vscript_flag=$ax_cv_check_vscript_flag
|
||||||
|
AC_CACHE_CHECK([if version scripts can use complex wildcards],
|
||||||
|
ax_cv_check_vscript_complex_wildcards, [
|
||||||
|
ax_cv_check_vscript_complex_wildcards=no
|
||||||
|
_AX_CHECK_VSCRIPT([$ax_cv_check_vscript_flag], [sh*], [
|
||||||
|
ax_cv_check_vscript_complex_wildcards=yes])
|
||||||
|
])
|
||||||
|
ax_check_vscript_complex_wildcards="$ax_cv_check_vscript_complex_wildcards"
|
||||||
|
], [
|
||||||
|
ax_check_vscript_flag=
|
||||||
|
ax_check_vscript_complex_wildcards=no
|
||||||
|
])
|
||||||
|
], [
|
||||||
|
AC_MSG_CHECKING([linker version script flag])
|
||||||
|
AC_MSG_RESULT([disabled])
|
||||||
|
|
||||||
|
ax_check_vscript_flag=
|
||||||
|
ax_check_vscript_complex_wildcards=no
|
||||||
|
])
|
||||||
|
|
||||||
|
AS_IF([test x$ax_check_vscript_flag != x], [
|
||||||
|
VSCRIPT_LDFLAGS="-Wl,$ax_check_vscript_flag"
|
||||||
|
AC_SUBST([VSCRIPT_LDFLAGS])
|
||||||
|
])
|
||||||
|
|
||||||
|
AM_CONDITIONAL([HAVE_VSCRIPT],
|
||||||
|
[test x$ax_check_vscript_flag != x])
|
||||||
|
AM_CONDITIONAL([HAVE_VSCRIPT_COMPLEX],
|
||||||
|
[test x$ax_check_vscript_complex_wildcards = xyes])
|
||||||
|
|
||||||
|
]) dnl AX_CHECK_VSCRIPT
|
4
src/libzmq.vers
Normal file
4
src/libzmq.vers
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
{
|
||||||
|
global: zmq_*;
|
||||||
|
local: *;
|
||||||
|
};
|
Loading…
Reference in New Issue
Block a user