Skip to content

Commit fbc1dfc

Browse files
committed
Add lib-ld.m4
1 parent 1e67db4 commit fbc1dfc

File tree

1 file changed

+168
-0
lines changed

1 file changed

+168
-0
lines changed

m4/lib-ld.m4

Lines changed: 168 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,168 @@
1+
# lib-ld.m4 serial 9
2+
dnl Copyright (C) 1996-2003, 2009-2020 Free Software Foundation, Inc.
3+
dnl This file is free software; the Free Software Foundation
4+
dnl gives unlimited permission to copy and/or distribute it,
5+
dnl with or without modifications, as long as this notice is preserved.
6+
7+
dnl Subroutines of libtool.m4,
8+
dnl with replacements s/_*LT_PATH/AC_LIB_PROG/ and s/lt_/acl_/ to avoid
9+
dnl collision with libtool.m4.
10+
11+
dnl From libtool-2.4. Sets the variable with_gnu_ld to yes or no.
12+
AC_DEFUN([AC_LIB_PROG_LD_GNU],
13+
[AC_CACHE_CHECK([if the linker ($LD) is GNU ld], [acl_cv_prog_gnu_ld],
14+
[# I'd rather use --version here, but apparently some GNU lds only accept -v.
15+
case `$LD -v 2>&1 </dev/null` in
16+
*GNU* | *'with BFD'*)
17+
acl_cv_prog_gnu_ld=yes
18+
;;
19+
*)
20+
acl_cv_prog_gnu_ld=no
21+
;;
22+
esac])
23+
with_gnu_ld=$acl_cv_prog_gnu_ld
24+
])
25+
26+
dnl From libtool-2.4. Sets the variable LD.
27+
AC_DEFUN([AC_LIB_PROG_LD],
28+
[AC_REQUIRE([AC_PROG_CC])dnl
29+
AC_REQUIRE([AC_CANONICAL_HOST])dnl
30+
31+
AC_ARG_WITH([gnu-ld],
32+
[AS_HELP_STRING([--with-gnu-ld],
33+
[assume the C compiler uses GNU ld [default=no]])],
34+
[test "$withval" = no || with_gnu_ld=yes],
35+
[with_gnu_ld=no])dnl
36+
37+
# Prepare PATH_SEPARATOR.
38+
# The user is always right.
39+
if test "${PATH_SEPARATOR+set}" != set; then
40+
# Determine PATH_SEPARATOR by trying to find /bin/sh in a PATH which
41+
# contains only /bin. Note that ksh looks also at the FPATH variable,
42+
# so we have to set that as well for the test.
43+
PATH_SEPARATOR=:
44+
(PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 \
45+
&& { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 \
46+
|| PATH_SEPARATOR=';'
47+
}
48+
fi
49+
50+
if test -n "$LD"; then
51+
AC_MSG_CHECKING([for ld])
52+
elif test "$GCC" = yes; then
53+
AC_MSG_CHECKING([for ld used by $CC])
54+
elif test "$with_gnu_ld" = yes; then
55+
AC_MSG_CHECKING([for GNU ld])
56+
else
57+
AC_MSG_CHECKING([for non-GNU ld])
58+
fi
59+
if test -n "$LD"; then
60+
# Let the user override the test with a path.
61+
:
62+
else
63+
AC_CACHE_VAL([acl_cv_path_LD],
64+
[
65+
acl_cv_path_LD= # Final result of this test
66+
ac_prog=ld # Program to search in $PATH
67+
if test "$GCC" = yes; then
68+
# Check if gcc -print-prog-name=ld gives a path.
69+
case $host in
70+
*-*-mingw*)
71+
# gcc leaves a trailing carriage return which upsets mingw
72+
acl_output=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;;
73+
*)
74+
acl_output=`($CC -print-prog-name=ld) 2>&5` ;;
75+
esac
76+
case $acl_output in
77+
# Accept absolute paths.
78+
[[\\/]]* | ?:[[\\/]]*)
79+
re_direlt='/[[^/]][[^/]]*/\.\./'
80+
# Canonicalize the pathname of ld
81+
acl_output=`echo "$acl_output" | sed 's%\\\\%/%g'`
82+
while echo "$acl_output" | grep "$re_direlt" > /dev/null 2>&1; do
83+
acl_output=`echo $acl_output | sed "s%$re_direlt%/%"`
84+
done
85+
# Got the pathname. No search in PATH is needed.
86+
acl_cv_path_LD="$acl_output"
87+
ac_prog=
88+
;;
89+
"")
90+
# If it fails, then pretend we aren't using GCC.
91+
;;
92+
*)
93+
# If it is relative, then search for the first ld in PATH.
94+
with_gnu_ld=unknown
95+
;;
96+
esac
97+
fi
98+
if test -n "$ac_prog"; then
99+
# Search for $ac_prog in $PATH.
100+
acl_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
101+
for ac_dir in $PATH; do
102+
IFS="$acl_save_ifs"
103+
test -z "$ac_dir" && ac_dir=.
104+
if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then
105+
acl_cv_path_LD="$ac_dir/$ac_prog"
106+
# Check to see if the program is GNU ld. I'd rather use --version,
107+
# but apparently some variants of GNU ld only accept -v.
108+
# Break only if it was the GNU/non-GNU ld that we prefer.
109+
case `"$acl_cv_path_LD" -v 2>&1 </dev/null` in
110+
*GNU* | *'with BFD'*)
111+
test "$with_gnu_ld" != no && break
112+
;;
113+
*)
114+
test "$with_gnu_ld" != yes && break
115+
;;
116+
esac
117+
fi
118+
done
119+
IFS="$acl_save_ifs"
120+
fi
121+
case $host in
122+
*-*-aix*)
123+
AC_COMPILE_IFELSE(
124+
[AC_LANG_SOURCE(
125+
[[#if defined __powerpc64__ || defined _ARCH_PPC64
126+
int ok;
127+
#else
128+
error fail
129+
#endif
130+
]])],
131+
[# The compiler produces 64-bit code. Add option '-b64' so that the
132+
# linker groks 64-bit object files.
133+
case "$acl_cv_path_LD " in
134+
*" -b64 "*) ;;
135+
*) acl_cv_path_LD="$acl_cv_path_LD -b64" ;;
136+
esac
137+
], [])
138+
;;
139+
sparc64-*-netbsd*)
140+
AC_COMPILE_IFELSE(
141+
[AC_LANG_SOURCE(
142+
[[#if defined __sparcv9 || defined __arch64__
143+
int ok;
144+
#else
145+
error fail
146+
#endif
147+
]])],
148+
[],
149+
[# The compiler produces 32-bit code. Add option '-m elf32_sparc'
150+
# so that the linker groks 32-bit object files.
151+
case "$acl_cv_path_LD " in
152+
*" -m elf32_sparc "*) ;;
153+
*) acl_cv_path_LD="$acl_cv_path_LD -m elf32_sparc" ;;
154+
esac
155+
])
156+
;;
157+
esac
158+
])
159+
LD="$acl_cv_path_LD"
160+
fi
161+
if test -n "$LD"; then
162+
AC_MSG_RESULT([$LD])
163+
else
164+
AC_MSG_RESULT([no])
165+
AC_MSG_ERROR([no acceptable ld found in \$PATH])
166+
fi
167+
AC_LIB_PROG_LD_GNU
168+
])

0 commit comments

Comments
 (0)