summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Robbins <drobbins@gentoo.org>2002-09-01 21:23:16 +0000
committerDaniel Robbins <drobbins@gentoo.org>2002-09-01 21:23:16 +0000
commitabf30524eef52b5a74dea18799d17de6a41e86d5 (patch)
tree5ab191a9ad0a2a4b0b898773423da19679240f92 /sys-kernel/linux-headers
parentresolved bug 4242 (remove vim as default editor) (diff)
downloadgentoo-2-abf30524eef52b5a74dea18799d17de6a41e86d5.tar.gz
gentoo-2-abf30524eef52b5a74dea18799d17de6a41e86d5.tar.bz2
gentoo-2-abf30524eef52b5a74dea18799d17de6a41e86d5.zip
new linux-headers
Diffstat (limited to 'sys-kernel/linux-headers')
-rw-r--r--sys-kernel/linux-headers/linux-headers-2.4.19.ebuild145
1 files changed, 145 insertions, 0 deletions
diff --git a/sys-kernel/linux-headers/linux-headers-2.4.19.ebuild b/sys-kernel/linux-headers/linux-headers-2.4.19.ebuild
new file mode 100644
index 000000000000..e3c96c702b81
--- /dev/null
+++ b/sys-kernel/linux-headers/linux-headers-2.4.19.ebuild
@@ -0,0 +1,145 @@
+# Copyright 1999-2002 Gentoo Technologies, Inc.
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/sys-kernel/linux-headers/linux-headers-2.4.19.ebuild,v 1.3 2002/09/01 21:23:16 drobbins Exp $
+#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.19
+KV=2.4.19
+S=${WORKDIR}/linux-${KV}
+
+#These are *stock* 2.4.18 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="0"
+KEYWORDS="x86 ppc sparc sparc64"
+
+KERNEL_ARCH=`echo $ARCH |\
+ sed -e s/[i]*.86/i386/ -e s/sun4u/sparc64/ -e s/arm.*/arm/ -e s/sa110/arm/`
+if [ -z "$KERNEL_ARCH" ]
+then
+ KERNEL_ARCH=`uname -m |\
+ sed -e s/[i]*.86/i386/ -e s/sun4u/sparc64/ -e s/arm.*/arm/ -e s/sa110/arm/`
+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 sparc64? 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
+ mv linux-${OKV} linux-${KV} || die
+ cd ${S}
+
+ #sometimes we have icky kernel symbols; this seems to get rid of them
+ make mrproper || die
+
+ #this file is required for other things to build properly, so we autogenerate it
+ make include/linux/version.h || die
+
+ #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 # 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
+ mkdir -p ${D}/usr/include/asm-sparc64 ${D}/usr/include/asm-sparc
+ 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 -ax ${SPARCFILEDIR}/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 -ax ${SPARCFILEDIR}/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-sparc64 ] && rm ${ROOT}usr/include/asm-sparc64
+ [ -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
+}