diff options
author | Tim Yamin <plasmaroo@gentoo.org> | 2004-04-16 18:14:00 +0000 |
---|---|---|
committer | Tim Yamin <plasmaroo@gentoo.org> | 2004-04-16 18:14:00 +0000 |
commit | 29e5db4b45d7b0deaa2bc2b552f048b0427b81d0 (patch) | |
tree | 760a50b0251d4d34d0f45b73fc364642f29ac98f /eclass/kernel-2.eclass | |
parent | ver bump #46535 (diff) | |
download | historical-29e5db4b45d7b0deaa2bc2b552f048b0427b81d0.tar.gz historical-29e5db4b45d7b0deaa2bc2b552f048b0427b81d0.tar.bz2 historical-29e5db4b45d7b0deaa2bc2b552f048b0427b81d0.zip |
Added in johnm's changes to fix issues with development Portage versions.
Diffstat (limited to 'eclass/kernel-2.eclass')
-rw-r--r-- | eclass/kernel-2.eclass | 115 |
1 files changed, 85 insertions, 30 deletions
diff --git a/eclass/kernel-2.eclass b/eclass/kernel-2.eclass index 03421e20bddf..126d21537644 100644 --- a/eclass/kernel-2.eclass +++ b/eclass/kernel-2.eclass @@ -1,6 +1,6 @@ # Copyright 1999-2004 Gentoo Technologies, Inc. # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/eclass/kernel-2.eclass,v 1.32 2004/03/14 06:43:16 seemant Exp $ +# $Header: /var/cvsroot/gentoo-x86/eclass/kernel-2.eclass,v 1.33 2004/04/16 18:14:00 plasmaroo Exp $ # kernel.eclass rewrite for a clean base regarding the 2.6 series of kernel # with back-compatibility for 2.4 @@ -33,6 +33,7 @@ # UNIPATCH_STRICTORDER - if this is set places patches into directories of order, so they are applied in the order passed ECLASS="kernel-2" +INHERITED="$INHERITED $ECLASS" EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_preinst pkg_postinst # to prevent errors if theres no sources in /usr/src @@ -53,9 +54,31 @@ KV_PATCH=${KV_PATCH/[-_]*/} # set LINUX_HOSTCFLAGS if not already set [ -z "$LINUX_HOSTCFLAGS" ] && LINUX_HOSTCFLAGS="-Wall -Wstrict-prototypes -Os -fomit-frame-pointer -I${S}/include" - -#eclass functions only from here onwards. +#Eclass functions only from here onwards... #============================================================== +kernel_is() { + local RESULT + RESULT=1 + + if [ -n "${1}" ] + then + [ "${1}" = "${KV_MAJOR}" ] && RESULT=0 + fi + + if [ -n "${2}" ] + then + RESULT=1 + [ "${2}" = "${KV_MINOR}" ] && RESULT=0 + fi + + if [ -n "${3}" ] + then + RESULT=1 + [ "${3}" = "${KV_PATCH}" ] && RESULT=0 + fi + return ${RESULT} +} + kernel_is_2_4() { [ ${KV_MAJOR} -eq 2 -a ${KV_MINOR} -eq 4 ] && return 0 || return 1 } @@ -64,12 +87,13 @@ kernel_is_2_6() { [ ${KV_MAJOR} -eq 2 -a ${KV_MINOR} -eq 5 -o ${KV_MINOR} -eq 6 ] && return 0 || return 1 } -# capture the sources type and set depends +# Capture the sources type and set DEPENDs if [ "${ETYPE}" == "sources" ] then - #kbd is needed to solve the loadkeys fiasco; binutils version needed to avoid Athlon/PIII/SSE assembler bugs. + #console-tools is needed to solve the loadkeys fiasco; binutils version needed to avoid Athlon/PIII/SSE assembler bugs. DEPEND="!build? ( sys-apps/sed - >=sys-devel/binutils-2.11.90.0.31 )" + >=sys-devel/binutils-2.11.90.0.31 ) + >=sys-kernel/config-kernel-0.3.3" RDEPEND="${DEPEND} !build? ( >=sys-libs/ncurses-5.2 @@ -99,6 +123,16 @@ unpack_2_4() { } universal_unpack() { + [ -z "${OKV}" ] && OKV="${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}" + + cd ${WORKDIR} + unpack linux-${OKV}.tar.bz2 + if [ "${OKV}" != "${KV}" ] + then + mv linux-${OKV} linux-${KV} || die "Unable to move source tree to ${KV}." + fi + cd ${S} + # remove all backup files find . -iname "*~" -exec rm {} \; 2> /dev/null @@ -211,7 +245,10 @@ preinst_headers() { # pkg_postinst functions #============================================================== postinst_sources() { - if [ ! -h ${ROOT}usr/src/linux ] + if [ -x "${ROOT}/usr/bin/config-kernel" ] + then + ${ROOT}/usr/bin/config-kernel --eclass-symlink ${KV} + elif [ ! -h ${ROOT}usr/src/linux ] then ln -sf ${ROOT}usr/src/linux-${KV} ${ROOT}usr/src/linux fi @@ -240,6 +277,15 @@ postinst_sources() { echo fi + # Show policy version, if this kernel has SELinux... + local secfile="${ROOT}usr/src/linux-${KV}/security/selinux/include/security.h" + if [ -n "`use selinux`" -a -f "$secfile" ] + then + local polver=$(awk '/POLICYDB_VERSION /{print $3}' $secfile) + einfo "The SELinux policy version of this kernel is $polver." + echo + fi + # if K_EXTRAEWARN is set then lets display it now if [ -n "${K_EXTRAEWARN}" ] then @@ -413,7 +459,7 @@ unipatch() { ebegin "Applying ${i/*\//}" while [ ${PATCH_DEPTH} -lt 5 ] do - echo "Attempting Dry-run:" > ${STDERR_T} + echo "Attempting Dry-run:" >> ${STDERR_T} echo "cmd: patch -p${PATCH_DEPTH} --dry-run -f < ${i}" >> ${STDERR_T} echo "=======================================================" >> ${STDERR_T} if [ $(patch -p${PATCH_DEPTH} --dry-run -f < ${i} >> ${STDERR_T}) $? -eq 0 ] @@ -469,7 +515,12 @@ detect_version() { RELEASE=${PV/${OKV}/} RELEASE=${RELEASE/_beta/} RELEASE=${RELEASE/_rc/-rc} + if [ $(kernel_is_2_4) $? == 0 ] + then + RELEASE=${RELEASE/_pre/-pre} + else RELEASE=${RELEASE/_pre/-bk} + fi RELEASETYPE=${RELEASE//[0-9]/} EXTRAVERSION="${RELEASE}" @@ -488,7 +539,7 @@ detect_version() { # these cannot be supported, but the code here can handle it up until this point # and theoretically thereafter. - if [ "${RELEASETYPE}" == "-rc" ] + if [ "${RELEASETYPE}" == "-rc" -o "${RELEASETYPE}" == "-pre" ] then OKV="${KV_MAJOR}.${KV_MINOR}.$([ $((${KV_PATCH} - 1)) -lt 0 ] && echo ${KV_PATCH} || echo $((${KV_PATCH} - 1)))" KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/testing/patch-${PV//_/-}.bz2 @@ -520,7 +571,6 @@ detect_version() { S=${WORKDIR}/linux-${KV} } - detect_arch() { # This function sets ARCH_URI and ARCH_PATCH # with the neccessary info for the arch sepecific compatibility @@ -529,60 +579,65 @@ detect_arch() { local ALL_ARCH local LOOP_ARCH local COMPAT_URI + local i + + # COMPAT_URI is the contents of ${ARCH}_URI + # ARCH_URI is the URI for all the ${ARCH}_URI patches + # ARCH_PATCH is ARCH_URI broken into files for UNIPATCH + + ARCH_URI="" + ARCH_PATCH="" + ALL_ARCH="X86 PPC PPC64 SPARC MIPS ALPHA ARM HPPA AMD64 IA64 X86OBSD S390" - ALL_ARCH="X86 PPC PCC64 SPARC MIPS ALPHA ARM HPPA AMD64 IA64 X86OBSD" for LOOP_ARCH in ${ALL_ARCH} do COMPAT_URI="${LOOP_ARCH}_URI" COMPAT_URI="${!COMPAT_URI}" - ARCH_URI="${ARCH_URI} $(echo ${LOOP_ARCH} | tr [A-Z] [a-z])? ( ${COMPAT_URI} )" - [ "${LOOP_ARCH}" == "$(echo ${ARCH} | tr [a-z] [A-Z])" ] && ARCH_PATCH="${DISTDIR}/${COMPAT_URI/*\//}" + [ -n "${COMPAT_URI}" ] && ARCH_URI="${ARCH_URI} $(echo ${LOOP_ARCH} | tr [A-Z] [a-z])? ( ${COMPAT_URI} )" + + if [ "${LOOP_ARCH}" == "$(echo ${ARCH} | tr [a-z] [A-Z])" ] + then + for i in ${COMPAT_URI} + do + ARCH_PATCH="${ARCH_PATCH} ${DISTDIR}/${i/*\//}" + done + fi done } # common functions #============================================================== -src_unpack() { - [ -z "${OKV}" ] && OKV="${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}" - - cd ${WORKDIR} - unpack linux-${OKV}.tar.bz2 - if [ "${OKV}" != "${KV}" ] - then - mv linux-${OKV} linux-${KV} || die "Unable to move source tree to ${KV}." - fi - cd ${S} - +kernel-2_src_unpack() { universal_unpack [ -n "${UNIPATCH_LIST}" -o -n "${UNIPATCH_LIST_DEFAULT}" ] && unipatch "${UNIPATCH_LIST_DEFAULT} ${UNIPATCH_LIST}" [ -z "${K_NOSETEXTRAVERSION}" ] && unpack_set_extraversion [ $(kernel_is_2_4) $? == 0 ] && unpack_2_4 } -src_compile() { +kernel-2_src_compile() { [ "${ETYPE}" == "headers" ] && compile_headers } -pkg_preinst() { +kernel-2_pkg_preinst() { [ "${ETYPE}" == "headers" ] && preinst_headers } -src_install() { +kernel-2_src_install() { install_universal [ "${ETYPE}" == "headers" ] && install_headers [ "${ETYPE}" == "sources" ] && install_sources } -pkg_postinst() { +kernel-2_pkg_postinst() { [ "${ETYPE}" == "headers" ] && postinst_headers [ "${ETYPE}" == "sources" ] && postinst_sources } -pkg_setup() { +kernel-2_pkg_setup() { [ "${ETYPE}" == "headers" ] && setup_headers - # this is to fix some weird portage bug? in stable versions of portage. + # This is to fix some weird portage bug? in stable versions of portage. [ "${ETYPE}" == "sources" ] && echo ">>> Preparing to unpack..." } |