This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
Re: 5.005_03 and gcc, GNU ld under Solaris 2.6
[perl5.git] / hints / dec_osf.sh
index 6bde1b4..4ab535d 100644 (file)
@@ -1,9 +1,6 @@
 # hints/dec_osf.sh
 
-#
-# How to make a DEBUGGING VERSION of perl for DECs cc compiler
-#
-#      If you want to debug perl or want to send a
+#      * If you want to debug perl or want to send a
 #      stack trace for inclusion into an bug report, call
 #      Configure with the additional argument  -Doptimize=-g2
 #      or uncomment this assignment to "optimize":
 #      If you want both to optimise and debug with the DEC cc
 #      you must have -g3, e.g. "-O4 -g3", and (re)run Configure.
 #
-#      Note 1: gcc can always have both -g and optimisation on.
+#      * gcc can always have both -g and optimisation on.
 #
-#      Note 2: debugging optimised code, no matter what compiler
+#      * debugging optimised code, no matter what compiler
 #      one is using, can be surprising and confusing because of
 #      the optimisation tricks like code motion, code removal,
 #      loop unrolling, and inlining. The source code and the
 #      executable code simply do not agree any more while in
 #      mid-execution, the optimiser only cares about the results.
 #
-#      Note 3: Configure will automatically add the often quoted
+#      * Configure will automatically add the often quoted
 #      -DDEBUGGING for you if the -g is specified.
 #
-#      Note 4: There is even more optimisation available in the new
+#      * There is even more optimisation available in the new
 #      (GEM) DEC cc: -O5 and -fast. "man cc" will tell more about them.
 #      The jury is still out whether either or neither help for Perl
 #      and how much. Based on very quick testing, -fast boosts
@@ -34,7 +31,7 @@
 #      hand searching things (index, m//, s///), seems to get slower.
 #      Your mileage will vary.
 #
-#      Note 5: The -std is needed because the following compiled
+#      * The -std is needed because the following compiled
 #      without the -std and linked with -lm
 #
 #      #include <math.h>
 #      UNIX 4.0{,a} dump core: Floating point exception in the printf(),
 #      the y has become a signaling NaN.
 #
+#      * Compilation warnings like:
+#
+#      "Undefined the ANSI standard macro ..."
+#
+#      can be ignored, at least while compiling the POSIX extension
+#      and especially if using the sfio (the latter is not a standard
+#      part of Perl, never mind if it says little to you).
+#
 
 # If using the DEC compiler we must find out the DEC compiler style:
 # the style changed between Digital UNIX (aka DEC OSF/1) 3 and
 # and it is called GEM. Many of the options we are going to use depend
 # on the compiler style.
 
-# do NOT, I repeat, *NOT* take away that leading tab
-       _DEC_cc_style=
+# do NOT, I repeat, *NOT* take away the leading tabs
 # Configure Black Magic (TM)
-
+       # reset
+       _DEC_cc_style=
 case "$cc" in
 *gcc*) ;; # pass
 *)     # compile something small: taint.c is fine for this.
@@ -74,6 +79,17 @@ case "$cc" in
        ;;
 esac
 
+# be nauseatingly ANSI
+case "$cc" in
+*gcc*) ccflags="$ccflags -ansi"
+       ;;
+*)     ccflags="$ccflags -std"
+       ;;
+esac
+
+# for gcc the Configure knows about the -fpic:
+# position-independent code for dynamic loading
+
 # we want optimisation
 
 case "$optimize" in
@@ -81,54 +97,125 @@ case "$optimize" in
        *gcc*)  
                optimize='-O3'                          ;;
        *)      case "$_DEC_cc_style" in
-               new)    optimize='-O4'                  ;;
+               new)    optimize='-O4'
+                       ccflags="$ccflags -fprm d -ieee"
+                       ;;
                old)    optimize='-O2 -Olimit 3200'     ;;
                esac
+               ccflags="$ccflags -D_INTRINSICS"
                ;;
        esac
        ;;
 esac
 
-# all compilers are ANSI
-ccflags="$ccflags -DSTANDARD_C"
-
-# be nauseatingly ANSI
-case "$cc" in
-gcc)   ccflags="$ccflags -ansi"
-       ;;
-*)     ccflags="$ccflags -std"
-       ;;
-esac
+# Make glibpth agree with the compiler suite.  Note that /shlib
+# is not here.  That's on purpose.  Even though that's where libc
+# really lives from V4.0 on, the linker (and /sbin/loader) won't
+# look there by default.  The sharable /sbin utilities were all
+# built with "-Wl,-rpath,/shlib" to get around that.  This makes
+# no attempt to figure out the additional location(s) searched by
+# gcc, since not all versions of gcc are easily coerced into
+# revealing that information.
+glibpth="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc"
+glibpth="$glibpth /usr/lib /usr/local/lib /var/shlib"
 
 # dlopen() is in libc
 libswanted="`echo $libswanted | sed -e 's/ dl / /'`"
 
-# PW contains nothing useful for perl
+# libPW contains nothing useful for perl
 libswanted="`echo $libswanted | sed -e 's/ PW / /'`"
 
-# bsd contains nothing used by perl that is not already in libc
+# libnet contains nothing useful for perl here, and doesn't work
+libswanted="`echo $libswanted | sed -e 's/ net / /'`"
+
+# libbsd contains nothing used by perl that is not already in libc
 libswanted="`echo $libswanted | sed -e 's/ bsd / /'`"
 
-# c need not be separately listed
+# libc need not be separately listed
 libswanted="`echo $libswanted | sed -e 's/ c / /'`"
 
-# dbm is already in libc (as is ndbm)
-libswanted="`echo $libswanted | sed -e 's/ dbm / /'`"
+# ndbm is already in libc
+libswanted="`echo $libswanted | sed -e 's/ ndbm / /'`"
 
 # the basic lddlflags used always
 lddlflags='-shared -expect_unresolved "*"'
 
-# Check if it's a CMW version of OSF1,
-# if so, do not hide the symbols.
-test `uname -s` = "MLS+" || lddlflags="$lddlflags -hidden"
+# Fancy compiler suites use optimising linker as well as compiler.
+# <spider@Orb.Nashua.NH.US>
+case "`uname -r`" in
+*[123].*)      # old loader
+               lddlflags="$lddlflags -O3"
+               ;;
+*)            if $test "X$optimize" = "X$undef"; then
+                      lddlflags="$lddlflags -msym"
+              else
+                      lddlflags="$lddlflags $optimize -msym"
+              fi
+               # -msym: If using a sufficiently recent /sbin/loader,
+               # keep the module symbols with the modules.
+               ;;
+esac
+# Yes, the above loses if gcc does not use the system linker.
+# If that happens, let me know about it. <jhi@iki.fi>
+
 
-# If debugging (-g) do not strip the objects, otherwise, strip.
+# If debugging or (old systems and doing shared)
+# then do not strip the lib, otherwise, strip.
+# As noted above the -DDEBUGGING is added automagically by Configure if -g.
 case "$optimize" in
        *-g*) ;; # left intentionally blank
+*)     case "`uname -r`" in
+       *[123].*)
+               case "$useshrplib" in
+               false|undef|'') lddlflags="$lddlflags -s"       ;;
+               esac
+               ;;
         *) lddlflags="$lddlflags -s"
+               ;;
+       esac
+       ;;
 esac
 
 #
+# Make embedding in things like INN and Apache more memory friendly.
+# Keep it overridable on the Configure command line, though, so that
+# "-Uuseshrplib" prevents this default.
+#
+
+case "$_DEC_cc_style.$useshrplib" in
+       new.)   useshrplib="$define"    ;;
+esac
+
+# The EFF_ONLY_OK from <sys/access.h> is present but dysfunctional for
+# [RWX]_OK as of Digital UNIX 4.0[A-D]?.  If and when this gets fixed,
+# please adjust this appropriately.  See also pp_sys.c just before the
+# emulate_eaccess().
+
+pp_sys_cflags='ccflags="$ccflags -DNO_EFF_ONLY_OK"'
+
+# 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]*)
+        # Threads interfaces changed with V4.0.
+        case "`uname -r`" in
+        *[123].*)
+           libswanted="$libswanted pthreads mach exc c_r"
+           ccflags="-threads $ccflags"
+           ;;
+        *)
+           libswanted="$libswanted pthread exc"
+           ccflags="-pthread $ccflags"
+           ;;
+        esac
+
+        usemymalloc='n'
+       ;;
+esac
+EOCBU
+
+#
 # Unset temporary variables no more needed.
 #
 
@@ -137,6 +224,61 @@ unset _DEC_cc_style
 #
 # History:
 #
+# perl5.005_51:
+#
+#      September-1998 Jarkko Hietaniemi <jhi@iki.fi>
+#
+#      * Added the -DNO_EFF_ONLY_OK flag ('use filetest;' support).
+#
+# perl5.004_57:
+#
+#      19-Dec-1997 Spider Boardman <spider@Orb.Nashua.NH.US>
+#
+#      * Newer Digital UNIX compilers enforce signaling for NaN without
+#        -ieee.  Added -fprm d at the same time since it's friendlier for
+#        embedding.
+#
+#      * Fixed the library search path to match cc, ld, and /sbin/loader.
+#
+#      * Default to building -Duseshrplib on newer systems.  -Uuseshrplib
+#        still overrides.
+#
+#      * Fix -pthread additions for useshrplib.  ld has no -pthread option.
+#
+#
+# perl5.004_04:
+#
+#       19-Sep-1997 Spider Boardman <spider@Orb.Nashua.NH.US>
+#
+#      * libnet on Digital UNIX is for JAVA, not for sockets.
+#
+#
+# perl5.003_28:
+#
+#       22-Feb-1997 Jarkko Hietaniemi <jhi@iki.fi>
+#
+#      * Restructuring Spider's suggestions.
+#
+#      * Older Digital UNIXes cannot handle -Olimit ... for $lddlflags.
+#      
+#      * ld -s cannot be used in older Digital UNIXes when doing shared.
+#
+#
+#       21-Feb-1997 Spider Boardman <spider@Orb.Nashua.NH.US>
+#
+#      * -hidden removed.
+#      
+#      * -DSTANDARD_C removed.
+#
+#      * -D_INTRINSICS added. (that -fast does not seem to buy much confirmed)
+#
+#      * odbm not in libc, only ndbm. Therefore dbm back to $libswanted.
+#
+#      * -msym for the newer runtime loaders.
+#
+#      * $optimize also in $lddflags.
+#
+#
 # perl5.003_27:
 #
 #      18-Feb-1997 Jarkko Hietaniemi <jhi@iki.fi>
@@ -208,3 +350,5 @@ unset _DEC_cc_style
 #      * Set -Olimit to 3200 because perl_yylex.c got too big
 #        for the optimizer.
 #
+
+