NetBSD Problem Report #48842
From www@NetBSD.org Wed May 28 08:48:15 2014
Return-Path: <www@NetBSD.org>
Received: from mail.netbsd.org (mail.netbsd.org [149.20.53.66])
(using TLSv1 with cipher ECDHE-RSA-AES256-SHA (256/256 bits))
(Client CN "mail.netbsd.org", Issuer "Postmaster NetBSD.org" (verified OK))
by mollari.NetBSD.org (Postfix) with ESMTPS id E7B3FA651F
for <gnats-bugs@gnats.NetBSD.org>; Wed, 28 May 2014 08:48:14 +0000 (UTC)
Message-Id: <20140528084813.8EAA9A6520@mollari.NetBSD.org>
Date: Wed, 28 May 2014 08:48:13 +0000 (UTC)
From: manphiz@gmail.com
Reply-To: manphiz@gmail.com
To: gnats-bugs@NetBSD.org
Subject: Wrong flag for linker to extract all symbols from static archives
X-Send-Pr-Version: www-1.0
>Number: 48842
>Category: pkg
>Synopsis: Wrong flag for linker to extract all symbols from static archives
>Confidential: no
>Severity: serious
>Priority: high
>Responsible: macos-pkg-people
>State: open
>Class: change-request
>Submitter-Id: net
>Arrival-Date: Wed May 28 08:50:01 +0000 2014
>Last-Modified: Fri Jul 18 08:33:47 +0000 2014
>Originator: Xiyue Deng
>Release: pkgsrc-current
>Organization:
>Environment:
Darwin Xiyues-MBP.local 13.2.0 Darwin Kernel Version 13.2.0: Thu Apr 17 23:03:13 PDT 2014; root:xnu-2422.100.13~1/RELEASE_X86_64 x86_64
>Description:
The flag for linker to extract all symbols from static archives in Darwin is wrong. It assumes ld is GNU ld which is wrong. The correct flag should be "-Wl,-force_load". A patch is supplied.
>How-To-Repeat:
>Fix:
$NetBSD$
--- mk/platform/Darwin.mk.orig 2013-12-31 11:13:43.000000000 +0000
+++ mk/platform/Darwin.mk
@@ -120,9 +120,8 @@ _OPSYS_PREFER.linux-pam?= native
_OPSYS_PREFER.mit-krb5?= native
# flags passed to the linker to extract all symbols from static archives.
-# this is GNU ld.
-_OPSYS_WHOLE_ARCHIVE_FLAG= -Wl,--whole-archive
-_OPSYS_NO_WHOLE_ARCHIVE_FLAG= -Wl,--no-whole-archive
+_OPSYS_WHOLE_ARCHIVE_FLAG= -Wl,-force_load
+_OPSYS_NO_WHOLE_ARCHIVE_FLAG=
_OPSYS_CAN_CHECK_SHLIBS= no # can't use readelf in check/bsd.check-vars.mk
>Release-Note:
>Audit-Trail:
From: David Holland <dholland-pbugs@netbsd.org>
To: gnats-bugs@netbsd.org
Cc:
Subject: Re: pkg/48842: Wrong flag for linker to extract all symbols from
static archives
Date: Fri, 30 May 2014 08:22:24 +0000
(comments on PRs should be sent to gnats-bugs; mail sent to
gnats-admin is often lost as it vanishes in a flood of administrative
reporting -- note that replying to yourself often requires manual
adjustment of the to-address)
------
From: Xiyue Deng <manphiz@gmail.com>
To: pkg-manager@netbsd.org, gnats-admin@netbsd.org, pkgsrc-bugs@netbsd.org
Subject: Re: pkg/48842: Wrong flag for linker to extract all symbols from
static archives
Date: Wed, 28 May 2014 01:54:41 -0700
On Wed, May 28, 2014 at 1:50 AM, <manphiz@gmail.com> wrote:
> [...]
Forgot to mention, package affected by this issue includes
libexecinfo. Details see
http://mail-index.netbsd.org/pkgsrc-users/2014/05/26/msg019743.html.
From: David Holland <dholland-pbugs@netbsd.org>
To: gnats-bugs@netbsd.org
Cc:
Subject: Re: pkg/48842: Wrong flag for linker to extract all symbols from
static archives
Date: Fri, 30 May 2014 08:24:35 +0000
(also not sent to gnats)
------
From: Xiyue Deng <manphiz@gmail.com>
To: pkg-manager@netbsd.org, gnats-admin@netbsd.org, pkgsrc-bugs@netbsd.org
Subject: Re: pkg/48842: Wrong flag for linker to extract all symbols from
static archives
Date: Wed, 28 May 2014 17:46:41 -0700
On Wed, May 28, 2014 at 1:54 AM, Xiyue Deng <manphiz@gmail.com> wrote:
> Forgot to mention, package affected by this issue includes
> libexecinfo. Details see
> http://mail-index.netbsd.org/pkgsrc-users/2014/05/26/msg019743.html.
Besides the previous patch, pkgtools/bootstrap-mk-files also handles
Darwin wrong. I have made several changes, including:
* Add another OBJECT_FMT "MACH-O" in files/mods/bsd.own.mk.in, using
"OS!= uname -s" to detect Darwin and set properly.
* Modify files/Darwin.bsd.lib.mk to align with Darwin customs.
- Use .dylib instead of .so
- Versioned shared libraries is named
lib${LIB}.${SHLIB_VERSION}.dylib (This including FULLVERSION and
MAJOR_VERSION)
- The flag to extract all symbols from static library is "-force_load".
- A minor fix for lorder as not all objects contain "o" anymore (dylib).
The patches are attached.
$NetBSD$
--- pkgtools/bootstrap-mk-files/files/mods/Darwin.bsd.lib.mk.orig 2013-10-25 13:53:03.000000000 +0000
+++ pkgtools/bootstrap-mk-files/files/mods/Darwin.bsd.lib.mk
@@ -70,9 +70,9 @@ SHLIB_FULLVERSION=${SHLIB_MAJOR}
# add additional suffixes not exported.
# .po is used for profiling object files.
-# .so is used for PIC object files.
-.SUFFIXES: .out .a .ln .so .po .o .s .S .c .cc .C .m .F .f .r .y .l .cl .p .h
-.SUFFIXES: .sh .m4 .m
+# .dylib is used for PIC object files.
+.SUFFIXES: .out .a .ln .dylib .po .o .s .S .c .cc .C .m .F .f .r .y .l .cl .p .h
+.SUFFIXES: .sh .m4 .m .so
# Set PICFLAGS to cc flags for producing position-independent code,
@@ -80,21 +80,23 @@ SHLIB_FULLVERSION=${SHLIB_MAJOR}
# Data-driven table using make variables to control how shared libraries
# are built for different platforms and object formats.
-# OBJECT_FMT: currently either "ELF" or "a.out", from <bsd.own.mk>
+# OBJECT_FMT: currently either "MACH-O" or "a.out", from <bsd.own.mk>
# SHLIB_SOVERSION: version number to be compiled into a shared library
-# via -soname. Usualy ${SHLIB_MAJOR} on ELF.
+# via -dynamiclib. Usualy ${SHLIB_MAJOR} on MAC-O.
# NetBSD/pmax used to use ${SHLIB_MAJOR}[.${SHLIB_MINOR}
# [.${SHLIB_TEENY}]]
# SHLIB_SHFLAGS: Flags to tell ${LD} to emit shared library.
-# with ELF, also set shared-lib version for ld.so.
+# with MACH-O, also set shared-lib version.
# SHLIB_LDSTARTFILE: support .o file, call C++ file-level constructors
# SHLIB_LDENDFILE: support .o file, call C++ file-level destructors
-# FPICFLAGS: flags for ${FC} to compile .[fF] files to .so objects.
+# FPICFLAGS: flags for ${FC} to compile .[fF] files to .dylib
+# objects.
# CPPICFLAGS: flags for ${CPP} to preprocess .[sS] files for ${AS}
-# CPICFLAGS: flags for ${CC} to compile .[cC] files to .so objects.
+# CPICFLAGS: flags for ${CC} to compile .[cC] files to .dylib
+# objects.
# CAPICFLAGS flags for {$CC} to compiling .[Ss] files
-# (usually just ${CPPPICFLAGS} ${CPICFLAGS})
-# APICFLAGS: flags for ${AS} to assemble .[sS] to .so objects.
+# (usually just ${CPPPICFLAGS} ${CPICFLAGS})
+# APICFLAGS: flags for ${AS} to assemble .[sS] to .dylib objects.
.if ${MACHINE_ARCH} == "alpha"
# Alpha-specific shared library flags
@@ -114,12 +116,12 @@ AINC+=-DABICALLS
AFLAGS+= -fPIC
AS+= -KPIC
-.elif ${MACHINE_ARCH} == "vax" && ${OBJECT_FMT} == "ELF"
+.elif ${MACHINE_ARCH} == "vax" && ${OBJECT_FMT} == "MACH-O"
# On the VAX, all object are PIC by default, not just sharedlibs.
MKPICLIB= no
.elif (${MACHINE_ARCH} == "sparc" || ${MACHINE_ARCH} == "sparc64") && \
- ${OBJECT_FMT} == "ELF"
+ ${OBJECT_FMT} == "MACH-O"
FPICFLAGS ?= -fPIC
CPICFLAGS ?= -fPIC -DPIC
@@ -144,10 +146,10 @@ APICFLAGS?= -k
MKPICLIB?= yes
-# Platform-independent linker flags for ELF shared libraries
-.if ${OBJECT_FMT} == "ELF"
+# Platform-independent linker flags for MACH-O shared libraries
+.if ${OBJECT_FMT} == "MACH-O"
SHLIB_SOVERSION= ${SHLIB_MAJOR}
-SHLIB_SHFLAGS= -soname lib${LIB}.so.${SHLIB_SOVERSION}
+SHLIB_SHFLAGS= -install_name lib${LIB}.${SHLIB_SOVERSION}.dylib
SHLIB_LDSTARTFILE?= ${DESTDIR}/usr/lib/crtbeginS.o
SHLIB_LDENDFILE?= ${DESTDIR}/usr/lib/crtendS.o
.endif
@@ -175,7 +177,7 @@ FFLAGS+= ${FOPTS}
@rm -f ${.TARGET}.o
.endif
-.c.so:
+.c.dylib:
.if defined(COPTS) && !empty(COPTS:M*-g*)
${COMPILE.c} ${CPICFLAGS} ${.IMPSRC} -o ${.TARGET}
.else
@@ -208,7 +210,7 @@ FFLAGS+= ${FOPTS}
@rm -f ${.TARGET}.o
.endif
-.cc.so .C.so:
+.cc.dylib .C.dylib:
.if defined(COPTS) && !empty(COPTS:M*-g*)
${COMPILE.cc} ${CPICFLAGS} ${.IMPSRC} -o ${.TARGET}
.else
@@ -238,7 +240,7 @@ FFLAGS+= ${FOPTS}
@rm -f ${.TARGET}.o
.endif
-.f.so:
+.f.dylib:
.if defined(FOPTS) && !empty(FOPTS:M*-g*)
${COMPILE.f} ${FPICFLAGS} ${.IMPSRC} -o ${.TARGET}
.else
@@ -271,7 +273,7 @@ FFLAGS+= ${FOPTS}
@rm -f ${.TARGET}.o
.endif
-.m.so:
+.m.dylib:
.if defined(OBJCFLAGS) && !empty(OBJCFLAGS:M*-g*)
${COMPILE.m} ${CPICFLAGS} ${.IMPSRC} -o ${.TARGET}
.else
@@ -293,7 +295,7 @@ FFLAGS+= ${FOPTS}
@${LD} -r ${.TARGET}.o -o ${.TARGET}
@rm -f ${.TARGET}.o
-.S.so .s.so:
+.S.dylib .s.dylib:
@echo ${COMPILE.S:Q} ${CAPICFLAGS} ${CFLAGS:M-[ID]*} ${AINC} ${.IMPSRC} -o ${.TARGET}
@${COMPILE.S} ${CAPICFLAGS} ${CFLAGS:M-[ID]*} ${AINC} ${.IMPSRC} -o ${.TARGET}.o
@${LD} -r ${.TARGET}.o -o ${.TARGET}
@@ -319,10 +321,10 @@ SOLIB=lib${LIB}.a
.else
SOLIB=lib${LIB}_pic.a
_LIBS+=${SOLIB}
-SOBJS+=${OBJS:.o=.so}
+SOBJS+=${OBJS:.o=.dylib}
.endif
.if defined(SHLIB_FULLVERSION)
-_LIBS+=lib${LIB}.so.${SHLIB_FULLVERSION}
+_LIBS+=lib${LIB}.${SHLIB_FULLVERSION}.dylib
.endif
.endif
@@ -346,7 +348,7 @@ realall: ${SRCS} ${ALLOBJS:O} ${_LIBS}
__archivebuild: .USE
@rm -f ${.TARGET}
- ${AR} -c -q ${.TARGET} `NM=${NM} ${LORDER} ${.ALLSRC:M*o} | ${TSORT}`
+ ${AR} -c -q ${.TARGET} `NM=${NM} ${LORDER} ${.ALLSRC:M*o} ${.ALLSRC:M*dylib} | ${TSORT}`
${RANLIB} ${.TARGET}
__archiveinstall: .USE
@@ -370,28 +372,28 @@ lib${LIB}_p.a:: ${POBJS} __archivebuild
lib${LIB}_pic.a:: ${SOBJS} __archivebuild
@echo building shared object ${LIB} library
-lib${LIB}.so.${SHLIB_FULLVERSION}: ${SOLIB} ${DPADD} \
+lib${LIB}.${SHLIB_FULLVERSION}.dylib: ${SOLIB} ${DPADD} \
${SHLIB_LDSTARTFILE} ${SHLIB_LDENDFILE}
@echo building shared ${LIB} library \(version ${SHLIB_FULLVERSION}\)
- @rm -f lib${LIB}.so.${SHLIB_FULLVERSION}
+ @rm -f lib${LIB}.${SHLIB_FULLVERSION}.dylib
.if defined(DESTDIR)
- $(CC) -nostdlib -shared ${SHLIB_SHFLAGS} -o ${.TARGET} \
+ $(CC) -nostdlib -dynamiclib ${SHLIB_SHFLAGS} -o ${.TARGET} \
${SHLIB_LDSTARTFILE} \
- --whole-archive ${SOLIB} \
- --no-whole-archive ${LDADD} \
+ -force_load ${SOLIB} \
+ ${LDADD} \
-L${DESTDIR}${LIBDIR} -R${LIBDIR} \
${SHLIB_LDENDFILE}
.else
$(CC) -shared ${SHLIB_SHFLAGS} -o ${.TARGET} \
${SHLIB_LDSTARTFILE} \
- --whole-archive ${SOLIB} --no-whole-archive ${LDADD} \
+ -force_load ${SOLIB} ${LDADD} \
${SHLIB_LDENDFILE}
.endif
-.if ${OBJECT_FMT} == "ELF"
- ln -sf lib${LIB}.so.${SHLIB_FULLVERSION} lib${LIB}.so.${SHLIB_MAJOR}.tmp
- mv -f lib${LIB}.so.${SHLIB_MAJOR}.tmp lib${LIB}.so.${SHLIB_MAJOR}
- ln -sf lib${LIB}.so.${SHLIB_FULLVERSION} lib${LIB}.so.tmp
- mv -f lib${LIB}.so.tmp lib${LIB}.so
+.if ${OBJECT_FMT} == "MACH-O"
+ ln -sf lib${LIB}.${SHLIB_FULLVERSION}.dylib lib${LIB}.${SHLIB_MAJOR}.dylib.tmp
+ mv -f lib${LIB}.${SHLIB_MAJOR}.dylib.tmp lib${LIB}.${SHLIB_MAJOR}.dylib
+ ln -sf lib${LIB}.${SHLIB_FULLVERSION}.dylib lib${LIB}.dylib.tmp
+ mv -f lib${LIB}.dylib.tmp lib${LIB}.dylib
.endif
.if !empty(LOBJS)
@@ -406,13 +408,13 @@ cleanlib:
rm -f a.out [Ee]rrs mklog core *.core ${CLEANFILES}
rm -f lib${LIB}.a ${OBJS}
rm -f lib${LIB}_p.a ${POBJS}
- rm -f lib${LIB}_pic.a lib${LIB}.so.* lib${LIB}.so ${SOBJS}
+ rm -f lib${LIB}_pic.a lib${LIB}.dylib.* lib${LIB}.dylib ${SOBJS}
rm -f llib-l${LIB}.ln ${LOBJS}
.if defined(SRCS)
afterdepend: .depend
@(TMP=/tmp/_depend$$$$; \
- sed -e 's/^\([^\.]*\).o[ ]*:/\1.o \1.po \1.so \1.ln:/' \
+ sed -e 's/^\([^\.]*\).o[ ]*:/\1.o \1.po \1.dylib \1.ln:/' \
< .depend > $$TMP; \
mv $$TMP .depend)
.endif
@@ -467,31 +469,31 @@ ${DESTDIR}${LIBDIR}/lib${LIB}_pic.a: lib
.endif
.if ${MKPIC} != "no" && defined(SHLIB_FULLVERSION)
-libinstall:: ${DESTDIR}${LIBDIR}/lib${LIB}.so.${SHLIB_FULLVERSION}
-.PRECIOUS: ${DESTDIR}${LIBDIR}/lib${LIB}.so.${SHLIB_FULLVERSION}
+libinstall:: ${DESTDIR}${LIBDIR}/lib${LIB}.${SHLIB_FULLVERSION}.dylib
+.PRECIOUS: ${DESTDIR}${LIBDIR}/lib${LIB}.${SHLIB_FULLVERSION}.dylib
.if !defined(UPDATE)
-.PHONY: ${DESTDIR}${LIBDIR}/lib${LIB}.so.${SHLIB_FULLVERSION}
+.PHONY: ${DESTDIR}${LIBDIR}/lib${LIB}.${SHLIB_FULLVERSION}.dylib
.endif
-.if !defined(BUILD) && !make(all) && !make(lib${LIB}.so.${SHLIB_FULLVERSION})
-${DESTDIR}${LIBDIR}/lib${LIB}.so.${SHLIB_FULLVERSION}: .MADE
+.if !defined(BUILD) && !make(all) && !make(lib${LIB}.${SHLIB_FULLVERSION}.dylib)
+${DESTDIR}${LIBDIR}/lib${LIB}.${SHLIB_FULLVERSION}.dylib: .MADE
.endif
-${DESTDIR}${LIBDIR}/lib${LIB}.so.${SHLIB_FULLVERSION}: lib${LIB}.so.${SHLIB_FULLVERSION}
+${DESTDIR}${LIBDIR}/lib${LIB}.${SHLIB_FULLVERSION}.dylib: lib${LIB}.${SHLIB_FULLVERSION}.dylib
${INSTALL} ${RENAME} ${PRESERVE} ${COPY} ${INSTPRIV} -o ${LIBOWN} \
-g ${LIBGRP} -m ${LIBMODE} ${.ALLSRC} ${.TARGET}
.if ${OBJECT_FMT} == "a.out" && !defined(DESTDIR)
/sbin/ldconfig -m ${LIBDIR}
.endif
-.if ${OBJECT_FMT} == "ELF"
- ln -sf lib${LIB}.so.${SHLIB_FULLVERSION}\
- ${DESTDIR}${LIBDIR}/lib${LIB}.so.${SHLIB_MAJOR}.tmp
- mv -f ${DESTDIR}${LIBDIR}/lib${LIB}.so.${SHLIB_MAJOR}.tmp\
- ${DESTDIR}${LIBDIR}/lib${LIB}.so.${SHLIB_MAJOR}
+.if ${OBJECT_FMT} == "MACH-O"
+ ln -sf lib${LIB}.${SHLIB_FULLVERSION}.dylib\
+ ${DESTDIR}${LIBDIR}/lib${LIB}.${SHLIB_MAJOR}.dylib.tmp
+ mv -f ${DESTDIR}${LIBDIR}/lib${LIB}.${SHLIB_MAJOR}.dylib.tmp\
+ ${DESTDIR}${LIBDIR}/lib${LIB}.${SHLIB_MAJOR}.dylib
.if ${MKLINKLIB} != "no"
- ln -sf lib${LIB}.so.${SHLIB_FULLVERSION}\
- ${DESTDIR}${LIBDIR}/lib${LIB}.so.tmp
- mv -f ${DESTDIR}${LIBDIR}/lib${LIB}.so.tmp\
- ${DESTDIR}${LIBDIR}/lib${LIB}.so
+ ln -sf lib${LIB}.${SHLIB_FULLVERSION}.dylib\
+ ${DESTDIR}${LIBDIR}/lib${LIB}.dylib.tmp
+ mv -f ${DESTDIR}${LIBDIR}/lib${LIB}.dylib.tmp\
+ ${DESTDIR}${LIBDIR}/lib${LIB}.dylib
.endif
.endif
.endif
Responsible-Changed-From-To: pkg-manager->macos-pkg-people
Responsible-Changed-By: obache@NetBSD.org
Responsible-Changed-When: Fri, 18 Jul 2014 08:33:47 +0000
Responsible-Changed-Why:
Problem on Darwin.
>Unformatted:
(Contact us)
$NetBSD: query-full-pr,v 1.39 2013/11/01 18:47:49 spz Exp $
$NetBSD: gnats_config.sh,v 1.8 2006/05/07 09:23:38 tsutsui Exp $
Copyright © 1994-2007
The NetBSD Foundation, Inc. ALL RIGHTS RESERVED.