Subject: pkg/29608: gcc options not always passed to imake on Solaris
To: None <pkg-manager@netbsd.org, gnats-admin@netbsd.org,>
From: None <grant@NetBSD.org>
List: pkgsrc-bugs
Date: 03/06/2005 03:27:00
>Number: 29608
>Category: pkg
>Synopsis: gcc options not always passed to imake on Solaris
>Confidential: no
>Severity: serious
>Priority: medium
>Responsible: pkg-manager
>State: open
>Class: sw-bug
>Submitter-Id: net
>Arrival-Date: Sun Mar 06 03:27:00 +0000 2005
>Originator: grant beattie
>Release: SunOS 5.8
>Organization:
>Environment:
System: SunOS sunburst 5.8 Generic_108528-13 sun4u sparc SUNW,Sun-Blade-1000
Architecture: sparc
Machine: sun4u
>Description:
compiler/gcc.mk has:
# Pass the required flags to imake to tell it we're using gcc on
# Solaris.
.if ${OPSYS} == "SunOS"
IMAKEOPTS+= -DHasGcc2=YES -DHasGcc2ForCplusplus=YES
.endif
however, these flags aren't passed to imake when it is called, so the
compiler flags for sunpro are passed to gcc, resulting in:
===> Building for xpm-3.4knb2
making all in ./lib...
rm -f data.o unshared/data.o
cc -c -Xc -xF -xcg92 -I. -I/usr/pkg/include -Dsun -Dsparc -DSVR4 -DSYSV -O2 data.c
gcc: unrecognized option `-Xc'
gcc: language cg92 not recognized
I suspect this is related to the xpkgwedge and the imake wrapper. the
values of IMAKEOPTS and IMAKE respectively:
-DHasGcc2=YES -DHasGcc2ForCplusplus=YES
/usr/openwin/bin/imake -DHasGcc2=YES -DHasGcc2ForCplusplus=YES
upon closer inspection, pkgxmkmf is called without ${IMAKEOPTS}, so
the flags are not passed to the imake wrapper. however, even when
IMAKEOPTS is added to XMKMF_CMD:
/usr/pkg/bin/pkgxmkmf -DHasGcc2=YES -DHasGcc2ForCplusplus=YES
the flags are not passed to all invocations of imake, and the SunPro
flags are still passed.
>How-To-Repeat:
attempt to build graphics/xpm with gcc on Solaris.
>Fix:
the real fix is probably to always add the required flags in the imake
wrapper.
the imake config files on Solaris 8 still pass -Kpic to ${CC}, which
is ignored by gcc and results in relocation errors at link time. this
can be fixed wholesale by adding a wrapper for gcc on Solaris to
transform this flag.