diff options
Diffstat (limited to 'sys-kernel/mips-sources/mips-sources-2.6.12.ebuild')
-rw-r--r-- | sys-kernel/mips-sources/mips-sources-2.6.12.ebuild | 341 |
1 files changed, 341 insertions, 0 deletions
diff --git a/sys-kernel/mips-sources/mips-sources-2.6.12.ebuild b/sys-kernel/mips-sources/mips-sources-2.6.12.ebuild new file mode 100644 index 000000000000..e89644a40ad9 --- /dev/null +++ b/sys-kernel/mips-sources/mips-sources-2.6.12.ebuild @@ -0,0 +1,341 @@ +# Copyright 1999-2005 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/sys-kernel/mips-sources/mips-sources-2.6.12.ebuild,v 1.1 2005/07/06 04:18:45 kumba Exp $ + + +# INCLUDED: +# 1) linux sources from kernel.org +# 2) linux-mips.org CVS snapshot diff from 03 Jul 2005 +# 3) Generic Fixes +# 4) Security fixes +# 5) Patch for IP30 Octane Support (http://helios.et.put.poznan.pl/~sskowron/ip30/) +# 6) Patch for Remaining Cobalt Bits (http://www.colonel-panic.org/cobalt-mips/) +# 7) Experimental patches + + +#//------------------------------------------------------------------------------ + + + +# Version Data +OKV=${PV/_/-} +CVSDATE="20050703" # Date of diff between kernel.org and lmo CVS +SECPATCHVER="1.14" # Tarball version for security patches +GENPATCHVER="1.13" # Tarball version for generic patches +EXTRAVERSION="-mipscvs-${CVSDATE}" +KV="${OKV}${EXTRAVERSION}" +USERC="no" # If set to "yes", then attempt to use an RC kernel + +# Directories +S="${WORKDIR}/linux-${OKV}-${CVSDATE}" +MIPS_PATCHES="${WORKDIR}/mips-patches" +MIPS_SECURITY="${WORKDIR}/security" + +# Inherit Eclasses +ETYPE="sources" +inherit kernel eutils + +# Portage Vars +HOMEPAGE="http://www.linux-mips.org/ http://www.gentoo.org/" +SLOT="${OKV}" +PROVIDE="virtual/linux-sources virtual/alsa" +KEYWORDS="-* ~mips" +IUSE="cobalt ip27 ip28 ip30 livecd" + + +# If USERC == "yes", use a release candidate kernel (2.6.X-rcY) +if [ "${USERC}" = "yes" ]; then + KVMjMn="${OKV%.*}" # Kernel Major/Minor + KVREV="${OKV%%-*}" # Kernel Revision Pt. 1 + KVREV="${KVREV##*.}" # Kernel Revision Pt. 2 + KVRC="${OKV#*-}" # Kernel RC + STABLEVER="${KVMjMn}.$((${KVREV} - 1))" # Last stable Kernel version (Revision - 1) + PATCHVER="mirror://kernel/linux/kernel/v2.6/testing/patch-${OKV}.bz2" + EXTRAVERSION="-${KVRC}-mipscvs-${CVSDATE}" + KV="${OKV}-${EXTRAVERSION}" +else + STABLEVER="${OKV}" + PATCHVER="" +fi + + +DESCRIPTION="Linux-Mips CVS sources for MIPS-based machines, dated ${CVSDATE}" +SRC_URI="mirror://kernel/linux/kernel/v2.6/linux-${STABLEVER}.tar.bz2 + mirror://gentoo/mipscvs-${OKV}-${CVSDATE}.diff.bz2 + mirror://gentoo/${PN}-security_patches-${SECPATCHVER}.tar.bz2 + mirror://gentoo/${PN}-generic_patches-${GENPATCHVER}.tar.bz2 + ${PATCHVER}" + + + +#//------------------------------------------------------------------------------ + + + +# Error message +err_only_one_arch_allowed() { + echo -e "" + eerror "A patchset for a specific machine-type has already been selected." + eerror "No other patches for machines-types are permitted. You will need a" + eerror "separate copy of the kernel sources for each different machine-type" + eerror "you want to build a kernel for." + die "Only one machine-type patchset allowed" +} + + +# Check our USE flags for machine-specific flags and give appropriate warnings. +# Hope the user isn't crazy enough to try using combinations of these flags. +# Only use one machine-specific flag at a time for each type of desired machine-support. +# +# Affected machines: ip27 ip28 ip30 +# Not Affected: cobalt ip22 ip32 +pkg_setup() { + local arch_is_selected="no" + + # See if we're using IP27 (Origin) + if use ip27; then + if [ "${arch_is_selected}" = "no" ]; then + echo -e "" + einfo "IP27 support can be considered a game of Russian Roulette. It'll work" + einfo "great for some but not for others. It also uses some rather horrible" + einfo "hacks to get going -- hopefully these will be repaired in the future." + echo -e "" + ewarn "Please keep all kittens and any other small, cute, and fluffy creatures" + ewarn "away from an IP27 Box running these sources. Failure to do so may cause" + ewarn "the IP27 to consume the hapless creature. Consider this your only" + ewarn "warning regarding the experimental nature of this particular machine." + echo -e "" + arch_is_selected="yes" + else + err_only_one_arch_allowed + fi + fi + + + # See if we're using IP28 (Indigo2 Impact R10000) + if use ip28; then + if [ "${arch_is_selected}" = "no" ]; then + echo -e "" + einfo "Support for the Indigo2 Impact R10000 is probably even more experimental" + einfo "than Octane support. If you seriously do not have a clue in the world about" + einfo "what you are doing, what an IP28 is, what a mips is, or even what gentoo is," + einfo "then stop now, and return to regularly scheduled x86 programming. Consider" + einfo "this the warning that you are about to venture into no-man's land with a" + einfo "machine that is barely supported, likely very unstable, and may very well" + einfo "eat your grandmother's pet cat Fluffy." + echo -e "" + ewarn "That said, support for this system REQUIRES that you use the ip28 cascade" + ewarn "profile (default-linux/mips/mips64/ip28/XXXX.Y), because a very special" + ewarn "patch is used on the system gcc, kernel-gcc (gcc-mips64) and the kernel" + ewarn "itself in order to support this machine. These patches will only be applied" + ewarn "if \"ip28\" is defined in USE, which the profile sets. Other things to keep" + ewarn "in mind are that this system requires a full 64-bit kernel, serial-console" + einfo "only (Impact graphics not supported yet), and _nothing_ is guaranteed to" + einfo "work smoothly." + echo -e "" + arch_is_selected="yes" + else + err_only_one_arch_allowed + fi + fi + + + # See if we're using IP30 (Octane) + if use ip30; then + if [ "${arch_is_selected}" = "no" ]; then + echo -e "" + einfo "With this release, Octane now uses the qla1280 driver. Please refrain" + einfo "from using the old qlogicisp driver. It is marked BROKEN and will be" + einfo "removed from the kernel soon. qla1280 is a much better driver, as you" + einfo "can now use multiple disks with it." + echo -e "" + einfo "This release also has a basic driver for VPro-based systems now. Like" + einfo "MGRAS, it's console-only, no X support yet." + echo -e "" + arch_is_selected="yes" + else + err_only_one_arch_allowed + fi + fi + + + # See if we're on a cobalt system (must use the cobalt-mips profile) + if use cobalt; then + echo -e "" + einfo "Please keep in mind that the 2.6 kernel will NOT boot on Cobalt" + einfo "systems that are still using the old Cobalt bootloader. In" + einfo "order to boot a 2.6 kernel on Cobalt systems, you must be using" + einfo "Peter Horton's new bootloader, which does not have the kernel" + einfo "size limitation that the older bootloader has. If you want" + einfo "to use the newer bootloader, make sure you have sys-boot/colo" + einfo "installed and setup." + echo -e "" + arch_is_selected="yes" + fi +} + + + +#//------------------------------------------------------------------------------ + + + +# Generic Patches - Safe to use globally +do_generic_patches() { + echo -e "" + ebegin ">>> Generic Patches" + # IP22 Patches + epatch ${MIPS_PATCHES}/misc-2.6.11-ip22-chk-consoleout-is-serial.patch + + # IP32 Patches (Safe for non-IP32 use) + epatch ${MIPS_PATCHES}/misc-2.6.12-ip32-onion2-gbefb-fixes.patch + epatch ${MIPS_PATCHES}/misc-2.6.10-ip32-tweak-makefile.patch + epatch ${MIPS_PATCHES}/misc-2.6.11-ip32-mace-is-always-eth0.patch + epatch ${MIPS_PATCHES}/misc-2.6.12-ip32-stupid-gbefb-typo.patch + + # Cobalt Patches (Safe for non-Cobalt use) + epatch ${MIPS_PATCHES}/misc-2.6.12-cobalt-bits.patch + + # Generic + epatch ${MIPS_PATCHES}/misc-2.6.12-ths-mips-tweaks.patch + epatch ${MIPS_PATCHES}/misc-2.6.12-pdh-mips-tweaks.patch + epatch ${MIPS_PATCHES}/misc-2.6.12-add-ramdisk-back.patch + epatch ${MIPS_PATCHES}/misc-2.6.12-mips-iomap-functions.patch + epatch ${MIPS_PATCHES}/misc-2.6.12-seccomp-no-default.patch + epatch ${MIPS_PATCHES}/misc-2.6.12-rem-qlogicisp-scsi_to_pci_dma_dir.patch + epatch ${MIPS_PATCHES}/misc-2.6.11-add-byteorder-to-proc.patch + + # Ugly Hacks (Long Story, ask about it on IRC if you really want to know) + if ! use ip30 && ! use ip28; then + epatch ${MIPS_PATCHES}/misc-2.6.11-ugly-wrong-kphysaddr-hack.patch + fi + eend +} + + +# NOT safe for production systems +# Use at own risk, do _not_ file bugs on effects of these patches +do_sekret_patches() { + # /* EXPERIMENTAL - DO NOT USE IN PRODUCTION KERNELS */ + # Patches used in building LiveCDs + if use livecd; then + epatch ${MIPS_PATCHES}/misc-2.6-livecd-partitioned-cdroms.patch + fi + # /* EXPERIMENTAL - DO NOT USE IN PRODUCTION KERNELS */ +} + + +do_security_patches() { + echo -e "" + ebegin ">>> Applying Security Fixes" + epatch ${MIPS_SECURITY}/security-2.6-nfsacl-remote-nfs.patch + eend +} + + + +#//------------------------------------------------------------------------------ + + + +# These patches are separate from generic patches for a good reason - namely because it is +# possible (but untested) that patches for one machine-type may conflict with patches from +# another machine type and therefore produce unwanted side-effects. We therefore enforce +# this by checking if an arch patch has already been applied, and if so, error out. + +# SGI Origin (IP27) +do_ip27_support() { + echo -e "" + einfo ">>> Patching kernel for SGI Origin (IP27) support ..." + epatch ${MIPS_PATCHES}/misc-2.6.11-ip27-horrible-hacks_may-eat-kittens.patch +# epatch ${MIPS_PATCHES}/misc-2.6.12-ip27-iluxa-fixes.patch +} + +# SGI Indigo2 Impact R10000 (IP28) +do_ip28_support() { + echo -e "" + einfo ">>> Patching kernel for SGI Indigo2 Impact R10000 (IP28) support ..." + epatch ${MIPS_PATCHES}/misc-2.6.12-ip28-i2_impact-support.patch +} + + +# SGI Octane 'Speedracer' (IP30) +do_ip30_support() { + echo -e "" + einfo ">>> Patching kernel for SGI Octane (IP30) support ..." + epatch ${MIPS_PATCHES}/misc-2.6.12-ip30-octane-support.patch + epatch ${MIPS_PATCHES}/misc-2.6.12-ip30-switch-to-plat_setup.patch +} + + + +#//------------------------------------------------------------------------------ + + + +# Renames source trees for the few machines that we have separate patches for +rename_source_tree() { + if [ ! -z "${1}" ]; then + if use ${1}; then + mv ${S} ${S}.${1} + S="${S}.${1}" + fi + fi +} + + + +#//------------------------------------------------------------------------------ + + + +src_unpack() { + unpack ${A} + mv ${WORKDIR}/linux-${STABLEVER} ${WORKDIR}/linux-${OKV}-${CVSDATE} + cd ${S} + + + # If USERC == "yes", use a release candidate kernel (2.6.x-rcy) + if [ "${USERC}" = "yes" ]; then + echo -e "" + einfo ">>> linux-${STABLEVER} --> linux-${OKV} ..." + epatch ${WORKDIR}/patch-${OKV} + fi + + + # Update the vanilla sources with linux-mips CVS changes + echo -e "" + einfo ">>> linux-${OKV} --> linux-${OKV}-${CVSDATE} patch ..." + epatch ${WORKDIR}/mipscvs-${OKV}-${CVSDATE}.diff + + # Generic patches we always include + do_generic_patches + + # Machine-specific patches + use ip27 && do_ip27_support + use ip28 && do_ip28_support + use ip30 && do_ip30_support + + # Patches for experimental use + do_sekret_patches + + # Security Fixes + do_security_patches + + + # All done, resume normal portage work + kernel_universal_unpack +} + + +src_install() { + use ip27 && rename_source_tree ip27 + use ip28 && rename_source_tree ip28 + use ip30 && rename_source_tree ip30 + + kernel_src_install +} + + + +#//------------------------------------------------------------------------------ |