diff options
Diffstat (limited to 'sys-kernel/grsec-sources/grsec-sources-2.4.26.2.0-r1.ebuild')
-rw-r--r-- | sys-kernel/grsec-sources/grsec-sources-2.4.26.2.0-r1.ebuild | 86 |
1 files changed, 86 insertions, 0 deletions
diff --git a/sys-kernel/grsec-sources/grsec-sources-2.4.26.2.0-r1.ebuild b/sys-kernel/grsec-sources/grsec-sources-2.4.26.2.0-r1.ebuild new file mode 100644 index 000000000000..0fb8010a99be --- /dev/null +++ b/sys-kernel/grsec-sources/grsec-sources-2.4.26.2.0-r1.ebuild @@ -0,0 +1,86 @@ +# Copyright 1999-2004 Gentoo Technologies, Inc. +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/sys-kernel/grsec-sources/grsec-sources-2.4.26.2.0-r1.ebuild,v 1.1 2004/04/19 02:13:08 solar Exp $ + +# We control what versions of what we download based on the KEYWORDS we +# are using for the various arches. Thus if we want grsec1 stable we run +# the with "arch" ACCEPT_KEYWORDS or ~arch and we will get the +# grsec-2.0-preX which has alot more features. + +# the only thing that should ever differ in one of these 1.9.x ebuilds +# and 2.x of the same kernel version is the KEYWORDS and header. +# shame cvs symlinks don't exist + +ETYPE="sources" +IUSE="" + +inherit eutils +inherit kernel + +[ "$OKV" == "" ] && OKV="2.4.26" + +PATCH_BASE="${PV/${OKV}./}" +PATCH_BASE="${PATCH_BASE/_/-}" +EXTRAVERSION="-grsec-${PATCH_BASE}" +KV="${OKV}${EXTRAVERSION}" + +PATCH_SRC_BASE="grsecurity-${PATCH_BASE}-${OKV}.patch.bz2" + +# hppa takes a special patch and usually has play catch up between +# versions of this package we. + +HPPA_SRC_URI="" +if [ "${ARCH}" == "hppa" ]; then + PARISC_KERNEL_VERSION="pa1" + KV="${OKV}-${PARISC_KERNEL_VERSION}${EXTRAVERSION}" + HPPA_PATCH_SRC_BASE="parisc-linux-${OKV}-${PARISC_KERNEL_VERSION}${EXTRAVERSION}.gz" + HPPA_SRC_URI="mirror://gentoo/${HPPA_PATCH_SRC_BASE} http://dev.gentoo.org/~pappy/gentoo-x86/sys-kernel/grsec-sources/${HPPA_PATCH_SRC_BASE}" + PATCH_SRC_BASE="${HPPA_PATCH_SRC_BASE}" +fi + +DESCRIPTION="Vanilla sources of the linux kernel with the grsecurity ${PATCH_BASE} patch" + +#DYSFUNCTIONAL_SRC_URI="hppa? ( $HPPA_SRC_URI ) \ +# !hppa? ( http://grsecurity.net/grsecurity-${PATCH_BASE}-${OKV}.patch \ +# http://grsecurity.net/grsecurity-${PATCH_BASE}-${OKV}.patch.sign ) \ +# http://www.kernel.org/pub/linux/kernel/v2.4/linux-${OKV}.tar.bz2" + +# grr... gotta love it when upstream changes a patch without rolling a revision number. +#SRC_URI="http://grsecurity.net/grsecurity-${PATCH_BASE}-${OKV}.patch \ +# http://grsecurity.net/grsecurity-${PATCH_BASE}-${OKV}.patch.sign \ +# http://www.kernel.org/pub/linux/kernel/v2.4/linux-${OKV}.tar.bz2" + +SRC_URI="mirror://gentoo/grsecurity-${PATCH_BASE}-${OKV}.patch.bz2 \ + http://www.kernel.org/pub/linux/kernel/v2.4/linux-${OKV}.tar.bz2" + +HOMEPAGE="http://www.kernel.org/ http://www.grsecurity.net" + +KEYWORDS="x86 sparc ppc alpha amd64 -hppa" + +SLOT="${KV}" +S="${WORKDIR}/linux-${KV}" + +src_unpack() { + unpack linux-"${OKV}".tar.bz2 || die "unable to unpack the kernel" + mv linux-"${OKV}" linux-"${KV}" || die "unable to move the kernel" + cd linux-"${KV}" || die "unable to cd into the kernel source tree" + + [ -f "${DISTDIR}/${PATCH_SRC_BASE}" ] || die "File does not exist?" + + # users are often confused by what settings should be set. + # so we provide an example of what a P4 desktop would look like. + cp ${FILESDIR}/2.4.24-x86.config gentoo-grsec-custom-example-2.4.24-x86.config + + ebegin "Patching the kernel with ${PATCH_SRC_BASE}" + case "${ARCH}" in + hppa) zcat ${DISTDIR}/${PATCH_SRC_BASE} | patch -g0 -p1 --quiet ;; + *) bzcat ${DISTDIR}/${PATCH_SRC_BASE} | patch -g0 -p1 --quiet ;; + esac + [ $? == 0 ] || die "failed patching with ${PATCH_SRC_BASE}" + eend 0 + + mkdir docs + touch docs/patches.txt + kernel_universal_unpack + +} |