diff options
author | Tim Yamin <plasmaroo@gentoo.org> | 2004-07-24 20:41:03 +0000 |
---|---|---|
committer | Tim Yamin <plasmaroo@gentoo.org> | 2004-07-24 20:41:03 +0000 |
commit | 2191fc62a5d954c46afd2ab92a4aa4eae71b2bc8 (patch) | |
tree | 4ede00c39e2a0f61dc3f4f0883a59eaaf22b9072 /sys-kernel | |
parent | Some cleanup that remove use of which from ferret <james.noble@worc.ox.ac.uk>, (diff) | |
download | gentoo-2-2191fc62a5d954c46afd2ab92a4aa4eae71b2bc8.tar.gz gentoo-2-2191fc62a5d954c46afd2ab92a4aa4eae71b2bc8.tar.bz2 gentoo-2-2191fc62a5d954c46afd2ab92a4aa4eae71b2bc8.zip |
Added a fix for X.Org on AMD64: bug #58138.
Diffstat (limited to 'sys-kernel')
4 files changed, 148 insertions, 1 deletions
diff --git a/sys-kernel/linux26-headers/ChangeLog b/sys-kernel/linux26-headers/ChangeLog index f5234bc3d082..7b19f008da61 100644 --- a/sys-kernel/linux26-headers/ChangeLog +++ b/sys-kernel/linux26-headers/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for sys-kernel/linux26-headers # Copyright 1999-2004 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/sys-kernel/linux26-headers/ChangeLog,v 1.15 2004/07/23 09:26:28 lv Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-kernel/linux26-headers/ChangeLog,v 1.16 2004/07/24 20:41:03 plasmaroo Exp $ + +*linux26-headers-2.6.7-r4 (24 Jul 2004) + + 24 Jul 2004; <plasmaroo@gentoo.org> +linux26-headers-2.6.7-r4.ebuild, + files/linux26-headers-2.6.7-appCompat.patch: + Added a fix for X.Org on AMD64: bug #58138. 23 Jul 2004; Travis Tilley <lv@gentoo.org> linux26-headers-2.6.7-r3.ebuild: fixed a bug that would prevent merging linux26-headers-2.6.7-r3 when no system diff --git a/sys-kernel/linux26-headers/files/digest-linux26-headers-2.6.7-r4 b/sys-kernel/linux26-headers/files/digest-linux26-headers-2.6.7-r4 new file mode 100644 index 000000000000..fbf6945c9a39 --- /dev/null +++ b/sys-kernel/linux26-headers/files/digest-linux26-headers-2.6.7-r4 @@ -0,0 +1 @@ +MD5 a74671ea68b0e3c609e8785ed8497c14 linux-2.6.7.tar.bz2 35092228 diff --git a/sys-kernel/linux26-headers/files/linux26-headers-2.6.7-appCompat.patch b/sys-kernel/linux26-headers/files/linux26-headers-2.6.7-appCompat.patch index 25f6c9da0d45..0c933be79b37 100644 --- a/sys-kernel/linux26-headers/files/linux26-headers-2.6.7-appCompat.patch +++ b/sys-kernel/linux26-headers/files/linux26-headers-2.6.7-appCompat.patch @@ -1300,3 +1300,15 @@ diff -ur linux-2.6.7/scripts/file2alias.c linux-2.6.7-gentoo/scripts/file2alias. #include "modpost.h" /* We use the ELF typedefs, since we can't rely on stdint.h being present. */ +diff -ur linux-2.6.7/include/asm-x86_64/pda.h linux-2.6.7-gentoo/include/asm-x86_64/pda.h +--- linux-2.6.7/include/asm-x86_64/pda.h 2004-07-24 21:30:43.213205064 +0100 ++++ linux-2.6.7-gentoo/include/asm-x86_64/pda.h 2004-07-24 21:31:24.238968200 +0100 +@@ -36,7 +36,7 @@ + * have to mention %fs/%gs. So it needs to be done this Torvaldian way. + */ + #define sizeof_field(type,field) (sizeof(((type *)0)->field)) +-#define typeof_field(type,field) typeof(((type *)0)->field) ++#define typeof_field(type,field) __typeof__(((type *)0)->field) + + extern void __bad_pda_field(void); + diff --git a/sys-kernel/linux26-headers/linux26-headers-2.6.7-r4.ebuild b/sys-kernel/linux26-headers/linux26-headers-2.6.7-r4.ebuild new file mode 100644 index 000000000000..1609d80a9fc0 --- /dev/null +++ b/sys-kernel/linux26-headers/linux26-headers-2.6.7-r4.ebuild @@ -0,0 +1,128 @@ +# Copyright 1999-2004 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/sys-kernel/linux26-headers/linux26-headers-2.6.7-r4.ebuild,v 1.1 2004/07/24 20:41:03 plasmaroo Exp $ + +ETYPE="headers" +inherit kernel eutils + +OKV="${PV/_/-}" +KV="${OKV}" +S=${WORKDIR}/linux-${OKV} +EXTRAVERSION="" + +# What's in this kernel? + +# INCLUDED: +# 1) linux sources from kernel.org + +DESCRIPTION="Linux ${OKV} headers from kernel.org" +SRC_URI="mirror://kernel/linux/kernel/v2.6/linux-${OKV}.tar.bz2" +HOMEPAGE="http://www.kernel.org/ http://www.gentoo.org/" +LICENSE="GPL-2" +SLOT="0" +PROVIDE="virtual/kernel virtual/os-headers" +KEYWORDS="-* ~amd64" +IUSE="" + +DEPEND="!virtual/os-headers" + +pkg_setup() { + # Archs which have their own separate header packages, add a check here + # and redirect the user to them + case "${ARCH}" in + mips) + eerror "These headers are not appropriate for your architecture." + eerror "Please use sys-kernel/mips-headers instead." + die + ;; + esac +} + +src_unpack() { + + unpack ${A} + cd ${S} + + # Do Stuff + kernel_universal_unpack + + # User-space patches for various things + epatch ${FILESDIR}/${PN}-2.6.3-strict-ansi-fix.patch + epatch ${FILESDIR}/${PN}-2.6.0-sysctl_h-compat.patch + epatch ${FILESDIR}/${PN}-2.6.0-fb.patch + epatch ${FILESDIR}/${PN}-2.6.7-generic-arm-prepare.patch + epatch ${FILESDIR}/${PN}-2.6.7-appCompat.patch +} + +src_compile() { + # autoconf.h isnt generated unless it already exists. plus, we have + # no gurentee that any headers are installed on the system... + [ -f ${ROOT}/usr/include/linux/autoconf.h ] || \ + touch ${S}/include/linux/autoconf.h + # if there arent any installed headers, then there also isnt an asm + # symlink in /usr/include/, and make defconfig will fail. + set_arch_to_kernel + ln -sf ${S}/include/asm-${ARCH} ${S}/include/asm + make defconfig HOSTCFLAGS="-Wall -Wstrict-prototypes -O2 -fomit-frame-pointer -I${S}/include/" || die "defconfig failed" + make prepare HOSTCFLAGS="-Wall -Wstrict-prototypes -O2 -fomit-frame-pointer -I${S}/include/" || die "prepare failed" + set_arch_to_portage +} + +src_install() { + # Do normal src_install stuff + kernel_src_install + + # If this is sparc, then we need to place asm_offsets.h in the proper location(s) + if [ "${PROFILE_ARCH}" = "sparc64" ]; then + + # We don't need /usr/include/asm, generate-asm-sparc will take care of this + rm -Rf ${D}/usr/include/asm + + # We do need empty directories, though... + dodir /usr/include/asm + dodir /usr/include/asm-sparc + dodir /usr/include/asm-sparc64 + + # Copy asm-sparc and asm-sparc64 + cp -ax ${S}/include/asm-sparc/* ${D}/usr/include/asm-sparc + cp -ax ${S}/include/asm-sparc64/* ${D}/usr/include/asm-sparc64 + + # Check if generate-asm-sparc exists + if [ -a "${FILESDIR}/generate-asm-sparc" ]; then + + # Copy generate-asm-sparc into the sandox + cp ${FILESDIR}/generate-asm-sparc ${WORKDIR}/generate-asm-sparc + + # Just in case generate-asm-sparc isn't executable, make it so + if [ ! -x "${WORKDIR}/generate-asm-sparc" ]; then + chmod +x ${WORKDIR}/generate-asm-sparc + fi + + # Generate /usr/include/asm for sparc systems + ${WORKDIR}/generate-asm-sparc ${D}/usr/include + else + eerror "${FILESDIR}/generate-asm-sparc doesn't exist!" + die + fi + fi + + # If this is 2.5 or 2.6 headers, then we need asm-generic too + if [ "`KV_to_int ${OKV}`" -ge "`KV_to_int 2.6.0`" ]; then + dodir /usr/include/asm-generic + cp -ax ${S}/include/asm-generic/* ${D}/usr/include/asm-generic + fi +} + +pkg_preinst() { + kernel_pkg_preinst +} + +pkg_postinst() { + kernel_pkg_postinst + + einfo "Kernel headers are usually only used when recompiling glibc, as such, following the installation" + einfo "of newer headers, it is advised that you re-merge glibc as follows:" + einfo "emerge glibc" + einfo "Failure to do so will cause glibc to not make use of newer features present in the updated kernel" + einfo "headers." +} |