mirror of
https://github.com/samba-team/samba.git
synced 2025-01-11 05:18:09 +03:00
s3:configure: not simply check for "ld" but for the linker used by $CC
this hopefully fixes Solaris' gcc build which uses the system ld by default. All in all we should clean up most of the compiler and linker flags depending on the actual compilers and linkers we use. Only some tweaks are OS-specific. A cleanup in this area should be done along with the move to a new build system (whensoever that will be ...).
This commit is contained in:
parent
d8ba02b73d
commit
1969b4acc3
@ -209,15 +209,14 @@ AC_SAMBA_PERL([true], [merged_build_possible=no])
|
|||||||
|
|
||||||
AC_CHECK_TOOL(AR, ar)
|
AC_CHECK_TOOL(AR, ar)
|
||||||
|
|
||||||
dnl Check if we use GNU ld
|
dnl Check if we (actually our C compiler!) use GNU ld
|
||||||
LD=ld
|
|
||||||
AC_PROG_LD_GNU
|
AC_PROG_LD_GNU
|
||||||
|
|
||||||
dnl Certain versions of GNU ld the default is not to have the
|
dnl Certain versions of GNU ld the default is not to have the
|
||||||
dnl --allow-shlib-undefined flag defined. This causes a stackload of
|
dnl --allow-shlib-undefined flag defined. This causes a stackload of
|
||||||
dnl warnings when building modules.
|
dnl warnings when building modules.
|
||||||
if test "$ac_cv_prog_gnu_ld" = "yes"; then
|
if test "$ac_cv_prog_gnu_ld" = "yes"; then
|
||||||
ac_cv_gnu_ld_version=`$LD -v 2>/dev/null | head -1`
|
ac_cv_gnu_ld_version=`$CC -Wl,-v /dev/null 2>/dev/null | head -1`
|
||||||
AC_MSG_CHECKING(GNU ld release date)
|
AC_MSG_CHECKING(GNU ld release date)
|
||||||
changequote(,)dnl
|
changequote(,)dnl
|
||||||
ac_cv_gnu_ld_date=`echo $ac_cv_gnu_ld_version | sed -n 's,^.*\([2-9][0-9][0-9][0-9]\)[-]*\([01][0-9]\)[-]*\([0-3][0-9]\).*$,\1\2\3,p'`
|
ac_cv_gnu_ld_date=`echo $ac_cv_gnu_ld_version | sed -n 's,^.*\([2-9][0-9][0-9][0-9]\)[-]*\([01][0-9]\)[-]*\([0-3][0-9]\).*$,\1\2\3,p'`
|
||||||
@ -1553,16 +1552,17 @@ DSO_EXPORTS=""
|
|||||||
;;
|
;;
|
||||||
*solaris*) AC_DEFINE(SUNOS5,1,[Whether the host os is solaris])
|
*solaris*) AC_DEFINE(SUNOS5,1,[Whether the host os is solaris])
|
||||||
BLDSHARED="true"
|
BLDSHARED="true"
|
||||||
LDSHFLAGS="-G"
|
|
||||||
SONAMEFLAG="-h "
|
|
||||||
if test "${GCC}" = "yes"; then
|
if test "${GCC}" = "yes"; then
|
||||||
PICFLAG="-fPIC"
|
PICFLAG="-fPIC"
|
||||||
SONAMEFLAG="-Wl,-soname="
|
SONAMEFLAG="-Wl,-soname="
|
||||||
if test "${ac_cv_prog_gnu_ld}" = "yes"; then
|
if test "${ac_cv_prog_gnu_ld}" = "yes"; then
|
||||||
DYNEXP="-Wl,-E"
|
DYNEXP="-Wl,-E"
|
||||||
fi
|
fi
|
||||||
|
# TODO: need to add $CFLAGS here for explicit 64-bit builds?
|
||||||
|
LDSHFLAGS="-shared"
|
||||||
else
|
else
|
||||||
PICFLAG="-KPIC"
|
PICFLAG="-KPIC"
|
||||||
|
SONAMEFLAG="-h "
|
||||||
## ${CFLAGS} added for building 64-bit shared
|
## ${CFLAGS} added for building 64-bit shared
|
||||||
## libs using Sun's Compiler
|
## libs using Sun's Compiler
|
||||||
LDSHFLAGS="-G \${CFLAGS}"
|
LDSHFLAGS="-G \${CFLAGS}"
|
||||||
|
4
source3/m4/aclocal.m4
vendored
4
source3/m4/aclocal.m4
vendored
@ -363,9 +363,9 @@ EOF
|
|||||||
|
|
||||||
dnl Copied from libtool.m4
|
dnl Copied from libtool.m4
|
||||||
AC_DEFUN(AC_PROG_LD_GNU,
|
AC_DEFUN(AC_PROG_LD_GNU,
|
||||||
[AC_CACHE_CHECK([if the linker ($LD) is GNU ld], ac_cv_prog_gnu_ld,
|
[AC_CACHE_CHECK([if the linker used by compiler is GNU ld], ac_cv_prog_gnu_ld,
|
||||||
[# I'd rather use --version here, but apparently some GNU ld's only accept -v.
|
[# I'd rather use --version here, but apparently some GNU ld's only accept -v.
|
||||||
if $LD -v 2>&1 </dev/null | egrep '(GNU|with BFD)' 1>&5; then
|
if $CC -Wl,-v /dev/null 2>&1 </dev/null | egrep '(GNU|with BFD)' 1>&5; then
|
||||||
ac_cv_prog_gnu_ld=yes
|
ac_cv_prog_gnu_ld=yes
|
||||||
else
|
else
|
||||||
ac_cv_prog_gnu_ld=no
|
ac_cv_prog_gnu_ld=no
|
||||||
|
Loading…
Reference in New Issue
Block a user