summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGuy Martin <gmsoft@gentoo.org>2003-02-06 16:31:57 +0000
committerGuy Martin <gmsoft@gentoo.org>2003-02-06 16:31:57 +0000
commit39da85ee60333f92ed2d3a032274624ce57b5a9d (patch)
treea3d827e1d28155acb3d22e0957da41fe8bd083fc
parentdep fix (diff)
downloadgentoo-2-39da85ee60333f92ed2d3a032274624ce57b5a9d.tar.gz
gentoo-2-39da85ee60333f92ed2d3a032274624ce57b5a9d.tar.bz2
gentoo-2-39da85ee60333f92ed2d3a032274624ce57b5a9d.zip
Added linux-2.4.20.ebuild needed for hppa
-rw-r--r--sys-kernel/linux-headers/ChangeLog7
-rw-r--r--sys-kernel/linux-headers/files/digest-linux-headers-2.4.202
-rw-r--r--sys-kernel/linux-headers/linux-headers-2.4.20.ebuild164
3 files changed, 172 insertions, 1 deletions
diff --git a/sys-kernel/linux-headers/ChangeLog b/sys-kernel/linux-headers/ChangeLog
index 3bdf8dbd0d9e..c506ce4dc8a2 100644
--- a/sys-kernel/linux-headers/ChangeLog
+++ b/sys-kernel/linux-headers/ChangeLog
@@ -1,6 +1,11 @@
# ChangeLog for sys-kernel/linux-headers
# Copyright 2002 Gentoo Technologies, Inc.; Distributed under the GPL
-# $Header: /var/cvsroot/gentoo-x86/sys-kernel/linux-headers/ChangeLog,v 1.9 2003/01/19 17:05:13 tuxus Exp $
+# $Header: /var/cvsroot/gentoo-x86/sys-kernel/linux-headers/ChangeLog,v 1.10 2003/02/06 16:31:57 gmsoft Exp $
+
+ 06 Feb 2003; Guy Martin <gmsoft@gentoo.org> linux-headers-2.4.20.ebuild :
+ Released 2.4.20 needed for hppa. Others archs are masked.
+
+*linux-headers-2.4.20 (06 Feb 2003)
20 Dec 2002; Dean Bailey <alron@gentoo.org> : added missing sparc64 to ebuild.
diff --git a/sys-kernel/linux-headers/files/digest-linux-headers-2.4.20 b/sys-kernel/linux-headers/files/digest-linux-headers-2.4.20
new file mode 100644
index 000000000000..921e9088b4f1
--- /dev/null
+++ b/sys-kernel/linux-headers/files/digest-linux-headers-2.4.20
@@ -0,0 +1,2 @@
+MD5 c439d5c93d7fc9a1480a90842465bb97 linux-2.4.20.tar.bz2 27421046
+MD5 9f94b177668cee8e09281358bf0db410 patch-2.4.20-pa23.diff.gz 121706
diff --git a/sys-kernel/linux-headers/linux-headers-2.4.20.ebuild b/sys-kernel/linux-headers/linux-headers-2.4.20.ebuild
new file mode 100644
index 000000000000..e41273ceafb0
--- /dev/null
+++ b/sys-kernel/linux-headers/linux-headers-2.4.20.ebuild
@@ -0,0 +1,164 @@
+# Copyright 1999-2002 Gentoo Technologies, Inc.
+# Distributed under the terms of the GNU General Public License v2
+#OKV=original kernel version, KV=patched kernel version. They can be the same.
+
+#we use this next variable to avoid duplicating stuff on cvs
+GFILESDIR=${PORTDIR}/sys-kernel/linux-sources/files
+SPARCFILEDIR=${PORTDIR}/sys-kernel/sparc-sources/files
+OKV=2.4.20
+KV=2.4.20
+S=${WORKDIR}/linux-${KV}
+
+#These are *stock* 2.4.20 headers, for niceness.
+
+DESCRIPTION="Full sources for the Gentoo Linux kernel"
+SRC_URI="http://www.kernel.org/pub/linux/kernel/v2.4/linux-${OKV}.tar.bz2"
+PROVIDE="virtual/kernel"
+HOMEPAGE="http://www.kernel.org/ http://www.gentoo.org/"
+LICENSE="GPL-2"
+SLOT="${KV}"
+KEYWORDS="hppa ~x86 ~ppc ~sparc ~alpha"
+
+KERNEL_ARCH=`echo $ARCH |\
+ sed -e s/[i]*.86/i386/ -e s/sun4u// -e s/arm.*/arm/ -e s/sa110/arm/ -e s/hppa*/parisc/`
+if [ -z "$KERNEL_ARCH" ]
+then
+ KERNEL_ARCH=`uname -m |\
+ sed -e s/[i]*.86/i386/ -e s/sun4u// -e s/arm.*/arm/ -e s/sa110/arm/`
+fi
+
+# Download the latest hppa patch
+HPPA_PATCH_LEVEL="23"
+if [ `use hppa` ]
+then
+ SRC_URI="${SRC_URI} http://ftp.parisc-linux.org/cvs/patch-${OKV}-pa${HPPA_PATCH_LEVEL}.diff.gz"
+ KV="${OKV}-pa${HPPA_PATCH_LEVEL}"
+ S=${WORKDIR}/linux-${KV}
+fi
+
+if [ $PN = "linux-sources" ] && [ -z "`use build`" ]
+then
+ #console-tools is needed to solve the loadkeys fiasco; binutils version needed to avoid Athlon/PIII/SSE assembler bugs.
+ DEPEND=">=sys-devel/binutils-2.11.90.0.31"
+ RDEPEND =">=sys-libs/ncurses-5.2 sys-devel/perl >=sys-apps/modutils-2.4.2 sys-devel/make ? sys-devel/egcs64-sparc"
+fi
+
+[ -z "$LINUX_HOSTCFLAGS" ] && LINUX_HOSTCFLAGS="-Wall -Wstrict-prototypes -O2 -fomit-frame-pointer -I${S}/include"
+
+src_unpack() {
+ cd ${WORKDIR}
+ unpack linux-${OKV}.tar.bz2
+ #the main source dir for linux-2.4.19 (and higher?) has the version attached
+ if [ $OKV != $KV ]; then
+ mv linux-${OKV} linux-${KV} || die "moving kernel"
+ fi
+ cd ${S}
+
+ # glibc need patched headers for hppa
+ if [ ${ARCH} = "hppa" ]
+ then
+ einfo "Applying patches for hppa ..."
+ unpack patch-${OKV}-pa${HPPA_PATCH_LEVEL}.diff.gz
+ patch -p 1 < ${S}/patch-${OKV}-pa${HPPA_PATCH_LEVEL}.diff
+ einfo "... Done"
+ fi
+
+ #sometimes we have icky kernel symbols; this seems to get rid of them
+ make mrproper || die "making proper"
+
+ #this file is required for other things to build properly, so we autogenerate it
+ make include/linux/version.h || die "making headers"
+
+ #fix silly permissions in tarball
+ cd ${WORKDIR}
+ chown -R 0.0 *
+ chmod -R a+r-w+X,u+w *
+
+ # Gentoo Linux uses /boot, so fix 'make install' to work properly
+ cd ${S}
+ mv Makefile Makefile.orig
+ sed -e 's:#export\tINSTALL_PATH:export\tINSTALL_PATH:' \
+ Makefile.orig >Makefile || die "sed makefile" # test, remove me if Makefile ok
+ rm Makefile.orig
+}
+
+src_compile() {
+ if [ "$PN" = "linux-headers" ]
+ then
+ yes "" | make oldconfig
+ echo "Ignore any errors from the yes command above."
+ fi
+}
+
+src_install() {
+ if [ "$PN" = "linux-sources" ]
+ then
+ dodir /usr/src
+ echo ">>> Copying sources..."
+ mv ${WORKDIR}/* ${D}/usr/src
+ else
+ #linux-headers
+ dodir /usr/include/linux
+ cp -ax ${S}/include/linux/* ${D}/usr/include/linux
+ rm -rf ${D}/usr/include/linux/modules
+ dodir /usr/include/asm
+ if [ `expr $KERNEL_ARCH ":" "sparc"` -eq 5 ]
+ then
+ dodir /usr/include/asm-{sparc,sparc64}
+ if [ "$KERNEL_ARCH" = "sparc64" ]
+ then
+ cp -ax ${S}/include/asm-sparc64/* ${D}/usr/include/asm-sparc64
+ if [ ! -r ${D}/usr/include/asm-sparc64/asm_offsets.h ]
+ then
+ cp ${SPARCFILEDIR}/${OKV}/sparc64-asm_offsets.h \
+ ${D}/usr/include/asm-sparc64/asm_offsets.h
+ fi
+ fi
+
+ cp -ax ${S}/include/asm-sparc/* ${D}/usr/include/asm-sparc
+ if [ ! -r ${D}/usr/include/asm-sparc/asm_offsets.h ]
+ then
+ cp ${SPARCFILEDIR}/${OKV}/sparc-asm_offsets.h \
+ ${D}/usr/include/asm-sparc/asm_offsets.h
+ fi
+ ${SPARCFILEDIR}/generate-asm-sparc ${D}/usr/include
+
+ else
+ cp -ax ${S}/include/asm-${KERNEL_ARCH}/* ${D}/usr/include/asm
+ fi
+ fi
+}
+
+pkg_preinst() {
+ if [ "$PN" = "linux-headers" ]
+ then
+ [ -L ${ROOT}usr/include/linux ] && rm ${ROOT}usr/include/linux
+ [ -L ${ROOT}usr/include/asm ] && rm ${ROOT}usr/include/asm
+ [ -L ${ROOT}usr/include/asm-sparc ] && rm ${ROOT}usr/include/asm-sparc
+ [ -L ${ROOT}usr/include/asm- ] && rm ${ROOT}usr/include/asm-
+ [ -L ${ROOT}usr/include/asm-${KERNEL_ARCH} ] && rm ${ROOT}usr/include/asm-${KERNEL_ARCH}
+ true
+ fi
+}
+
+pkg_postinst() {
+ [ "$PN" = "linux-headers" ] && return
+ cd ${ROOT}usr/src/linux-${KV}
+ make mrproper
+ if [ -e "${ROOT}usr/src/linux/.config" ]
+ then
+ cp "${ROOT}usr/src/linux/.config" .config
+ #we only make dep when upgrading to a new kernel (with existing config)
+ #The default setting will be selected.
+ yes "" | make oldconfig
+ echo "Ignore any errors from the yes command above."
+ make dep
+ else
+ cp "${ROOT}usr/src/linux-${KV}/arch/${KERNEL_ARCH}/defconfig" .config \
+ || cp "${ROOT}usr/src/linux-${KV}/arch/i386/defconfig" .config
+ fi
+ #remove /usr/src/linux symlink
+ rm -f ${ROOT}/usr/src/linux
+ #set up a new one
+ ln -sf linux-${KV} ${ROOT}/usr/src/linux
+}