diff options
author | H.Merijn Brand <h.m.brand@xs4all.nl> | 2004-02-25 09:32:12 +0000 |
---|---|---|
committer | H.Merijn Brand <h.m.brand@xs4all.nl> | 2004-02-25 09:32:12 +0000 |
commit | 2463cec9eed76df1882d67924716c953eafc3a83 (patch) | |
tree | a742495238e628eb2a1238d69d8d8afef9ffbab0 /hints/aix.sh | |
parent | 0a76ff6528f0ab52947d4f1b9664310ce137b9a0 (diff) | |
download | perl-2463cec9eed76df1882d67924716c953eafc3a83.tar.gz |
AIX hints stage 3: remove AIX 3 and AIX 4 after split off
One open issue left: promoting to cc_r for threaded builds
need a review to permit users using -Dcc=xlc_r for non
threaded builds
p4raw-id: //depot/perl@22374
Diffstat (limited to 'hints/aix.sh')
-rw-r--r-- | hints/aix.sh | 576 |
1 files changed, 223 insertions, 353 deletions
diff --git a/hints/aix.sh b/hints/aix.sh index 4cad922704..da61d31564 100644 --- a/hints/aix.sh +++ b/hints/aix.sh @@ -1,25 +1,16 @@ # hints/aix.sh -# -# AIX 4.1 hints thanks to Christopher Chan-Nui <channui@austin.ibm.com>. -# AIX 4.1 pthreading by Christopher Chan-Nui <channui@austin.ibm.com> and -# Jarkko Hietaniemi <jhi@iki.fi>. -# AIX 4.3.x LP64 build by Steven Hirsch <hirschs@btv.ibm.com> -# Merged on Mon Feb 6 10:22:35 EST 1995 by -# Andy Dougherty <doughera@lafayette.edu> -# +# AIX 3 and AIX 4 are split off to aix_3.sh and aix_4.sh +# early Feb 2004 by H.Merijn Brand +# please read comments in there for historic questions. +# many now stripped here + # Contact dfavor@corridor.com for any of the following: # # - AIX 43x and above support # - gcc + threads support # - socks support # -# Apr 99 changes: -# -# - use nm in AIX 43x and above -# - gcc + threads now builds -# [(added support for socks) Jul 99 SOCKS support rewritten] -# # Notes: # # - shared libperl support is tricky. if ever libperl.a ends up @@ -45,29 +36,15 @@ d_setruid='undef' alignbytes=8 case "$usemymalloc" in -'') usemymalloc='n' ;; -esac + '') usemymalloc='n' ;; + esac # Intuiting the existence of system calls under AIX is difficult, # at best; the safest technique is to find them empirically. -# AIX 4.3.* and above default to letting Configure test if nm -# extraction will work. -case "$osvers" in - 4.1.*|4.2.*) - case "$usenm" in - '') usenm='undef' - esac - case "$usenativedlopen" in - '') usenativedlopen='false' - esac - ;; - *) - case "$usenativedlopen" in - '') usenativedlopen='true' - esac - ;; -esac +case "$usenativedlopen" in + '') usenativedlopen='true' ;; + esac so="a" # AIX itself uses .o (libc.o) but we prefer compatibility @@ -80,36 +57,28 @@ dlext="so" # environment, we can override it later. If set for 64, the # 'sizeof' test sees a native 64-bit architecture and never looks back. case "$OBJECT_MODE" in -32) - cat >&4 <<EOF + 32) cat >&4 <<EOF -You have OBJECT_MODE=32 set in the environment. +You have OBJECT_MODE=32 set in the environment. I take this as a hint you do not want to build for a 64-bit address space. You will be given the opportunity to change this later. EOF - ;; -64) - cat >&4 <<EOF + ;; + 64) cat >&4 <<EOF -You have OBJECT_MODE=64 set in the environment. +You have OBJECT_MODE=64 set in the environment. This forces a full 64-bit build. If that is not what you intended, please terminate this program, unset it and restart. EOF - ;; -*) ;; -esac - -# Trying to set this breaks the POSIX.c compilation - -# Make setsockopt work correctly. See man page. -# ccflags='-D_BSD=44' + ;; + esac # uname -m output is too specific and not appropriate here case "$archname" in -'') archname="$osname" ;; -esac + '') archname="$osname" ;; + esac cc=${cc:-cc} @@ -130,79 +99,48 @@ d_setreuid='undef' cccdlflags='none' # All AIX code is position independent cc_type=xlc # do not export to config.sh case "$cc" in -*gcc*) - cc_type=gcc - ccdlflags='-Xlinker' - if [ "X$gccversion" = "X" ]; then - # Done too late in Configure if hinted - gccversion=`$cc --version | sed 's/.*(GCC) *//'` - fi - ;; -*) ccversion=`lslpp -L | grep 'C for AIX Compiler$' | grep -v '\.msg\.[A-Za-z_]*\.' | head -1 | awk '{print $1,$2}'` - case "$ccversion" in - '') ccversion=`lslpp -L | grep 'IBM C and C++ Compilers LUM$'` - ;; - *.*.*.*.*.*.*) # Ahhrgg, more than one C compiler installed - first_cc_path=`which ${cc:-cc}` - case "$first_cc_path" in - *vac*) - cc_type=vac ;; - /usr/bin/cc) # Check the symlink - if [ -h $first_cc_path ] ; then - ls -l $first_cc_path > reflect - if grep -i vac reflect >/dev/null 2>&1 ; then - cc_type=vac - fi - rm -f reflect - fi - ;; - esac - ccversion=`lslpp -L | grep 'C for AIX Compiler$' | grep -i $cc_type | head -1` - ;; - vac*.*.*.*) - cc_type=vac - ;; - esac - ccversion=`echo "$ccversion" | awk '{print $2}'` - case "$ccversion" in - 3.6.6.0) - optimize='none' - ;; - 4.4.0.0|4.4.0.1|4.4.0.2) - cat >&4 <<EOF -*** -*** This C compiler ($ccversion) is outdated. -*** -*** Please upgrade to at least 4.4.0.3. -*** -EOF - ;; - 5.0.0.0) - cat >&4 <<EOF -*** -*** This C compiler ($ccversion) is known to have too many optimizer -*** bugs to compile a working Perl. -*** -*** Consider upgrading your C compiler, or getting the GNU cc (gcc). -*** -*** Cannot continue, aborting. -EOF - exit 1 + *gcc*) + cc_type=gcc + ccdlflags='-Xlinker' + if [ "X$gccversion" = "X" ]; then + # Done too late in Configure if hinted + gccversion=`$cc --version | sed 's/.*(GCC) *//'` + fi ;; - 5.0.1.0) - cat >&4 <<EOF -*** -*** This C compiler ($ccversion) is known to have optimizer problems -*** when compiling regcomp.c. -*** -*** Disabling optimization for that file but consider upgrading -*** your C compiler. -*** -EOF -regcomp_cflags='optimize=' + + *) ccversion=`lslpp -L | grep 'C for AIX Compiler$' | grep -v '\.msg\.[A-Za-z_]*\.' | head -1 | awk '{print $1,$2}'` + case "$ccversion" in + '') ccversion=`lslpp -L | grep 'IBM C and C++ Compilers LUM$'` ;; + + *.*.*.*.*.*.*) # Ahhrgg, more than one C compiler installed + first_cc_path=`which ${cc:-cc}` + case "$first_cc_path" in + *vac*) + cc_type=vac ;; + + /usr/bin/cc) # Check the symlink + if [ -h $first_cc_path ] ; then + ls -l $first_cc_path > reflect + if grep -i vac reflect >/dev/null 2>&1 ; then + cc_type=vac + fi + rm -f reflect + fi + ;; + esac + ccversion=`lslpp -L | grep 'C for AIX Compiler$' | grep -i $cc_type | head -1` + ;; + + vac*.*.*.*) + cc_type=vac + ;; + esac + + ccversion=`echo "$ccversion" | awk '{print $2}'` + # Redbooks state AIX-5 only supports vac-5.0.2.0 and up ;; - esac -esac + esac + # the required -bE:$installarchlib/CORE/perl.exp is added by # libperl.U (Configure) later. @@ -230,15 +168,17 @@ case $cc_type in lddlflags=`echo "$lddlflags " | sed -e 's/ -lc / -lc128 -lc /'` ;; esac + ;; esac case "$cc" in -*gcc*) ;; -cc*|xlc*) # cc should've been set by line 116 or so if empty. + *gcc*) ;; + + cc*|xlc*) # cc should've been set by line 116 or so if empty. if test ! -x /usr/bin/$cc -a -x /usr/vac/bin/$cc; then - case ":$PATH:" in + case ":$PATH:" in *:/usr/vac/bin:*) ;; - *) if test ! -x /QOpenSys/usr/bin/$cc; then + *) if test ! -x /QOpenSys/usr/bin/$cc; then # The /QOpenSys/usr/bin/$cc saves us if we are # building natively in OS/400 PASE. cat >&4 <<EOF @@ -251,87 +191,57 @@ cc*|xlc*) # cc should've been set by line 116 or so if empty. *** EOF exit 1 - fi - ;; + fi + ;; esac - fi + fi ;; -esac + esac case "$ldlibpthname" in -'') ldlibpthname=LIBPATH ;; -esac - -# AIX 4.2 (using latest patchlevels on 20001130) has a broken bind -# library (getprotobyname and getprotobynumber are outversioned by -# the same calls in libc, at least for xlc version 3... -case "`oslevel`" in - 4.2.1.*) - case "$ccversion" in # Don't know if needed for gcc - 3.1.4.*|5.0.2.*) # libswanted "bind ... c ..." => "... c bind ..." - set `echo X "$libswanted "| sed -e 's/ bind\( .*\) \([cC]\) / \1 \2 bind /'` - shift - libswanted="$*" - ;; - esac - ;; + '') ldlibpthname=LIBPATH ;; esac -# This script UU/usethreads.cbu will get 'called-back' by Configure +# This script UU/usethreads.cbu will get 'called-back' by Configure # after it has prompted the user for whether to use threads. cat > UU/usethreads.cbu <<'EOCBU' case "$usethreads" in -$define|true|[yY]*) + $define|true|[yY]*) + d_drand48_r='undef' + d_endgrent_r='undef' + d_endpwent_r='undef' + d_getgrent_r='undef' + d_getpwent_r='undef' + d_random_r='undef' + d_setgrent_r='undef' + d_setpwent_r='undef' + d_srand48_r='undef' + d_strerror_r='undef' + ccflags="$ccflags -DNEED_PTHREAD_INIT" case "$cc" in - *gcc*) - ccflags="-D_THREAD_SAFE $ccflags" - echo "GCC $gccversion disabling some _r functions" >&4 - case "$gccversion" in - 3*) d_drand48_r='undef' - d_endgrent_r='undef' - d_endpwent_r='undef' - d_getgrent_r='undef' - d_getpwent_r='undef' - d_random_r='undef' - d_srand48_r='undef' - d_strerror_r='undef' - ;; - esac - ;; - cc_r) ;; - cc|xl[cC]|xl[cC]_r) - echo >&4 "Switching cc to cc_r because of POSIX threads." - # xlc_r has been known to produce buggy code in AIX 4.3.2. - # (e.g. pragma/overload core dumps) Let's suspect xlC_r, too. - # --jhi@iki.fi - cc=cc_r - - case "`oslevel`" in - 4.2.1.*) i_crypt='undef' ;; - esac - ;; - '') - cc=cc_r - ;; - *) - cat >&4 <<EOM + *gcc*) ccflags="-D_THREAD_SAFE $ccflags" ;; + + cc_r) ;; + cc|xl[cC]|xl[cC]_r) + echo >&4 "Switching cc to cc_r because of POSIX threads." + # xlc_r has been known to produce buggy code in AIX 4.3.2. + # (e.g. pragma/overload core dumps) Let's suspect xlC_r, too. + # --jhi@iki.fi + cc=cc_r + ;; + + '') cc=cc_r ;; + + *) + cat >&4 <<EOM *** For pthreads you should use the AIX C compiler cc_r. *** (now your compiler was set to '$cc') *** Cannot continue, aborting. EOM - exit 1 - ;; - esac - - # c_rify libswanted. - set `echo X "$libswanted "| sed -e 's/ \([cC]\) / \1_r /g'` - shift - libswanted="$*" - # c_rify lddlflags. - set `echo X "$lddlflags "| sed -e 's/ \(-l[cC]\) / \1_r /g'` - shift - lddlflags="$*" + exit 1 + ;; + esac # Insert pthreads to libswanted, before any libc or libC. set `echo X "$libswanted "| sed -e 's/ \([cC]_r\) / pthreads \1 /'` @@ -346,123 +256,88 @@ EOM esac EOCBU -# This script UU/uselargefiles.cbu will get 'called-back' by Configure +# This script UU/uselargefiles.cbu will get 'called-back' by Configure # after it has prompted the user for whether to use large files. cat > UU/uselargefiles.cbu <<'EOCBU' case "$uselargefiles" in -''|$define|true|[yY]*) - # Configure should take care of use64bitint and use64bitall being - # defined before uselargefiles.cbu is consulted. - if test X"$use64bitint:$quadtype" = X"$define:long" -o X"$use64bitall" = Xdefine; then + ''|$define|true|[yY]*) + # Configure should take care of use64bitint and use64bitall being + # defined before uselargefiles.cbu is consulted. + if test X"$use64bitint:$quadtype" = X"$define:long" -o X"$use64bitall" = Xdefine; then # Keep these at the left margin. ccflags_uselargefiles="`getconf XBS5_LP64_OFF64_CFLAGS 2>/dev/null`" ldflags_uselargefiles="`getconf XBS5_LP64_OFF64_LDFLAGS 2>/dev/null`" - else + else # Keep these at the left margin. ccflags_uselargefiles="`getconf XBS5_ILP32_OFFBIG_CFLAGS 2>/dev/null`" ldflags_uselargefiles="`getconf XBS5_ILP32_OFFBIG_LDFLAGS 2>/dev/null`" - fi - # _Somehow_ in AIX 4.3.1.0 the above getconf call manages to - # insert(?) *something* to $ldflags so that later (in Configure) evaluating - # $ldflags causes a newline after the '-b64' (the result of the getconf). - # (nothing strange shows up in $ldflags even in hexdump; - # so it may be something (a bug) in the shell, instead?) - # Try it out: just uncomment the below line and rerun Configure: -# echo >&4 "AIX 4.3.1.0 $ldflags_uselargefiles mystery" ; exit 1 - # Just don't ask me how AIX does it, I spent hours wondering. - # Therefore the line re-evaluating ldflags_uselargefiles: it seems to fix - # the whatever it was that AIX managed to break. --jhi - ldflags_uselargefiles="`echo $ldflags_uselargefiles`" - if test X"$use64bitint:$quadtype" = X"$define:long" -o X"$use64bitall" = Xdefine; then + fi + if test X"$use64bitint:$quadtype" = X"$define:long" -o X"$use64bitall" = Xdefine; then # Keep this at the left margin. libswanted_uselargefiles="`getconf XBS5_LP64_OFF64_LIBS 2>/dev/null|sed -e 's@^-l@@' -e 's@ -l@ @g`" - else + else # Keep this at the left margin. libswanted_uselargefiles="`getconf XBS5_ILP32_OFFBIG_LIBS 2>/dev/null|sed -e 's@^-l@@' -e 's@ -l@ @g`" - fi + fi + case "$ccflags_uselargefiles$ldflags_uselargefiles$libs_uselargefiles" in - '');; - *) ccflags="$ccflags $ccflags_uselargefiles" - ldflags="$ldflags $ldflags_uselargefiles" - libswanted="$libswanted $libswanted_uselargefiles" - ;; - esac - case "$gccversion" in - '') ;; - *) # Remove xlc-specific -qflags. - ccflags="`echo $ccflags | sed -e 's@ -q[^ ]*@ @g' -e 's@^-q[^ ]* @@g'`" - ldflags="`echo $ldflags | sed -e 's@ -q[^ ]*@ @g' -e 's@^-q[^ ]* @@g'`" - # Move xlc-specific -bflags. - ccflags="`echo $ccflags | sed -e 's@ -b@ -Wl,-b@g'`" - ldflags="`echo ' '$ldflags | sed -e 's@ -b@ -Wl,-b@g'`" - lddlflags="`echo ' '$lddlflags | sed -e 's@ -b@ -Wl,-b@g'`" - ld='gcc' - echo >&4 "(using ccflags $ccflags)" - echo >&4 "(using ldflags $ldflags)" - echo >&4 "(using lddlflags $lddlflags)" - ;; - esac - ;; -esac -EOCBU + '') ;; + *) ccflags="$ccflags $ccflags_uselargefiles" + ldflags="$ldflags $ldflags_uselargefiles" + libswanted="$libswanted $libswanted_uselargefiles" + ;; + esac -# This script UU/use64bitint.cbu will get 'called-back' by Configure -# after it has prompted the user for whether to use 64 bit integers. -cat > UU/use64bitint.cbu <<'EOCBU' -case "$use64bitint" in -$define|true|[yY]*) - case "`oslevel`" in - 4.[012].*) - cat >&4 <<EOM -AIX `oslevel` does not support 64-bit interfaces. -You should upgrade to at least AIX 4.3. -EOM - exit 1 + case "$gccversion" in + '') ;; + *) # Remove xlc-specific -qflags. + ccflags="`echo $ccflags | sed -e 's@ -q[^ ]*@ @g' -e 's@^-q[^ ]* @@g'`" + ldflags="`echo $ldflags | sed -e 's@ -q[^ ]*@ @g' -e 's@^-q[^ ]* @@g'`" + # Move xlc-specific -bflags. + ccflags="`echo $ccflags | sed -e 's@ -b@ -Wl,-b@g'`" + ldflags="`echo ' '$ldflags | sed -e 's@ -b@ -Wl,-b@g'`" + lddlflags="`echo ' '$lddlflags | sed -e 's@ -b@ -Wl,-b@g'`" + ld='gcc' + echo >&4 "(using ccflags $ccflags)" + echo >&4 "(using ldflags $ldflags)" + echo >&4 "(using lddlflags $lddlflags)" ;; esac - ;; -esac + ;; + esac EOCBU cat > UU/use64bitall.cbu <<'EOCBU' -# This script UU/use64bitall.cbu will get 'called-back' by Configure +# This script UU/use64bitall.cbu will get 'called-back' by Configure # after it has prompted the user for whether to be maximally 64-bitty. case "$use64bitall" in -$define|true|[yY]*) - case "`oslevel`" in - 4.[012].*) - cat >&4 <<EOM -AIX `oslevel` does not support 64-bit interfaces. -You should upgrade to at least AIX 4.3. -EOM - exit 1 - ;; - esac - echo " " - echo "Checking the CPU width of your hardware..." >&4 - $cat >size.c <<EOCP + $define|true|[yY]*) + echo " " + echo "Checking the CPU width of your hardware..." >&4 + $cat >size.c <<EOCP #include <stdio.h> #include <sys/systemcfg.h> int main (void) { - printf("%d\n",_system_configuration.width); - return(0); -} + printf ("%d\n", _system_configuration.width); + return (0); + } EOCP - set size - if eval $compile_ok; then - qacpuwidth=`./size` - echo "You are running on $qacpuwidth bit hardware." - else - dflt="32" - echo " " - echo "(I can't seem to compile the test program. Guessing...)" - rp="What is the width of your CPU (in bits)?" - . ./myread - qacpuwidth="$ans" + set size + if eval $compile_ok; then + qacpuwidth=`./size` + echo "You are running on $qacpuwidth bit hardware." + else + dflt="32" + echo " " + echo "(I can't seem to compile the test program. Guessing...)" + rp="What is the width of your CPU (in bits)?" + . ./myread + qacpuwidth="$ans" fi - $rm -f size.c size - case "$qacpuwidth" in + $rm -f size.c size + + case "$qacpuwidth" in 32*) cat >&4 <<EOM Bzzzt! At present, you can only perform a @@ -471,90 +346,85 @@ EOM exit 1 ;; esac - qacflags="`getconf XBS5_LP64_OFF64_CFLAGS 2>/dev/null`" - qaldflags="`getconf XBS5_LP64_OFF64_LDFLAGS 2>/dev/null`" - # See jhi's comments above regarding this re-eval. I've - # seen similar weirdness in the form of: - # + qacflags="`getconf XBS5_LP64_OFF64_CFLAGS 2>/dev/null`" + qaldflags="`getconf XBS5_LP64_OFF64_LDFLAGS 2>/dev/null`" + # See jhi's comments above regarding this re-eval. I've + # seen similar weirdness in the form of: + # # 1506-173 (W) Option lm is not valid. Enter xlc for list of valid options. - # - # error messages from 'cc -E' invocation. Again, the offending - # string is simply not detectable by any means. Since it doesn't - # do any harm, I didn't pursue it. -- sh - qaldflags="`echo $qaldflags`" - qalibs="`getconf XBS5_LP64_OFF64_LIBS 2>/dev/null|sed -e 's@^-l@@' -e 's@ -l@ @g`" - # -q32 and -b32 may have been set by uselargefiles or user. - # Remove them. - ccflags="`echo $ccflags | sed -e 's@-q32@@'`" - ldflags="`echo $ldflags | sed -e 's@-b32@@'`" - # Tell archiver to use large format. Unless we remove 'ar' - # from 'trylist', the Configure script will just reset it to 'ar' - # immediately prior to writing config.sh. This took me hours - # to figure out. - trylist="`echo $trylist | sed -e 's@^ar @@' -e 's@ ar @ @g' -e 's@ ar$@@'`" - ar="ar -X64" - nm_opt="-X64 $nm_opt" - # Note: Placing the 'qacflags' variable into the 'ldflags' string - # is NOT a typo. ldflags is passed to the C compiler for final - # linking, and it wants -q64 (-b64 is for ld only!). - case "$qacflags$qaldflags$qalibs" in - '');; - *) ccflags="$ccflags $qacflags" - ldflags="$ldflags $qacflags" - lddlflags="$qaldflags $lddlflags" - libswanted="$libswanted $qalibs" - ;; + # + # error messages from 'cc -E' invocation. Again, the offending + # string is simply not detectable by any means. Since it doesn't + # do any harm, I didn't pursue it. -- sh + qaldflags="`echo $qaldflags`" + qalibs="`getconf XBS5_LP64_OFF64_LIBS 2>/dev/null|sed -e 's@^-l@@' -e 's@ -l@ @g`" + # -q32 and -b32 may have been set by uselargefiles or user. + # Remove them. + ccflags="`echo $ccflags | sed -e 's@-q32@@'`" + ldflags="`echo $ldflags | sed -e 's@-b32@@'`" + # Tell archiver to use large format. Unless we remove 'ar' + # from 'trylist', the Configure script will just reset it to 'ar' + # immediately prior to writing config.sh. This took me hours + # to figure out. + trylist="`echo $trylist | sed -e 's@^ar @@' -e 's@ ar @ @g' -e 's@ ar$@@'`" + ar="ar -X64" + nm_opt="-X64 $nm_opt" + # Note: Placing the 'qacflags' variable into the 'ldflags' string + # is NOT a typo. ldflags is passed to the C compiler for final + # linking, and it wants -q64 (-b64 is for ld only!). + case "$qacflags$qaldflags$qalibs" in + '') ;; + *) ccflags="$ccflags $qacflags" + ldflags="$ldflags $qacflags" + lddlflags="$qaldflags $lddlflags" + libswanted="$libswanted $qalibs" + ;; esac - case "$ccflags" in + case "$ccflags" in *-DUSE_64_BIT_ALL*) ;; - *) ccflags="$ccflags -DUSE_64_BIT_ALL";; + *) ccflags="$ccflags -DUSE_64_BIT_ALL";; esac - case "$archname64" in + case "$archname64" in ''|64*) archname64=64all ;; esac - longsize="8" - qacflags='' - qaldflags='' - qalibs='' - qacpuwidth='' - ;; -esac + longsize="8" + qacflags='' + qaldflags='' + qalibs='' + qacpuwidth='' + ;; + esac EOCBU -if test $usenativedlopen = 'true' -then +if test $usenativedlopen = 'true' ; then ccflags="$ccflags -DUSE_NATIVE_DLOPEN" case "$cc" in - *gcc*) ldflags="$ldflags -Wl,-brtl" ;; - *) ldflags="$ldflags -brtl" ;; - esac -else - case `oslevel` in - 4.2.*) ;; # libC_r has broke gettimeofday - *) # If the C++ libraries, libC and libC_r, are available we will - # prefer them over the vanilla libc, because the libC contain - # loadAndInit() and terminateAndUnload() which work correctly - # with C++ statics while libc load() and unload() do not. See - # ext/DynaLoader/dl_aix.xs. The C-to-C_r switch is done by - # usethreads.cbu, if needed. - if test -f /lib/libC.a -a X"`$cc -v 2>&1 | grep gcc`" = X; then - # Cify libswanted. - set `echo X "$libswanted "| sed -e 's/ c / C c /'` - shift - libswanted="$*" - # Cify lddlflags. - set `echo X "$lddlflags "| sed -e 's/ -lc / -lC -lc /'` - shift - lddlflags="$*" - fi + *gcc*) ldflags="$ldflags -Wl,-brtl" ;; + *) ldflags="$ldflags -brtl" ;; esac -fi +elif test -f /lib/libC.a -a X"`$cc -v 2>&1 | grep gcc`" = X; then + # If the C++ libraries, libC and libC_r, are available we will + # prefer them over the vanilla libc, because the libC contain + # loadAndInit() and terminateAndUnload() which work correctly + # with C++ statics while libc load() and unload() do not. See + # ext/DynaLoader/dl_aix.xs. The C-to-C_r switch is done by + # usethreads.cbu, if needed. + + # Cify libswanted. + set `echo X "$libswanted "| sed -e 's/ c / C c /'` + shift + libswanted="$*" + # Cify lddlflags. + set `echo X "$lddlflags "| sed -e 's/ -lc / -lC -lc /'` + shift + lddlflags="$*" + fi case "$PASE" in -define) + define) case "$prefix" in - '') prefix=/QOpenSys/perl ;; - esac + '') prefix=/QOpenSys/perl ;; + esac cat >&4 <<EOF *** @@ -578,9 +448,9 @@ EOF # V5R1 tries to use code compiled assuming fchdir(), # lots of grief will issue forth from Cwd. case "$d_fchdir" in - '') d_fchdir="$undef" ;; - esac + '') d_fchdir="$undef" ;; + esac ;; -esac + esac # EOF |