summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'sys-devel/crossdev')
-rw-r--r--sys-devel/crossdev/ChangeLog8
-rw-r--r--sys-devel/crossdev/crossdev-0.9.8.ebuild21
-rwxr-xr-xsys-devel/crossdev/files/crossdev105
-rw-r--r--sys-devel/crossdev/files/digest-crossdev-0.9.80
4 files changed, 103 insertions, 31 deletions
diff --git a/sys-devel/crossdev/ChangeLog b/sys-devel/crossdev/ChangeLog
index 1fa9dacb87a5..d95f82349426 100644
--- a/sys-devel/crossdev/ChangeLog
+++ b/sys-devel/crossdev/ChangeLog
@@ -1,6 +1,12 @@
# ChangeLog for sys-devel/crossdev
# Copyright 1999-2005 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/sys-devel/crossdev/ChangeLog,v 1.20 2005/07/15 03:13:09 vapier Exp $
+# $Header: /var/cvsroot/gentoo-x86/sys-devel/crossdev/ChangeLog,v 1.21 2005/07/25 23:00:49 vapier Exp $
+
+*crossdev-0.9.8 (25 Jul 2005)
+
+ 25 Jul 2005; Mike Frysinger <vapier@gentoo.org> files/crossdev,
+ +crossdev-0.9.8.ebuild:
+ Add an option to create a cross gdb.
*crossdev-0.9.7 (15 Jul 2005)
diff --git a/sys-devel/crossdev/crossdev-0.9.8.ebuild b/sys-devel/crossdev/crossdev-0.9.8.ebuild
new file mode 100644
index 000000000000..e6167ec9ded2
--- /dev/null
+++ b/sys-devel/crossdev/crossdev-0.9.8.ebuild
@@ -0,0 +1,21 @@
+# Copyright 1999-2005 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/sys-devel/crossdev/crossdev-0.9.8.ebuild,v 1.1 2005/07/25 23:00:49 vapier Exp $
+
+DESCRIPTION="Gentoo Cross-toolchain generator"
+HOMEPAGE="http://www.gentoo.org/"
+SRC_URI=""
+
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="alpha amd64 arm hppa ia64 m68k mips ppc ppc64 s390 sh sparc x86"
+IUSE=""
+
+RDEPEND="sys-apps/portage
+ app-shells/bash
+ sys-apps/coreutils"
+
+src_install() {
+ dosbin "${FILESDIR}"/crossdev || die
+ dosed "s:GENTOO_PV:${PV}:" /usr/sbin/crossdev
+}
diff --git a/sys-devel/crossdev/files/crossdev b/sys-devel/crossdev/files/crossdev
index 5cf1652feeef..ea649e5267e7 100755
--- a/sys-devel/crossdev/files/crossdev
+++ b/sys-devel/crossdev/files/crossdev
@@ -1,7 +1,7 @@
#!/bin/bash
# Copyright 1999-2005 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/sys-devel/crossdev/files/crossdev,v 1.27 2005/07/15 03:13:09 vapier Exp $
+# $Header: /var/cvsroot/gentoo-x86/sys-devel/crossdev/files/crossdev,v 1.28 2005/07/25 23:00:49 vapier Exp $
if [[ ${ROOT:-/} != "/" ]] ; then
echo "Sorry, but crossdev does not support ROOT."
@@ -28,22 +28,29 @@ ${GOOD}Options${NORMAL}:
${GOOD}--g, --gcc${NORMAL} ver Specify version of gcc to use
${GOOD}--k, --kernel${NORMAL} ver Specify version of kernel headers to use
${GOOD}--l, --libc${NORMAL} ver Specify version of libc to use
-
- ${GOOD}-V, --version${NORMAL} Show crossdev version
${GOOD}-C, --clean${NORMAL} target Uninstall specified target
${GOOD}-b, -p, -v${NORMAL} Options to pass to emerge (see emerge(1))
-
+Basic Targets:
${GOOD}-s0, --stage0${NORMAL} Build just binutils
- ${GOOD}-s1, --stage1${NORMAL} Build a C compiler (no libc/C++)
- ${GOOD}-s2, --stage2${NORMAL} Build a C compiler & libc (no C++)
- ${GOOD}-s3, --stage3${NORMAL} Build a C/C++ compiler & libc [default]
-
-${BRACKET}Target (-t)${NORMAL}:
- The target takes the form: ${BRACKET}ARCH-VENDOR-OS-LIBC${NORMAL}
- Examples: arm-unknown-linux-gnu sh4-gentoo-linux-uclibc mips-gentoo-linux-uclibc
+ ${GOOD}-s1, --stage1${NORMAL} Also build a C compiler (no libc/C++)
+ ${GOOD}-s2, --stage2${NORMAL} Also build kernel headers
+ ${GOOD}-s3, --stage3${NORMAL} Also build the C library (no C++)
+ ${GOOD}-s4, --stage4${NORMAL} Also build a C++ compiler [default]
+Extra Fun (must be run after above stages):
+ ${GOOD}--ex-only${NORMAL} Skip the stage steps above
+ ${GOOD}--ex-gcc${NORMAL} Build extra gcc targets (gcj/ada/etc...)
+ ${GOOD}--ex-gdb${NORMAL} Build a cross gdb
+
+${BRACKET}Target (-t)${NORMAL}: takes the form: ${BRACKET}ARCH-VENDOR-OS-LIBC${NORMAL}
+ Examples: arm-unknown-linux-gnu sh4-gentoo-linux-uclibc
EOF
exit ${1:-0}
}
+STAGE_BINUTILS=0
+STAGE_C_ONLY=1
+STAGE_LIBC=3
+STAGE_C_CPP=4
+STAGE_DISP=( "binutils" "C compiler only" "kernel headers" "C compiler & libc" "C/C++ compiler" )
parse_target() {
[[ -z $1 ]] && usage 1
@@ -85,7 +92,7 @@ parse_target() {
#####################
### other targets ###
avr*) TARCH=${HARCH}; CPOST="";
- KPKG="[none]"; STAGE="3";
+ KPKG="[none]"; STAGE=${STAGE_LIBC};
LCAT="dev-embedded"; LPKG="avr-libc";
GVER="3.4.4"; BVER="2.16.1";
GUSE="-fortran -gtk -gcj -objc";;
@@ -98,15 +105,15 @@ parse_target() {
ee*) TARCH=${HARCH}; CPOST="";
KPKG="[none]"
GVER="3.2.2"; BVER="2.14";
- STAGE="1";
+ STAGE=${STAGE_C_ONLY};
GUSE="-fortran -gtk -gcj -objc";;
iop*) TARCH=${HARCH}; CPOST="";
GVER="3.2.2"; BVER="2.14";
- STAGE="1";
+ STAGE=${STAGE_C_ONLY};
GUSE="-fortran -gtk -gcj -objc";;
dvp*) TARCH=${HARCH}; CPOST="";
GVER="3.2.2"; BVER="2.14";
- STAGE="0";;
+ STAGE=${STAGE_BINUTILS};;
#######################
### unknown targets ###
@@ -160,9 +167,18 @@ uninstall() {
exit 0
}
-is_s1() { [[ ${STAGE} -gt 0 ]] ; }
-is_s2() { [[ ${STAGE} -gt 1 ]] ; }
-is_s3() { [[ ${STAGE} -gt 2 ]] ; }
+
+is_stage() { [[ ${STAGE} -ge $1 ]] ; }
+is_s0() { is_stage 0 ; }
+is_s1() { is_stage 1 ; }
+is_s2() { is_stage 2 ; }
+is_s3() { is_stage 3 ; }
+is_s4() { is_stage 4 ; }
+is_s5() { is_stage 5 ; }
+
+ex_fast() { [[ ${EX_FAST} == "yes" ]] ; }
+ex_gcc() { [[ ${EX_GCC} == "yes" ]] ; }
+ex_gdb() { [[ ${EX_GDB} == "yes" ]] ; }
hr() {
local c=${COLUMNS:-0}
@@ -187,12 +203,14 @@ UOPTS=
TARCH=
HARCH=$(env -uARCH portageq envvar ARCH)
CTARGET=
-STAGE=4
-STAGE_DISP=( "binutils" "C compiler only" "C compiler & libc" "C/C++ compiler" )
+STAGE=COW
BCAT="sys-devel" ; BPKG="binutils" ; BVER="[latest]" ; BUSE=""
GCAT="sys-devel" ; GPKG="gcc" ; GVER="[latest]" ; GUSE=""
KCAT="sys-kernel" ; KPKG="linux-headers" ; KVER="[latest]" ; KUSE=""
LCAT="sys-libs" ; LPKG="glibc" ; LVER="[latest]" ; LUSE=""
+EX_FAST="no"
+EX_GCC="no"
+EX_GDB="no"
while [[ $# -gt 0 ]] ; do
case $1 in
@@ -203,7 +221,10 @@ while [[ $# -gt 0 ]] ; do
--k|--kernel) shift; KVER=$1;;
--l|--libc) shift; LVER=$1;;
-C|--clean) shift; parse_target $1; uninstall;;
- -s?|--stage?) [[ ${STAGE} -eq 4 ]] && STAGE=${1:0-1};;
+ -s?|--stage?) [[ ${STAGE} == "COW" ]] && STAGE=${1:0-1};;
+ --ex-only) EX_FAST="yes";;
+ --ex-gcc) EX_GCC="yes";;
+ --ex-gdb) EX_GDB="yes";;
-b|-p|-v) UOPTS="${UOPTS} $1";;
-h|--help) usage;;
*) eerror "UNKNOWN OPTION: '$1'" ; usage 1;;
@@ -212,7 +233,7 @@ while [[ $# -gt 0 ]] ; do
done
[[ -z ${CTARGET} ]] && usage 1
[[ ${CTARGET} == *-uclibc ]] && LPKG="uclibc"
-[[ ${STAGE} -eq 4 ]] && STAGE=3
+[[ ${STAGE} == "COW" ]] && STAGE=${STAGE_C_CPP}
#####################
### sanity checks ###
@@ -246,22 +267,34 @@ einfo "Target Portage ARCH: ${TARCH}"
einfo "Target System: ${CTARGET}"
einfo "Stage: ${STAGE} (${STAGE_DISP[${STAGE}]})"
echo
+ex_fast || {
+is_s0 && {
einfo "binutils: ${BPKG}-${BVER}"
+}
is_s1 && {
einfo "gcc: ${GPKG}-${GVER}"
}
is_s2 && {
[[ ${KPKG} != "[none]" ]] && \
einfo "headers: ${KPKG}-${KVER}"
+}
+is_s3 && {
einfo "libc: ${LPKG}-${LVER}"
}
+}
+ex_gcc && {
+einfo "Extra: gcc pass: DO IT"
+}
+ex_gdb && {
+einfo "Extra: gdb: DO IT"
+}
echo
einfo "PORTDIR_OVERLAY: ${PORTDIR_OVERLAY}"
einfo "PORT_LOGDIR: ${PORT_LOGDIR}"
einfo "PKGDIR: ${PKGDIR}"
einfo "PORTAGE_TMPDIR: ${PORTAGE_TMPDIR}"
hr
-) >& ${PORT_LOGDIR}/cross-${CTARGET}-info.log
+) >& ${PORT_LOGDIR}/cross-${CTARGET}-info.log || exit 1
cat ${PORT_LOGDIR}/cross-${CTARGET}-info.log
emerge info >> ${PORT_LOGDIR}/cross-${CTARGET}-info.log
@@ -272,7 +305,7 @@ set_keywords() {
local pkg=$1 ver=$2
[[ -z ${pkg} ]] && return 0
sed -i -e "/cross-${CTARGET}\/${pkg}/d" package.keywords package.mask
- if [[ ${ver} == "[latest]" ]] ; then
+ if [[ ${ver} == "[latest]" ]] || [[ -z ${ver} ]] ; then
echo "cross-${CTARGET}/${pkg} $TARCH ~$TARCH" >> package.keywords
else
echo ">cross-${CTARGET}/${pkg}-${ver}" >> package.mask
@@ -313,10 +346,11 @@ mkdir -p "${PORTDIR_OVERLAY}"/cross-${CTARGET}
cd /etc/portage
touch package.{keywords,mask,use}
- set_portage ${BCAT} ${BPKG} ${BVER} ${BUSE}
-is_s1 && set_portage ${GCAT} ${GPKG} ${GVER} ${GUSE}
-is_s2 && set_portage ${KCAT} ${KPKG} ${KVER} ${KUSE}
-is_s2 && set_portage ${LCAT} ${LPKG} ${LVER} ${LUSE}
+ set_portage ${BCAT} ${BPKG} ${BVER} ${BUSE}
+is_s1 && set_portage ${GCAT} ${GPKG} ${GVER} ${GUSE}
+is_s2 && set_portage ${KCAT} ${KPKG} ${KVER} ${KUSE}
+is_s2 && set_portage ${LCAT} ${LPKG} ${LVER} ${LUSE}
+ex_gdb && set_portage sys-devel gdb
#################
doemerge() {
@@ -347,16 +381,27 @@ export ABI="this-abi-var-sucks"
# we include the '-u' so that we don't re-emerge packages
EOPTS="${UOPTS} -u --nodeps"
+ex_fast || {
+
doemerge ${BPKG}
is_s1 || exit 0
USE="-boundschecking -fortran -gcj -objc nocxx -static" \
doemerge ${GPKG} ${GPKG}-stage1
is_s2 || exit 0
doemerge ${KPKG}
+is_s3 || exit 0
USE=$TARCH doemerge ${LPKG}
-[[ ${STAGE} -gt 2 ]] || exit 0
+is_s4 || exit 0
if ! type -p ${CTARGET}-g++ > /dev/null ; then
EOPTS="${UOPTS} --nodeps"
fi
-doemerge ${GPKG} ${GPKG}-stage2
+USE="-fortran -gcj -objc" \
+ doemerge ${GPKG} ${GPKG}-stage2
+
+}
+
+ex_gcc && doemerge ${GPKG} ${GPK}-extra
+ex_gdb && doemerge gdb
+
+exit 0
diff --git a/sys-devel/crossdev/files/digest-crossdev-0.9.8 b/sys-devel/crossdev/files/digest-crossdev-0.9.8
new file mode 100644
index 000000000000..e69de29bb2d1
--- /dev/null
+++ b/sys-devel/crossdev/files/digest-crossdev-0.9.8