Subject: Re: pkg/30070 (lang/perl58 fails to build under Solaris 9)
To: None <solaris-pkg-people@NetBSD.org, gnats-admin@netbsd.org,>
From: Gilles Dauphin <Gilles.Dauphin@enst.fr>
List: pkgsrc-bugs
Date: 06/26/2006 13:00:05
The following reply was made to PR pkg/30070; it has been noted by GNATS.
From: Gilles Dauphin <Gilles.Dauphin@enst.fr>
To: solaris-pkg-people@NetBSD.org, gnats-admin@NetBSD.org,
markd@NetBSD.org, andrew@ugh.net.au, gnats-bugs@NetBSD.org
Cc:
Subject: Re: pkg/30070 (lang/perl58 fails to build under Solaris 9)
Date: Mon, 26 Jun 2006 14:57:47 +0200 (CEST)
--Herd_of_Elephants_001_000
Content-Type: TEXT/plain; charset=us-ascii
Content-MD5: rUfMShy5xOHVhf+LlthtlQ==
> Synopsis: lang/perl58 fails to build under Solaris 9
>
> State-Changed-From-To: open->feedback
> State-Changed-By: markd@netbsd.org
> State-Changed-When: Mon, 26 Jun 2006 10:45:11 +0000
> State-Changed-Why:
> is this still a problem for you with latest pkgsrc? perl5 package builds
> fine for me on Solaris 9/sparc and Solaris 10/i386 for both gcc and sunpro.
That's not true for Solaris10/amd64 gcc (ABI=64)
I apply the following path to Makefile and create patch-da:
---------------------------------------------------------------
--- perl5/Makefile Sat May 6 14:32:20 2006
+++ perl5.save//Makefile Mon May 22 16:03:31 2006
@@ -164,6 +164,10 @@
SYSLIBPATH.NetBSD= /usr/lib
SYSLIBPATH.OpenBSD= /usr/lib
SYSLIBPATH.SunOS= /usr/lib
+.if defined(ABI) && ${ABI} == "64"
+SYSLIBPATH.SunOS= /usr/lib/64
+.endif
+
SYSLIBPATH= ${SYSLIBPATH.${OPSYS}}
# Nail down the directories in which headers and libraries of
-------------------------------------------------------------
Gilles
--Herd_of_Elephants_001_000
Content-Type: TEXT/plain; name=patch-da; charset=us-ascii; x-unix-mode=0644
Content-Description: patch-da
Content-MD5: 965QpcKPn3OkZ91WTJ6lHw==
--- hints/solaris_2.sh.orig Tue Oct 11 17:41:18 2005
+++ hints/solaris_2.sh Wed Apr 12 14:23:27 2006
@@ -241,6 +241,9 @@
if echo "$verbose" | grep ' /usr/ccs/bin/ld ' >/dev/null 2>&1; then
# Ok, gcc directly calls the Solaris /usr/ccs/bin/ld.
+ # OK, but gcc 3,4,3 use the -shared option to pass -G to the linker
+ #ccdlflags="$ccdlflags -Wl,-E"
+ lddlflags="$lddlflags -shared"
:
elif echo "$verbose" | grep "ld: Software Generation Utilities" >/dev/null 2>&1; then
# Hmm. gcc doesn't call /usr/ccs/bin/ld directly, but it
@@ -446,7 +449,7 @@
# Keep these in the left margin.
ccflags_uselargefiles="`getconf LFS_CFLAGS 2>/dev/null`"
ldflags_uselargefiles="`getconf LFS_LDFLAGS 2>/dev/null`"
-libswanted_uselargefiles="`getconf LFS_LIBS 2>/dev/null|sed -e 's@^-l@@' -e 's@ -l@ @g`"
+libswanted_uselargefiles="`getconf LFS_LIBS 2>/dev/null|sed -e 's@^-l@@' -e 's@ -l@ @g'`"
ccflags="$ccflags $ccflags_uselargefiles"
ldflags="$ldflags $ldflags_uselargefiles"
@@ -463,7 +466,17 @@
;;
esac
-if test `uname -p` = sparc -o `uname -p` = i386; then
+arch_given=$archname
+case "$arch_given" in
+ x86_64*)
+ arch_result="x86_64"
+ ;;
+ '')
+ arch_result=""
+esac
+
+if test `uname -p` = "sparc" || test "X$arch_result" = "Xx86_64"; then
+#if test `uname -p` = sparc -o `uname -p` = i386; then
cat > UU/use64bitint.cbu <<'EOCBU'
# This script UU/use64bitint.cbu will get 'called-back' by Configure
# after it has prompted the user for whether to use 64 bit integers.
@@ -513,9 +526,7 @@
exit 1
;;
esac
- processor=`uname -p`;
- if test "$processor" = sparc; then
- libc='/usr/lib/sparcv9/libc.so'
+ libc='/usr/lib/64/libc.so'
if test ! -f $libc; then
cat >&4 <<EOM
@@ -525,11 +536,10 @@
EOM
exit 1
fi
- fi
case "${cc:-cc} -v 2>/dev/null" in
*gcc*)
echo 'int main() { return 0; }' > try.c
- case "`${cc:-cc} -mcpu=v9 -m64 -S try.c 2>&1 | grep 'm64 is not supported by this configuration'`" in
+ case "`${cc:-cc} -m64 -S try.c 2>&1 | grep 'm64 is not supported by this configuration'`" in
*"m64 is not supported"*)
cat >&4 <<EOM
@@ -543,19 +553,19 @@
exit 1
;;
esac
- if test "$processor" = sparc; then
- loclibpth="/usr/lib/sparcv9 $loclibpth"
- ccflags="$ccflags -mcpu=v9"
- fi
+ loclibpth="/usr/lib/64 $loclibpth"
ccflags="$ccflags -m64"
- if test $processor = sparc -a X`getconf XBS5_LP64_OFF64_CFLAGS 2>/dev/null` != X; then
+ if test X`getconf XBS5_LP64_OFF64_CFLAGS 2>/dev/null` != X; then
# This adds in -Wa,-xarch=v9. I suspect that's superfluous,
# since the -m64 above should do that already. Someone
# with gcc-3.x.x, please test with gcc -v. A.D. 20-Nov-2003
- ccflags="$ccflags -Wa,`getconf XBS5_LP64_OFF64_CFLAGS 2>/dev/null`"
+ # You are right , does not work on Solaris 10 GD 09-Mar-2006
+ #ccflags="$ccflags -Wa,`getconf XBS5_LP64_OFF64_CFLAGS 2>/dev/null`"
+ :
+
fi
ldflags="$ldflags -m64"
- lddlflags="$lddlflags -G -m64"
+ lddlflags="$lddlflags -shared -m64"
;;
*)
ccflags="$ccflags `getconf XBS5_LP64_OFF64_CFLAGS 2>/dev/null`"
@@ -563,13 +573,10 @@
lddlflags="$lddlflags -G `getconf XBS5_LP64_OFF64_LDFLAGS 2>/dev/null`"
echo "int main() { return(0); } " > try.c
tryworkshopcc="${cc:-cc} try.c -o try $ccflags"
- if test "$processor" = sparc; then
- loclibpth="/usr/lib/sparcv9 /usr/ccs/lib/sparcv9 $loclibpth"
- fi
- loclibpth="`$getworkshoplibs` $loclibpth"
+ loclibpth="/usr/lib/64 `$getworkshoplibs` $loclibpth"
;;
esac
- unset processor
+# unset processor
use64bitall_done=yes
archname64=64
;;
--Herd_of_Elephants_001_000--