1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
|
# Copyright 1999-2003 Gentoo Technologies, Inc.
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/sys-kernel/gentoo-sources/gentoo-sources-2.4.20-r7.ebuild,v 1.3 2003/09/24 19:31:53 plasmaroo Exp $
IUSE="build crypt evms2 aavm usagi"
# OKV=original kernel version, KV=patched kernel version. They can be the same.
# Kernel ebuilds using the kernel.eclass can remove any patch that you
# do not want to apply by simply setting the KERNEL_EXCLUDE shell
# variable to the string you want to exclude (for instance
# KERNEL_EXCLUDE="evms" would not patch any patches whose names match
# *evms*). Kernels are only tested in the default configuration, but
# this may be useful if you know that a particular patch is causing a
# conflict with a patch you personally want to apply, or some other
# similar situation.
ETYPE="sources"
inherit kernel
OKV="2.4.20"
# Documentation on the patches contained in this kernel will be installed
# to /usr/share/doc/gentoo-sources-${PV}/patches.txt.gz
DESCRIPTION="Full sources for the Gentoo Kernel."
SRC_URI="mirror://kernel/linux/kernel/v2.4/linux-${OKV}.tar.bz2
mirror://gentoo/patches-${KV/7/5}.tar.bz2"
HOMEPAGE="http://www.gentoo.org/ http://www.kernel.org/"
LICENSE="GPL-2"
KEYWORDS="x86 -ppc -sparc -alpha -hppa -mips -arm"
SLOT="${KV}"
src_unpack() {
unpack ${A}
mv linux-${OKV} linux-${KV} || die "Error moving kernel source tree to linux-${KV}"
cd ${WORKDIR}/${KV/7/5}
# This is the *ratified* aavm USE flag, enables aavm support in this kernel
if [ -z "`use aavm`" ]; then
einfo "Setting up kernel for rmap support(default)."
for file in *.aavm ;do
einfo "Dropping ${file}..."
rm -f ${file}
done
else
einfo "Setting up kernel for aavm support."
for file in *.rmap ;do
einfo "Dropping ${file}..."
rm -f ${file}
done
fi
# If the compiler isn't gcc>3.1 drop the gcc>=3.1 patches
if [[ "${COMPILER}" == "gcc3" ]]; then
einfo "Enabling gcc > 3.1 processor optimizations..."
einfo "To use them, choose the processor families labelled with (gcc>31)"
einfo "in \"Processor type and features -> Processor Family\""
else
einfo "Your compiler is not gcc3, dropping patches..."
for file in *gcc3*;do
einfo "Dropping ${file}..."
rm -f ${file}
done
fi
# This is the *ratified* evms2 USE flag, enables evms2 support
if [ -z "`use evms2`" ]; then
einfo "Setting up kernel for EVMS 1.2.1 support (default)..."
for file in 2* ;do
einfo "Dropping ${file}..."
rm -f ${file}
done
else
einfo "Setting up kernel for EVMS 2.0.1 support..."
ewarn "This is very beta. Please read the 'evms2' doc provided with this kernel."
ewarn "It is the install doc from the evms 2.0.1 tarball."
for file in 1* ;do
einfo "Dropping ${file}..."
rm -f ${file}
done
fi
# This is the crypt USE flag, keeps {USAGI/superfreeswan/patch-int/loop-jari}
if [ -z "`use crypt`" ]; then
einfo "No Cryptographic support, dropping patches..."
for file in 6* 8* ;do
einfo "Dropping ${file}..."
rm -f ${file}
done
else
einfo "Cryptographic patches will be applied."
fi
# This is the usagi USE flag, keeps USAGI, drops {superfreeswan/patch-int/loop-jari}
# Using USAGI will also cause you to drop all iptables ipv6 patches
if [ -z "`use usagi`" ]; then
einfo "Keeping {superfreeswan/patch-int/loop-jari} patches, dropping USAGI"
for file in 6* ;do
einfo "Dropping ${file}..."
rm -f ${file}
done
else
einfo "Keeping USAGI patch, dropping {superfreeswan/patch-int/loop-jari}"
for file in *.ipv6 8* ;do
einfo "Dropping ${file}..."
rm -f ${file}
done
fi
kernel_src_unpack
epatch ${FILESDIR}/security.patch1
epatch ${FILESDIR}/security.patch2
epatch ${FILESDIR}/security.patch3
epatch ${FILESDIR}/security.patch4
epatch ${FILESDIR}/gentoo-sources-2.4.20-gcc33.patch
epatch ${FILESDIR}/gentoo-sources-2.4.20-grsec-disabled.patch
epatch ${FILESDIR}/gentoo-sources-2.4.20-sched-interrupt.patch
}
pkg_postinst() {
kernel_pkg_postinst
ewarn "There is no xfs support in this kernel."
ewarn "If you need xfs support, emerge xfs-sources."
echo
ewarn "If iptables/netfilter behaves abnormally, such as 'Invalid Argument',"
ewarn "you will need to re-emerge iptables to restore proper functionality."
echo
einfo "This set contains the ptrace patch as part of grsecurity."
echo
einfo "If there are issues with it, read the docs and associated help provided."
einfo "Next you should check http://forums.gentoo.org/ for assistance."
einfo "Otherwise check http://bugs.gentoo.org/ for an existing bug."
einfo "Only create a new bug if you have not found one that matches your issue."
einfo "It is best to do an advanced search to increase search yield."
einfo "Assign bugs to x86-kernel@gentoo.org"
echo
einfo "Please read the ChangeLog and associated docs for more information."
}
|