/[gentoo-x86]/eclass/kernel-2.eclass
Gentoo

Diff of /eclass/kernel-2.eclass

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.65 Revision 1.159
1# Copyright 1999-2004 Gentoo Foundation 1# Copyright 1999-2005 Gentoo Foundation
2# Distributed under the terms of the GNU General Public License v2 2# Distributed under the terms of the GNU General Public License v2
3# $Header: /var/cvsroot/gentoo-x86/eclass/kernel-2.eclass,v 1.65 2004/12/28 20:58:35 johnm Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/kernel-2.eclass,v 1.159 2006/02/17 22:18:20 swegener Exp $
4 4
5# Description: kernel.eclass rewrite for a clean base regarding the 2.6 5# Description: kernel.eclass rewrite for a clean base regarding the 2.6
6# series of kernel with back-compatibility for 2.4 6# series of kernel with back-compatibility for 2.4
7# 7#
8# Maintainer: John Mylchreest <johnm@gentoo.org> 8# Maintainer: John Mylchreest <johnm@gentoo.org>
9# Copyright 2004 Gentoo Linux
10# 9#
11# Please direct your bugs to the current eclass maintainer :) 10# Please direct your bugs to the current eclass maintainer :)
12 11
13# added functionality: 12# added functionality:
14# unipatch - a flexible, singular method to extract, add and remove patches. 13# unipatch - a flexible, singular method to extract, add and remove patches.
15 14
16# A Couple of env vars are available to effect usage of this eclass 15# A Couple of env vars are available to effect usage of this eclass
17# These are as follows: 16# These are as follows:
18# 17#
18# K_USEPV - When setting the EXTRAVERSION variable, it should
19# add PV to the end.
20# this is useful for thigns like wolk. IE:
21# EXTRAVERSION would be something like : -wolk-4.19-r1
19# K_NOSETEXTRAVERSION - if this is set then EXTRAVERSION will not be 22# K_NOSETEXTRAVERSION - if this is set then EXTRAVERSION will not be
20# automatically set within the kernel Makefile 23# automatically set within the kernel Makefile
21# K_NOUSENAME - if this is set then EXTRAVERSION will not include the 24# K_NOUSENAME - if this is set then EXTRAVERSION will not include the
22# first part of ${PN} in EXTRAVERSION 25# first part of ${PN} in EXTRAVERSION
23# K_PREPATCHED - if the patchset is prepatched (ie: mm-sources, 26# K_PREPATCHED - if the patchset is prepatched (ie: mm-sources,
24# ck-sources, ac-sources) it will use PR (ie: -r5) as 27# ck-sources, ac-sources) it will use PR (ie: -r5) as
25# the patchset version for 28# the patchset version for
26# - and not use it as a true package revision 29# and not use it as a true package revision
27# K_EXTRAEINFO - this is a new-line seperated list of einfo displays in 30# K_EXTRAEINFO - this is a new-line seperated list of einfo displays in
28# postinst and can be used to carry additional postinst 31# postinst and can be used to carry additional postinst
29# messages 32# messages
30# K_EXTRAEWARN - same as K_EXTRAEINFO except ewarn's instead of einfo's 33# K_EXTRAEWARN - same as K_EXTRAEINFO except ewarn's instead of einfo's
34# K_SYMLINK - if this is set, then forcably create symlink anyway
35#
36# K_DEFCONFIG - Allow specifying a different defconfig target.
37# If length zero, defaults to "defconfig".
38# K_WANT_GENPATCHES - Apply genpatches to kernel source. Provide any
39# combination of "base" and "extras"
40# K_GENPATCHES_VER - The version of the genpatches tarball(s) to apply.
41# A value of "5" would apply genpatches-2.6.12-5 to
42# my-sources-2.6.12.ebuild
31 43
32# H_SUPPORTEDARCH - this should be a space separated list of ARCH's which 44# H_SUPPORTEDARCH - this should be a space separated list of ARCH's which
33# can be supported by the headers ebuild 45# can be supported by the headers ebuild
34 46
35# UNIPATCH_LIST - space delimetered list of patches to be applied to the 47# UNIPATCH_LIST - space delimetered list of patches to be applied to the
41# UNIPATCH_DOCS - space delimemeted list of docs to be installed to 53# UNIPATCH_DOCS - space delimemeted list of docs to be installed to
42# the doc dir 54# the doc dir
43# UNIPATCH_STRICTORDER - if this is set places patches into directories of 55# UNIPATCH_STRICTORDER - if this is set places patches into directories of
44# order, so they are applied in the order passed 56# order, so they are applied in the order passed
45 57
46ECLASS="kernel-2" 58inherit toolchain-funcs versionator multilib
47INHERITED="$INHERITED $ECLASS"
48EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_preinst pkg_postinst 59EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install \
60 pkg_preinst pkg_postinst
49 61
62# Added by Daniel Ostrow <dostrow@gentoo.org>
63# This is an ugly hack to get around an issue with a 32-bit userland on ppc64.
64# I will remove it when I come up with something more reasonable.
65[[ ${PROFILE_ARCH} == 'ppc64' ]] && CHOST='powerpc64-unknown-linux-gnu'
66
50export CTARGET="${CTARGET:-${CHOST}}" 67export CTARGET=${CTARGET:-${CHOST}}
68if [[ ${CTARGET} == ${CHOST} && ${CATEGORY/cross-} != ${CATEGORY} ]]; then
69 export CTARGET=${CATEGORY/cross-}
70fi
51 71
52HOMEPAGE="http://www.kernel.org/ http://www.gentoo.org/" 72HOMEPAGE="http://www.kernel.org/ http://www.gentoo.org/"
53LICENSE="GPL-2" 73LICENSE="GPL-2"
54IUSE="${IUSE} build doc"
55SLOT="${PVR}"
56 74
57# set LINUX_HOSTCFLAGS if not already set 75# set LINUX_HOSTCFLAGS if not already set
76[[ -z ${LINUX_HOSTCFLAGS} ]] && \
58[ -z "$LINUX_HOSTCFLAGS" ] && LINUX_HOSTCFLAGS="-Wall -Wstrict-prototypes -Os -fomit-frame-pointer -I${S}/include" 77 LINUX_HOSTCFLAGS="-Wall -Wstrict-prototypes -Os -fomit-frame-pointer -I${S}/include"
59 78
60#Eclass functions only from here onwards ... 79#Eclass functions only from here onwards ...
61#============================================================== 80#==============================================================
81handle_genpatches() {
82 local tarball
83 [[ -z ${K_WANT_GENPATCHES} || -z ${K_GENPATCHES_VER} ]] && return -1
84
85 for i in ${K_WANT_GENPATCHES} ; do
86 tarball="genpatches-${OKV}-${K_GENPATCHES_VER}.${i}.tar.bz2"
87 GENPATCHES_URI="${GENPATCHES_URI} mirror://gentoo/${tarball}"
88 UNIPATCH_LIST_GENPATCHES="${UNIPATCH_LIST_GENPATCHES} ${DISTDIR}/${tarball}"
89 done
90}
91
92detect_version() {
93 # this function will detect and set
94 # - OKV: Original Kernel Version (2.6.0/2.6.0-test11)
95 # - KV: Kernel Version (2.6.0-gentoo/2.6.0-test11-gentoo-r1)
96 # - EXTRAVERSION: The additional version appended to OKV (-gentoo/-gentoo-r1)
97
98 if [[ -n ${KV_FULL} ]]; then
99 # we will set this for backwards compatibility.
100 KV=${KV_FULL}
101
102 # we know KV_FULL so lets stop here. but not without resetting S
103 S=${WORKDIR}/linux-${KV_FULL}
104 return
105 fi
106
107 # CKV is used as a comparison kernel version, which is used when
108 # PV doesnt reflect the genuine kernel version.
109 # this gets set to the portage style versioning. ie:
110 # CKV=2.6.11_rc4
111 CKV=${CKV:-${PV}}
112 OKV=${OKV:-${CKV}}
113 OKV=${OKV/_beta/-test}
114 OKV=${OKV/_rc/-rc}
115 OKV=${OKV/-r*}
116 OKV=${OKV/_p*}
117
118 KV_MAJOR=$(get_version_component_range 1 ${OKV})
119 KV_MINOR=$(get_version_component_range 2 ${OKV})
120 KV_PATCH=$(get_version_component_range 3 ${OKV})
121
122 if [[ ${KV_MAJOR}${KV_MINOR}${KV_PATCH} -ge 269 ]]; then
123 KV_EXTRA=$(get_version_component_range 4- ${OKV})
124 KV_EXTRA=${KV_EXTRA/[-_]*}
125 else
126 KV_PATCH=$(get_version_component_range 3- ${OKV})
127 fi
128 KV_PATCH=${KV_PATCH/[-_]*}
129
130 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${OKV}.tar.bz2"
131
132 RELEASE=${CKV/${OKV}}
133 RELEASE=${RELEASE/_beta}
134 RELEASE=${RELEASE/_rc/-rc}
135 RELEASE=${RELEASE/_pre/-pre}
136 kernel_is ge 2 6 && RELEASE=${RELEASE/-pre/-git}
137 RELEASETYPE=${RELEASE//[0-9]}
138
139 # Now we know that RELEASE is the -rc/-git
140 # and RELEASETYPE is the same but with its numerics stripped
141 # we can work on better sorting EXTRAVERSION.
142 # first of all, we add the release
143 EXTRAVERSION="${RELEASE}"
144 [[ -n ${KV_EXTRA} ]] && EXTRAVERSION=".${KV_EXTRA}${EXTRAVERSION}"
145
146 if [[ -n ${K_PREPATCHED} ]]; then
147 EXTRAVERSION="${EXTRAVERSION}-${PN/-*}${PR/r}"
148 elif [[ "${ETYPE}" = "sources" ]]; then
149 # For some sources we want to use the PV in the extra version
150 # This is because upstream releases with a completely different
151 # versioning scheme.
152 case ${PN/-*} in
153 wolk) K_USEPV=1;;
154 vserver) K_USEPV=1;;
155 esac
156
157 [[ -z ${K_NOUSENAME} ]] && EXTRAVERSION="${EXTRAVERSION}-${PN/-*}"
158 [[ -n ${K_USEPV} ]] && EXTRAVERSION="${EXTRAVERSION}-${PV//_/-}"
159 [[ -n ${PR//r0} ]] && EXTRAVERSION="${EXTRAVERSION}-${PR}"
160 fi
161
162 # The only messing around which should actually effect this is for KV_EXTRA
163 # since this has to limit OKV to MAJ.MIN.PAT and strip EXTRA off else
164 # KV_FULL evaluates to MAJ.MIN.PAT.EXT.EXT after EXTRAVERSION
165 if [[ -n ${KV_EXTRA} ]]; then
166 OKV="${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}"
167 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/patch-${CKV}.bz2
168 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}.tar.bz2"
169 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${CKV}.bz2"
170 fi
171
172 # We need to set this using OKV, but we need to set it before we do any
173 # messing around with OKV based on RELEASETYPE
174 KV_FULL=${OKV}${EXTRAVERSION}
175
176 # we will set this for backwards compatibility.
177 S=${WORKDIR}/linux-${KV_FULL}
178 KV=${KV_FULL}
179
180 # -rc-git pulls can be achieved by specifying CKV
181 # for example:
182 # CKV="2.6.11_rc3_pre2"
183 # will pull:
184 # linux-2.6.10.tar.bz2 & patch-2.6.11-rc3.bz2 & patch-2.6.11-rc3-git2.bz2
185
186 if [[ ${RELEASETYPE} == -rc ]] || [[ ${RELEASETYPE} == -pre ]]; then
187 OKV="${KV_MAJOR}.${KV_MINOR}.$((${KV_PATCH} - 1))"
188 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/testing/patch-${CKV//_/-}.bz2
189 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${OKV}.tar.bz2"
190 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${CKV//_/-}.bz2"
191 fi
192
193 if [[ ${RELEASETYPE} == -git ]]; then
194 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/snapshots/patch-${OKV}${RELEASE}.bz2
195 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${OKV}.tar.bz2"
196 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${OKV}${RELEASE}.bz2"
197 fi
198
199 if [[ ${RELEASETYPE} == -rc-git ]]; then
200 OKV="${KV_MAJOR}.${KV_MINOR}.$((${KV_PATCH} - 1))"
201 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/snapshots/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE}.bz2
202 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/testing/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE/-git*}.bz2
203 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${OKV}.tar.bz2"
204 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE/-git*}.bz2 ${DISTDIR}/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE}.bz2"
205 fi
206
207 handle_genpatches
208}
209
62kernel_is() { 210kernel_is() {
63 # if we haven't determined the version yet, we need too. 211 [[ -z ${OKV} ]] && detect_version
64 get_version; 212 local operator test value x=0 y=0 z=0
65
66 local RESULT operator value test
67 RESULT=0
68
69 operator="="
70 if [ "${1}" == "lt" ]
71 then
72 operator="-lt"
73 shift
74 elif [ "${1}" == "gt" ]
75 then
76 operator="-gt"
77 shift
78 elif [ "${1}" == "le" ]
79 then
80 operator="-le"
81 shift
82 elif [ "${1}" == "ge" ]
83 then
84 operator="-ge"
85 shift
86 fi
87 213
88 if [ -n "${1}" ] 214 case ${1} in
89 then 215 lt) operator="-lt"; shift;;
90 [ ${KV_MAJOR} ${operator} ${1} ] || RESULT=1 216 gt) operator="-gt"; shift;;
91 fi 217 le) operator="-le"; shift;;
92 if [ -n "${2}" ] 218 ge) operator="-ge"; shift;;
93 then 219 eq) operator="-eq"; shift;;
94 [ ${KV_MINOR} ${operator} ${2} -a ${RESULT} -eq 0 ] || RESULT=1 220 *) operator="-eq";;
95 fi 221 esac
96 if [ -n "${3}" ]
97 then
98 [ ${KV_PATCH} ${operator} ${3} -a ${RESULT} -eq 0 ] || RESULT=1
99 fi
100 return ${RESULT}
101}
102 222
223 for x in ${@}; do
224 for((y=0; y<$((3 - ${#x})); y++)); do value="${value}0"; done
225 value="${value}${x}"
226 z=$((${z} + 1))
227
228 case ${z} in
229 1) for((y=0; y<$((3 - ${#KV_MAJOR})); y++)); do test="${test}0"; done;
230 test="${test}${KV_MAJOR}";;
231 2) for((y=0; y<$((3 - ${#KV_MINOR})); y++)); do test="${test}0"; done;
232 test="${test}${KV_MINOR}";;
233 3) for((y=0; y<$((3 - ${#KV_PATCH})); y++)); do test="${test}0"; done;
234 test="${test}${KV_PATCH}";;
235 *) die "Error in kernel-2_kernel_is(): Too many parameters.";;
236 esac
237 done
238
239 [ ${test} ${operator} ${value} ] && return 0 || return 1
240}
103 241
104kernel_is_2_4() { 242kernel_is_2_4() {
105 kernel_is 2 4 243 kernel_is 2 4
106 return $?
107} 244}
108 245
109kernel_is_2_6() { 246kernel_is_2_6() {
110 [ ${KV_MAJOR} -eq 2 -a ${KV_MINOR} -eq 5 -o ${KV_MINOR} -eq 6 ] && \ 247 kernel_is 2 6 || kernel_is 2 5
111 return 0 || return 1
112} 248}
113 249
250# Capture the sources type and set DEPENDs
251if [[ ${ETYPE} == sources ]]; then
252 DEPEND="!build? ( sys-apps/sed
253 >=sys-devel/binutils-2.11.90.0.31 )
254 doc? ( app-text/docbook-sgml-utils
255 app-text/xmlto )"
256 RDEPEND="!build? ( >=sys-libs/ncurses-5.2
257 sys-devel/make )
258 virtual/dev-manager"
259
260 PROVIDE="virtual/linux-sources"
261 kernel_is gt 2 4 && PROVIDE="${PROVIDE} virtual/alsa"
262
263 SLOT="${PVR}"
264 DESCRIPTION="Sources for the ${KV_MAJOR}.${KV_MINOR} linux kernel"
265 IUSE="symlink build doc"
266elif [[ ${ETYPE} == headers ]]; then
267 DESCRIPTION="Linux system headers"
268 IUSE=""
269
270 if [[ ${CTARGET} = ${CHOST} ]]; then
271 DEPEND="!virtual/os-headers"
272 PROVIDE="virtual/os-headers"
273 SLOT="0"
274 else
275 SLOT="${CTARGET}"
276 fi
277else
278 eerror "Unknown ETYPE=\"${ETYPE}\", must be \"sources\" or \"headers\""
279 die "Unknown ETYPE=\"${ETYPE}\", must be \"sources\" or \"headers\""
280fi
281
282# Cross-compile support functions
283#==============================================================
114kernel_header_destdir() { 284kernel_header_destdir() {
115 [ "${CTARGET}" = "${CHOST}" ] \ 285 [[ ${CTARGET} == ${CHOST} ]] \
116 && echo /usr/include \ 286 && echo /usr/include \
117 || echo /usr/${CTARGET}/include 287 || echo /usr/${CTARGET}/include
118} 288}
119 289
120# Capture the sources type and set DEPENDs 290cross_pre_c_headers() {
121if [ "${ETYPE}" == "sources" ] 291 [[ -z ${_E_CROSS_HEADERS_ONLY} ]] && return 1
122then 292 [[ ${CHOST} == ${CTARGET} ]] && return 1
123 # binutils version needed to avoid Athlon/PIII/SSE assembler bugs. 293 return 0
124 DEPEND="!build? ( sys-apps/sed 294}
125 >=sys-devel/binutils-2.11.90.0.31 )
126 doc? ( !arm? ( !s390? ( app-text/docbook-sgml-utils ) ) )"
127 295
128 RDEPEND="${DEPEND} 296env_setup_xmakeopts() {
129 !build? ( >=sys-libs/ncurses-5.2 297 # Kernel ARCH != portage ARCH
130 dev-lang/perl 298 export KARCH=$(tc-arch-kernel)
131 sys-apps/module-init-tools
132 sys-devel/make )"
133 299
134 [ $(kernel_is_2_4) $? == 0 ] && PROVIDE="virtual/linux-sources" \ 300 # When cross-compiling, we need to set the ARCH/CROSS_COMPILE
135 || PROVIDE="virtual/linux-sources virtual/alsa" 301 # variables properly or bad things happen !
136 302 xmakeopts="ARCH=${KARCH}"
137elif [ "${ETYPE}" == "headers" ] 303 if [[ ${CTARGET} != ${CHOST} ]] && ! cross_pre_c_headers ; then
138then 304 xmakeopts="${xmakeopts} CROSS_COMPILE=${CTARGET}-"
139 PROVIDE="virtual/kernel virtual/os-headers" 305 elif type -p ${CHOST}-ar > /dev/null ; then
140else 306 xmakeopts="${xmakeopts} CROSS_COMPILE=${CHOST}-"
141 eerror "Unknown ETYPE=\"${ETYPE}\", must be \"sources\" or \"headers\""
142 die
143fi 307 fi
308 export xmakeopts
309}
144 310
145# Unpack functions 311# Unpack functions
146#============================================================== 312#==============================================================
147unpack_2_4() { 313unpack_2_4() {
314 env_setup_xmakeopts
315
148 cd ${S} 316 cd "${S}"
149 # this file is required for other things to build properly, 317 # this file is required for other things to build properly,
150 # so we autogenerate it 318 # so we autogenerate it
151 make mrproper || die "make mrproper died" 319 make -s mrproper ${xmakeopts} || die "make mrproper failed"
320 make -s symlinks ${xmakeopts} || die "make symlinks failed"
152 make include/linux/version.h || die "make include/linux/version.h failed" 321 make -s include/linux/version.h ${xmakeopts} || die "make include/linux/version.h failed"
153 echo ">>> version.h compiled successfully." 322 echo ">>> version.h compiled successfully."
154} 323}
155 324
325unpack_2_6() {
326 env_setup_xmakeopts
327
328 cd "${S}"
329 # this file is required for other things to build properly, so we
330 # autogenerate it ... touch .config to keep version.h build from
331 # spitting out an annoying warning
332 make -s mrproper ${xmakeopts} || die "make mrproper failed"
333 touch .config
334 make -s include/linux/version.h ${xmakeopts} || die "make include/linux/version.h failed"
335 rm -f .config
336}
337
156universal_unpack() { 338universal_unpack() {
157 [ -z "${OKV}" ] && OKV="${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}"
158
159 cd ${WORKDIR} 339 cd ${WORKDIR}
160 unpack linux-${OKV}.tar.bz2 340 unpack linux-${OKV}.tar.bz2
161 if [ "${OKV}" != "${KV_FULL}" ] 341 if [[ "${OKV}" != "${KV_FULL}" ]]; then
162 then
163 mv linux-${OKV} linux-${KV_FULL} \ 342 mv linux-${OKV} linux-${KV_FULL} \
164 || die "Unable to move source tree to ${KV_FULL}." 343 || die "Unable to move source tree to ${KV_FULL}."
165 fi 344 fi
166 cd ${S} 345 cd "${S}"
167
168 # change incorrect install path
169 sed -ie 's:#export\tINSTALL_PATH:export\tINSTALL_PATH:' Makefile
170 346
171 # remove all backup files 347 # remove all backup files
172 find . -iname "*~" -exec rm {} \; 2> /dev/null 348 find . -iname "*~" -exec rm {} \; 2> /dev/null
173 349
174 if [ -d "${S}/Documentation/DocBook" ] 350 # fix a problem on ppc where TOUT writes to /usr/src/linux breaking sandbox
175 then
176 cd ${S}/Documentation/DocBook
177 sed -e "s:db2:docbook2:g" Makefile > Makefile.new \
178 && mv Makefile.new Makefile
179 cd ${S}
180 fi
181 # fix a problem on ppc
182 use ppc && \ 351 use ppc && \
183 sed -ie 's|TOUT := .tmp_gas_check|TOUT := $(T).tmp_gas_check|' \ 352 sed -ie 's|TOUT := .tmp_gas_check|TOUT := $(T).tmp_gas_check|' \
184 ${S}/arch/ppc/Makefile 353 "${S}"/arch/ppc/Makefile
185} 354}
186 355
187unpack_set_extraversion() { 356unpack_set_extraversion() {
188 cd ${S} 357 cd "${S}"
189 sed -ie "s:^\(EXTRAVERSION =\).*:\1 ${EXTRAVERSION}:" Makefile 358 sed -i -e "s:^\(EXTRAVERSION =\).*:\1 ${EXTRAVERSION}:" Makefile
359 cd ${OLDPWD}
360}
361
362# Should be done after patches have been applied
363# Otherwise patches that modify the same area of Makefile will fail
364unpack_fix_install_path() {
365 cd "${S}"
366 sed -i -e 's:#export\tINSTALL_PATH:export\tINSTALL_PATH:' Makefile
367}
368
369unpack_fix_docbook() {
370 if [[ -d ${S}/Documentation/DocBook ]]; then
371 cd "${S}"/Documentation/DocBook
372 sed -ie "s:db2:docbook2:g" Makefile
373 cd ${OLDPWD}
374 fi
190} 375}
191 376
192# Compile Functions 377# Compile Functions
193#============================================================== 378#==============================================================
194compile_headers() { 379compile_headers() {
195 local MY_ARCH 380 env_setup_xmakeopts
196 381
197 MY_ARCH=${ARCH} 382 # Since KBUILD_OUTPUT shouldnt be used when compiling headers, lets unset it
198 unset ${ARCH} 383 # if it exists.
384 [[ -n ${KBUILD_OUTPUT} ]] && unset KBUILD_OUTPUT
385
386 # if we couldnt obtain HOSTCFLAGS from the Makefile,
387 # then set it to something sane
388 local HOSTCFLAGS=$(getfilevar HOSTCFLAGS "${S}"/Makefile)
389 HOSTCFLAGS=${HOSTCFLAGS:--Wall -Wstrict-prototypes -O2 -fomit-frame-pointer}
390
391 if kernel_is 2 4; then
199 yes "" | make oldconfig 392 yes "" | make oldconfig ${xmakeopts}
200 echo ">>> make oldconfig complete" 393 echo ">>> make oldconfig complete"
201 ARCH=${MY_ARCH} 394 make dep ${xmakeopts}
395 elif kernel_is 2 6; then
396 # autoconf.h isnt generated unless it already exists. plus, we have
397 # no guarantee that any headers are installed on the system...
398 [[ -f ${ROOT}/usr/include/linux/autoconf.h ]] \
399 || touch include/linux/autoconf.h
400
401 # if K_DEFCONFIG isn't set, force to "defconfig"
402 # needed by mips
403 if [[ -z ${K_DEFCONFIG} ]]; then
404 K_DEFCONFIG="defconfig"
405 fi
406
407 # if there arent any installed headers, then there also isnt an asm
408 # symlink in /usr/include/, and make defconfig will fail, so we have
409 # to force an include path with $S.
410 HOSTCFLAGS="${HOSTCFLAGS} -I${S}/include/"
411 ln -sf asm-${KARCH} "${S}"/include/asm
412 cross_pre_c_headers && return 0
413
414 make ${K_DEFCONFIG} HOSTCFLAGS="${HOSTCFLAGS}" ${xmakeopts} || die "defconfig failed"
415 make prepare HOSTCFLAGS="${HOSTCFLAGS}" ${xmakeopts} || die "prepare failed"
416 make prepare-all HOSTCFLAGS="${HOSTCFLAGS}" ${xmakeopts} || die "prepare failed"
417 fi
202} 418}
203 419
204compile_manpages() { 420compile_manpages() {
205 local MY_ARCH
206
207 einfo "Making manpages ..." 421 einfo "Making manpages ..."
208 MY_ARCH=${ARCH} 422 env -u ARCH make mandocs
209 unset ARCH
210 make mandocs
211 ARCH=${MY_ARCH}
212} 423}
213 424
214# install functions 425# install functions
215#============================================================== 426#==============================================================
216install_universal() { 427install_universal() {
217 #fix silly permissions in tarball 428 #fix silly permissions in tarball
218 cd ${WORKDIR} 429 cd ${WORKDIR}
219 chown -R root:root * 430 chown -R root:root *
220 chmod -R a+r-w+X,u+w * 431 chmod -R a+r-w+X,u+w *
432 cd ${OLDPWD}
221} 433}
222 434
223install_headers() { 435install_headers() {
224 [ $(kernel_is_2_4) $? == 0 ] && unpack_2_4
225
226 local ddir=$(kernel_header_destdir) 436 local ddir=$(kernel_header_destdir)
437
227 cd ${S} 438 cd "${S}"
228 dodir ${ddir}/linux 439 dodir ${ddir}/linux
229 ln -sf ${S}/include/asm-${ARCH} ${S}/include/asm
230 cp -ax ${S}/include/linux/* ${D}/${ddir}/linux 440 cp -ax "${S}"/include/linux/* ${D}/${ddir}/linux
231 rm -rf ${D}/${ddir}/linux/modules 441 rm -rf ${D}/${ddir}/linux/modules
232 442
443 # Handle multilib headers and crap
444 local multi_dirs="" multi_defs=""
445 case $(tc-arch-kernel) in
446 sparc64)
447 multi_dirs="sparc sparc64"
448 multi_defs="!__arch64__ __arch64__"
449 ;;
450 x86_64)
451 multi_dirs="i386 x86_64"
452 multi_defs="__i386__ __x86_64__"
453 ;;
454 ppc64)
455 multi_dirs="ppc ppc64"
456 multi_defs="!__powerpc64__ __powerpc64__"
457 ;;
458 s390x)
459 multi_dirs="s390 s390x"
460 multi_defs="!__s390x__ __s390x__"
461 ;;
462 arm)
233 dodir ${ddir}/asm 463 dodir ${ddir}/asm
464 cp -ax "${S}"/include/asm/* "${D}"/${ddir}/asm
465 [[ ! -e ${D}/${ddir}/asm/arch ]] && ln -sf arch-ebsa285 "${D}"/${ddir}/asm/arch
466 [[ ! -e ${D}/${ddir}/asm/proc ]] && ln -sf proc-armv "${D}"/${ddir}/asm/proc
467 ;;
468 powerpc)
469 dodir ${ddir}/asm
234 cp -ax ${S}/include/asm/* ${D}/${ddir}/asm 470 cp -ax "${S}"/include/asm/* ${D}/${ddir}/asm
471 if [[ -e "${S}"/include/asm-ppc ]] ; then
472 dodir ${ddir}/asm-ppc
473 cp -ax "${S}"/include/asm-ppc/* ${D}/${ddir}/asm-ppc
474 fi
475 ;;
476 *)
477 dodir ${ddir}/asm
478 cp -ax "${S}"/include/asm/* ${D}/${ddir}/asm
479 ;;
480 esac
481 if [[ -n ${multi_dirs} ]] ; then
482 local d ml_inc=""
483 for d in ${multi_dirs} ; do
484 dodir ${ddir}/asm-${d}
485 cp -ax "${S}"/include/asm-${d}/* ${D}/${ddir}/asm-${d}/ || die "cp asm-${d} failed"
235 486
236 if [ $(kernel_is_2_6) $? == 0 ] 487 ml_inc="${ml_inc} ${multi_defs%% *}:${ddir}/asm-${d}"
237 then 488 multi_defs=${multi_defs#* }
489 done
490 create_ml_includes ${ddir}/asm ${ml_inc}
491 fi
492
493 if kernel_is 2 6; then
238 dodir ${ddir}/asm-generic 494 dodir ${ddir}/asm-generic
239 cp -ax ${S}/include/asm-generic/* ${D}/${ddir}/asm-generic 495 cp -ax "${S}"/include/asm-generic/* ${D}/${ddir}/asm-generic
240 fi 496 fi
497
498 # clean up
499 find "${D}" -name '*.orig' -exec rm -f {} \;
500
501 cd ${OLDPWD}
241} 502}
242 503
243install_sources() { 504install_sources() {
244 local doc 505 local doc docs file
245 local docs
246 local file
247 506
248 cd ${S} 507 cd "${S}"
249 dodir /usr/src 508 dodir /usr/src
250 echo ">>> Copying sources ..." 509 echo ">>> Copying sources ..."
510
251 file="$(find ${WORKDIR} -iname "docs" -type d)" 511 file="$(find ${WORKDIR} -iname "docs" -type d)"
252 if [ -n "${file}" ] 512 if [[ -n ${file} ]]; then
253 then
254 for file in $(find ${file} -type f) 513 for file in $(find ${file} -type f); do
255 do
256 echo "${file/*docs\//}" >> ${S}/patches.txt 514 echo "${file//*docs\/}" >> "${S}"/patches.txt
257 echo "===================================================" >> ${S}/patches.txt 515 echo "===================================================" >> "${S}"/patches.txt
258 cat ${file} >> ${S}/patches.txt 516 cat ${file} >> "${S}"/patches.txt
259 echo "===================================================" >> ${S}/patches.txt 517 echo "===================================================" >> "${S}"/patches.txt
260 echo "" >> ${S}/patches.txt 518 echo "" >> "${S}"/patches.txt
261 done 519 done
262 fi 520 fi
263 521
264 if [ ! -f ${S}/patches.txt ] 522 if [[ ! -f ${S}/patches.txt ]]; then
265 then
266 # patches.txt is empty so lets use our ChangeLog 523 # patches.txt is empty so lets use our ChangeLog
267 [ -f ${FILESDIR}/../ChangeLog ] && echo "Please check the ebuild ChangeLog for more details." > ${S}/patches.txt 524 [[ -f ${FILESDIR}/../ChangeLog ]] && \
525 echo "Please check the ebuild ChangeLog for more details." \
526 > "${S}"/patches.txt
268 fi 527 fi
269 528
270 for doc in ${UNIPATCH_DOCS} 529 if use doc ; then
271 do
272 [ -f ${doc} ] && docs="${docs} ${doc}"
273 done
274
275 if [ -f ${S}/patches.txt ]; then
276 docs="${docs} ${S}/patches.txt"
277 fi
278
279 if use doc && ! use arm && ! use s390; then
280 install_manpages 530 install_manpages
531
532 for doc in ${UNIPATCH_DOCS}; do [[ -f ${doc} ]] && docs="${docs} ${doc}"; done
533 if [[ -f ${S}/patches.txt ]]; then docs="${docs} ${S}/patches.txt"; fi
534 [[ -n ${docs} ]] && dodoc ${docs}
281 fi 535 fi
282 536
283 dodoc ${docs}
284 mv ${WORKDIR}/linux* ${D}/usr/src 537 mv ${WORKDIR}/linux* ${D}/usr/src
285} 538}
286 539
287install_manpages() { 540install_manpages() {
288 local MY_ARCH 541 kernel_is lt 2 5 && return
289 542
543 local myfiles="Documentation/DocBook/Makefile"
544 kernel_is lt 2 6 12 && myfiles="scripts/makeman ${myfiles}"
545
546 sed -ie "s#/usr/local/man#${D}/usr/share/man#g" ${myfiles}
290 ebegin "Installing manpages" 547 ebegin "Installing manpages"
291 MY_ARCH=${ARCH}
292 unset ARCH
293 sed -ie "s#/usr/local/man#${D}/usr/man#g" scripts/makeman
294 make installmandocs 548 env -u ARCH make installmandocs
295 eend $? 549 eend $?
296 sed -ie "s#${D}/usr/man#/usr/local/man#g" scripts/makeman 550 sed -ie "s#${D}/usr/share/man#/usr/local/man#g" ${myfiles}
297 ARCH=${MY_ARCH}
298} 551}
299 552
300# pkg_preinst functions 553# pkg_preinst functions
301#============================================================== 554#==============================================================
302preinst_headers() { 555preinst_headers() {
303 local ddir=$(kernel_header_destdir) 556 local ddir=$(kernel_header_destdir)
304 [[ -L ${ROOT}${ddir}/linux ]] && rm "${ROOT}"${ddir}/linux 557 [[ -L ${ddir}/linux ]] && rm ${ddir}/linux
305 [[ -L ${ROOT}${ddir}/asm ]] && rm "${ROOT}"${ddir}/asm 558 [[ -L ${ddir}/asm ]] && rm ${ddir}/asm
306} 559}
307 560
308# pkg_postinst functions 561# pkg_postinst functions
309#============================================================== 562#==============================================================
310postinst_sources() { 563postinst_sources() {
311 if [ ! -h ${ROOT}usr/src/linux ] 564 local MAKELINK=0
312 then 565
566 # if we have USE=symlink, then force K_SYMLINK=1
567 use symlink && K_SYMLINK=1
568
569 # if we are to forcably symlink, delete it if it already exists first.
570 if [[ -n ${K_SYMLINK} ]]; then
313 ln -sf ${ROOT}usr/src/linux-${KV_FULL} ${ROOT}usr/src/linux 571 [[ -h ${ROOT}usr/src/linux ]] && rm ${ROOT}usr/src/linux
572 MAKELINK=1
573 fi
574
575 # if the link doesnt exist, lets create it
576 [[ ! -h ${ROOT}usr/src/linux ]] && MAKELINK=1
577
578 if [[ ${MAKELINK} == 1 ]]; then
579 cd ${ROOT}usr/src
580 ln -sf linux-${KV_FULL} linux
581 cd ${OLDPWD}
314 fi 582 fi
315 583
316 # Don't forget to make directory for sysfs 584 # Don't forget to make directory for sysfs
317 [ ! -d "${ROOT}/sys" -a $(kernel_is_2_6) $? == 0 ] && mkdir /sys 585 [[ ! -d ${ROOT}sys ]] && kernel_is 2 6 && mkdir ${ROOT}sys
318 586
319 echo 587 echo
320 einfo "After installing a new kernel of any version, it is important" 588 einfo "After installing a new kernel of any version, it is important"
321 einfo "that you have the appropriate /etc/modules.autoload.d/kernel-X.Y" 589 einfo "that you have the appropriate /etc/modules.autoload.d/kernel-X.Y"
322 einfo "created (X.Y is the first 2 parts of your new kernel version)" 590 einfo "created (X.Y is the first 2 parts of your new kernel version)"
323 echo 591 echo
324 einfo "For example, this kernel will require:" 592 einfo "For example, this kernel will require:"
325 einfo "/etc/modules.autoload.d/kernel-${KV_MAJOR}.${KV_MINOR}" 593 einfo "/etc/modules.autoload.d/kernel-${KV_MAJOR}.${KV_MINOR}"
326 echo 594 echo
595 einfo "If you are upgrading from a previous kernel, you may be interested"
596 einfo "in the following documents:"
597 einfo " - General upgrade guide: http://www.gentoo.org/doc/en/kernel-upgrade.xml"
598 kernel_is_2_6 && einfo " - 2.4 to 2.6 migration guide: http://www.gentoo.org/doc/en/migration-to-2.6.xml"
599 if kernel_is ge 2 6 13; then
600 ewarn "As of 2.6.13 the support for devfs has been removed."
601 ewarn "You will be required to either manage a static /dev"
602 ewarn "or to ensure that udev is starting on boot."
603 fi
604 echo
327 605
328 # if K_EXTRAEINFO is set then lets display it now 606 # if K_EXTRAEINFO is set then lets display it now
329 if [ -n "${K_EXTRAEINFO}" ] 607 if [[ -n ${K_EXTRAEINFO} ]]; then
330 then
331 echo ${K_EXTRAEINFO} | fmt | 608 echo ${K_EXTRAEINFO} | fmt |
332 while read -s ELINE 609 while read -s ELINE; do einfo "${ELINE}"; done
333 do 610 fi
334 einfo "${ELINE}" 611
612 # if K_EXTRAEWARN is set then lets display it now
613 if [[ -n ${K_EXTRAEWARN} ]]; then
614 echo ${K_EXTRAEWARN} | fmt |
615 while read -s ELINE; do ewarn "${ELINE}"; done
616 fi
617}
618
619postinst_headers() {
620 einfo "Kernel headers are usually only used when recompiling glibc, as such, following the installation"
621 einfo "of newer headers, it is advised that you re-merge glibc as follows:"
622 einfo "emerge glibc"
623 einfo "Failure to do so will cause glibc to not make use of newer features present in the updated kernel"
624 einfo "headers."
625}
626
627# pkg_setup functions
628#==============================================================
629setup_headers() {
630 [[ -z ${H_SUPPORTEDARCH} ]] && H_SUPPORTEDARCH=${PN/-*/}
631 for i in ${H_SUPPORTEDARCH}; do
632 [[ $(tc-arch) == "${i}" ]] && H_ACCEPT_ARCH="yes"
335 done 633 done
336 634
635 if [[ ${H_ACCEPT_ARCH} != "yes" ]]; then
337 echo 636 echo
338 fi
339
340 # Show policy version, if this kernel has SELinux ...
341 local secfile
342 secfile="${ROOT}usr/src/linux-${KV_FULL}/security/selinux/include/security.h"
343 if use selinux && [ -f "$secfile" ]
344 then
345 local polver=$(awk '/POLICYDB_VERSION /{print $3}' $secfile)
346 einfo "The SELinux policy version of this kernel is $polver."
347 echo
348 fi
349
350 # if K_EXTRAEWARN is set then lets display it now
351 if [ -n "${K_EXTRAEWARN}" ]
352 then
353 echo ${K_EXTRAEWARN} | fmt |
354 while read -s ELINE
355 do
356 ewarn "${ELINE}"
357 done
358
359 echo
360 fi
361}
362
363postinst_headers() {
364 echo
365 einfo "Kernel headers are usually only used when recompiling glibc."
366 einfo "Following the installation of newer headers it is advised that"
367 einfo "you re-merge glibc as follows:"
368 einfo "# emerge glibc"
369 einfo "Failure to do so will cause glibc to not make use of newer"
370 einfo "features present in the updated kernelheaders."
371 echo
372}
373
374# pkg_setup functions
375#==============================================================
376setup_headers() {
377 ARCH=$(uname -m | sed -e s/[i].86/i386/ -e s/x86/i386/ -e s/sun4u/sparc64/ \
378 -e s/arm.*/arm/ -e s/sa110/arm/ -e s/amd64/x86_64/)
379 [ "$ARCH" == "sparc" -a "$PROFILE_ARCH" == "sparc64" ] && ARCH="sparc64"
380
381 [ -z "${H_SUPPORTEDARCH}" ] && H_SUPPORTEDARCH="${PN/-*/}"
382 for i in ${H_SUPPORTEDARCH}
383 do
384 [ "${ARCH}" == "${i}" ] && H_ACCEPT_ARCH="yes"
385 done
386
387 if [ "${H_ACCEPT_ARCH}" != "yes" ]
388 then
389 echo
390 eerror "This version of ${PN} does not support ${ARCH}." 637 eerror "This version of ${PN} does not support $(tc-arch)."
391 eerror "Please merge the appropriate sources, in most cases" 638 eerror "Please merge the appropriate sources, in most cases"
392 eerror "this will be ${ARCH}-headers." 639 eerror "(but not all) this will be called $(tc-arch)-headers."
393 die "incorrect headers" 640 die "Package unsupported for $(tc-arch)"
394 fi 641 fi
395} 642}
396 643
397# unipatch 644# unipatch
398#============================================================== 645#==============================================================
399unipatch() { 646unipatch() {
400 local i 647 local i x y z extention PIPE_CMD UNIPATCH_DROP KPATCH_DIR PATCH_DEPTH ELINE
401 local x 648 local STRICT_COUNT PATCH_LEVEL myLC_ALL myLANG
402 local extention 649
403 local PIPE_CMD 650 # set to a standard locale to ensure sorts are ordered properly.
404 local UNIPATCH_DROP 651 myLC_ALL="${LC_ALL}"
405 local KPATCH_DIR 652 myLANG="${LANG}"
406 local PATCH_DEPTH 653 LC_ALL="C"
407 local ELINE 654 LANG=""
408 local STRICT_COUNT
409 local PATCH_LEVEL
410 655
411 [ -z "${KPATCH_DIR}" ] && KPATCH_DIR="${WORKDIR}/patches/" 656 [ -z "${KPATCH_DIR}" ] && KPATCH_DIR="${WORKDIR}/patches/"
412 [ ! -d ${KPATCH_DIR} ] && mkdir -p ${KPATCH_DIR} 657 [ ! -d ${KPATCH_DIR} ] && mkdir -p ${KPATCH_DIR}
413 658
414 # We're gonna need it when doing patches with a predefined patchlevel 659 # We're gonna need it when doing patches with a predefined patchlevel
420 # it shall be by param only. 665 # it shall be by param only.
421 # -z "${UNIPATCH_LIST}" ] && UNIPATCH_LIST="${@}" 666 # -z "${UNIPATCH_LIST}" ] && UNIPATCH_LIST="${@}"
422 UNIPATCH_LIST="${@}" 667 UNIPATCH_LIST="${@}"
423 668
424 #unpack any passed tarballs 669 #unpack any passed tarballs
425 for i in ${UNIPATCH_LIST} 670 for i in ${UNIPATCH_LIST}; do
426 do
427 if [ -n "$(echo ${i} | grep -e "\.tar" -e "\.tbz" -e "\.tgz")" ] 671 if [ -n "$(echo ${i} | grep -e "\.tar" -e "\.tbz" -e "\.tgz")" ]; then
428 then
429 extention=${i/*./} 672 extention=${i/*./}
430 extention=${extention/:*/} 673 extention=${extention/:*/}
431 case ${extention} in 674 case ${extention} in
432 tbz2) PIPE_CMD="tar -xvjf";; 675 tbz2) PIPE_CMD="tar -xvjf";;
433 bz2) PIPE_CMD="tar -xvjf";; 676 bz2) PIPE_CMD="tar -xvjf";;
435 gz) PIPE_CMD="tar -xvzf";; 678 gz) PIPE_CMD="tar -xvzf";;
436 *) eerror "Unrecognized tarball compression" 679 *) eerror "Unrecognized tarball compression"
437 die "Unrecognized tarball compression";; 680 die "Unrecognized tarball compression";;
438 esac 681 esac
439 682
440 if [ -n "${UNIPATCH_STRICTORDER}" ] 683 if [ -n "${UNIPATCH_STRICTORDER}" ]; then
441 then 684 unset z
442 STRICT_COUNT=$((${STRICT_COUNT} + 1)) 685 STRICT_COUNT=$((10#${STRICT_COUNT} + 1))
686 for((y=0; y<$((6 - ${#STRICT_COUNT})); y++));
687 do z="${z}0";
688 done
689 PATCH_ORDER="${z}${STRICT_COUNT}"
690
443 mkdir -p ${KPATCH_DIR}/${STRICT_COUNT}/ 691 mkdir -p ${KPATCH_DIR}/${PATCH_ORDER}/
444 ${PIPE_CMD} ${i/:*/} -C ${KPATCH_DIR}/${STRICT_COUNT}/ 1>/dev/null 692 ${PIPE_CMD} ${i/:*/} -C ${KPATCH_DIR}/${PATCH_ORDER}/ 1>/dev/null
445 else 693 else
446 ${PIPE_CMD} ${i/:*/} -C ${KPATCH_DIR} 1>/dev/null 694 ${PIPE_CMD} ${i/:*/} -C ${KPATCH_DIR} 1>/dev/null
447 fi 695 fi
448 696
449 if [ $? == 0 ] 697 if [ $? == 0 ]; then
450 then
451 einfo "${i/*\//} unpacked" 698 einfo "${i/*\//} unpacked"
452 [ -n "$(echo ${i} | grep ':')" ] && echo ">>> Strict patch levels not currently supported for tarballed patchsets" 699 [ -n "$(echo ${i} | grep ':')" ] && echo ">>> Strict patch levels not currently supported for tarballed patchsets"
453 else 700 else
454 eerror "Failed to unpack ${i/:*/}" 701 eerror "Failed to unpack ${i/:*/}"
455 die "unable to unpack patch tarball" 702 die "unable to unpack patch tarball"
470 PATCH_LEVEL=${i/*([^:])?(:)} 717 PATCH_LEVEL=${i/*([^:])?(:)}
471 i=${i/:*/} 718 i=${i/:*/}
472 x=${i/*\//} 719 x=${i/*\//}
473 x=${x/\.${extention}/} 720 x=${x/\.${extention}/}
474 721
475 if [ -n "${PIPE_CMD}" ] 722 if [ -n "${PIPE_CMD}" ]; then
476 then
477 if [ ! -r "${i}" ] 723 if [ ! -r "${i}" ]; then
478 then
479 echo 724 echo
480 eerror "FATAL: unable to locate:" 725 eerror "FATAL: unable to locate:"
481 eerror "${i}" 726 eerror "${i}"
482 eerror "for read-only. The file either has incorrect permissions" 727 eerror "for read-only. The file either has incorrect permissions"
483 eerror "or does not exist." 728 eerror "or does not exist."
484 die Unable to locate ${i} 729 die Unable to locate ${i}
485 fi 730 fi
486 731
487 if [ -n "${UNIPATCH_STRICTORDER}" ] 732 if [ -n "${UNIPATCH_STRICTORDER}" ]; then
488 then 733 unset z
489 STRICT_COUNT=$((${STRICT_COUNT} + 1)) 734 STRICT_COUNT=$((10#${STRICT_COUNT} + 1))
735 for((y=0; y<$((6 - ${#STRICT_COUNT})); y++));
736 do z="${z}0";
737 done
738 PATCH_ORDER="${z}${STRICT_COUNT}"
739
490 mkdir -p ${KPATCH_DIR}/${STRICT_COUNT}/ 740 mkdir -p ${KPATCH_DIR}/${PATCH_ORDER}/
491 $(${PIPE_CMD} ${i} > ${KPATCH_DIR}/${STRICT_COUNT}/${x}.patch${PATCH_LEVEL}) 741 $(${PIPE_CMD} ${i} > ${KPATCH_DIR}/${PATCH_ORDER}/${x}.patch${PATCH_LEVEL})
492 else 742 else
493 $(${PIPE_CMD} ${i} > ${KPATCH_DIR}/${x}.patch${PATCH_LEVEL}) 743 $(${PIPE_CMD} ${i} > ${KPATCH_DIR}/${x}.patch${PATCH_LEVEL})
494 fi 744 fi
495 fi 745 fi
496 fi 746 fi
497 done 747 done
498 748
499 #populate KPATCH_DIRS so we know where to look to remove the excludes 749 #populate KPATCH_DIRS so we know where to look to remove the excludes
500 x=${KPATCH_DIR} 750 x=${KPATCH_DIR}
501 KPATCH_DIR="" 751 KPATCH_DIR=""
502 LC_ALL="C"
503 for i in $(find ${x} -type d | sort -n) 752 for i in $(find ${x} -type d | sort -n); do
504 do
505 KPATCH_DIR="${KPATCH_DIR} ${i}" 753 KPATCH_DIR="${KPATCH_DIR} ${i}"
506 done 754 done
507 755
508 #so now lets get rid of the patchno's we want to exclude 756 #so now lets get rid of the patchno's we want to exclude
509 UNIPATCH_DROP="${UNIPATCH_EXCLUDE} ${UNIPATCH_DROP}" 757 UNIPATCH_DROP="${UNIPATCH_EXCLUDE} ${UNIPATCH_DROP}"
510 for i in ${UNIPATCH_DROP} 758 for i in ${UNIPATCH_DROP}; do
511 do
512 ebegin "Excluding Patch #${i}" 759 ebegin "Excluding Patch #${i}"
513 for x in ${KPATCH_DIR} 760 for x in ${KPATCH_DIR}; do rm -f ${x}/${i}* 2>/dev/null; done
514 do
515 rm -f ${x}/${i}* 2>/dev/null
516 done
517 eend $? 761 eend $?
518 done 762 done
519 763
520 # and now, finally, we patch it :) 764 # and now, finally, we patch it :)
521 for x in ${KPATCH_DIR} 765 for x in ${KPATCH_DIR}; do
522 do
523 for i in $(find ${x} -maxdepth 1 -iname "*.patch*" -or -iname "*.diff*" | sort -n) 766 for i in $(find ${x} -maxdepth 1 -iname "*.patch*" -or -iname "*.diff*" | sort -n); do
524 do
525 STDERR_T="${T}/${i/*\//}" 767 STDERR_T="${T}/${i/*\//}"
526 STDERR_T="${STDERR_T/.patch*/.err}" 768 STDERR_T="${STDERR_T/.patch*/.err}"
527 769
528 [ -z ${i/*.patch*/} ] && PATCH_DEPTH=${i/*.patch/} 770 [ -z ${i/*.patch*/} ] && PATCH_DEPTH=${i/*.patch/}
529 [ -z ${i/*.diff*/} ] && PATCH_DEPTH=${i/*.diff/} 771 #[ -z ${i/*.diff*/} ] && PATCH_DEPTH=${i/*.diff/}
530 772
531 if [ -z "${PATCH_DEPTH}" ]; then 773 if [ -z "${PATCH_DEPTH}" ]; then PATCH_DEPTH=0; fi
532 PATCH_DEPTH=0
533 fi
534 774
535 ebegin "Applying ${i/*\//} (-p${PATCH_DEPTH}+)" 775 ebegin "Applying ${i/*\//} (-p${PATCH_DEPTH}+)"
536 while [ ${PATCH_DEPTH} -lt 5 ] 776 while [ ${PATCH_DEPTH} -lt 5 ]; do
537 do
538 echo "Attempting Dry-run:" >> ${STDERR_T} 777 echo "Attempting Dry-run:" >> ${STDERR_T}
539 echo "cmd: patch -p${PATCH_DEPTH} --dry-run -f < ${i}" >> ${STDERR_T} 778 echo "cmd: patch -p${PATCH_DEPTH} --dry-run -f < ${i}" >> ${STDERR_T}
540 echo "=======================================================" >> ${STDERR_T} 779 echo "=======================================================" >> ${STDERR_T}
541 if [ $(patch -p${PATCH_DEPTH} --dry-run -f < ${i} >> ${STDERR_T}) $? -eq 0 ] 780 if [ $(patch -p${PATCH_DEPTH} --dry-run -f < ${i} >> ${STDERR_T}) $? -eq 0 ]; then
542 then
543 echo "Attempting patch:" > ${STDERR_T} 781 echo "Attempting patch:" > ${STDERR_T}
544 echo "cmd: patch -p${PATCH_DEPTH} -f < ${i}" >> ${STDERR_T} 782 echo "cmd: patch -p${PATCH_DEPTH} -f < ${i}" >> ${STDERR_T}
545 echo "=======================================================" >> ${STDERR_T} 783 echo "=======================================================" >> ${STDERR_T}
546 if [ $(patch -p${PATCH_DEPTH} -f < ${i} >> ${STDERR_T}) "$?" -eq 0 ] 784 if [ $(patch -p${PATCH_DEPTH} -f < ${i} >> ${STDERR_T}) "$?" -eq 0 ]; then
547 then
548 eend 0 785 eend 0
549 rm ${STDERR_T} 786 rm ${STDERR_T}
550 break 787 break
551 else 788 else
552 eend 1 789 eend 1
556 fi 793 fi
557 else 794 else
558 PATCH_DEPTH=$((${PATCH_DEPTH} + 1)) 795 PATCH_DEPTH=$((${PATCH_DEPTH} + 1))
559 fi 796 fi
560 done 797 done
561 if [ ${PATCH_DEPTH} -eq 5 ] 798 if [ ${PATCH_DEPTH} -eq 5 ]; then
562 then
563 eend 1 799 eend 1
564 eerror "Please attach ${STDERR_T} to any bug you may post." 800 eerror "Please attach ${STDERR_T} to any bug you may post."
565 die "Unable to dry-run patch." 801 die "Unable to dry-run patch."
566 fi 802 fi
567 done 803 done
568 done 804 done
569 805
806 # This is a quick, and kind of nasty hack to deal with UNIPATCH_DOCS which
807 # sit in KPATCH_DIR's. This is handled properly in the unipatch rewrite,
808 # which is why I'm not taking too much time over this.
809 local tmp
810 for i in ${UNIPATCH_DOCS}; do
811 tmp="${tmp} ${i//*\/}"
812 cp -f ${i} ${T}/
813 done
814 UNIPATCH_DOCS="${tmp}"
815
570 # clean up KPATCH_DIR's - fixes bug #53610 816 # clean up KPATCH_DIR's - fixes bug #53610
571 for x in ${KPATCH_DIR} 817 for x in ${KPATCH_DIR}; do rm -Rf ${x}; done
572 do
573 rm -Rf ${x}
574 done
575 unset LC_ALL
576}
577 818
578# custom functions 819 LC_ALL="${myLC_ALL}"
579#============================================================== 820 LANG="${myLANG}"
580detect_version() { 821}
581 # this function will detect and set
582 # - OKV: Original Kernel Version (2.6.0/2.6.0-test11)
583 # - KV: Kernel Version (2.6.0-gentoo/2.6.0-test11-gentoo-r1)
584 # - EXTRAVERSION: The additional version appended to OKV (-gentoo/-gentoo-r1)
585 822
586 if [ -n "${KV_FULL}" ] ; 823# getfilevar accepts 2 vars as follows:
587 then 824# getfilevar <VARIABLE> <CONFIGFILE>
588 # we will set this for backwards compatibility. 825# pulled from linux-info
589 KV=${KV_FULL}
590 826
591 # we know KV_FULL so lets stop here. but not without resetting S 827getfilevar() {
592 S=${WORKDIR}/linux-${KV_FULL} 828 local workingdir basefname basedname xarch=$(tc-arch-kernel)
593 return
594 fi
595 829
596 OKV=${PV/_beta/-test} 830 if [[ -z ${1} ]] && [[ ! -f ${2} ]]; then
597 OKV=${OKV/_rc/-rc} 831 echo -e "\n"
598 OKV=${OKV/_p*/} 832 eerror "getfilevar requires 2 variables, with the second a valid file."
599 OKV=${OKV/-r*/} 833 eerror " getfilevar <VARIABLE> <CONFIGFILE>"
600
601 KV_MAJOR=$(echo ${OKV} | cut -d. -f1)
602 KV_MINOR=$(echo ${OKV} | cut -d. -f2)
603 KV_PATCH=$(echo ${OKV} | cut -d. -f3-)
604 KV_PATCH=${KV_PATCH/[-_]*/}
605
606 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${OKV}.tar.bz2"
607
608 RELEASE=${PV/${OKV}/}
609 RELEASE=${RELEASE/_beta/}
610 RELEASE=${RELEASE/_rc/-rc}
611 if [ $(kernel_is_2_4) $? == 0 ]
612 then
613 RELEASE=${RELEASE/_pre/-pre}
614 else 834 else
615 RELEASE=${RELEASE/_pre/-bk} 835 workingdir=${PWD}
616 fi 836 basefname=$(basename ${2})
617 RELEASETYPE=${RELEASE//[0-9]/} 837 basedname=$(dirname ${2})
618 EXTRAVERSION="${RELEASE}" 838 unset ARCH
619 839
620 if [ -n "${K_PREPATCHED}" ] 840 cd ${basedname}
621 then 841 echo -e "include ${basefname}\ne:\n\t@echo \$(${1})" | \
622 EXTRAVERSION="${EXTRAVERSION}-${PN/-*/}${PR/r/}" 842 make ${BUILD_FIXES} -s -f - e 2>/dev/null
623 else 843 cd ${workingdir}
624 [ -z "${K_NOUSENAME}" ] && EXTRAVERSION="${EXTRAVERSION}-${PN/-*/}"
625 [ "${PR}" != "r0" ] && EXTRAVERSION="${EXTRAVERSION}-${PR}"
626 fi
627 844
628 KV_FULL=${OKV}${EXTRAVERSION} 845 ARCH=${xarch}
629
630 # -rcXX-bkXX pulls are *IMPOSSIBLE* to support within the portage naming convention
631 # these cannot be supported, but the code here can handle it up until this point
632 # and theoretically thereafter.
633
634 if [ "${RELEASETYPE}" == "-rc" -o "${RELEASETYPE}" == "-pre" ]
635 then
636 OKV="${KV_MAJOR}.${KV_MINOR}.$([ $((${KV_PATCH} - 1)) -lt 0 ] && echo ${KV_PATCH} || echo $((${KV_PATCH} - 1)))"
637 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/testing/patch-${PV//_/-}.bz2
638 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${OKV}.tar.bz2"
639 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${PV//_/-}.bz2"
640 KV_FULL=${PV/[-_]*/}${EXTRAVERSION}
641 fi 846 fi
642
643 if [ "${RELEASETYPE}" == "-bk" ]
644 then
645 OKV="${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}"
646 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/snapshots/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE}.bz2
647 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${OKV}.tar.bz2"
648 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE}.bz2"
649 KV_FULL=${PV/[-_]*/}${EXTRAVERSION}
650 fi
651
652 if [ "${RELEASETYPE}" == "-rc-bk" ]
653 then
654 OKV="${KV_MAJOR}.${KV_MINOR}.$((${KV_PATCH} - 1))-${RELEASE/-bk*}"
655 EXTRAVERSION="$([ -n "${RELEASE}" ] && echo ${RELEASE/*-bk/-bk})$([ -n "${K_USENAME}" ] && echo -${PN/-*/})$([ ! "${PR}" == "r0" ] && echo -${PR})"
656
657 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/snapshots/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE}.bz2
658 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${OKV}.tar.bz2"
659 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE}.bz2"
660 KV_FULL=${PV/[-_]*/}${EXTRAVERSION}
661 fi
662
663 S=${WORKDIR}/linux-${KV_FULL}
664 # we will set this for backwards compatibility.
665 KV=${KV_FULL}
666} 847}
667 848
668detect_arch() { 849detect_arch() {
669 # This function sets ARCH_URI and ARCH_PATCH 850 # This function sets ARCH_URI and ARCH_PATCH
670 # with the neccessary info for the arch sepecific compatibility 851 # with the neccessary info for the arch sepecific compatibility
671 # patchsets. 852 # patchsets.
672 853
673 local ALL_ARCH 854 local ALL_ARCH LOOP_ARCH COMPAT_URI i
674 local LOOP_ARCH
675 local COMPAT_URI
676 local i
677 855
678 # COMPAT_URI is the contents of ${ARCH}_URI 856 # COMPAT_URI is the contents of ${ARCH}_URI
679 # ARCH_URI is the URI for all the ${ARCH}_URI patches 857 # ARCH_URI is the URI for all the ${ARCH}_URI patches
680 # ARCH_PATCH is ARCH_URI broken into files for UNIPATCH 858 # ARCH_PATCH is ARCH_URI broken into files for UNIPATCH
681 859
682 ARCH_URI="" 860 ARCH_URI=""
683 ARCH_PATCH="" 861 ARCH_PATCH=""
684 ALL_ARCH="X86 PPC PPC64 SPARC MIPS ALPHA ARM HPPA AMD64 IA64 X86OBSD S390" 862 ALL_ARCH="ALPHA AMD64 ARM HPPA IA64 M68K MIPS PPC PPC64 S390 SH SPARC X86"
685 863
686 for LOOP_ARCH in ${ALL_ARCH} 864 for LOOP_ARCH in ${ALL_ARCH}; do
687 do
688 COMPAT_URI="${LOOP_ARCH}_URI" 865 COMPAT_URI="${LOOP_ARCH}_URI"
689 COMPAT_URI="${!COMPAT_URI}" 866 COMPAT_URI="${!COMPAT_URI}"
690 867
691 [ -n "${COMPAT_URI}" ] && \ 868 [[ -n ${COMPAT_URI} ]] && \
692 ARCH_URI="${ARCH_URI} $(echo ${LOOP_ARCH} | tr '[:upper:]' '[:lower:]')? ( ${COMPAT_URI} )" 869 ARCH_URI="${ARCH_URI} $(echo ${LOOP_ARCH} | tr '[:upper:]' '[:lower:]')? ( ${COMPAT_URI} )"
693 870
694 if [ "${LOOP_ARCH}" == "$(echo ${ARCH} | tr '[:lower:]' '[:upper:]')" ] 871 if [[ ${LOOP_ARCH} == "$(echo $(tc-arch-kernel) | tr '[:lower:]' '[:upper:]')" ]]; then
695 then
696 for i in ${COMPAT_URI} 872 for i in ${COMPAT_URI}; do
697 do
698 ARCH_PATCH="${ARCH_PATCH} ${DISTDIR}/${i/*\//}" 873 ARCH_PATCH="${ARCH_PATCH} ${DISTDIR}/${i/*\//}"
699 done 874 done
700 fi 875 fi
701 done 876 done
702} 877}
703 878
879# sparc nastiness
880#==============================================================
881# This script generates the files in /usr/include/asm for sparc systems
882# during installation of sys-kernel/linux-headers.
883# Will no longer be needed when full 64 bit support is used on sparc64
884# systems.
885#
886# Shamefully ripped from Debian
887# ----------------------------------------------------------------------
888
889# Idea borrowed from RedHat's kernel package
890
891# This is gonna get replaced by something in multilib.eclass soon...
892# --eradicator
893generate_sparc_asm() {
894 local name
895
896 cd $1 || die
897 mkdir asm
898
899 for h in `( ls asm-sparc; ls asm-sparc64 ) | grep '\.h$' | sort -u`; do
900 name="$(echo $h | tr a-z. A-Z_)"
901 # common header
902 echo "/* All asm/ files are generated and point to the corresponding
903 * file in asm-sparc or asm-sparc64.
904 */
905
906#ifndef __SPARCSTUB__${name}__
907#define __SPARCSTUB__${name}__
908" > asm/${h}
909
910 # common for sparc and sparc64
911 if [ -f asm-sparc/$h -a -f asm-sparc64/$h ]; then
912 echo "#ifdef __arch64__
913#include <asm-sparc64/$h>
914#else
915#include <asm-sparc/$h>
916#endif
917" >> asm/${h}
918
919 # sparc only
920 elif [ -f asm-sparc/$h ]; then
921echo "#ifndef __arch64__
922#include <asm-sparc/$h>
923#endif
924" >> asm/${h}
925
926 # sparc64 only
927 else
928echo "#ifdef __arch64__
929#include <asm-sparc64/$h>
930#endif
931" >> asm/${h}
932 fi
933
934 # common footer
935 echo "#endif /* !__SPARCSTUB__${name}__ */" >> asm/${h}
936 done
937 return 0
938}
939
940headers___fix() {
941 # Voodoo to partially fix broken upstream headers.
942 # Issues with this function should go to plasmaroo.
943 sed -i \
944 -e "s/\([ "$'\t'"]\)\(u\|s\)\(8\|16\|32\|64\)\([ "$'\t'"]\)/\1__\2\3\4/g;" \
945 -e 's/ \(u\|s\)\(8\|16\|32\|64\)$/ __\1\2/g' \
946 -e 's/\([(, ]\)\(u\|s\)64\([, )]\)/\1__\264\3/g' \
947 -e "s/^\(u\|s\)\(8\|16\|32\|64\)\([ "$'\t'"]\)/__\1\2\3/g;" \
948 -e "s/ inline / __inline__ /g" \
949 "$@"
950}
704 951
705# common functions 952# common functions
706#============================================================== 953#==============================================================
707kernel-2_src_unpack() { 954kernel-2_src_unpack() {
708 detect_version
709 universal_unpack 955 universal_unpack
710 956
711 [ -n "${UNIPATCH_LIST}" -o -n "${UNIPATCH_LIST_DEFAULT}" ] && \ 957 [[ -n ${UNIPATCH_LIST} || -n ${UNIPATCH_LIST_DEFAULT} || -n ${UNIPATCH_LIST_GENPATCHES} ]] && \
712 unipatch "${UNIPATCH_LIST_DEFAULT} ${UNIPATCH_LIST}" 958 unipatch "${UNIPATCH_LIST_DEFAULT} ${UNIPATCH_LIST_GENPATCHES} ${UNIPATCH_LIST}"
713 959
714 [ -z "${K_NOSETEXTRAVERSION}" ] && \ 960 # allow ebuilds to massage the source tree after patching but before
715 unpack_set_extraversion 961 # we run misc `make` functions below
962 [[ $(type -t kernel-2_hook_premake) == "function" ]] && kernel-2_hook_premake
963
964 [[ -z ${K_NOSETEXTRAVERSION} ]] && unpack_set_extraversion
965 unpack_fix_docbook
966 unpack_fix_install_path
716 967
717 kernel_is 2 4 && unpack_2_4 968 kernel_is 2 4 && unpack_2_4
969 kernel_is 2 6 && unpack_2_6
718} 970}
719 971
720kernel-2_src_compile() { 972kernel-2_src_compile() {
973 cd "${S}"
721 [ "${ETYPE}" == "headers" ] && compile_headers 974 [[ ${ETYPE} == headers ]] && compile_headers
722 [ "${ETYPE}" == "sources" ] && \ 975 [[ ${ETYPE} == sources ]] && \
723 use doc && ! use arm && ! use s390 && compile_manpages 976 use doc && compile_manpages
724} 977}
725 978
726kernel-2_pkg_preinst() { 979kernel-2_pkg_preinst() {
727 [ "${ETYPE}" == "headers" ] && preinst_headers 980 [[ ${ETYPE} == headers ]] && preinst_headers
728} 981}
729 982
730kernel-2_src_install() { 983kernel-2_src_install() {
731 install_universal 984 install_universal
732 [ "${ETYPE}" == "headers" ] && install_headers 985 [[ ${ETYPE} == headers ]] && install_headers
733 [ "${ETYPE}" == "sources" ] && install_sources 986 [[ ${ETYPE} == sources ]] && install_sources
734} 987}
735 988
736kernel-2_pkg_postinst() { 989kernel-2_pkg_postinst() {
737 [ "${ETYPE}" == "headers" ] && postinst_headers 990 [[ ${ETYPE} == headers ]] && postinst_headers
738 [ "${ETYPE}" == "sources" ] && postinst_sources 991 [[ ${ETYPE} == sources ]] && postinst_sources
739} 992}
740 993
741kernel-2_pkg_setup() { 994kernel-2_pkg_setup() {
742 [ "${ETYPE}" == "headers" ] && setup_headers 995 [[ ${ETYPE} == headers ]] && setup_headers
743
744 # This is to fix some weird portage bug? in stable versions of portage.
745 [ "${ETYPE}" == "sources" ] && echo ">>> Preparing to unpack ..." 996 [[ ${ETYPE} == sources ]] && echo ">>> Preparing to unpack ..."
746} 997}
747
748

Legend:
Removed from v.1.65  
changed lines
  Added in v.1.159

  ViewVC Help
Powered by ViewVC 1.1.20