/[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.131 Revision 1.159
1# Copyright 1999-2005 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.131 2005/07/02 04:37:17 dostrow 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 2005 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.
55# the doc dir 54# the doc dir
56# UNIPATCH_STRICTORDER - if this is set places patches into directories of 55# UNIPATCH_STRICTORDER - if this is set places patches into directories of
57# order, so they are applied in the order passed 56# order, so they are applied in the order passed
58 57
59inherit toolchain-funcs versionator multilib 58inherit toolchain-funcs versionator multilib
60ECLASS="kernel-2"
61INHERITED="$INHERITED $ECLASS"
62EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install \ 59EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install \
63 pkg_preinst pkg_postinst pkg_prerm 60 pkg_preinst pkg_postinst
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'
64 66
65export CTARGET=${CTARGET:-${CHOST}} 67export CTARGET=${CTARGET:-${CHOST}}
66if [[ ${CTARGET} == ${CHOST} && ${CATEGORY/cross-} != ${CATEGORY} ]]; then 68if [[ ${CTARGET} == ${CHOST} && ${CATEGORY/cross-} != ${CATEGORY} ]]; then
67 export CTARGET=${CATEGORY/cross-} 69 export CTARGET=${CATEGORY/cross-}
68fi 70fi
69 71
70HOMEPAGE="http://www.kernel.org/ http://www.gentoo.org/" 72HOMEPAGE="http://www.kernel.org/ http://www.gentoo.org/"
71LICENSE="GPL-2" 73LICENSE="GPL-2"
72 74
73# set LINUX_HOSTCFLAGS if not already set 75# set LINUX_HOSTCFLAGS if not already set
74[ -z "$LINUX_HOSTCFLAGS" ] && \ 76[[ -z ${LINUX_HOSTCFLAGS} ]] && \
75 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"
76 78
77#Eclass functions only from here onwards ... 79#Eclass functions only from here onwards ...
78#============================================================== 80#==============================================================
79handle_genpatches() { 81handle_genpatches() {
129 131
130 RELEASE=${CKV/${OKV}} 132 RELEASE=${CKV/${OKV}}
131 RELEASE=${RELEASE/_beta} 133 RELEASE=${RELEASE/_beta}
132 RELEASE=${RELEASE/_rc/-rc} 134 RELEASE=${RELEASE/_rc/-rc}
133 RELEASE=${RELEASE/_pre/-pre} 135 RELEASE=${RELEASE/_pre/-pre}
134 kernel_is ge 2 6 && RELEASE=${RELEASE/-pre/-bk} 136 kernel_is ge 2 6 && RELEASE=${RELEASE/-pre/-git}
135 RELEASETYPE=${RELEASE//[0-9]} 137 RELEASETYPE=${RELEASE//[0-9]}
136 138
137 # Now we know that RELEASE is the -rc/-bk 139 # Now we know that RELEASE is the -rc/-git
138 # and RELEASETYPE is the same but with its numerics stripped 140 # and RELEASETYPE is the same but with its numerics stripped
139 # we can work on better sorting EXTRAVERSION. 141 # we can work on better sorting EXTRAVERSION.
140 # first of all, we add the release 142 # first of all, we add the release
141 EXTRAVERSION="${RELEASE}" 143 EXTRAVERSION="${RELEASE}"
142 [[ -n ${KV_EXTRA} ]] && EXTRAVERSION=".${KV_EXTRA}${EXTRAVERSION}" 144 [[ -n ${KV_EXTRA} ]] && EXTRAVERSION=".${KV_EXTRA}${EXTRAVERSION}"
164 OKV="${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}" 166 OKV="${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}"
165 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/patch-${CKV}.bz2 167 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/patch-${CKV}.bz2
166 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}.tar.bz2" 168 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}.tar.bz2"
167 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${CKV}.bz2" 169 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${CKV}.bz2"
168 fi 170 fi
169 171
170 # We need to set this using OKV, but we need to set it before we do any 172 # We need to set this using OKV, but we need to set it before we do any
171 # messing around with OKV based on RELEASETYPE 173 # messing around with OKV based on RELEASETYPE
172 KV_FULL=${OKV}${EXTRAVERSION} 174 KV_FULL=${OKV}${EXTRAVERSION}
173 175
174 # we will set this for backwards compatibility. 176 # we will set this for backwards compatibility.
175 S=${WORKDIR}/linux-${KV_FULL} 177 S=${WORKDIR}/linux-${KV_FULL}
176 KV=${KV_FULL} 178 KV=${KV_FULL}
177 179
178 # -rc-bk pulls can be achieved by specifying CKV 180 # -rc-git pulls can be achieved by specifying CKV
179 # for example: 181 # for example:
180 # CKV="2.6.11_rc3_pre2" 182 # CKV="2.6.11_rc3_pre2"
181 # will pull: 183 # will pull:
182 # linux-2.6.10.tar.bz2 & patch-2.6.11-rc3.bz2 & patch-2.6.11-rc3-bk2.bz2 184 # linux-2.6.10.tar.bz2 & patch-2.6.11-rc3.bz2 & patch-2.6.11-rc3-git2.bz2
183 185
184 if [[ ${RELEASETYPE} == -rc ]] || [[ ${RELEASETYPE} == -pre ]]; then 186 if [[ ${RELEASETYPE} == -rc ]] || [[ ${RELEASETYPE} == -pre ]]; then
185 OKV="${KV_MAJOR}.${KV_MINOR}.$((${KV_PATCH} - 1))" 187 OKV="${KV_MAJOR}.${KV_MINOR}.$((${KV_PATCH} - 1))"
186 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/testing/patch-${CKV//_/-}.bz2 188 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/testing/patch-${CKV//_/-}.bz2
187 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${OKV}.tar.bz2" 189 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${OKV}.tar.bz2"
188 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${CKV//_/-}.bz2" 190 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${CKV//_/-}.bz2"
189 fi 191 fi
190 192
191 if [[ ${RELEASETYPE} == -bk ]]; then 193 if [[ ${RELEASETYPE} == -git ]]; then
192 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/snapshots/patch-${OKV}${RELEASE}.bz2 194 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/snapshots/patch-${OKV}${RELEASE}.bz2
193 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${OKV}.tar.bz2" 195 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${OKV}.tar.bz2"
194 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${OKV}${RELEASE}.bz2" 196 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${OKV}${RELEASE}.bz2"
195 fi 197 fi
196 198
197 if [[ ${RELEASETYPE} == -rc-bk ]]; then 199 if [[ ${RELEASETYPE} == -rc-git ]]; then
198 OKV="${KV_MAJOR}.${KV_MINOR}.$((${KV_PATCH} - 1))" 200 OKV="${KV_MAJOR}.${KV_MINOR}.$((${KV_PATCH} - 1))"
199 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/snapshots/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE}.bz2 201 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/snapshots/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE}.bz2
200 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/testing/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE/-bk*}.bz2 202 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/testing/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE/-git*}.bz2
201 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${OKV}.tar.bz2" 203 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${OKV}.tar.bz2"
202 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE/-bk*}.bz2 ${DISTDIR}/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE}.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"
203 fi 205 fi
204 206
205 handle_genpatches 207 handle_genpatches
206} 208}
207 209
208kernel_is() { 210kernel_is() {
209 [[ -z ${OKV} ]] && detect_version 211 [[ -z ${OKV} ]] && detect_version
210 local operator test value x=0 y=0 z=0 212 local operator test value x=0 y=0 z=0
211 213
212 case ${1} in 214 case ${1} in
213 lt) operator="-lt"; shift;; 215 lt) operator="-lt"; shift;;
214 gt) operator="-gt"; shift;; 216 gt) operator="-gt"; shift;;
220 222
221 for x in ${@}; do 223 for x in ${@}; do
222 for((y=0; y<$((3 - ${#x})); y++)); do value="${value}0"; done 224 for((y=0; y<$((3 - ${#x})); y++)); do value="${value}0"; done
223 value="${value}${x}" 225 value="${value}${x}"
224 z=$((${z} + 1)) 226 z=$((${z} + 1))
225 227
226 case ${z} in 228 case ${z} in
227 1) for((y=0; y<$((3 - ${#KV_MAJOR})); y++)); do test="${test}0"; done; 229 1) for((y=0; y<$((3 - ${#KV_MAJOR})); y++)); do test="${test}0"; done;
228 test="${test}${KV_MAJOR}";; 230 test="${test}${KV_MAJOR}";;
229 2) for((y=0; y<$((3 - ${#KV_MINOR})); y++)); do test="${test}0"; done; 231 2) for((y=0; y<$((3 - ${#KV_MINOR})); y++)); do test="${test}0"; done;
230 test="${test}${KV_MINOR}";; 232 test="${test}${KV_MINOR}";;
243 245
244kernel_is_2_6() { 246kernel_is_2_6() {
245 kernel_is 2 6 || kernel_is 2 5 247 kernel_is 2 6 || kernel_is 2 5
246} 248}
247 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#==============================================================
248kernel_header_destdir() { 284kernel_header_destdir() {
249 [[ ${CTARGET} == ${CHOST} ]] \ 285 [[ ${CTARGET} == ${CHOST} ]] \
250 && echo /usr/include \ 286 && echo /usr/include \
251 || echo /usr/${CTARGET}/include 287 || echo /usr/${CTARGET}/include
252} 288}
253 289
254# Capture the sources type and set DEPENDs 290cross_pre_c_headers() {
255if [[ ${ETYPE} == sources ]]; then 291 [[ -z ${_E_CROSS_HEADERS_ONLY} ]] && return 1
256 DEPEND="!build? ( sys-apps/sed 292 [[ ${CHOST} == ${CTARGET} ]] && return 1
257 >=sys-devel/binutils-2.11.90.0.31 ) 293 return 0
258 doc? ( app-text/docbook-sgml-utils 294}
259 app-text/xmlto )"
260 RDEPEND="${DEPEND}
261 !build? ( >=sys-libs/ncurses-5.2
262 sys-devel/make )"
263 295
264 PROVIDE="virtual/linux-sources" 296env_setup_xmakeopts() {
265 kernel_is gt 2 4 && PROVIDE="${PROVIDE} virtual/alsa" 297 # Kernel ARCH != portage ARCH
266 SLOT="${PVR}" 298 export KARCH=$(tc-arch-kernel)
267 DESCRIPTION="Sources for the Linux kernel" 299
268 IUSE="${IUSE} symlink build doc" 300 # When cross-compiling, we need to set the ARCH/CROSS_COMPILE
269elif [[ ${ETYPE} == headers ]]; then 301 # variables properly or bad things happen !
270 DESCRIPTION="Linux system headers" 302 xmakeopts="ARCH=${KARCH}"
271 IUSE="${IUSE}" 303 if [[ ${CTARGET} != ${CHOST} ]] && ! cross_pre_c_headers ; then
272 304 xmakeopts="${xmakeopts} CROSS_COMPILE=${CTARGET}-"
273 if [[ ${CTARGET} = ${CHOST} ]]; then 305 elif type -p ${CHOST}-ar > /dev/null ; then
274 DEPEND="!virtual/os-headers" 306 xmakeopts="${xmakeopts} CROSS_COMPILE=${CHOST}-"
275 PROVIDE="virtual/kernel virtual/os-headers"
276 SLOT="0"
277 else
278 SLOT="${CTARGET}"
279 fi
280else
281 eerror "Unknown ETYPE=\"${ETYPE}\", must be \"sources\" or \"headers\""
282 die "Unknown ETYPE=\"${ETYPE}\", must be \"sources\" or \"headers\""
283fi 307 fi
308 export xmakeopts
309}
284 310
285# Unpack functions 311# Unpack functions
286#============================================================== 312#==============================================================
287unpack_2_4() { 313unpack_2_4() {
288 # Kernel ARCH != portage ARCH 314 env_setup_xmakeopts
289 local ARCH=$(tc-arch-kernel)
290 315
291 cd ${S} 316 cd "${S}"
292 # this file is required for other things to build properly, 317 # this file is required for other things to build properly,
293 # so we autogenerate it 318 # so we autogenerate it
294 make mrproper || die "make mrproper died" 319 make -s mrproper ${xmakeopts} || die "make mrproper failed"
320 make -s symlinks ${xmakeopts} || die "make symlinks failed"
295 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"
296 echo ">>> version.h compiled successfully." 322 echo ">>> version.h compiled successfully."
323}
297 324
298 ARCH=$(tc-arch) 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
299} 336}
300 337
301universal_unpack() { 338universal_unpack() {
302 cd ${WORKDIR} 339 cd ${WORKDIR}
303 unpack linux-${OKV}.tar.bz2 340 unpack linux-${OKV}.tar.bz2
304 if [[ "${OKV}" != "${KV_FULL}" ]]; then 341 if [[ "${OKV}" != "${KV_FULL}" ]]; then
305 mv linux-${OKV} linux-${KV_FULL} \ 342 mv linux-${OKV} linux-${KV_FULL} \
306 || die "Unable to move source tree to ${KV_FULL}." 343 || die "Unable to move source tree to ${KV_FULL}."
307 fi 344 fi
308 cd ${S} 345 cd "${S}"
309 346
310 # remove all backup files 347 # remove all backup files
311 find . -iname "*~" -exec rm {} \; 2> /dev/null 348 find . -iname "*~" -exec rm {} \; 2> /dev/null
312 349
313 # fix a problem on ppc where TOUT writes to /usr/src/linux breaking sandbox 350 # fix a problem on ppc where TOUT writes to /usr/src/linux breaking sandbox
314 use ppc && \ 351 use ppc && \
315 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|' \
316 ${S}/arch/ppc/Makefile 353 "${S}"/arch/ppc/Makefile
317} 354}
318 355
319unpack_set_extraversion() { 356unpack_set_extraversion() {
320 cd ${S} 357 cd "${S}"
321 sed -i -e "s:^\(EXTRAVERSION =\).*:\1 ${EXTRAVERSION}:" Makefile 358 sed -i -e "s:^\(EXTRAVERSION =\).*:\1 ${EXTRAVERSION}:" Makefile
322 cd ${OLDPWD} 359 cd ${OLDPWD}
323} 360}
324 361
325# Should be done after patches have been applied 362# Should be done after patches have been applied
326# Otherwise patches that modify the same area of Makefile will fail 363# Otherwise patches that modify the same area of Makefile will fail
327unpack_fix_install_path() { 364unpack_fix_install_path() {
328 cd ${S} 365 cd "${S}"
329 sed -i -e 's:#export\tINSTALL_PATH:export\tINSTALL_PATH:' Makefile 366 sed -i -e 's:#export\tINSTALL_PATH:export\tINSTALL_PATH:' Makefile
330} 367}
331 368
332unpack_fix_docbook() { 369unpack_fix_docbook() {
333 if [[ -d ${S}/Documentation/DocBook ]]; then 370 if [[ -d ${S}/Documentation/DocBook ]]; then
334 cd ${S}/Documentation/DocBook 371 cd "${S}"/Documentation/DocBook
335 sed -ie "s:db2:docbook2:g" Makefile 372 sed -ie "s:db2:docbook2:g" Makefile
336 cd ${OLDPWD} 373 cd ${OLDPWD}
337 fi 374 fi
338} 375}
339 376
340# Compile Functions 377# Compile Functions
341#============================================================== 378#==============================================================
342compile_headers() { 379compile_headers() {
380 env_setup_xmakeopts
381
343 # Since KBUILD_OUTPUT shouldnt be used when compiling headers, lets unset it 382 # Since KBUILD_OUTPUT shouldnt be used when compiling headers, lets unset it
344 # if it exists. 383 # if it exists.
345 [[ -n ${KBUILD_OUTPUT} ]] && unset KBUILD_OUTPUT 384 [[ -n ${KBUILD_OUTPUT} ]] && unset KBUILD_OUTPUT
346 385
347 # if we couldnt obtain HOSTCFLAGS from the Makefile, 386 # if we couldnt obtain HOSTCFLAGS from the Makefile,
348 # then set it to something sane 387 # then set it to something sane
349 local HOSTCFLAGS=$(getfilevar HOSTCFLAGS ${S}/Makefile) 388 local HOSTCFLAGS=$(getfilevar HOSTCFLAGS "${S}"/Makefile)
350 HOSTCFLAGS=${HOSTCFLAGS:--Wall -Wstrict-prototypes -O2 -fomit-frame-pointer} 389 HOSTCFLAGS=${HOSTCFLAGS:--Wall -Wstrict-prototypes -O2 -fomit-frame-pointer}
351
352 # Kernel ARCH != portage ARCH
353 local KARCH=$(tc-arch-kernel)
354
355 # When cross-compiling, we need to set the ARCH/CROSS_COMPILE
356 # variables properly or bad things happen !
357 local xmakeopts="ARCH=${KARCH}"
358 if [[ ${CTARGET} != ${CHOST} ]]; then
359 xmakeopts="${xmakeopts} CROSS_COMPILE=${CTARGET}-"
360 elif type -p ${CHOST}-ar; then
361 xmakeopts="${xmakeopts} CROSS_COMPILE=${CHOST}-"
362 fi
363 390
364 if kernel_is 2 4; then 391 if kernel_is 2 4; then
365 yes "" | make oldconfig ${xmakeopts} 392 yes "" | make oldconfig ${xmakeopts}
366 echo ">>> make oldconfig complete" 393 echo ">>> make oldconfig complete"
367 use sparc && make dep ${xmakeopts} 394 make dep ${xmakeopts}
368 elif kernel_is 2 6; then 395 elif kernel_is 2 6; then
369 # autoconf.h isnt generated unless it already exists. plus, we have 396 # autoconf.h isnt generated unless it already exists. plus, we have
370 # no guarantee that any headers are installed on the system... 397 # no guarantee that any headers are installed on the system...
371 [[ -f ${ROOT}/usr/include/linux/autoconf.h ]] \ 398 [[ -f ${ROOT}/usr/include/linux/autoconf.h ]] \
372 || touch include/linux/autoconf.h 399 || touch include/linux/autoconf.h
380 # if there arent any installed headers, then there also isnt an asm 407 # if there arent any installed headers, then there also isnt an asm
381 # symlink in /usr/include/, and make defconfig will fail, so we have 408 # symlink in /usr/include/, and make defconfig will fail, so we have
382 # to force an include path with $S. 409 # to force an include path with $S.
383 HOSTCFLAGS="${HOSTCFLAGS} -I${S}/include/" 410 HOSTCFLAGS="${HOSTCFLAGS} -I${S}/include/"
384 ln -sf asm-${KARCH} "${S}"/include/asm 411 ln -sf asm-${KARCH} "${S}"/include/asm
412 cross_pre_c_headers && return 0
413
385 make ${K_DEFCONFIG} HOSTCFLAGS="${HOSTCFLAGS}" ${xmakeopts} || die "defconfig failed" 414 make ${K_DEFCONFIG} HOSTCFLAGS="${HOSTCFLAGS}" ${xmakeopts} || die "defconfig failed"
386 make prepare HOSTCFLAGS="${HOSTCFLAGS}" ${xmakeopts} || die "prepare failed" 415 make prepare HOSTCFLAGS="${HOSTCFLAGS}" ${xmakeopts} || die "prepare failed"
387 make prepare-all HOSTCFLAGS="${HOSTCFLAGS}" ${xmakeopts} || die "prepare failed" 416 make prepare-all HOSTCFLAGS="${HOSTCFLAGS}" ${xmakeopts} || die "prepare failed"
388 fi 417 fi
389} 418}
404} 433}
405 434
406install_headers() { 435install_headers() {
407 local ddir=$(kernel_header_destdir) 436 local ddir=$(kernel_header_destdir)
408 437
409 cd ${S} 438 cd "${S}"
410 dodir ${ddir}/linux 439 dodir ${ddir}/linux
411 cp -ax ${S}/include/linux/* ${D}/${ddir}/linux 440 cp -ax "${S}"/include/linux/* ${D}/${ddir}/linux
412 rm -rf ${D}/${ddir}/linux/modules 441 rm -rf ${D}/${ddir}/linux/modules
413 442
414 # Handle multilib headers 443 # Handle multilib headers and crap
444 local multi_dirs="" multi_defs=""
415 case $(tc-arch-kernel) in 445 case $(tc-arch-kernel) in
416 sparc64) 446 sparc64)
417 dodir ${ddir}/asm-sparc 447 multi_dirs="sparc sparc64"
418 cp -ax ${S}/include/asm-sparc/* ${D}/${ddir}/asm-sparc 448 multi_defs="!__arch64__ __arch64__"
419
420 dodir ${ddir}/asm-sparc64
421 cp -ax ${S}/include/asm-sparc64/* ${D}/${ddir}/asm-sparc64
422
423 create_ml_includes ${ddir}/asm !__arch64__:${ddir}/asm-sparc __arch64__:${ddir}/asm-sparc64
424 ;; 449 ;;
425 x86_64) 450 x86_64)
426 dodir ${ddir}/asm-i386 451 multi_dirs="i386 x86_64"
427 cp -ax ${S}/include/asm-i386/* ${D}/${ddir}/asm-i386 452 multi_defs="__i386__ __x86_64__"
428
429 dodir ${ddir}/asm-x86_64
430 cp -ax ${S}/include/asm-x86_64/* ${D}/${ddir}/asm-x86_64
431
432 create_ml_includes ${ddir}/asm __i386__:${ddir}/asm-i386 __x86_64__:${ddir}/asm-x86_64
433 ;; 453 ;;
434 ppc64) 454 ppc64)
435 dodir ${ddir}/asm-ppc 455 multi_dirs="ppc ppc64"
436 cp -ax ${S}/include/asm-ppc/* ${D}/${ddir}/asm-ppc 456 multi_defs="!__powerpc64__ __powerpc64__"
437 457 ;;
438 dodir ${ddir}/asm-ppc64 458 s390x)
439 cp -ax ${S}/include/asm-ppc64/* ${D}/${ddir}/asm-ppc64 459 multi_dirs="s390 s390x"
440 460 multi_defs="!__s390x__ __s390x__"
441 create_ml_includes ${ddir}/asm !__powerpc64__:${ddir}/asm-ppc __powerpc64__:${ddir}/asm-ppc64
442 ;; 461 ;;
443 arm) 462 arm)
444 dodir ${ddir}/asm 463 dodir ${ddir}/asm
445 cp -ax ${S}/include/asm/* ${D}/${ddir}/asm 464 cp -ax "${S}"/include/asm/* "${D}"/${ddir}/asm
446 [[ ! -e ${D}/${ddir}/asm/arch ]] && ln -s arch-ebsa285 ${D}/${ddir}/asm/arch 465 [[ ! -e ${D}/${ddir}/asm/arch ]] && ln -sf arch-ebsa285 "${D}"/${ddir}/asm/arch
447 [[ ! -e ${D}/${ddir}/asm/proc ]] && ln -s proc-armv ${D}/${ddir}/asm/proc 466 [[ ! -e ${D}/${ddir}/asm/proc ]] && ln -sf proc-armv "${D}"/${ddir}/asm/proc
467 ;;
468 powerpc)
469 dodir ${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
448 ;; 475 ;;
449 *) 476 *)
450 dodir ${ddir}/asm 477 dodir ${ddir}/asm
451 cp -ax ${S}/include/asm/* ${D}/${ddir}/asm 478 cp -ax "${S}"/include/asm/* ${D}/${ddir}/asm
452 ;; 479 ;;
453 esac 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"
486
487 ml_inc="${ml_inc} ${multi_defs%% *}:${ddir}/asm-${d}"
488 multi_defs=${multi_defs#* }
489 done
490 create_ml_includes ${ddir}/asm ${ml_inc}
491 fi
454 492
455 if kernel_is 2 6; then 493 if kernel_is 2 6; then
456 dodir ${ddir}/asm-generic 494 dodir ${ddir}/asm-generic
457 cp -ax ${S}/include/asm-generic/* ${D}/${ddir}/asm-generic 495 cp -ax "${S}"/include/asm-generic/* ${D}/${ddir}/asm-generic
458 fi 496 fi
459 497
460 # clean up 498 # clean up
461 find "${D}" -name '*.orig' -exec rm -f {} \; 499 find "${D}" -name '*.orig' -exec rm -f {} \;
462 500
464} 502}
465 503
466install_sources() { 504install_sources() {
467 local doc docs file 505 local doc docs file
468 506
469 cd ${S} 507 cd "${S}"
470 dodir /usr/src 508 dodir /usr/src
471 echo ">>> Copying sources ..." 509 echo ">>> Copying sources ..."
472 510
473 file="$(find ${WORKDIR} -iname "docs" -type d)" 511 file="$(find ${WORKDIR} -iname "docs" -type d)"
474 if [[ -n ${file} ]]; then 512 if [[ -n ${file} ]]; then
475 for file in $(find ${file} -type f); do 513 for file in $(find ${file} -type f); do
476 echo "${file//*docs\/}" >> ${S}/patches.txt 514 echo "${file//*docs\/}" >> "${S}"/patches.txt
477 echo "===================================================" >> ${S}/patches.txt 515 echo "===================================================" >> "${S}"/patches.txt
478 cat ${file} >> ${S}/patches.txt 516 cat ${file} >> "${S}"/patches.txt
479 echo "===================================================" >> ${S}/patches.txt 517 echo "===================================================" >> "${S}"/patches.txt
480 echo "" >> ${S}/patches.txt 518 echo "" >> "${S}"/patches.txt
481 done 519 done
482 fi 520 fi
483 521
484 if [[ ! -f ${S}/patches.txt ]]; then 522 if [[ ! -f ${S}/patches.txt ]]; then
485 # patches.txt is empty so lets use our ChangeLog 523 # patches.txt is empty so lets use our ChangeLog
486 [[ -f ${FILESDIR}/../ChangeLog ]] && \ 524 [[ -f ${FILESDIR}/../ChangeLog ]] && \
487 echo "Please check the ebuild ChangeLog for more details." \ 525 echo "Please check the ebuild ChangeLog for more details." \
488 > ${S}/patches.txt 526 > "${S}"/patches.txt
489 fi 527 fi
490 528
529 if use doc ; then
530 install_manpages
531
491 for doc in ${UNIPATCH_DOCS}; do [[ -f ${doc} ]] && docs="${docs} ${doc}"; done 532 for doc in ${UNIPATCH_DOCS}; do [[ -f ${doc} ]] && docs="${docs} ${doc}"; done
492 if [[ -f ${S}/patches.txt ]]; then docs="${docs} ${S}/patches.txt"; fi 533 if [[ -f ${S}/patches.txt ]]; then docs="${docs} ${S}/patches.txt"; fi
493 use doc && ! use arm && ! use s390 && install_manpages 534 [[ -n ${docs} ]] && dodoc ${docs}
494 dodoc ${docs} 535 fi
495 536
496 mv ${WORKDIR}/linux* ${D}/usr/src 537 mv ${WORKDIR}/linux* ${D}/usr/src
497} 538}
498 539
499install_manpages() { 540install_manpages() {
500 kernel_is lt 2 5 && return 541 kernel_is lt 2 5 && return
542
543 local myfiles="Documentation/DocBook/Makefile"
544 kernel_is lt 2 6 12 && myfiles="scripts/makeman ${myfiles}"
545
501 sed -ie "s#/usr/local/man#${D}/usr/share/man#g" \ 546 sed -ie "s#/usr/local/man#${D}/usr/share/man#g" ${myfiles}
502 scripts/makeman Documentation/DocBook/Makefile
503 ebegin "Installing manpages" 547 ebegin "Installing manpages"
504 env -u ARCH make installmandocs 548 env -u ARCH make installmandocs
505 eend $? 549 eend $?
506 sed -ie "s#${D}/usr/share/man#/usr/local/man#g" \ 550 sed -ie "s#${D}/usr/share/man#/usr/local/man#g" ${myfiles}
507 scripts/makeman Documentation/DocBook/Makefile
508} 551}
509 552
510# pkg_preinst functions 553# pkg_preinst functions
511#============================================================== 554#==============================================================
512preinst_headers() { 555preinst_headers() {
517 560
518# pkg_postinst functions 561# pkg_postinst functions
519#============================================================== 562#==============================================================
520postinst_sources() { 563postinst_sources() {
521 local MAKELINK=0 564 local MAKELINK=0
522 565
523 # if we have USE=symlink, then force K_SYMLINK=1 566 # if we have USE=symlink, then force K_SYMLINK=1
524 use symlink && K_SYMLINK=1 567 use symlink && K_SYMLINK=1
525 568
526 # if we are to forcably symlink, delete it if it already exists first. 569 # if we are to forcably symlink, delete it if it already exists first.
527 if [[ -n ${K_SYMLINK} ]]; then 570 if [[ -n ${K_SYMLINK} ]]; then
528 [[ -h ${ROOT}usr/src/linux ]] && rm ${ROOT}usr/src/linux 571 [[ -h ${ROOT}usr/src/linux ]] && rm ${ROOT}usr/src/linux
529 MAKELINK=1 572 MAKELINK=1
530 fi 573 fi
531 574
532 # if the link doesnt exist, lets create it 575 # if the link doesnt exist, lets create it
533 [[ ! -h ${ROOT}usr/src/linux ]] && MAKELINK=1 576 [[ ! -h ${ROOT}usr/src/linux ]] && MAKELINK=1
534 577
535 if [[ ${MAKELINK} == 1 ]]; then 578 if [[ ${MAKELINK} == 1 ]]; then
536 cd ${ROOT}usr/src 579 cd ${ROOT}usr/src
537 ln -sf linux-${KV_FULL} linux 580 ln -sf linux-${KV_FULL} linux
538 cd ${OLDPWD} 581 cd ${OLDPWD}
539 fi 582 fi
551 echo 594 echo
552 einfo "If you are upgrading from a previous kernel, you may be interested" 595 einfo "If you are upgrading from a previous kernel, you may be interested"
553 einfo "in the following documents:" 596 einfo "in the following documents:"
554 einfo " - General upgrade guide: http://www.gentoo.org/doc/en/kernel-upgrade.xml" 597 einfo " - General upgrade guide: http://www.gentoo.org/doc/en/kernel-upgrade.xml"
555 kernel_is_2_6 && einfo " - 2.4 to 2.6 migration guide: http://www.gentoo.org/doc/en/migration-to-2.6.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
556 echo 604 echo
557 605
558 # if K_EXTRAEINFO is set then lets display it now 606 # if K_EXTRAEINFO is set then lets display it now
559 if [[ -n ${K_EXTRAEINFO} ]]; then 607 if [[ -n ${K_EXTRAEINFO} ]]; then
560 echo ${K_EXTRAEINFO} | fmt | 608 echo ${K_EXTRAEINFO} | fmt |
596# unipatch 644# unipatch
597#============================================================== 645#==============================================================
598unipatch() { 646unipatch() {
599 local i x y z extention PIPE_CMD UNIPATCH_DROP KPATCH_DIR PATCH_DEPTH ELINE 647 local i x y z extention PIPE_CMD UNIPATCH_DROP KPATCH_DIR PATCH_DEPTH ELINE
600 local STRICT_COUNT PATCH_LEVEL myLC_ALL myLANG 648 local STRICT_COUNT PATCH_LEVEL myLC_ALL myLANG
601 649
602 # set to a standard locale to ensure sorts are ordered properly. 650 # set to a standard locale to ensure sorts are ordered properly.
603 myLC_ALL="${LC_ALL}" 651 myLC_ALL="${LC_ALL}"
604 myLANG="${LANG}" 652 myLANG="${LANG}"
605 LC_ALL="C" 653 LC_ALL="C"
606 LANG="" 654 LANG=""
753 die "Unable to dry-run patch." 801 die "Unable to dry-run patch."
754 fi 802 fi
755 done 803 done
756 done 804 done
757 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
758 # clean up KPATCH_DIR's - fixes bug #53610 816 # clean up KPATCH_DIR's - fixes bug #53610
759 for x in ${KPATCH_DIR}; do rm -Rf ${x}; done 817 for x in ${KPATCH_DIR}; do rm -Rf ${x}; done
760 818
761 LC_ALL="${myLC_ALL}" 819 LC_ALL="${myLC_ALL}"
762 LANG="${myLANG}" 820 LANG="${myLANG}"
763} 821}
764 822
765# getfilevar accepts 2 vars as follows: 823# getfilevar accepts 2 vars as follows:
776 else 834 else
777 workingdir=${PWD} 835 workingdir=${PWD}
778 basefname=$(basename ${2}) 836 basefname=$(basename ${2})
779 basedname=$(dirname ${2}) 837 basedname=$(dirname ${2})
780 unset ARCH 838 unset ARCH
781 839
782 cd ${basedname} 840 cd ${basedname}
783 echo -e "include ${basefname}\ne:\n\t@echo \$(${1})" | \ 841 echo -e "include ${basefname}\ne:\n\t@echo \$(${1})" | \
784 make ${BUILD_FIXES} -s -f - e 2>/dev/null 842 make ${BUILD_FIXES} -s -f - e 2>/dev/null
785 cd ${workingdir} 843 cd ${workingdir}
786 844
787 ARCH=${xarch} 845 ARCH=${xarch}
788 fi 846 fi
789} 847}
790 848
791detect_arch() { 849detect_arch() {
799 # ARCH_URI is the URI for all the ${ARCH}_URI patches 857 # ARCH_URI is the URI for all the ${ARCH}_URI patches
800 # ARCH_PATCH is ARCH_URI broken into files for UNIPATCH 858 # ARCH_PATCH is ARCH_URI broken into files for UNIPATCH
801 859
802 ARCH_URI="" 860 ARCH_URI=""
803 ARCH_PATCH="" 861 ARCH_PATCH=""
804 ALL_ARCH="X86 PPC PPC64 SPARC MIPS ALPHA ARM HPPA AMD64 IA64 X86OBSD S390 SH" 862 ALL_ARCH="ALPHA AMD64 ARM HPPA IA64 M68K MIPS PPC PPC64 S390 SH SPARC X86"
805 863
806 for LOOP_ARCH in ${ALL_ARCH}; do 864 for LOOP_ARCH in ${ALL_ARCH}; do
807 COMPAT_URI="${LOOP_ARCH}_URI" 865 COMPAT_URI="${LOOP_ARCH}_URI"
808 COMPAT_URI="${!COMPAT_URI}" 866 COMPAT_URI="${!COMPAT_URI}"
809 867
885 sed -i \ 943 sed -i \
886 -e "s/\([ "$'\t'"]\)\(u\|s\)\(8\|16\|32\|64\)\([ "$'\t'"]\)/\1__\2\3\4/g;" \ 944 -e "s/\([ "$'\t'"]\)\(u\|s\)\(8\|16\|32\|64\)\([ "$'\t'"]\)/\1__\2\3\4/g;" \
887 -e 's/ \(u\|s\)\(8\|16\|32\|64\)$/ __\1\2/g' \ 945 -e 's/ \(u\|s\)\(8\|16\|32\|64\)$/ __\1\2/g' \
888 -e 's/\([(, ]\)\(u\|s\)64\([, )]\)/\1__\264\3/g' \ 946 -e 's/\([(, ]\)\(u\|s\)64\([, )]\)/\1__\264\3/g' \
889 -e "s/^\(u\|s\)\(8\|16\|32\|64\)\([ "$'\t'"]\)/__\1\2\3/g;" \ 947 -e "s/^\(u\|s\)\(8\|16\|32\|64\)\([ "$'\t'"]\)/__\1\2\3/g;" \
948 -e "s/ inline / __inline__ /g" \
890 "$@" 949 "$@"
891} 950}
892 951
893# common functions 952# common functions
894#============================================================== 953#==============================================================
895kernel-2_src_unpack() { 954kernel-2_src_unpack() {
896 universal_unpack 955 universal_unpack
897 956
898 [[ -n ${UNIPATCH_LIST} || -n ${UNIPATCH_LIST_DEFAULT} || -n ${UNIPATCH_LIST_GENPATCHES} ]] && \ 957 [[ -n ${UNIPATCH_LIST} || -n ${UNIPATCH_LIST_DEFAULT} || -n ${UNIPATCH_LIST_GENPATCHES} ]] && \
899 unipatch "${UNIPATCH_LIST_DEFAULT} ${UNIPATCH_LIST_GENPATCHES} ${UNIPATCH_LIST}" 958 unipatch "${UNIPATCH_LIST_DEFAULT} ${UNIPATCH_LIST_GENPATCHES} ${UNIPATCH_LIST}"
959
960 # allow ebuilds to massage the source tree after patching but before
961 # we run misc `make` functions below
962 [[ $(type -t kernel-2_hook_premake) == "function" ]] && kernel-2_hook_premake
900 963
901 [[ -z ${K_NOSETEXTRAVERSION} ]] && unpack_set_extraversion 964 [[ -z ${K_NOSETEXTRAVERSION} ]] && unpack_set_extraversion
902 unpack_fix_docbook 965 unpack_fix_docbook
903 unpack_fix_install_path 966 unpack_fix_install_path
904 967
905 kernel_is 2 4 && unpack_2_4 968 kernel_is 2 4 && unpack_2_4
969 kernel_is 2 6 && unpack_2_6
906} 970}
907 971
908kernel-2_src_compile() { 972kernel-2_src_compile() {
909 cd ${S} 973 cd "${S}"
910 [[ ${ETYPE} == headers ]] && compile_headers 974 [[ ${ETYPE} == headers ]] && compile_headers
911 [[ ${ETYPE} == sources ]] && \ 975 [[ ${ETYPE} == sources ]] && \
912 use doc && ! use arm && ! use s390 && compile_manpages 976 use doc && compile_manpages
913} 977}
914 978
915kernel-2_pkg_preinst() { 979kernel-2_pkg_preinst() {
916 [[ ${ETYPE} == headers ]] && preinst_headers 980 [[ ${ETYPE} == headers ]] && preinst_headers
917} 981}
929 993
930kernel-2_pkg_setup() { 994kernel-2_pkg_setup() {
931 [[ ${ETYPE} == headers ]] && setup_headers 995 [[ ${ETYPE} == headers ]] && setup_headers
932 [[ ${ETYPE} == sources ]] && echo ">>> Preparing to unpack ..." 996 [[ ${ETYPE} == sources ]] && echo ">>> Preparing to unpack ..."
933} 997}
934
935kernel-2_pkg_prerm() {
936 local KV_DIR=${ROOT}/usr/src/linux-${KV_FULL}
937
938 if [[ ${ETYPE} == sources ]]; then
939 # if we have a config for it then we should act on it.
940 if [[ -f ${KV_DIR}/.config ]]; then
941 gzip -c ${KV_DIR}/.config > ${KV_DIR}.config.gz
942 fi
943
944 # have kbuild clean up for us.
945 if [[ -f ${KV_DIR}/include/linux/version.h ]]; then
946 ARCH=$(tc-arch-kernel)
947 make -C ${KV_DIR} mrproper
948 fi
949 fi
950}

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

  ViewVC Help
Powered by ViewVC 1.1.20