2 # Last modified: Wed May 27 13:04:45 EDT 1998
3 # Andy Dougherty <doughera@lafcol.lafayette.edu>
4 # Based on input from lots of folks, especially
5 # Dean Roehrich <roehrich@ironwood-fddi.cray.com>
7 # If perl fails tests that involve dynamic loading of extensions, and
8 # you are using gcc, be sure that you are NOT using GNU as and ld. One
9 # way to do that is to invoke Configure with
11 # sh Configure -Dcc='gcc -B/usr/ccs/bin/'
19 # Avoid all libraries in /usr/ucblib.
20 set `echo $glibpth | sed -e 's@/usr/ucblib@@'`
23 # Remove bad libraries. -lucb contains incompatible routines.
24 # -lld doesn't do anything useful.
25 # -lmalloc can cause a problem with GNU CC & Solaris. Specifically,
26 # libmalloc.a may allocate memory that is only 4 byte aligned, but
27 # GNU CC on the Sparc assumes that doubles are 8 byte aligned.
28 # Thanks to Hallvard B. Furuseth <h.b.furuseth@usit.uio.no>
29 set `echo " $libswanted " | sed -e 's@ ld @ @' -e 's@ malloc @ @' -e 's@ ucb @ @'`
32 # Look for architecture name. We want to suggest a useful default.
35 if test -f /usr/bin/arch; then
36 archname=`/usr/bin/arch`
37 archname="${archname}-${osname}"
38 elif test -f /usr/ucb/arch; then
39 archname=`/usr/ucb/arch`
40 archname="${archname}-${osname}"
45 ######################################################
46 # General sanity testing. See below for excerpts from the Solaris FAQ.
48 # From roehrich@ironwood-fddi.cray.com Wed Sep 27 12:51:46 1995
49 # Date: Thu, 7 Sep 1995 16:31:40 -0500
50 # From: Dean Roehrich <roehrich@ironwood-fddi.cray.com>
51 # To: perl5-porters@africa.nicoh.com
52 # Subject: Re: On perl5/solaris/gcc
54 # Here's another draft of the perl5/solaris/gcc sanity-checker.
56 case `type ${cc:-cc}` in
57 */usr/ucb/cc*) cat <<END >&4
59 NOTE: Some people have reported problems with /usr/ucb/cc.
60 If you have difficulties, please make sure the directory
61 containing your C compiler is before /usr/ucb in your PATH.
68 # Check that /dev/fd is mounted. If it is not mounted, let the
69 # user know that suid scripts may not work.
70 /usr/bin/df /dev/fd 2>&1 > /dev/null
76 NOTE: Your system does not have /dev/fd mounted. If you want to
77 be able to use set-uid scripts you must ask your system administrator
85 # See if libucb can be found in /usr/lib. If it is, warn the user
86 # that this may cause problems while building Perl extensions.
87 /usr/bin/ls /usr/lib/libucb* >/dev/null 2>&1
92 NOTE: libucb has been found in /usr/lib. libucb should reside in
93 /usr/ucblib. You may have trouble while building Perl extensions.
99 # Use shell built-in 'type' command instead of /usr/bin/which to
100 # avoid possible csh start-up problems and also to use the same shell
101 # we'll be using to Configure and make perl.
102 # The path name is the last field in the output, but the type command
103 # has an annoying array of possible outputs, e.g.:
104 # make is hashed (/opt/gnu/bin/make)
107 # use a command like type make | awk '{print $NF}' | sed 's/[()]//g'
109 # See if make(1) is GNU make(1).
110 # If it is, make sure the setgid bit is not set.
111 make -v > make.vers 2>&1
112 if grep GNU make.vers > /dev/null 2>&1; then
113 tmp=`type make | awk '{print $NF}' | sed 's/[()]//g'`
114 case "`/usr/bin/ls -lL $tmp`" in
118 NOTE: Your PATH points to GNU make, and your GNU make has the set-group-id
119 bit set. You must either rearrange your PATH to put /usr/ccs/bin before the
120 GNU utilities or you must ask your system administrator to disable the
121 set-group-id bit on GNU make.
129 # XXX EXPERIMENTAL A.D. 2/27/1998
130 # XXX This script UU/cc.cbu will get 'called-back' by Configure after it
131 # XXX has prompted the user for the C compiler to use.
132 cat > UU/cc.cbu <<'EOSH'
133 # If the C compiler is gcc:
134 # - check the fixed-includes
135 # - check as(1) and ld(1), they should not be GNU
136 # (GNU as and ld 2.8.1 and later are reportedly ok, however.)
137 # If the C compiler is not gcc:
138 # - check as(1) and ld(1), they should not be GNU
139 # (GNU as and ld 2.8.1 and later are reportedly ok, however.)
141 # Watch out in case they have not set $cc.
143 # Get gcc to share its secrets.
144 echo 'main() { return 0; }' > try.c
145 # Indent to avoid propagation to config.sh
146 verbose=`${cc:-cc} -v -o try try.c 2>&1`
148 if echo "$verbose" | grep '^Reading specs from' >/dev/null 2>&1; then
154 tmp=`echo "$verbose" | grep '^Reading' |
155 awk '{print $NF}' | sed 's/specs$/include/'`
157 # Determine if the fixed-includes look like they'll work.
158 # Doesn't work anymore for gcc-2.7.2.
160 # See if as(1) is GNU as(1). GNU as(1) won't work for this job.
161 if echo "$verbose" | grep ' /usr/ccs/bin/as ' >/dev/null 2>&1; then
166 NOTE: You are using GNU as(1). GNU as(1) will not build Perl.
167 I'm arranging to use /usr/ccs/bin/as by including -B/usr/ccs/bin/
168 in your ${cc:-cc} command. (Note that the trailing "/" is required.)
171 cc="${cc:-cc} -B/usr/ccs/bin/"
174 # See if ld(1) is GNU ld(1). GNU ld(1) won't work for this job.
175 # Recompute $verbose since we may have just changed $cc.
176 verbose=`${cc:-cc} -v -o try try.c 2>&1 | grep ld 2>&1`
177 if echo "$verbose" | grep ' /usr/ccs/bin/ld ' >/dev/null 2>&1; then
180 # It's not /usr/ccs/bin/ld - but it might be egcs's ld wrapper,
181 # which calls /usr/ccs/bin/ld in turn. Passing -V to it will
182 # make it show its true colors.
184 myld=`echo $verbose| grep ld | awk '/\/ld/ {print $1}'`
185 # This assumes that gcc's output will not change, and that
186 # /full/path/to/ld will be the first word of the output.
188 # all Solaris versions of ld I've seen contain the magic
189 # string used in the grep below.
190 if $myld -V 2>&1 | grep "ld: Software Generation Utilities" >/dev/null 2>&1; then
193 Aha. You're using egcs and /usr/ccs/bin/ld.
200 NOTE: You are using GNU ld(1). GNU ld(1) will not build Perl.
201 I'm arranging to use /usr/ccs/bin/ld by including -B/usr/ccs/bin/
202 in your ${cc:-cc} command. (Note that the trailing "/" is required.)
205 cc="${cc:-cc} -B/usr/ccs/bin/"
215 # See if as(1) is GNU as(1). GNU as(1) won't work for this job.
216 case `as --version < /dev/null 2>&1` in
220 NOTE: You are using GNU as(1). GNU as(1) will not build Perl.
221 You must arrange to use /usr/ccs/bin/as, perhaps by adding /usr/ccs/bin
222 to the beginning of your PATH.
228 # See if ld(1) is GNU ld(1). GNU ld(1) won't work for this job.
229 # ld --version doesn't properly report itself as a GNU tool,
230 # as of ld version 2.6, so we need to be more strict. TWP 9/5/96
232 case `ld --version < /dev/null 2>&1` in
233 *GNU*|ld\ version\ 2*)
239 # Try to guess from path
240 case `type ld | awk '{print $NF}'` in
248 NOTE: You are apparently using GNU ld(1). GNU ld(1) will not build Perl.
249 You must arrange to use /usr/ccs/bin/ld, perhaps by adding /usr/ccs/bin
250 to the beginning of your PATH.
257 # as --version or ld --version might dump core.
264 if [ "X$usethreads" = "X$define" ]; then
265 ccflags="-D_REENTRANT $ccflags"
266 # -lpthread needs to come before -lc but after other libraries such
267 # as -lgdbm and such like. We assume here that -lc is present in
268 # libswanted. If that fails to be true in future, then this can be
269 # changed to add pthread to the very end of libswanted.
270 # sched_yield is in -lposix4
271 set `echo X "$libswanted "| sed -e 's/ c / posix4 pthread c /'`
275 # On Solaris 2.6 x86 there is a bug with sigsetjmp() and siglongjmp()
276 # when linked with the threads library, such that whatever positive value
277 # you pass to siglongjmp(), sigsetjmp() returns 1.
278 # Thanks to Simon Parsons <S.Parsons@ftel.co.uk> for this report.
279 # Sun BugID is 4117946, "sigsetjmp always returns 1 when called by
280 # siglongjmp in a MT program". As of 19980622, there is no patch
283 /* Test for sig(set|long)jmp bug. */
291 ret = sigsetjmp(env, 1);
292 if (ret) { return ret == 2; }
296 if test "`arch`" = i86pc -a "$osvers" = 2.6 \
297 && ${cc:-cc} try.c -lpthread >/dev/null 2>&1 && ./a.out; then
301 You will see a *** WHOA THERE!!! *** message from Configure for
302 d_sigsetjmp. Keep the recommended value. See hints/solaris_2.sh
303 for more information.
309 # This is just a trick to include some useful notes.
310 cat > /dev/null <<'End_of_Solaris_Notes'
312 Here are some notes kindly contributed by Dean Roehrich.
315 Generic notes about building Perl5 on Solaris:
316 - Use /usr/ccs/bin/make.
317 - If you use GNU make, remove its setgid bit.
318 - Remove all instances of *ucb* from your path.
319 - Make sure libucb is not in /usr/lib (it should be in /usr/ucblib).
320 - Do not use GNU as or GNU ld, or any of GNU binutils or GNU libc.
321 - Do not use /usr/ucb/cc.
322 - Do not change Configure's default answers, except for the path names.
323 - Do not use -lmalloc.
324 - Do not build on SunOS 4 and expect it to work properly on SunOS 5.
325 - /dev/fd must be mounted if you want set-uid scripts to work.
328 Here are the gcc-related questions and answers from the Solaris 2 FAQ. Note
331 - run fixincludes correctly
332 - don't use GNU as or GNU ld
334 Question 5.7 covers the __builtin_va_alist problem people are always seeing.
335 Question 6.1.3 covers the GNU as and GNU ld issues which are always biting
337 Question 6.9 is for those who are still trying to compile Perl4.
339 The latest Solaris 2 FAQ can be found in the following locations:
340 rtfm.mit.edu:/pub/usenet-by-group/comp.sys.sun.admin
341 ftp.fwi.uva.nl:/pub/solaris
343 Perl5 comes with a script in the top-level directory called "myconfig" which
344 will print a summary of the configuration in your config.sh. My summary for
345 Solaris 2.4 and gcc 2.6.3 follows. I have also built with gcc 2.7.0 and the
346 results are identical. This configuration was generated with Configure's -d
347 option (take all defaults, don't bother prompting me). All tests pass for
350 Summary of my perl5 (patchlevel 1) configuration:
352 osname=solaris, osver=2.4, archname=sun4-solaris
353 uname='sunos poplar 5.4 generic_101945-27 sun4d sparc '
356 cc='gcc', optimize='-O', ld='gcc'
360 stdchar='unsigned char', d_stdstdio=define, usevfork=false
361 voidflags=15, castflags=0, d_casti32=define, d_castneg=define
362 intsize=4, alignbytes=8, usemymalloc=y, randbits=15
365 libpth=/lib /usr/lib /usr/ccs/lib /usr/local/lib
366 libs=-lsocket -lnsl -ldl -lm -lc -lcrypt
367 libc=/usr/lib/libc.so
369 dlsrc=dl_dlopen.xs, dlext=so, d_dlsymun=undef
370 cccdlflags='-fpic', ccdlflags=' ', lddlflags='-G'
379 From: Casper.Dik@Holland.Sun.COM (Casper H.S. Dik - Network Security Engineer)
380 Subject: Solaris 2 Frequently Asked Questions (FAQ) 1.48
381 Date: 25 Jul 1995 12:20:18 GMT
383 5.7) Why do I get __builtin_va_alist or __builtin_va_arg_incr undefined?
385 You're using gcc without properly installing the gcc fixed
386 include files. Or you ran fixincludes after installing gcc
387 w/o moving the gcc supplied varargs.h and stdarg.h files
388 out of the way and moving them back again later. This often
389 happens when people install gcc from a binary distribution.
390 If there's a tmp directory in gcc's include directory, fixincludes
391 didn't complete. You should have run "just-fixinc" instead.
393 Another possible cause is using ``gcc -I/usr/include.''
395 6.1) Where is the C compiler or where can I get one?
401 Gcc is available from the GNU archives in source and binary
402 form. Look in a directory called sparc-sun-solaris2 for
403 binaries. You need gcc 2.3.3 or later. You should not use
404 GNU as or GNU ld. Make sure you run just-fixinc if you use
405 a binary distribution. Better is to get a binary version and
406 use that to bootstrap gcc from source.
410 When you install gcc, don't make the mistake of installing
411 GNU binutils or GNU libc, they are not as capable as their
412 counterparts you get with Solaris 2.x.
414 6.9) I can't get perl 4.036 to compile or run.
416 Run Configure, and use the solaris_2_0 hints, *don't* use
417 the solaris_2_1 hints and don't use the config.sh you may
418 already have. First you must make sure Configure and make
419 don't find /usr/ucb/cc. (It must use gcc or the native C
420 compiler: /opt/SUNWspro/bin/cc)
422 Some questions need a special answer.
424 Are your system (especially dbm) libraries compiled with gcc? [y] y
426 yes: gcc 2.3.3 or later uses the standard calling
427 conventions, same as Sun's C.
429 Any additional cc flags? [ -traditional -Dvolatile=__volatile__
430 -I/usr/ucbinclude] -traditional -Dvolatile=__volatile__
431 Remove /usr/ucbinclude.
433 Any additional libraries? [-lsocket -lnsl -ldbm -lmalloc -lm
434 -lucb] -lsocket -lnsl -lm
436 Don't include -ldbm, -lmalloc and -lucb.
438 Perl 5 compiled out of the box.