summaryrefslogtreecommitdiff
blob: a38ee90e2827455927d07f05a1627bd32777c80b (plain)
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
# Copyright 1999-2003 Gentoo Technologies, Inc.
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/sys-kernel/aa-sources/aa-sources-2.4.22-r1.ebuild,v 1.1 2003/09/02 09:08:55 aliz Exp $

IUSE="build"

# OKV=original kernel version, KV=patched kernel version.  

ETYPE="sources"

inherit kernel

# AAV=andrea arcangeli release version
AAV=aa${PR/r/}
# KV=patched kernel version
KV="${PV/_/-}-${AAV}"
# OKV=original kernel version as provided by ebuild
OKV="`echo ${KV} | cut -d- -f1`"
# OKVLAST=(working) last digit of OKV
OKVLAST="`echo ${OKV} | cut -d. -f3`"
# OKVLASTPR=the previous kernel version (for a marcelo pre/rc release)
OKVLASTPR="`expr ${OKVLAST} - 1`"
# If _ isn't there, then it's a stable+ac, otherwise last-stable+pre/rc+ac
PRERC="`echo ${PV}|grep \_`"

# Other working variables
S=${WORKDIR}/linux-${KV}
EXTRAVERSION="`echo ${KV}|sed -e 's:[^-]*\(-.*$\):\1:'`"
BASE="`echo ${KV}|sed -e s:${EXTRAVERSION}::`"

# If it's a last-stable+pre/rc+aa (marcelo), we need to handle it differently
# ourkernel is the stable kernel we'll be working with (previous or current)
if [ ${PRERC} ]; then
        OURKERNEL="2.4.${OKVLASTPR}"
        SRC_URI="mirror:/kernel/linux/kernel/v2.4/linux-${OURKERNEL}.tar.bz2
                mirror://kernel/linux/kernel/people/andrea/kernels/v2.4/${KV/-}.bz2
                mirror://kernel/linux/kernel/v2.4/testing/patch-${PV/_/-}.bz2"
else
        OURKERNEL="2.4.${OKVLAST}"
        SRC_URI="mirror:/kernel//linux/kernel/v2.4/linux-${OURKERNEL}.tar.bz2
                mirror://kernel/linux/kernel/people/andrea/kernels/v2.4/${KV/-}.bz2"
fi


DESCRIPTION="Full sources for Andrea Arcangeli's Linux kernel"
KEYWORDS="x86"
SLOT="${KV}"

src_unpack() {
        sleep 1
        unpack linux-${OURKERNEL}.tar.bz2
        mv linux-${OURKERNEL} linux-${KV} || die

        cd linux-${KV}

        # if we need a pre/rc patch, then use it
        if [ ${PRERC} ]; then
                bzcat ${DISTDIR}/patch-${PV/_/-}.bz2|patch -p1 || die "-marcelo patch failed"
        fi

        bzcat ${DISTDIR}/${KV/-}.bz2|patch -p1 || die "-aa patch failed"

        kernel_universal_unpack
}