version 1.324.2.3, 2013/06/23 06:28:54 |
version 1.363, 2016/01/31 15:30:14 |
Line 42 realinstall: checkver libinstall |
|
Line 42 realinstall: checkver libinstall |
|
# XXX: This is needed for programs that link with .a libraries |
# XXX: This is needed for programs that link with .a libraries |
# Perhaps a more correct solution is to always generate _pic.a |
# Perhaps a more correct solution is to always generate _pic.a |
# files or always have a shared library. |
# files or always have a shared library. |
.if defined(MKPIE) && (${MKPIE} != "no") |
.if defined(MKPIE) && (${MKPIE} != "no") && !defined(NOPIE) |
CFLAGS+= ${PIE_CFLAGS} |
CFLAGS+= ${PIE_CFLAGS} |
AFLAGS+= ${PIE_AFLAGS} |
AFLAGS+= ${PIE_AFLAGS} |
.endif |
.endif |
Line 64 DPADD+= ${LIBDO.${_lib}}/lib${_lib}.so |
|
Line 64 DPADD+= ${LIBDO.${_lib}}/lib${_lib}.so |
|
.endif # } |
.endif # } |
|
|
##### Build and install rules |
##### Build and install rules |
MKDEP_SUFFIXES?= .o .po .pico .go .ln |
MKDEP_SUFFIXES?= .o .po .pico .go .ln .d |
|
|
.if !defined(SHLIB_MAJOR) && exists(${SHLIB_VERSION_FILE}) # { |
.if !defined(SHLIB_MAJOR) && exists(${SHLIB_VERSION_FILE}) # { |
SHLIB_MAJOR != . ${SHLIB_VERSION_FILE} ; echo $$major |
SHLIB_MAJOR != . ${SHLIB_VERSION_FILE} ; echo $$major |
Line 129 SHLIB_FULLVERSION=${SHLIB_MAJOR} |
|
Line 129 SHLIB_FULLVERSION=${SHLIB_MAJOR} |
|
|
|
|
|
# Set PICFLAGS to cc flags for producing position-independent code, |
# Set PICFLAGS to cc flags for producing position-independent code, |
# if not already set. Includes -DPIC, if required. |
# if not already set. |
|
|
# Data-driven table using make variables to control how shared libraries |
# Data-driven table using make variables to control how shared libraries |
# are built for different platforms and object formats. |
# are built for different platforms and object formats. |
Line 143 SHLIB_FULLVERSION=${SHLIB_MAJOR} |
|
Line 143 SHLIB_FULLVERSION=${SHLIB_MAJOR} |
|
# with ELF, also set shared-lib version for ld.so. |
# with ELF, also set shared-lib version for ld.so. |
# SHLIB_LDSTARTFILE: support .o file, call C++ file-level constructors |
# SHLIB_LDSTARTFILE: support .o file, call C++ file-level constructors |
# SHLIB_LDENDFILE: support .o file, call C++ file-level destructors |
# SHLIB_LDENDFILE: support .o file, call C++ file-level destructors |
# FPICFLAGS: flags for ${FC} to compile .[fF] files to .pico objects. |
|
# CPPPICFLAGS: flags for ${CPP} to preprocess .[sS] files for ${AS} |
|
# CPICFLAGS: flags for ${CC} to compile .[cC] files to pic objects. |
|
# CSHLIBFLAGS: flags for ${CC} to compile .[cC] files to .pico objects. |
|
# (usually includes ${CPICFLAGS}) |
|
# CAPICFLAGS: flags for ${CC} to compiling .[Ss] files |
|
# (usually just ${CPPPICFLAGS} ${CPICFLAGS}) |
|
# APICFLAGS: flags for ${AS} to assemble .[sS] to .pico objects. |
|
|
|
.if ${MACHINE_ARCH} == "alpha" # { |
|
|
|
FPICFLAGS ?= -fPIC |
|
CPICFLAGS ?= -fPIC -DPIC |
|
CPPPICFLAGS?= -DPIC |
|
CAPICFLAGS?= ${CPPPICFLAGS} ${CPICFLAGS} |
|
APICFLAGS ?= |
|
|
|
.elif (${MACHINE_ARCH} == "sparc" || ${MACHINE_ARCH} == "sparc64") # } { |
|
|
|
# If you use -fPIC you need to define BIGPIC to turn on 32-bit |
|
# relocations in asm code |
|
FPICFLAGS ?= -fPIC |
|
CPICFLAGS ?= -fPIC -DPIC |
|
CPPPICFLAGS?= -DPIC -DBIGPIC |
|
CAPICFLAGS?= ${CPPPICFLAGS} ${CPICFLAGS} |
|
APICFLAGS ?= -KPIC |
|
|
|
.else # } { |
|
|
|
# Platform-independent flags for NetBSD shared libraries |
|
SHLIB_SOVERSION=${SHLIB_FULLVERSION} |
|
SHLIB_SHFLAGS= |
|
FPICFLAGS ?= -fPIC |
|
CPICFLAGS?= -fPIC -DPIC |
|
CPPPICFLAGS?= -DPIC |
|
CAPICFLAGS?= ${CPPPICFLAGS} ${CPICFLAGS} |
|
APICFLAGS?= -k |
|
|
|
.endif # } |
PICFLAGS ?= -fPIC |
|
|
.if ${MKPICLIB} != "no" |
.if ${MKPICLIB} != "no" |
CSHLIBFLAGS+= ${CPICFLAGS} |
CSHLIBFLAGS+= ${PICFLAGS} |
.endif |
.endif |
|
|
.if defined(CSHLIBFLAGS) && !empty(CSHLIBFLAGS) |
.if defined(CSHLIBFLAGS) && !empty(CSHLIBFLAGS) |
|
|
# Platform-independent linker flags for ELF shared libraries |
# Platform-independent linker flags for ELF shared libraries |
SHLIB_SOVERSION= ${SHLIB_MAJOR} |
SHLIB_SOVERSION= ${SHLIB_MAJOR} |
SHLIB_SHFLAGS= -Wl,-soname,${_LIB}.so.${SHLIB_SOVERSION} |
SHLIB_SHFLAGS= -Wl,-soname,${_LIB}.so.${SHLIB_SOVERSION} |
|
.if !defined(SHLIB_WARNTEXTREL) || ${SHLIB_WARNTEXTREL} != "no" |
SHLIB_SHFLAGS+= -Wl,--warn-shared-textrel |
SHLIB_SHFLAGS+= -Wl,--warn-shared-textrel |
|
.endif |
|
.if !defined(SHLIB_MKMAP) || ${SHLIB_MKMAP} != "no" |
|
SHLIB_SHFLAGS+= -Wl,-Map=${_LIB}.so.${SHLIB_SOVERSION}.map |
|
.endif |
|
CLEANFILES+= ${_LIB}.so.${SHLIB_SOVERSION}.map |
SHLIB_LDSTARTFILE?= ${_GCC_CRTI} ${_GCC_CRTBEGINS} |
SHLIB_LDSTARTFILE?= ${_GCC_CRTI} ${_GCC_CRTBEGINS} |
SHLIB_LDENDFILE?= ${_GCC_CRTENDS} ${_GCC_CRTN} |
SHLIB_LDENDFILE?= ${_GCC_CRTENDS} ${_GCC_CRTN} |
|
|
Line 218 FFLAGS+= ${FOPTS} |
|
Line 187 FFLAGS+= ${FOPTS} |
|
.if defined(CTFCONVERT) |
.if defined(CTFCONVERT) |
.if defined(CFLAGS) && !empty(CFLAGS:M*-g*) |
.if defined(CFLAGS) && !empty(CFLAGS:M*-g*) |
CTFFLAGS+= -g |
CTFFLAGS+= -g |
|
.if defined(HAVE_GCC) && ${HAVE_GCC} >= 48 |
|
#CFLAGS+= -gdwarf-2 |
|
.endif |
.endif |
.endif |
.endif |
.endif |
|
|
Line 317 LIBSTRIPSHLIBOBJS= yes |
|
Line 289 LIBSTRIPSHLIBOBJS= yes |
|
|
|
.f.pico: |
.f.pico: |
${_MKTARGET_COMPILE} |
${_MKTARGET_COMPILE} |
${COMPILE.f} ${FPICFLAGS} ${.IMPSRC} -o ${.TARGET} |
${COMPILE.f} ${PICFLAGS} ${.IMPSRC} -o ${.TARGET} |
.if defined(LIBSTRIPFOBJS) |
.if defined(LIBSTRIPFOBJS) |
${OBJCOPY} ${OBJCOPYLIBFLAGS} ${.TARGET} |
${OBJCOPY} ${OBJCOPYLIBFLAGS} ${.TARGET} |
.endif |
.endif |
Line 410 LIBSTRIPSHLIBOBJS= yes |
|
Line 382 LIBSTRIPSHLIBOBJS= yes |
|
|
|
.s.pico: |
.s.pico: |
${_MKTARGET_COMPILE} |
${_MKTARGET_COMPILE} |
${COMPILE.s} ${CAPICFLAGS} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${.IMPSRC} -o ${.TARGET} |
${COMPILE.s} ${PICFLAGS} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${.IMPSRC} -o ${.TARGET} |
.if defined(LIBSTRIPAOBJS) |
.if defined(LIBSTRIPAOBJS) |
${OBJCOPY} ${OBJCOPYLIBFLAGS} ${.TARGET} |
${OBJCOPY} ${OBJCOPYLIBFLAGS} ${.TARGET} |
.endif |
.endif |
|
|
.S.pico: |
.S.pico: |
${_MKTARGET_COMPILE} |
${_MKTARGET_COMPILE} |
${COMPILE.S} ${CAPICFLAGS} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${.IMPSRC} -o ${.TARGET} |
${COMPILE.S} ${PICFLAGS} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${.IMPSRC} -o ${.TARGET} |
.if defined(LIBSTRIPAOBJS) |
.if defined(LIBSTRIPAOBJS) |
${OBJCOPY} ${OBJCOPYLIBFLAGS} ${.TARGET} |
${OBJCOPY} ${OBJCOPYLIBFLAGS} ${.TARGET} |
.endif |
.endif |
Line 434 _LIB.ln:=llib-l${LIB}.ln |
|
Line 406 _LIB.ln:=llib-l${LIB}.ln |
|
_LIB.so:=${_LIB}.so |
_LIB.so:=${_LIB}.so |
_LIB.so.major:=${_LIB}.so.${SHLIB_MAJOR} |
_LIB.so.major:=${_LIB}.so.${SHLIB_MAJOR} |
_LIB.so.full:=${_LIB}.so.${SHLIB_FULLVERSION} |
_LIB.so.full:=${_LIB}.so.${SHLIB_FULLVERSION} |
|
_LIB.so.link:=${_LIB}.so.${SHLIB_FULLVERSION}.link |
.if ${MKDEBUG} != "no" |
.if ${MKDEBUG} != "no" |
_LIB.so.debug:=${_LIB.so.full}.debug |
_LIB.so.debug:=${_LIB.so.full}.debug |
.endif |
.endif |
Line 472 ${_LIB}_combine.o: ${COMBINESRCS} |
|
Line 445 ${_LIB}_combine.o: ${COMBINESRCS} |
|
${_MKTARGET_COMPILE} |
${_MKTARGET_COMPILE} |
${COMPILE.c} -MD --combine ${.ALLSRC} -o ${.TARGET} |
${COMPILE.c} -MD --combine ${.ALLSRC} -o ${.TARGET} |
.if defined(LIBSTRIPOBJS) |
.if defined(LIBSTRIPOBJS) |
${OBJCOPY} -x ${.TARGET} |
${OBJCOPY} ${OBJCOPYLIBFLAGS} ${.TARGET} |
.endif |
.endif |
|
|
CLEANFILES+= ${_LIB}_combine.d |
CLEANFILES+= ${_LIB}_combine.d |
Line 551 _YLSRCS= ${SRCS:M*.[ly]:C/\..$/.c/} ${YH |
|
Line 524 _YLSRCS= ${SRCS:M*.[ly]:C/\..$/.c/} ${YH |
|
|
|
realall: ${SRCS} ${ALLOBJS:O} ${_LIBS} ${_LIB.so.debug} |
realall: ${SRCS} ${ALLOBJS:O} ${_LIBS} ${_LIB.so.debug} |
|
|
MKARZERO?=no |
MKARZERO?= ${MKREPRO:Uno} |
|
|
.if ${MKARZERO} == "yes" |
.if ${MKARZERO} == "yes" |
_ARFL=crsD |
_ARFL=crsD |
Line 622 DPLIBC ?= ${DESTDIR}${LIBC_SO} |
|
Line 595 DPLIBC ?= ${DESTDIR}${LIBC_SO} |
|
.endif |
.endif |
.else |
.else |
LDLIBC ?= -nodefaultlibs |
LDLIBC ?= -nodefaultlibs |
.if ${LIB} == "c" |
.if ${HAVE_LIBGCC} == "yes" && ${LIB} == "c" |
LDADD+= -lgcc |
LDADD+= -lgcc |
.endif |
.endif |
.endif |
.endif |
|
|
|
|
.if ${LIBISCXX} != "no" |
.if ${LIBISCXX} != "no" |
LIBCC:= ${CXX} |
LIBCC:= ${CXX} |
|
. if ${MKLIBCXX} == "yes" |
|
LIBDPLIBS+= c++ ${.CURDIR}/../../../../../external/bsd/libc++/lib |
|
. else |
|
LIBDPLIBS+= stdc++ ${.CURDIR}/../../../../../external/gpl3/${EXTERNAL_GCC_SUBDIR}/lib/libstdc++-v3 |
|
. endif |
.else |
.else |
LIBCC:= ${CC} |
LIBCC:= ${CC} |
.endif |
.endif |
|
|
_LDADD.${_LIB}= ${LDADD} ${LDADD.${_LIB}} |
_LDADD.${_LIB}= ${LDADD} ${LDADD.${_LIB}} |
_LDFLAGS.${_LIB}= ${LDFLAGS} ${LDFLAGS.${_LIB}} |
_LDFLAGS.${_LIB}= ${LDFLAGS} ${LDFLAGS.${_LIB}} |
|
|
${_LIB.so.full}: ${SOLIB} ${DPADD} ${DPLIBC} \ |
_MAINLIBDEPS= ${SOLIB} ${DPADD} ${DPLIBC} \ |
${SHLIB_LDSTARTFILE} ${SHLIB_LDENDFILE} |
${SHLIB_LDSTARTFILE} ${SHLIB_LDENDFILE} |
|
|
|
.if defined(_LIB.so.debug) |
|
${_LIB.so.debug}: ${_LIB.so.link} |
|
${_MKTARGET_CREATE} |
|
( ${OBJCOPY} --only-keep-debug \ |
|
${_LIB.so.link} ${_LIB.so.debug} \ |
|
) || (rm -f ${.TARGET}; false) |
|
${_LIB.so.full}: ${_LIB.so.link} ${_LIB.so.debug} |
|
${_MKTARGET_CREATE} |
|
( ${OBJCOPY} --strip-debug -p -R .gnu_debuglink \ |
|
--add-gnu-debuglink=${_LIB.so.debug} \ |
|
${_LIB.so.link} ${_LIB.so.full} \ |
|
) || (rm -f ${.TARGET}; false) |
|
${_LIB.so.link}: ${_MAINLIBDEPS} |
|
.else # aka no MKDEBUG |
|
${_LIB.so.full}: ${_MAINLIBDEPS} |
|
.endif |
${_MKTARGET_BUILD} |
${_MKTARGET_BUILD} |
rm -f ${.TARGET} |
rm -f ${.TARGET} |
${LIBCC} ${LDLIBC} -Wl,-x -shared ${SHLIB_SHFLAGS} \ |
${LIBCC} ${LDLIBC} -Wl,-x -shared ${SHLIB_SHFLAGS} \ |
Line 648 ${_LIB.so.full}: ${SOLIB} ${DPADD} ${DPL |
|
Line 643 ${_LIB.so.full}: ${SOLIB} ${DPADD} ${DPL |
|
# We don't use INSTALL_SYMLINK here because this is just |
# We don't use INSTALL_SYMLINK here because this is just |
# happening inside the build directory/objdir. XXX Why does |
# happening inside the build directory/objdir. XXX Why does |
# this spend so much effort on libraries that aren't live??? XXX |
# this spend so much effort on libraries that aren't live??? XXX |
|
# XXX Also creates dead symlinks until the .full rule runs |
|
# above and creates the main link |
.if defined(SHLIB_FULLVERSION) && defined(SHLIB_MAJOR) && \ |
.if defined(SHLIB_FULLVERSION) && defined(SHLIB_MAJOR) && \ |
"${SHLIB_FULLVERSION}" != "${SHLIB_MAJOR}" |
"${SHLIB_FULLVERSION}" != "${SHLIB_MAJOR}" |
${HOST_LN} -sf ${_LIB.so.full} ${_LIB.so.major}.tmp |
${HOST_LN} -sf ${_LIB.so.full} ${_LIB.so.major}.tmp |
Line 659 ${_LIB.so.full}: ${SOLIB} ${DPADD} ${DPL |
|
Line 656 ${_LIB.so.full}: ${SOLIB} ${DPADD} ${DPL |
|
${OBJCOPY} -R .ident ${.TARGET} |
${OBJCOPY} -R .ident ${.TARGET} |
.endif |
.endif |
|
|
.if defined(_LIB.so.debug) |
|
${_LIB.so.debug}: ${_LIB.so.full} |
|
${_MKTARGET_CREATE} |
|
( ${OBJCOPY} --only-keep-debug ${_LIB.so.full} ${_LIB.so.debug} \ |
|
&& ${OBJCOPY} --strip-debug -p -R .gnu_debuglink \ |
|
--add-gnu-debuglink=${_LIB.so.debug} ${_LIB.so.full} \ |
|
) || (rm -f ${.TARGET}; false) |
|
.endif |
|
|
|
.if !empty(LOBJS) # { |
.if !empty(LOBJS) # { |
LLIBS?= -lc |
LLIBS?= -lc |
${_LIB.ln}: ${LOBJS} |
${_LIB.ln}: ${LOBJS} |