fix AIX hints for PL_* changes
[p5sagit/p5-mst-13.2.git] / hints / solaris_2.sh
CommitLineData
8e07c86e 1# hints/solaris_2.sh
bd89102f 2# Last modified: Wed May 27 13:04:45 EDT 1998
8e07c86e 3# Andy Dougherty <doughera@lafcol.lafayette.edu>
4# Based on input from lots of folks, especially
5# Dean Roehrich <roehrich@ironwood-fddi.cray.com>
7beaa944 6
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
10#
11# sh Configure -Dcc='gcc -B/usr/ccs/bin/'
12#
a81c337c 13
8e07c86e 14# See man vfork.
a0d0e21e 15usevfork=false
b1db1e90 16
a0d0e21e 17d_suidsafe=define
b1db1e90 18
8e07c86e 19# Avoid all libraries in /usr/ucblib.
a0d0e21e 20set `echo $glibpth | sed -e 's@/usr/ucblib@@'`
21glibpth="$*"
b1db1e90 22
40000a8c 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>
29set `echo " $libswanted " | sed -e 's@ ld @ @' -e 's@ malloc @ @' -e 's@ ucb @ @'`
a0d0e21e 30libswanted="$*"
31
b1db1e90 32# Look for architecture name. We want to suggest a useful default.
a0d0e21e 33case "$archname" in
34'')
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}"
41 fi
42 ;;
43esac
a0d0e21e 44
b1db1e90 45######################################################
46# General sanity testing. See below for excerpts from the Solaris FAQ.
8e07c86e 47
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
53
54# Here's another draft of the perl5/solaris/gcc sanity-checker.
55
bd89102f 56case `type ${cc:-cc}` in
57*/usr/ucb/cc*) cat <<END >&4
8e07c86e 58
a0d0e21e 59NOTE: Some people have reported problems with /usr/ucb/cc.
bd89102f 60If you have difficulties, please make sure the directory
61containing your C compiler is before /usr/ucb in your PATH.
8e07c86e 62
63END
64;;
65esac
66
67
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
71case $? in
720) ;;
73*)
68dc0745 74 cat <<END >&4
8e07c86e 75
76NOTE: Your system does not have /dev/fd mounted. If you want to
77be able to use set-uid scripts you must ask your system administrator
78to mount /dev/fd.
79
80END
81 ;;
82esac
83
84
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
88case $? in
890)
68dc0745 90 cat <<END >&4
8e07c86e 91
92NOTE: libucb has been found in /usr/lib. libucb should reside in
93/usr/ucblib. You may have trouble while building Perl extensions.
94
a0d0e21e 95END
96;;
97esac
40000a8c 98
bd89102f 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)
105# cc is /usr/ucb/cc
106# foo not found
107# use a command like type make | awk '{print $NF}' | sed 's/[()]//g'
8e07c86e 108
109# See if make(1) is GNU make(1).
110# If it is, make sure the setgid bit is not set.
111make -v > make.vers 2>&1
112if grep GNU make.vers > /dev/null 2>&1; then
bd89102f 113 tmp=`type make | awk '{print $NF}' | sed 's/[()]//g'`
114 case "`/usr/bin/ls -lL $tmp`" in
8e07c86e 115 ??????s*)
68dc0745 116 cat <<END >&2
8e07c86e 117
118NOTE: Your PATH points to GNU make, and your GNU make has the set-group-id
119bit set. You must either rearrange your PATH to put /usr/ccs/bin before the
120GNU utilities or you must ask your system administrator to disable the
121set-group-id bit on GNU make.
122
123END
124 ;;
125 esac
126fi
127rm -f make.vers
128
693762b4 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.
132cat > UU/cc.cbu <<'EOSH'
8e07c86e 133# If the C compiler is gcc:
134# - check the fixed-includes
135# - check as(1) and ld(1), they should not be GNU
bd89102f 136# (GNU as and ld 2.8.1 and later are reportedly ok, however.)
8e07c86e 137# If the C compiler is not gcc:
138# - check as(1) and ld(1), they should not be GNU
bd89102f 139# (GNU as and ld 2.8.1 and later are reportedly ok, however.)
8e07c86e 140#
141# Watch out in case they have not set $cc.
1acf53c5 142
143# Get gcc to share its secrets.
144echo 'main() { return 0; }' > try.c
bd89102f 145 # Indent to avoid propagation to config.sh
146 verbose=`${cc:-cc} -v -o try try.c 2>&1`
1acf53c5 147
148if echo "$verbose" | grep '^Reading specs from' >/dev/null 2>&1; then
8e07c86e 149 #
150 # Using gcc.
151 #
152 #echo Using gcc
153
8e07c86e 154 tmp=`echo "$verbose" | grep '^Reading' |
155 awk '{print $NF}' | sed 's/specs$/include/'`
156
157 # Determine if the fixed-includes look like they'll work.
cee5ebb5 158 # Doesn't work anymore for gcc-2.7.2.
8e07c86e 159
160 # See if as(1) is GNU as(1). GNU as(1) won't work for this job.
1acf53c5 161 if echo "$verbose" | grep ' /usr/ccs/bin/as ' >/dev/null 2>&1; then
162 :
163 else
68dc0745 164 cat <<END >&2
8e07c86e 165
166NOTE: You are using GNU as(1). GNU as(1) will not build Perl.
bd89102f 167I'm arranging to use /usr/ccs/bin/as by including -B/usr/ccs/bin/
168in your ${cc:-cc} command. (Note that the trailing "/" is required.)
8e07c86e 169
170END
1acf53c5 171 cc="${cc:-cc} -B/usr/ccs/bin/"
172 fi
8e07c86e 173
174 # See if ld(1) is GNU ld(1). GNU ld(1) won't work for this job.
bd89102f 175 # Recompute $verbose since we may have just changed $cc.
176 verbose=`${cc:-cc} -v -o try try.c 2>&1`
177 if echo "$verbose" | grep ' /usr/ccs/bin/ld ' >/dev/null 2>&1; then
1acf53c5 178 :
179 else
68dc0745 180 cat <<END >&2
8e07c86e 181
bd89102f 182NOTE: You are using GNU ld(1). GNU ld(1) will not build Perl.
183I'm arranging to use /usr/ccs/bin/ld by including -B/usr/ccs/bin/
184in your ${cc:-cc} command. (Note that the trailing "/" is required.)
8e07c86e 185
186END
1acf53c5 187 cc="${cc:-cc} -B/usr/ccs/bin/"
188 fi
8e07c86e 189
1acf53c5 190else
8e07c86e 191 #
192 # Not using gcc.
193 #
194 #echo Not using gcc
195
196 # See if as(1) is GNU as(1). GNU as(1) won't work for this job.
197 case `as --version < /dev/null 2>&1` in
198 *GNU*)
68dc0745 199 cat <<END >&2
8e07c86e 200
201NOTE: You are using GNU as(1). GNU as(1) will not build Perl.
bd89102f 202You must arrange to use /usr/ccs/bin/as, perhaps by adding /usr/ccs/bin
203to the beginning of your PATH.
8e07c86e 204
205END
206 ;;
207 esac
208
209 # See if ld(1) is GNU ld(1). GNU ld(1) won't work for this job.
91d1e749 210 # ld --version doesn't properly report itself as a GNU tool,
211 # as of ld version 2.6, so we need to be more strict. TWP 9/5/96
212 gnu_ld=false
8e07c86e 213 case `ld --version < /dev/null 2>&1` in
91d1e749 214 *GNU*|ld\ version\ 2*)
215 gnu_ld=true ;;
216 *) ;;
217 esac
218 if $gnu_ld ; then :
219 else
bd89102f 220 # Try to guess from path
221 case `type ld | awk '{print $NF}'` in
222 *gnu*|*GNU*|*FSF*)
91d1e749 223 gnu_ld=true ;;
224 esac
225 fi
226 if $gnu_ld ; then
68dc0745 227 cat <<END >&2
8e07c86e 228
bd89102f 229NOTE: You are apparently using GNU ld(1). GNU ld(1) will not build Perl.
230You must arrange to use /usr/ccs/bin/ld, perhaps by adding /usr/ccs/bin
231to the beginning of your PATH.
8e07c86e 232
233END
91d1e749 234 fi
8e07c86e 235
1acf53c5 236fi
8e07c86e 237
238# as --version or ld --version might dump core.
bd89102f 239rm -f try try.c
8e07c86e 240rm -f core
241
693762b4 242# XXX
243EOSH
244
e5c9fcd0 245if [ "X$usethreads" = "X$define" ]; then
dfe9444c 246 ccflags="-D_REENTRANT $ccflags"
b981e18e 247 # -lpthread needs to come before -lc but after other libraries such
248 # as -lgdbm and such like. We assume here that -lc is present in
249 # libswanted. If that fails to be true in future, then this can be
250 # changed to add pthread to the very end of libswanted.
c4f23d77 251 # sched_yield is in -lposix4
252 set `echo X "$libswanted "| sed -e 's/ c / posix4 pthread c /'`
b981e18e 253 shift
254 libswanted="$*"
c4f23d77 255
256 # On Solaris 2.6 x86 there is a bug with sigsetjmp() and siglongjmp()
257 # when linked with the threads library, such that whatever positive value
258 # you pass to siglongjmp(), sigsetjmp() returns 1.
259 # Thanks to Simon Parsons <S.Parsons@ftel.co.uk> for this report.
ef6cdfd2 260 # Sun BugID is 4117946, "sigsetjmp always returns 1 when called by
261 # siglongjmp in a MT program". As of 19980622, there is no patch
262 # available.
263 cat >try.c <<'EOM'
264 /* Test for sig(set|long)jmp bug. */
265 #include <setjmp.h>
266
267 main()
268 {
269 sigjmp_buf env;
270 int ret;
271
272 ret = sigsetjmp(env, 1);
273 if (ret) { return ret == 2; }
274 siglongjmp(env, 2);
275 }
276EOM
277 if test "`arch`" = i86pc -a "$osvers" = 2.6 \
278 && ${cc:-cc} try.c -lpthread >/dev/null 2>&1 && ./a.out; then
279 d_sigsetjmp=$undef
c4f23d77 280 cat << 'EOM' >&2
281
282You will see a *** WHOA THERE!!! *** message from Configure for
ef6cdfd2 283d_sigsetjmp. Keep the recommended value. See hints/solaris_2.sh
c4f23d77 284for more information.
285
286EOM
287 fi
b981e18e 288fi
289
8e07c86e 290# This is just a trick to include some useful notes.
291cat > /dev/null <<'End_of_Solaris_Notes'
292
293Here are some notes kindly contributed by Dean Roehrich.
294
295-----
296Generic notes about building Perl5 on Solaris:
297- Use /usr/ccs/bin/make.
298- If you use GNU make, remove its setgid bit.
299- Remove all instances of *ucb* from your path.
300- Make sure libucb is not in /usr/lib (it should be in /usr/ucblib).
301- Do not use GNU as or GNU ld, or any of GNU binutils or GNU libc.
302- Do not use /usr/ucb/cc.
303- Do not change Configure's default answers, except for the path names.
304- Do not use -lmalloc.
305- Do not build on SunOS 4 and expect it to work properly on SunOS 5.
306- /dev/fd must be mounted if you want set-uid scripts to work.
307
308
309Here are the gcc-related questions and answers from the Solaris 2 FAQ. Note
310the themes:
311 - run fixincludes
312 - run fixincludes correctly
313 - don't use GNU as or GNU ld
314
315Question 5.7 covers the __builtin_va_alist problem people are always seeing.
316Question 6.1.3 covers the GNU as and GNU ld issues which are always biting
317people.
318Question 6.9 is for those who are still trying to compile Perl4.
319
320The latest Solaris 2 FAQ can be found in the following locations:
321 rtfm.mit.edu:/pub/usenet-by-group/comp.sys.sun.admin
322 ftp.fwi.uva.nl:/pub/solaris
323
324Perl5 comes with a script in the top-level directory called "myconfig" which
325will print a summary of the configuration in your config.sh. My summary for
326Solaris 2.4 and gcc 2.6.3 follows. I have also built with gcc 2.7.0 and the
327results are identical. This configuration was generated with Configure's -d
328option (take all defaults, don't bother prompting me). All tests pass for
329Perl5.001, patch.1m.
330
331Summary of my perl5 (patchlevel 1) configuration:
332 Platform:
333 osname=solaris, osver=2.4, archname=sun4-solaris
334 uname='sunos poplar 5.4 generic_101945-27 sun4d sparc '
335 hint=recommended
336 Compiler:
337 cc='gcc', optimize='-O', ld='gcc'
338 cppflags=''
339 ccflags =''
340 ldflags =''
341 stdchar='unsigned char', d_stdstdio=define, usevfork=false
342 voidflags=15, castflags=0, d_casti32=define, d_castneg=define
343 intsize=4, alignbytes=8, usemymalloc=y, randbits=15
344 Libraries:
345 so=so
346 libpth=/lib /usr/lib /usr/ccs/lib /usr/local/lib
347 libs=-lsocket -lnsl -ldl -lm -lc -lcrypt
348 libc=/usr/lib/libc.so
349 Dynamic Linking:
350 dlsrc=dl_dlopen.xs, dlext=so, d_dlsymun=undef
351 cccdlflags='-fpic', ccdlflags=' ', lddlflags='-G'
352
353
354Dean
355roehrich@cray.com
3569/7/95
357
358-----------
359
360From: Casper.Dik@Holland.Sun.COM (Casper H.S. Dik - Network Security Engineer)
361Subject: Solaris 2 Frequently Asked Questions (FAQ) 1.48
362Date: 25 Jul 1995 12:20:18 GMT
363
3645.7) Why do I get __builtin_va_alist or __builtin_va_arg_incr undefined?
365
366 You're using gcc without properly installing the gcc fixed
367 include files. Or you ran fixincludes after installing gcc
368 w/o moving the gcc supplied varargs.h and stdarg.h files
369 out of the way and moving them back again later. This often
370 happens when people install gcc from a binary distribution.
371 If there's a tmp directory in gcc's include directory, fixincludes
372 didn't complete. You should have run "just-fixinc" instead.
373
374 Another possible cause is using ``gcc -I/usr/include.''
375
3766.1) Where is the C compiler or where can I get one?
377
378 [...]
379
380 3) Gcc.
381
382 Gcc is available from the GNU archives in source and binary
383 form. Look in a directory called sparc-sun-solaris2 for
384 binaries. You need gcc 2.3.3 or later. You should not use
385 GNU as or GNU ld. Make sure you run just-fixinc if you use
386 a binary distribution. Better is to get a binary version and
387 use that to bootstrap gcc from source.
388
389 [...]
390
391 When you install gcc, don't make the mistake of installing
392 GNU binutils or GNU libc, they are not as capable as their
393 counterparts you get with Solaris 2.x.
394
3956.9) I can't get perl 4.036 to compile or run.
396
397 Run Configure, and use the solaris_2_0 hints, *don't* use
398 the solaris_2_1 hints and don't use the config.sh you may
399 already have. First you must make sure Configure and make
400 don't find /usr/ucb/cc. (It must use gcc or the native C
401 compiler: /opt/SUNWspro/bin/cc)
402
403 Some questions need a special answer.
404
405 Are your system (especially dbm) libraries compiled with gcc? [y] y
406
407 yes: gcc 2.3.3 or later uses the standard calling
408 conventions, same as Sun's C.
409
410 Any additional cc flags? [ -traditional -Dvolatile=__volatile__
411 -I/usr/ucbinclude] -traditional -Dvolatile=__volatile__
412 Remove /usr/ucbinclude.
413
414 Any additional libraries? [-lsocket -lnsl -ldbm -lmalloc -lm
415 -lucb] -lsocket -lnsl -lm
416
417 Don't include -ldbm, -lmalloc and -lucb.
418
419 Perl 5 compiled out of the box.
420
421End_of_Solaris_Notes
422