summaryrefslogtreecommitdiff
path: root/cross/COMMON/cross.mk
diff options
context:
space:
mode:
authortv <tv@pkgsrc.org>1998-08-12 02:42:28 +0000
committertv <tv@pkgsrc.org>1998-08-12 02:42:28 +0000
commitfd10f264e8eefd5c610424c96a2bb41dbf83cde8 (patch)
treef1168c1b8cb56ca82e6357379d328a6370990b8d /cross/COMMON/cross.mk
parent995b53b0b7d58c5c91069b4af21fc4ddc3d99933 (diff)
downloadpkgsrc-fd10f264e8eefd5c610424c96a2bb41dbf83cde8.tar.gz
Shared files used in many cross pkgs.
Diffstat (limited to 'cross/COMMON/cross.mk')
-rw-r--r--cross/COMMON/cross.mk137
1 files changed, 137 insertions, 0 deletions
diff --git a/cross/COMMON/cross.mk b/cross/COMMON/cross.mk
new file mode 100644
index 00000000000..8c4d22a8491
--- /dev/null
+++ b/cross/COMMON/cross.mk
@@ -0,0 +1,137 @@
+# $NetBSD: cross.mk,v 1.1 1998/08/12 02:42:29 tv Exp $
+
+# Shared definitions for building a cross-compile environment.
+
+DISTNAME= cross-${TARGET_ARCH}-${DISTVERSION}
+CATEGORIES+= cross lang
+USE_CROSSBASE= yes
+PLIST_SRC= ${WRKDIR}/.PLIST_SRC
+
+TARGET_DIR= ${PREFIX}/${TARGET_ARCH}
+COMMON_DIR= ${PKGSRCDIR}/cross/COMMON
+PLIST_PRE?= ${PKGDIR}/PLIST
+
+do-install: do-install-dirs
+do-install-dirs:
+ ${INSTALL_DATA_DIR} ${PREFIX}
+ ${INSTALL_DATA_DIR} ${PREFIX}/bin
+ ${INSTALL_DATA_DIR} ${PREFIX}/lib
+ ${INSTALL_DATA_DIR} ${TARGET_DIR}
+ ${INSTALL_DATA_DIR} ${TARGET_DIR}/bin
+ ${INSTALL_DATA_DIR} ${TARGET_DIR}/include
+ ${INSTALL_DATA_DIR} ${TARGET_DIR}/lib
+
+.if defined(USE_CROSS_GNU)
+BINUTILS_DISTNAME= binutils-2.9.1
+CROSS_DISTFILES+= ${BINUTILS_DISTNAME}.tar.gz
+MASTER_SITES+= ${MASTER_SITE_GNU}
+CONFIGURE_ARGS+= --with-gnu-as --with-gnu-ld
+PLIST_PRE+= ${COMMON_DIR}/PLIST-binutils
+USE_CROSS_EGCS= yes
+
+post-extract: post-extract-binutils
+post-extract-binutils:
+ @cd ${WRKSRC} && \
+ ${LN} -sf ../${BINUTILS_DISTNAME}/bfd && \
+ ${LN} -sf ../${BINUTILS_DISTNAME}/binutils && \
+ ${LN} -sf ../${BINUTILS_DISTNAME}/gas && \
+ ${LN} -sf ../${BINUTILS_DISTNAME}/ld && \
+ ${LN} -sf ../${BINUTILS_DISTNAME}/opcodes && \
+ ${LN} -sf ../gas/as-new gcc/as && \
+ ${LN} -sf ../ld/ld-new gcc/ld
+ @cd ${WRKDIR}/${BINUTILS_DISTNAME} && \
+ ${RM} -rf libiberty texinfo && \
+ ${LN} -sf ../${EGCS_DISTNAME}/libiberty
+
+do-install: do-install-binutils
+do-install-binutils:
+ @cd ${WRKSRC}/binutils && ${GMAKE} install-exec
+ @cd ${WRKSRC}/gas && ${GMAKE} install-exec
+ @cd ${WRKSRC}/ld && ${GMAKE} install-exec
+ for file in addr2line c++filt gasp objcopy objdump size strings; do \
+ ${LN} -f ${PREFIX}/bin/${TARGET_ARCH}-$$file ${TARGET_DIR}/bin/$$file; \
+ done
+.endif
+
+.if defined(USE_CROSS_EGCS)
+#.if defined(USE_CROSS_EGCS_SNAPSHOT)
+EGCS_DISTNAME= egcs-19980803
+EGCS_DISTDIR= snapshots/1998-08-03
+EGCS_INTVERSION= egcs-2.91.53
+EGCS_PLIST_PRE= ${COMMON_DIR}/PLIST-egcs-ss
+CROSS_PATCHFILES+= ${COMMON_DIR}/patches-egcs-ss/patch-*
+#.else
+#EGCS_DISTNAME= egcs-1.1
+#EGCS_DISTDIR= releases/egcs-1.1
+#EGCS_INTVERSION= egcs-2.??.??
+#.endif
+
+CROSS_DISTFILES+= ${EGCS_DISTNAME}.tar.gz
+MASTER_SITES+= ftp://egcs.cygnus.com/pub/egcs/${EGCS_DISTDIR}/
+WRKSRC= ${WRKDIR}/${EGCS_DISTNAME}
+PLIST_PRE+= ${EGCS_PLIST_PRE}
+
+GNU_CONFIGURE= yes
+CONFIGURE_ARGS+= --target=${TARGET_ARCH} \
+ --enable-version-specific-runtime-libs
+CONFIGURE_ENV+= CXXFLAGS="${CXXFLAGS}"
+USE_GMAKE= yes
+MAKE_FLAGS+= CC_FOR_TARGET="${WRKSRC}/gcc/xgcc -B${WRKSRC}/gcc/ -idirafter ${SYS_INCLUDE} -L${SYS_LIB}" \
+ GCC_FOR_TARGET='$${CC_FOR_TARGET}' \
+ CXX_FOR_TARGET='$${CC_FOR_TARGET}' \
+ LANGUAGES="c c++ f77 objc" \
+ SYSTEM_HEADER_DIR="${SYS_INCLUDE}"
+
+post-extract: post-extract-egcs
+post-extract-egcs:
+ @cd ${WRKSRC} && ${RM} -rf texinfo
+
+do-install: do-install-egcs
+do-install-egcs:
+ @cd ${WRKSRC}/gcc && ${GMAKE} ${MAKE_FLAGS} install-common install-headers install-libgcc install-driver
+ chown -R ${BINOWN}:${BINGRP} ${PREFIX}/lib/gcc-lib/${TARGET_ARCH}/${EGCS_INTVERSION}
+ @cd ${WRKSRC} && ${GMAKE} ${MAKE_FLAGS} install-target-libf2c install-target-libstdc++
+ ${LN} -f ${PREFIX}/bin/${TARGET_ARCH}-gcc ${PREFIX}/bin/${TARGET_ARCH}-cc
+ ${LN} -f ${PREFIX}/bin/${TARGET_ARCH}-g77 ${PREFIX}/bin/${TARGET_ARCH}-f77
+ for file in cc c++ f77 g++ g77; do \
+ ${LN} -f ${PREFIX}/bin/${TARGET_ARCH}-$$file ${TARGET_DIR}/bin/$$file; \
+ done
+ @${RMDIR} -p ${PREFIX}/info 2>/dev/null || ${TRUE}
+ @${RMDIR} -p ${PREFIX}/man/man1 2>/dev/null || ${TRUE}
+.endif
+
+.if defined(SYS_INCLUDE)
+do-install: do-install-includes
+do-install-includes:
+ cd ${SYS_INCLUDE} && pax -rw . ${TARGET_DIR}/include
+.endif
+
+.if defined(SYS_LIB)
+do-install: do-install-lib
+do-install-lib:
+ cd ${SYS_LIB} && pax -rw . ${TARGET_DIR}/lib
+.endif
+
+post-install: post-install-plist
+post-install-plist:
+ @${SED} -e 's|$${TARGET_ARCH}|${TARGET_ARCH}|' \
+ -e 's|$${EGCS_INTVERSION}|${EGCS_INTVERSION}|' \
+ ${PLIST_PRE} >${PLIST_SRC}
+ @${ECHO} '@dirrm ${TARGET_ARCH}/bin' >>${PLIST_SRC}
+ @${ECHO} '@dirrm ${TARGET_ARCH}/include' >>${PLIST_SRC}
+ @${ECHO} '@dirrm ${TARGET_ARCH}/lib' >>${PLIST_SRC}
+ @${ECHO} '@dirrm ${TARGET_ARCH}' >>${PLIST_SRC}
+
+.if defined(CROSS_PATCHFILES)
+PATCHFILES+= ${CROSS_PATCHFILES}
+ALLFILES= ${DISTFILES} # don't checksum shared patches
+.endif
+
+.if defined(CROSS_DISTFILES)
+DISTFILES+= ${CROSS_DISTFILES}
+.if defined(EXTRACT_ONLY)
+EXTRACT_ONLY+= ${CROSS_DISTFILES}
+.endif
+.endif
+
+.include "../../mk/bsd.pkg.mk"