/[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.221 Revision 1.253
1# Copyright 1999-2009 Gentoo Foundation 1# Copyright 1999-2011 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.221 2009/10/20 19:17:59 zmedico Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/kernel-2.eclass,v 1.253 2011/06/03 20:20:23 mpagano 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# Original author: John Mylchreest <johnm@gentoo.org> 8# Original author: John Mylchreest <johnm@gentoo.org>
43# combination of "base" and "extras" 43# combination of "base" and "extras"
44# K_GENPATCHES_VER - The version of the genpatches tarball(s) to apply. 44# K_GENPATCHES_VER - The version of the genpatches tarball(s) to apply.
45# A value of "5" would apply genpatches-2.6.12-5 to 45# A value of "5" would apply genpatches-2.6.12-5 to
46# my-sources-2.6.12.ebuild 46# my-sources-2.6.12.ebuild
47# K_SECURITY_UNSUPPORTED- If set, this kernel is unsupported by Gentoo Security 47# K_SECURITY_UNSUPPORTED- If set, this kernel is unsupported by Gentoo Security
48 48# K_DEBLOB_AVAILABLE - A value of "0" will disable all of the optional deblob
49# code. If empty, will be set to "1" if deblobbing is
50# possible. Test ONLY for "1".
51# K_PREDEBLOBBED - This kernel was already deblobbed elsewhere.
52# If false, either optional deblobbing will be available
53# or the license will note the inclusion of freedist
54# code.
55# K_LONGTERM - If set, the eclass will search for the kernel source
56# in the long term directories on the upstream servers
57# as the location has been changed by upstream
49# H_SUPPORTEDARCH - this should be a space separated list of ARCH's which 58# H_SUPPORTEDARCH - this should be a space separated list of ARCH's which
50# can be supported by the headers ebuild 59# can be supported by the headers ebuild
51 60
52# UNIPATCH_LIST - space delimetered list of patches to be applied to the 61# UNIPATCH_LIST - space delimetered list of patches to be applied to the
53# kernel 62# kernel
59# the doc dir 68# the doc dir
60# UNIPATCH_STRICTORDER - if this is set places patches into directories of 69# UNIPATCH_STRICTORDER - if this is set places patches into directories of
61# order, so they are applied in the order passed 70# order, so they are applied in the order passed
62 71
63inherit eutils toolchain-funcs versionator multilib 72inherit eutils toolchain-funcs versionator multilib
64EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_install pkg_preinst pkg_postinst 73EXPORT_FUNCTIONS pkg_setup src_unpack src_compile src_test src_install pkg_preinst pkg_postinst
65 74
66# Added by Daniel Ostrow <dostrow@gentoo.org> 75# Added by Daniel Ostrow <dostrow@gentoo.org>
67# This is an ugly hack to get around an issue with a 32-bit userland on ppc64. 76# This is an ugly hack to get around an issue with a 32-bit userland on ppc64.
68# I will remove it when I come up with something more reasonable. 77# I will remove it when I come up with something more reasonable.
69[[ ${PROFILE_ARCH} == "ppc64" ]] && CHOST="powerpc64-${CHOST#*-}" 78[[ ${PROFILE_ARCH} == "ppc64" ]] && CHOST="powerpc64-${CHOST#*-}"
72if [[ ${CTARGET} == ${CHOST} && ${CATEGORY/cross-} != ${CATEGORY} ]]; then 81if [[ ${CTARGET} == ${CHOST} && ${CATEGORY/cross-} != ${CATEGORY} ]]; then
73 export CTARGET=${CATEGORY/cross-} 82 export CTARGET=${CATEGORY/cross-}
74fi 83fi
75 84
76HOMEPAGE="http://www.kernel.org/ http://www.gentoo.org/ ${HOMEPAGE}" 85HOMEPAGE="http://www.kernel.org/ http://www.gentoo.org/ ${HOMEPAGE}"
86[[ -z ${LICENSE} ]] && \
77LICENSE="GPL-2" 87 LICENSE="GPL-2"
88
89# This is the latest KV_PATCH of the deblob tool available from the
90# libre-sources upstream. If you bump this, you MUST regenerate the Manifests
91# for ALL kernel-2 consumer packages where deblob is available.
92[[ -z ${DEBLOB_MAX_VERSION} ]] && DEBLOB_MAX_VERSION=38
78 93
79# No need to run scanelf/strip on kernel sources/headers (bug #134453). 94# No need to run scanelf/strip on kernel sources/headers (bug #134453).
80RESTRICT="binchecks strip" 95RESTRICT="binchecks strip"
81 96
82# set LINUX_HOSTCFLAGS if not already set 97# set LINUX_HOSTCFLAGS if not already set
87#============================================================== 102#==============================================================
88# this function exists only to help debug kernel-2.eclass 103# this function exists only to help debug kernel-2.eclass
89# if you are adding new functionality in, put a call to it 104# if you are adding new functionality in, put a call to it
90# at the start of src_unpack, or during SRC_URI/dep generation. 105# at the start of src_unpack, or during SRC_URI/dep generation.
91debug-print-kernel2-variables() { 106debug-print-kernel2-variables() {
92 debug-print "PVR: ${PVR}" 107 for v in PVR CKV OKV KV KV_FULL KV_MAJOR KV_MINOR KV_PATCH RELEASETYPE \
93 debug-print "CKV: ${CKV}" 108 RELEASE UNIPATCH_LIST_DEFAULT UNIPATCH_LIST_GENPATCHES \
94 debug-print "OKV: ${OKV}" 109 UNIPATCH_LIST S KERNEL_URI ; do
95 debug-print "KV: ${KV}" 110 debug-print "${v}: ${!v}"
96 debug-print "KV_FULL: ${KV_FULL}" 111 done
97 debug-print "RELEASETYPE: ${RELEASETYPE}"
98 debug-print "RELEASE: ${RELEASE}"
99 debug-print "UNIPATCH_LIST_DEFAULT: ${UNIPATCH_LIST_DEFAULT} "
100 debug-print "UNIPATCH_LIST_GENPATCHES: ${UNIPATCH_LIST_GENPATCHES} "
101 debug-print "UNIPATCH_LIST: ${UNIPATCH_LIST}"
102 debug-print "S: ${S}"
103 debug-print "KERNEL_URI: ${KERNEL_URI}"
104} 112}
105 113
106#Eclass functions only from here onwards ... 114#Eclass functions only from here onwards ...
107#============================================================== 115#==============================================================
108handle_genpatches() { 116handle_genpatches() {
141 OKV=${OKV/_rc/-rc} 149 OKV=${OKV/_rc/-rc}
142 OKV=${OKV/-r*} 150 OKV=${OKV/-r*}
143 OKV=${OKV/_p*} 151 OKV=${OKV/_p*}
144 152
145 KV_MAJOR=$(get_version_component_range 1 ${OKV}) 153 KV_MAJOR=$(get_version_component_range 1 ${OKV})
154
155 # if KV_MAJOR >= 3, then we have no more KV_MINOR
156 if [[ ${KV_MAJOR} -lt 3 ]]; then
146 KV_MINOR=$(get_version_component_range 2 ${OKV}) 157 KV_MINOR=$(get_version_component_range 2 ${OKV})
147 KV_PATCH=$(get_version_component_range 3 ${OKV}) 158 KV_PATCH=$(get_version_component_range 3 ${OKV})
148
149 if [[ ${KV_MAJOR}${KV_MINOR}${KV_PATCH} -ge 269 ]]; then 159 if [[ ${KV_MAJOR}${KV_MINOR}${KV_PATCH} -ge 269 ]]; then
160 KV_EXTRA=$(get_version_component_range 4- ${OKV})
161 KV_EXTRA=${KV_EXTRA/[-_]*}
162 else
163 KV_PATCH=$(get_version_component_range 3- ${OKV})
164 fi
165 else
166 KV_PATCH=$(get_version_component_range 2 ${OKV})
150 KV_EXTRA=$(get_version_component_range 4- ${OKV}) 167 KV_EXTRA=$(get_version_component_range 3- ${OKV})
151 KV_EXTRA=${KV_EXTRA/[-_]*} 168 KV_EXTRA=${KV_EXTRA/[-_]*}
169 fi
170
171 KV_PATCH=${KV_PATCH/[-_]*}
172
173 local v n=0 missing
174 if [[ ${KV_MAJOR} -lt 3 ]]; then
175 for v in CKV OKV KV_{MAJOR,MINOR,PATCH} ; do
176 [[ -z ${!v} ]] && n=1 && missing="${missing}${v} ";
177 done
152 else 178 else
153 KV_PATCH=$(get_version_component_range 3- ${OKV}) 179 for v in CKV OKV KV_{MAJOR,PATCH} ; do
180 [[ -z ${!v} ]] && n=1 && missing="${missing}${v} ";
181 done
154 fi 182 fi
155 KV_PATCH=${KV_PATCH/[-_]*}
156 183
184 [[ $n -eq 1 ]] && \
185 eerror "Missing variables: ${missing}" && \
186 die "Failed to extract kernel version (try explicit CKV in ebuild)!"
187 unset v n missing
188
189 if [[ ${KV_MAJOR} -ge 3 ]]; then
190 KV_PATCH_ARR=(${KV_PATCH//\./ })
191 KERNEL_BASE_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_PATCH_ARR}"
192 [[ -n "${K_LONGTERM}" ]] &&
193 KERNEL_BASE_URI="${KERNEL_BASE_URI}/longterm/v${KV_MAJOR}.${KV_PATCH_ARR}"
194 else
157 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${OKV}.tar.bz2" 195 KERNEL_BASE_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}"
196 [[ -n "${K_LONGTERM}" ]] &&
197 KERNEL_BASE_URI="${KERNEL_BASE_URI}/longterm/v${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}"
198 fi
199
200 KERNEL_URI="${KERNEL_BASE_URI}/linux-${OKV}.tar.bz2"
158 201
159 RELEASE=${CKV/${OKV}} 202 RELEASE=${CKV/${OKV}}
160 RELEASE=${RELEASE/_beta} 203 RELEASE=${RELEASE/_beta}
161 RELEASE=${RELEASE/_rc/-rc} 204 RELEASE=${RELEASE/_rc/-rc}
162 RELEASE=${RELEASE/_pre/-pre} 205 RELEASE=${RELEASE/_pre/-pre}
206 # We cannot trivally call kernel_is here, because it calls us to detect the
207 # version
163 kernel_is ge 2 6 && RELEASE=${RELEASE/-pre/-git} 208 #kernel_is ge 2 6 && RELEASE=${RELEASE/-pre/-git}
209 [ $(($KV_MAJOR * 1000 + ${KV_MINOR:-0})) -ge 2006 ] && RELEASE=${RELEASE/-pre/-git}
164 RELEASETYPE=${RELEASE//[0-9]} 210 RELEASETYPE=${RELEASE//[0-9]}
165 211
166 # Now we know that RELEASE is the -rc/-git 212 # Now we know that RELEASE is the -rc/-git
167 # and RELEASETYPE is the same but with its numerics stripped 213 # and RELEASETYPE is the same but with its numerics stripped
168 # we can work on better sorting EXTRAVERSION. 214 # we can work on better sorting EXTRAVERSION.
195 debug-print "2 EXTRAVERSION:${EXTRAVERSION}" 241 debug-print "2 EXTRAVERSION:${EXTRAVERSION}"
196 242
197 # The only messing around which should actually effect this is for KV_EXTRA 243 # The only messing around which should actually effect this is for KV_EXTRA
198 # since this has to limit OKV to MAJ.MIN.PAT and strip EXTRA off else 244 # since this has to limit OKV to MAJ.MIN.PAT and strip EXTRA off else
199 # KV_FULL evaluates to MAJ.MIN.PAT.EXT.EXT after EXTRAVERSION 245 # KV_FULL evaluates to MAJ.MIN.PAT.EXT.EXT after EXTRAVERSION
246
200 if [[ -n ${KV_EXTRA} ]]; then 247 if [[ -n ${KV_EXTRA} ]]; then
248 if [[ -n ${KV_MINOR} ]]; then
201 OKV="${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}" 249 OKV="${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}"
202 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/patch-${CKV}.bz2 250 else
203 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}.tar.bz2" 251 OKV="${KV_MAJOR}.${KV_PATCH}"
252 fi
253 KERNEL_URI="${KERNEL_BASE_URI}/patch-${CKV}.bz2
254 ${KERNEL_BASE_URI}/linux-${OKV}.tar.bz2"
204 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${CKV}.bz2" 255 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${CKV}.bz2"
205 fi 256 fi
206 257
207 # We need to set this using OKV, but we need to set it before we do any 258 # We need to set this using OKV, but we need to set it before we do any
208 # messing around with OKV based on RELEASETYPE 259 # messing around with OKV based on RELEASETYPE
216 # for example: 267 # for example:
217 # CKV="2.6.11_rc3_pre2" 268 # CKV="2.6.11_rc3_pre2"
218 # will pull: 269 # will pull:
219 # linux-2.6.10.tar.bz2 & patch-2.6.11-rc3.bz2 & patch-2.6.11-rc3-git2.bz2 270 # linux-2.6.10.tar.bz2 & patch-2.6.11-rc3.bz2 & patch-2.6.11-rc3-git2.bz2
220 271
272 if [[ ${KV_MAJOR}${KV_MINOR} -eq 26 ]]; then
273
221 if [[ ${RELEASETYPE} == -rc ]] || [[ ${RELEASETYPE} == -pre ]]; then 274 if [[ ${RELEASETYPE} == -rc ]] || [[ ${RELEASETYPE} == -pre ]]; then
222 OKV="${KV_MAJOR}.${KV_MINOR}.$((${KV_PATCH} - 1))" 275 OKV="${KV_MAJOR}.${KV_MINOR}.$((${KV_PATCH} - 1))"
223 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/testing/patch-${CKV//_/-}.bz2 276 KERNEL_URI="${KERNEL_BASE_URI}/testing/patch-${CKV//_/-}.bz2
224 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${OKV}.tar.bz2" 277 ${KERNEL_BASE_URI}/linux-${OKV}.tar.bz2"
225 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${CKV//_/-}.bz2" 278 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${CKV//_/-}.bz2"
226 fi 279 fi
227 280
228 if [[ ${RELEASETYPE} == -git ]]; then 281 if [[ ${RELEASETYPE} == -git ]]; then
229 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/snapshots/patch-${OKV}${RELEASE}.bz2 282 KERNEL_URI="${KERNEL_BASE_URI}/snapshots/patch-${OKV}${RELEASE}.bz2
230 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${OKV}.tar.bz2" 283 ${KERNEL_BASE_URI}/linux-${OKV}.tar.bz2"
231 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${OKV}${RELEASE}.bz2" 284 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${OKV}${RELEASE}.bz2"
232 fi 285 fi
233 286
234 if [[ ${RELEASETYPE} == -rc-git ]]; then 287 if [[ ${RELEASETYPE} == -rc-git ]]; then
235 OKV="${KV_MAJOR}.${KV_MINOR}.$((${KV_PATCH} - 1))" 288 OKV="${KV_MAJOR}.${KV_MINOR}.$((${KV_PATCH} - 1))"
236 KERNEL_URI="mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/snapshots/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE}.bz2 289 KERNEL_URI="${KERNEL_BASE_URI}/snapshots/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE}.bz2
237 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/testing/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE/-git*}.bz2 290 ${KERNEL_BASE_URI}/testing/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE/-git*}.bz2
238 mirror://kernel/linux/kernel/v${KV_MAJOR}.${KV_MINOR}/linux-${OKV}.tar.bz2" 291 ${KERNEL_BASE_URI}/linux-${OKV}.tar.bz2"
292
239 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE/-git*}.bz2 ${DISTDIR}/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE}.bz2" 293 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE/-git*}.bz2 ${DISTDIR}/patch-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${RELEASE}.bz2"
240 fi 294 fi
295 else
296 if [[ ${RELEASETYPE} == -rc ]] || [[ ${RELEASETYPE} == -pre ]]; then
297 if [[ ${KV_MAJOR}${KV_PATCH} -eq 30 ]]; then
298 OKV="2.6.39"
299 else
300 KV_PATCH_ARR=(${KV_PATCH//\./ })
301 OKV="${KV_MAJOR}.$((${KV_PATCH_ARR} - 1))"
302 fi
303 KERNEL_URI="${KERNEL_BASE_URI}/testing/patch-${CKV//_/-}.bz2
304 ${KERNEL_BASE_URI}/testing/linux-${OKV}.tar.bz2"
305 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${CKV//_/-}.bz2"
306 fi
307
308 if [[ ${RELEASETYPE} == -git ]]; then
309 KERNEL_URI="${KERNEL_BASE_URI}/snapshots/patch-${OKV}${RELEASE}.bz2
310 ${KERNEL_BASE_URI}/linux-${OKV}.tar.bz2"
311 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${OKV}${RELEASE}.bz2"
312 fi
313
314 if [[ ${RELEASETYPE} == -rc-git ]]; then
315 if [[ ${KV_MAJOR}${KV_PATCH} -eq 30 ]]; then
316 OKV="2.6.39"
317 else
318 KV_PATCH_ARR=(${KV_PATCH//\./ })
319 OKV="${KV_MAJOR}.$((${KV_PATCH_ARR} - 1))"
320 fi
321 KERNEL_URI="${KERNEL_BASE_URI}/snapshots/patch-${KV_MAJOR}.${KV_PATCH}${RELEASE}.bz2
322 ${KERNEL_BASE_URI}/testing/patch-${KV_MAJOR}.${KV_PATCH}${RELEASE/-git*}.bz2
323 ${KERNEL_BASE_URI}/linux-${OKV}.tar.bz2"
324
325 UNIPATCH_LIST_DEFAULT="${DISTDIR}/patch-${KV_MAJOR}.${KV_PATCH}${RELEASE/-git*}.bz2 ${DISTDIR}/patch-${KV_MAJOR}.${KV_PATCH}${RELEASE}.bz2"
326 fi
327
328
329 fi
330
241 331
242 debug-print-kernel2-variables 332 debug-print-kernel2-variables
243 333
244 handle_genpatches 334 handle_genpatches
245} 335}
246 336
247kernel_is() { 337kernel_is() {
338 # ALL of these should be set before we can safely continue this function.
339 # some of the sources have in the past had only one set.
340 local v n=0
341 for v in OKV KV_{MAJOR,MINOR,PATCH} ; do [[ -z ${!v} ]] && n=1 ; done
248 [[ -z ${OKV} ]] && detect_version 342 [[ $n -eq 1 ]] && detect_version
343 unset v n
344
345 # Now we can continue
249 local operator test value x=0 y=0 z=0 346 local operator test value x=0 y=0 z=0
250 347
251 case ${1} in 348 case ${1} in
252 lt) operator="-lt"; shift;; 349 lt) operator="-lt"; shift;;
253 gt) operator="-gt"; shift;; 350 gt) operator="-gt"; shift;;
287# Capture the sources type and set DEPENDs 384# Capture the sources type and set DEPENDs
288if [[ ${ETYPE} == sources ]]; then 385if [[ ${ETYPE} == sources ]]; then
289 DEPEND="!build? ( sys-apps/sed 386 DEPEND="!build? ( sys-apps/sed
290 >=sys-devel/binutils-2.11.90.0.31 )" 387 >=sys-devel/binutils-2.11.90.0.31 )"
291 RDEPEND="!build? ( >=sys-libs/ncurses-5.2 388 RDEPEND="!build? ( >=sys-libs/ncurses-5.2
292 sys-devel/make )" 389 sys-devel/make )"
293 PDEPEND="virtual/dev-manager" 390 PDEPEND="!build? ( virtual/dev-manager )"
294
295 PROVIDE="virtual/linux-sources"
296 kernel_is gt 2 4 && PROVIDE="${PROVIDE} virtual/alsa"
297 391
298 SLOT="${PVR}" 392 SLOT="${PVR}"
299 DESCRIPTION="Sources for the ${KV_MAJOR}.${KV_MINOR} linux kernel" 393 DESCRIPTION="Sources for the ${KV_MAJOR}.${KV_MINOR:-$KV_PATCH} linux kernel"
300 IUSE="symlink build" 394 IUSE="symlink build"
395
396 # Bug #266157, deblob for libre support
397 if [[ -z ${K_PREDEBLOBBED} ]] ; then
398 # Bug #359865, force a call to detect_version if needed
399 kernel_is ge 2 6 27 && \
400 [[ -z "${K_DEBLOB_AVAILABLE}" ]] && \
401 kernel_is le 2 6 ${DEBLOB_MAX_VERSION} && \
402 K_DEBLOB_AVAILABLE=1
403 if [[ ${K_DEBLOB_AVAILABLE} == "1" ]] ; then
404 IUSE="${IUSE} deblob"
405 # Reflect that kernels contain firmware blobs unless otherwise
406 # stripped
407 LICENSE="${LICENSE} !deblob? ( freedist )"
408
409 if [[ -n KV_MINOR ]]; then
410 DEBLOB_PV="${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}"
411 else
412 DEBLOB_PV="${KV_MAJOR}.${KV_PATCH}"
413 fi
414
415 DEBLOB_A="deblob-${DEBLOB_PV}"
416 DEBLOB_CHECK_A="deblob-check-${DEBLOB_PV}"
417 DEBLOB_HOMEPAGE="http://www.fsfla.org/svnwiki/selibre/linux-libre/"
418 DEBLOB_URI_PATH="download/releases/LATEST-${DEBLOB_PV}.N"
419 if ! has "${EAPI:-0}" 0 1 ; then
420 DEBLOB_CHECK_URI="${DEBLOB_HOMEPAGE}/${DEBLOB_URI_PATH}/deblob-check -> ${DEBLOB_CHECK_A}"
421 else
422 DEBLOB_CHECK_URI="mirror://gentoo/${DEBLOB_CHECK_A}"
423 fi
424 DEBLOB_URI="${DEBLOB_HOMEPAGE}/${DEBLOB_URI_PATH}/${DEBLOB_A}"
425 HOMEPAGE="${HOMEPAGE} ${DEBLOB_HOMEPAGE}"
426
427 KERNEL_URI="${KERNEL_URI}
428 deblob? (
429 ${DEBLOB_URI}
430 ${DEBLOB_CHECK_URI}
431 )"
432 else
433 # We have no way to deblob older kernels, so just mark them as
434 # tainted with non-libre materials.
435 LICENSE="${LICENSE} freedist"
436 fi
437 fi
438
301elif [[ ${ETYPE} == headers ]]; then 439elif [[ ${ETYPE} == headers ]]; then
302 DESCRIPTION="Linux system headers" 440 DESCRIPTION="Linux system headers"
303 441
304 # Since we should NOT honour KBUILD_OUTPUT in headers 442 # Since we should NOT honour KBUILD_OUTPUT in headers
305 # lets unset it here. 443 # lets unset it here.
306 unset KBUILD_OUTPUT 444 unset KBUILD_OUTPUT
307 445
308 if [[ ${CTARGET} = ${CHOST} ]]; then 446 if [[ ${CTARGET} = ${CHOST} ]]; then
309 DEPEND="!virtual/os-headers"
310 PROVIDE="virtual/os-headers"
311 SLOT="0" 447 SLOT="0"
312 else 448 else
313 SLOT="${CTARGET}" 449 SLOT="${CTARGET}"
314 fi 450 fi
315else 451else
375 || die "make include/linux/version.h failed" 511 || die "make include/linux/version.h failed"
376 rm -f .config >/dev/null 512 rm -f .config >/dev/null
377} 513}
378 514
379universal_unpack() { 515universal_unpack() {
380 cd ${WORKDIR} 516 cd "${WORKDIR}"
381 unpack linux-${OKV}.tar.bz2 517 unpack linux-${OKV}.tar.bz2
382 if [[ -d "linux" ]]; then 518 if [[ -d "linux" ]]; then
383 mv linux linux-${KV_FULL} \ 519 mv linux linux-${KV_FULL} \
384 || die "Unable to move source tree to ${KV_FULL}." 520 || die "Unable to move source tree to ${KV_FULL}."
385 elif [[ "${OKV}" != "${KV_FULL}" ]]; then 521 elif [[ "${OKV}" != "${KV_FULL}" ]]; then
392 find . -iname "*~" -exec rm {} \; 2> /dev/null 528 find . -iname "*~" -exec rm {} \; 2> /dev/null
393 529
394 # fix a problem on ppc where TOUT writes to /usr/src/linux breaking sandbox 530 # fix a problem on ppc where TOUT writes to /usr/src/linux breaking sandbox
395 # only do this for kernel < 2.6.27 since this file does not exist in later 531 # only do this for kernel < 2.6.27 since this file does not exist in later
396 # kernels 532 # kernels
397 if [[ ${KV_MAJOR}.${KV_MINOR}.${KV_PATCH} < 2.6.27 ]] 533 if [[ -n ${KV_MINOR} && ${KV_MAJOR}.${KV_MINOR}.${KV_PATCH} < 2.6.27 ]]
398 then 534 then
399 sed -i \ 535 sed -i \
400 -e 's|TOUT := .tmp_gas_check|TOUT := $(T).tmp_gas_check|' \ 536 -e 's|TOUT := .tmp_gas_check|TOUT := $(T).tmp_gas_check|' \
401 "${S}"/arch/ppc/Makefile 537 "${S}"/arch/ppc/Makefile
402 else 538 else
489 625
490# install functions 626# install functions
491#============================================================== 627#==============================================================
492install_universal() { 628install_universal() {
493 #fix silly permissions in tarball 629 #fix silly permissions in tarball
494 cd ${WORKDIR} 630 cd "${WORKDIR}"
495 chown -R root:0 * >& /dev/null 631 chown -R root:0 * >& /dev/null
496 chmod -R a+r-w+X,u+w * 632 chmod -R a+r-w+X,u+w *
497 cd ${OLDPWD} 633 cd ${OLDPWD}
498} 634}
499 635
512 return 0 648 return 0
513 fi 649 fi
514 650
515 # Do not use "linux/*" as that can cause problems with very long 651 # Do not use "linux/*" as that can cause problems with very long
516 # $S values where the cmdline to cp is too long 652 # $S values where the cmdline to cp is too long
517 cd "${S}" 653 pushd "${S}" >/dev/null
518 dodir ${ddir}/linux 654 dodir ${ddir}/linux
519 cp -pPR "${S}"/include/linux "${D}"/${ddir}/ || die 655 cp -pPR "${S}"/include/linux "${D}"/${ddir}/ || die
520 rm -rf "${D}"/${ddir}/linux/modules 656 rm -rf "${D}"/${ddir}/linux/modules
521 657
522 # Handle multilib headers and crap
523 local multi_dirs="" multi_defs=""
524 case $(tc-arch-kernel) in
525 sparc64)
526 multi_dirs="sparc sparc64"
527 multi_defs="!__arch64__ __arch64__"
528 ;;
529 x86_64)
530 multi_dirs="i386 x86_64"
531 multi_defs="__i386__ __x86_64__"
532 ;;
533 ppc64)
534 multi_dirs="ppc ppc64"
535 multi_defs="!__powerpc64__ __powerpc64__"
536 ;;
537 s390x)
538 multi_dirs="s390 s390x"
539 multi_defs="!__s390x__ __s390x__"
540 ;;
541 arm)
542 dodir ${ddir}/asm 658 dodir ${ddir}/asm
543 cp -pPR "${S}"/include/asm/* "${D}"/${ddir}/asm 659 cp -pPR "${S}"/include/asm/* "${D}"/${ddir}/asm
544 [[ ! -e ${D}/${ddir}/asm/arch ]] && ln -sf arch-ebsa285 "${D}"/${ddir}/asm/arch
545 [[ ! -e ${D}/${ddir}/asm/proc ]] && ln -sf proc-armv "${D}"/${ddir}/asm/proc
546 ;;
547 powerpc)
548 dodir ${ddir}/asm
549 cp -pPR "${S}"/include/asm/* ${D}/${ddir}/asm
550 if [[ -e "${S}"/include/asm-ppc ]] ; then
551 dodir ${ddir}/asm-ppc
552 cp -pPR "${S}"/include/asm-ppc/* ${D}/${ddir}/asm-ppc
553 fi
554 ;;
555 *)
556 dodir ${ddir}/asm
557 cp -pPR "${S}"/include/asm/* ${D}/${ddir}/asm
558 ;;
559 esac
560 if [[ -n ${multi_dirs} ]] ; then
561 local d ml_inc=""
562 for d in ${multi_dirs} ; do
563 dodir ${ddir}/asm-${d}
564 cp -pPR "${S}"/include/asm-${d}/* ${D}/${ddir}/asm-${d}/ || die "cp asm-${d} failed"
565 660
566 ml_inc="${ml_inc} ${multi_defs%% *}:${ddir}/asm-${d}"
567 multi_defs=${multi_defs#* }
568 done
569 create_ml_includes ${ddir}/asm ${ml_inc}
570 fi
571
572 if kernel_is 2 6; then 661 if kernel_is 2 6 ; then
573 dodir ${ddir}/asm-generic 662 dodir ${ddir}/asm-generic
574 cp -pPR "${S}"/include/asm-generic/* ${D}/${ddir}/asm-generic 663 cp -pPR "${S}"/include/asm-generic/* "${D}"/${ddir}/asm-generic
575 fi 664 fi
576 665
577 # clean up 666 # clean up
578 find "${D}" -name '*.orig' -exec rm -f {} \; 667 find "${D}" -name '*.orig' -exec rm -f {} \;
579 668
580 cd ${OLDPWD} 669 popd >/dev/null
581} 670}
582 671
583install_sources() { 672install_sources() {
584 local file 673 local file
585 674
603 [[ -f ${FILESDIR}/../ChangeLog ]] && \ 692 [[ -f ${FILESDIR}/../ChangeLog ]] && \
604 echo "Please check the ebuild ChangeLog for more details." \ 693 echo "Please check the ebuild ChangeLog for more details." \
605 > "${S}"/patches.txt 694 > "${S}"/patches.txt
606 fi 695 fi
607 696
608 mv ${WORKDIR}/linux* ${D}/usr/src 697 mv ${WORKDIR}/linux* "${D}"/usr/src
609} 698}
610 699
611# pkg_preinst functions 700# pkg_preinst functions
612#============================================================== 701#==============================================================
613preinst_headers() { 702preinst_headers() {
622 local MAKELINK=0 711 local MAKELINK=0
623 712
624 # if we have USE=symlink, then force K_SYMLINK=1 713 # if we have USE=symlink, then force K_SYMLINK=1
625 use symlink && K_SYMLINK=1 714 use symlink && K_SYMLINK=1
626 715
716 # if we're using a deblobbed kernel, it's not supported
717 [[ $K_DEBLOB_AVAILABLE == 1 ]] && \
718 use deblob && \
719 K_SECURITY_UNSUPPORTED=deblob
720
627 # if we are to forcably symlink, delete it if it already exists first. 721 # if we are to forcably symlink, delete it if it already exists first.
628 if [[ ${K_SYMLINK} > 0 ]]; then 722 if [[ ${K_SYMLINK} > 0 ]]; then
629 [[ -h ${ROOT}usr/src/linux ]] && rm ${ROOT}usr/src/linux 723 [[ -h ${ROOT}usr/src/linux ]] && rm ${ROOT}usr/src/linux
630 MAKELINK=1 724 MAKELINK=1
631 fi 725 fi
632 726
633 # if the link doesnt exist, lets create it 727 # if the link doesnt exist, lets create it
634 [[ ! -h ${ROOT}usr/src/linux ]] && MAKELINK=1 728 [[ ! -h ${ROOT}usr/src/linux ]] && MAKELINK=1
635 729
636 if [[ ${MAKELINK} == 1 ]]; then 730 if [[ ${MAKELINK} == 1 ]]; then
637 cd ${ROOT}usr/src 731 cd "${ROOT}"usr/src
638 ln -sf linux-${KV_FULL} linux 732 ln -sf linux-${KV_FULL} linux
639 cd ${OLDPWD} 733 cd ${OLDPWD}
640 fi 734 fi
641 735
642 # Don't forget to make directory for sysfs 736 # Don't forget to make directory for sysfs
665 echo ${K_EXTRAEWARN} | fmt | 759 echo ${K_EXTRAEWARN} | fmt |
666 while read -s ELINE; do ewarn "${ELINE}"; done 760 while read -s ELINE; do ewarn "${ELINE}"; done
667 fi 761 fi
668 762
669 # optionally display security unsupported message 763 # optionally display security unsupported message
764 # Start with why
765 if [[ ${K_SECURITY_UNSUPPORTED} = deblob ]]; then
766 ewarn "Deblobbed kernels are UNSUPPORTED by Gentoo Security."
767 elif [[ -n ${K_SECURITY_UNSUPPORTED} ]]; then
768 ewarn "${PN} is UNSUPPORTED by Gentoo Security."
769 fi
770 # And now the general message.
670 if [[ -n ${K_SECURITY_UNSUPPORTED} ]]; then 771 if [[ -n ${K_SECURITY_UNSUPPORTED} ]]; then
671 echo
672 ewarn "${PN} is UNSUPPORTED by Gentoo Security."
673 ewarn "This means that it is likely to be vulnerable to recent security issues." 772 ewarn "This means that it is likely to be vulnerable to recent security issues."
674 ewarn "For specific information on why this kernel is unsupported, please read:" 773 ewarn "For specific information on why this kernel is unsupported, please read:"
675 ewarn "http://www.gentoo.org/proj/en/security/kernel.xml" 774 ewarn "http://www.gentoo.org/proj/en/security/kernel.xml"
676 fi 775 fi
677 776
678 # warn sparc users that they need to do cross-compiling with >= 2.6.25(bug #214765) 777 # warn sparc users that they need to do cross-compiling with >= 2.6.25(bug #214765)
679 KV_MAJOR=$(get_version_component_range 1 ${OKV}) 778 KV_MAJOR=$(get_version_component_range 1 ${OKV})
680 KV_MINOR=$(get_version_component_range 2 ${OKV}) 779 KV_MINOR=$(get_version_component_range 2 ${OKV})
681 KV_PATCH=$(get_version_component_range 3 ${OKV}) 780 KV_PATCH=$(get_version_component_range 3 ${OKV})
682 if [[ "$(tc-arch)" = "sparc" ]] \ 781 if [[ "$(tc-arch)" = "sparc" ]]; then
683 && [[ ${KV_MAJOR}.${KV_MINOR}.${KV_PATCH} > 2.6.24 ]] 782 if [[ ${KV_MAJOR} -ge 3 || ${KV_MAJOR}.${KV_MINOR}.${KV_PATCH} > 2.6.24 ]]
684 then 783 then
685 echo 784 echo
686 elog "NOTE: Since 2.6.25 the kernel Makefile has changed in a way that" 785 elog "NOTE: Since 2.6.25 the kernel Makefile has changed in a way that"
687 elog "you now need to do" 786 elog "you now need to do"
688 elog " make CROSS_COMPILE=sparc64-unknown-linux-gnu-" 787 elog " make CROSS_COMPILE=sparc64-unknown-linux-gnu-"
689 elog "instead of just" 788 elog "instead of just"
690 elog " make" 789 elog " make"
691 elog "to compile the kernel. For more information please browse to" 790 elog "to compile the kernel. For more information please browse to"
692 elog "https://bugs.gentoo.org/show_bug.cgi?id=214765" 791 elog "https://bugs.gentoo.org/show_bug.cgi?id=214765"
693 echo 792 echo
694 fi 793 fi
695} 794 fi
696
697postinst_headers() {
698 elog "Kernel headers are usually only used when recompiling your system libc, as"
699 elog "such, following the installation of newer headers, it is advised that you"
700 elog "re-merge your system libc."
701 elog "Failure to do so will cause your system libc to not make use of newer"
702 elog "features present in the updated kernel headers."
703} 795}
704 796
705# pkg_setup functions 797# pkg_setup functions
706#============================================================== 798#==============================================================
707setup_headers() { 799setup_headers() {
721 813
722# unipatch 814# unipatch
723#============================================================== 815#==============================================================
724unipatch() { 816unipatch() {
725 local i x y z extention PIPE_CMD UNIPATCH_DROP KPATCH_DIR PATCH_DEPTH ELINE 817 local i x y z extention PIPE_CMD UNIPATCH_DROP KPATCH_DIR PATCH_DEPTH ELINE
726 local STRICT_COUNT PATCH_LEVEL myLC_ALL myLANG extglob_bak 818 local STRICT_COUNT PATCH_LEVEL myLC_ALL myLANG
727 819
728 # set to a standard locale to ensure sorts are ordered properly. 820 # set to a standard locale to ensure sorts are ordered properly.
729 myLC_ALL="${LC_ALL}" 821 myLC_ALL="${LC_ALL}"
730 myLANG="${LANG}" 822 myLANG="${LANG}"
731 LC_ALL="C" 823 LC_ALL="C"
733 825
734 [ -z "${KPATCH_DIR}" ] && KPATCH_DIR="${WORKDIR}/patches/" 826 [ -z "${KPATCH_DIR}" ] && KPATCH_DIR="${WORKDIR}/patches/"
735 [ ! -d ${KPATCH_DIR} ] && mkdir -p ${KPATCH_DIR} 827 [ ! -d ${KPATCH_DIR} ] && mkdir -p ${KPATCH_DIR}
736 828
737 # We're gonna need it when doing patches with a predefined patchlevel 829 # We're gonna need it when doing patches with a predefined patchlevel
738 extglob_bak=$(shopt -p extglob)
739 shopt -s extglob 830 eshopts_push -s extglob
740 831
741 # This function will unpack all passed tarballs, add any passed patches, and remove any passed patchnumbers 832 # This function will unpack all passed tarballs, add any passed patches, and remove any passed patchnumbers
742 # usage can be either via an env var or by params 833 # usage can be either via an env var or by params
743 # although due to the nature we pass this within this eclass 834 # although due to the nature we pass this within this eclass
744 # it shall be by param only. 835 # it shall be by param only.
770 else 861 else
771 extention=${i/*./} 862 extention=${i/*./}
772 extention=${extention/:*/} 863 extention=${extention/:*/}
773 PIPE_CMD="" 864 PIPE_CMD=""
774 case ${extention} in 865 case ${extention} in
866 xz) PIPE_CMD="xz -dc";;
867 lzma) PIPE_CMD="lzma -dc";;
775 bz2) PIPE_CMD="bzip2 -dc";; 868 bz2) PIPE_CMD="bzip2 -dc";;
776 patch) PIPE_CMD="cat";; 869 patch) PIPE_CMD="cat";;
777 diff) PIPE_CMD="cat";; 870 diff) PIPE_CMD="cat";;
778 gz|Z|z) PIPE_CMD="gzip -dc";; 871 gz|Z|z) PIPE_CMD="gzip -dc";;
779 ZIP|zip) PIPE_CMD="unzip -p";; 872 ZIP|zip) PIPE_CMD="unzip -p";;
802 do z="${z}0"; 895 do z="${z}0";
803 done 896 done
804 PATCH_ORDER="${z}${STRICT_COUNT}" 897 PATCH_ORDER="${z}${STRICT_COUNT}"
805 898
806 mkdir -p ${KPATCH_DIR}/${PATCH_ORDER}/ 899 mkdir -p ${KPATCH_DIR}/${PATCH_ORDER}/
807 $(${PIPE_CMD} ${i} > ${KPATCH_DIR}/${PATCH_ORDER}/${x}.patch${PATCH_LEVEL}) 900 $(${PIPE_CMD} ${i} > ${KPATCH_DIR}/${PATCH_ORDER}/${x}.patch${PATCH_LEVEL}) || die "uncompressing patch failed"
808 else 901 else
809 $(${PIPE_CMD} ${i} > ${KPATCH_DIR}/${x}.patch${PATCH_LEVEL}) 902 $(${PIPE_CMD} ${i} > ${KPATCH_DIR}/${x}.patch${PATCH_LEVEL}) || die "uncompressing patch failed"
810 fi 903 fi
811 fi 904 fi
812 fi 905 fi
813 done 906 done
814 907
820 done 913 done
821 914
822 # do not apply fbcondecor patch to sparc/sparc64 as it breaks boot 915 # do not apply fbcondecor patch to sparc/sparc64 as it breaks boot
823 # bug #272676 916 # bug #272676
824 if [[ "$(tc-arch)" = "sparc" || "$(tc-arch)" = "sparc64" ]]; then 917 if [[ "$(tc-arch)" = "sparc" || "$(tc-arch)" = "sparc64" ]]; then
825 if [[ ${KV_MAJOR}.${KV_MINOR}.${KV_PATCH} > 2.6.28 ]]; then 918 if [[ ${KV_MAJOR} -ge 3 || ${KV_MAJOR}.${KV_MINOR}.${KV_PATCH} > 2.6.28 ]]; then
826 UNIPATCH_DROP="${UNIPATCH_DROP} *_fbcondecor-0.9.6.patch" 919 UNIPATCH_DROP="${UNIPATCH_DROP} *_fbcondecor-0.9.6.patch"
827 echo 920 echo
828 ewarn "fbcondecor currently prevents sparc/sparc64 from booting" 921 ewarn "fbcondecor currently prevents sparc/sparc64 from booting"
829 ewarn "for kernel versions >= 2.6.29. Removing fbcondecor patch." 922 ewarn "for kernel versions >= 2.6.29. Removing fbcondecor patch."
830 ewarn "See https://bugs.gentoo.org/show_bug.cgi?id=272676 for details" 923 ewarn "See https://bugs.gentoo.org/show_bug.cgi?id=272676 for details"
866 break 959 break
867 else 960 else
868 eend 1 961 eend 1
869 eerror "Failed to apply patch ${i/*\//}" 962 eerror "Failed to apply patch ${i/*\//}"
870 eerror "Please attach ${STDERR_T} to any bug you may post." 963 eerror "Please attach ${STDERR_T} to any bug you may post."
964 eshopts_pop
871 die "Failed to apply ${i/*\//}" 965 die "Failed to apply ${i/*\//}"
872 fi 966 fi
873 else 967 else
874 PATCH_DEPTH=$((${PATCH_DEPTH} + 1)) 968 PATCH_DEPTH=$((${PATCH_DEPTH} + 1))
875 fi 969 fi
876 done 970 done
877 if [ ${PATCH_DEPTH} -eq 5 ]; then 971 if [ ${PATCH_DEPTH} -eq 5 ]; then
878 eend 1 972 eend 1
879 eerror "Please attach ${STDERR_T} to any bug you may post." 973 eerror "Please attach ${STDERR_T} to any bug you may post."
974 eshopts_pop
880 die "Unable to dry-run patch." 975 die "Unable to dry-run patch."
881 fi 976 fi
882 done 977 done
883 done 978 done
884 979
886 # sit in KPATCH_DIR's. This is handled properly in the unipatch rewrite, 981 # sit in KPATCH_DIR's. This is handled properly in the unipatch rewrite,
887 # which is why I'm not taking too much time over this. 982 # which is why I'm not taking too much time over this.
888 local tmp 983 local tmp
889 for i in ${UNIPATCH_DOCS}; do 984 for i in ${UNIPATCH_DOCS}; do
890 tmp="${tmp} ${i//*\/}" 985 tmp="${tmp} ${i//*\/}"
891 cp -f ${i} ${T}/ 986 cp -f ${i} "${T}"/
892 done 987 done
893 UNIPATCH_DOCS="${tmp}" 988 UNIPATCH_DOCS="${tmp}"
894 989
895 # clean up KPATCH_DIR's - fixes bug #53610 990 # clean up KPATCH_DIR's - fixes bug #53610
896 for x in ${KPATCH_DIR}; do rm -Rf ${x}; done 991 for x in ${KPATCH_DIR}; do rm -Rf ${x}; done
897 992
898 LC_ALL="${myLC_ALL}" 993 LC_ALL="${myLC_ALL}"
899 LANG="${myLANG}" 994 LANG="${myLANG}"
900 eval ${extglob_bak} 995 eshopts_pop
901} 996}
902 997
903# getfilevar accepts 2 vars as follows: 998# getfilevar accepts 2 vars as follows:
904# getfilevar <VARIABLE> <CONFIGFILE> 999# getfilevar <VARIABLE> <CONFIGFILE>
905# pulled from linux-info 1000# pulled from linux-info
1042 1137
1043 # allow ebuilds to massage the source tree after patching but before 1138 # allow ebuilds to massage the source tree after patching but before
1044 # we run misc `make` functions below 1139 # we run misc `make` functions below
1045 [[ $(type -t kernel-2_hook_premake) == "function" ]] && kernel-2_hook_premake 1140 [[ $(type -t kernel-2_hook_premake) == "function" ]] && kernel-2_hook_premake
1046 1141
1142 debug-print "Doing epatch_user"
1143 epatch_user
1144
1047 debug-print "Doing unpack_set_extraversion" 1145 debug-print "Doing unpack_set_extraversion"
1048 1146
1049 [[ -z ${K_NOSETEXTRAVERSION} ]] && unpack_set_extraversion 1147 [[ -z ${K_NOSETEXTRAVERSION} ]] && unpack_set_extraversion
1050 unpack_fix_install_path 1148 unpack_fix_install_path
1051 1149
1059 # unpack_2_6 should now be 2.6.17 safe anyways 1157 # unpack_2_6 should now be 2.6.17 safe anyways
1060 if [[ ${ETYPE} == headers ]]; then 1158 if [[ ${ETYPE} == headers ]]; then
1061 kernel_is 2 4 && unpack_2_4 1159 kernel_is 2 4 && unpack_2_4
1062 kernel_is 2 6 && unpack_2_6 1160 kernel_is 2 6 && unpack_2_6
1063 fi 1161 fi
1162
1163 if [[ $K_DEBLOB_AVAILABLE == 1 ]] && use deblob ; then
1164 cp "${DISTDIR}/${DEBLOB_A}" "${T}" || die "cp ${DEBLOB_A} failed"
1165 cp "${DISTDIR}/${DEBLOB_CHECK_A}" "${T}/deblob-check" || die "cp ${DEBLOB_CHECK_A} failed"
1166 chmod +x "${T}/${DEBLOB_A}" "${T}/deblob-check" || die "chmod deblob scripts failed"
1167 fi
1064} 1168}
1065 1169
1066kernel-2_src_compile() { 1170kernel-2_src_compile() {
1067 cd "${S}" 1171 cd "${S}"
1068 [[ ${ETYPE} == headers ]] && compile_headers 1172 [[ ${ETYPE} == headers ]] && compile_headers
1173
1174 if [[ $K_DEBLOB_AVAILABLE == 1 ]] && use deblob ; then
1175 echo ">>> Running deblob script ..."
1176 sh "${T}/${DEBLOB_A}" --force || \
1177 die "Deblob script failed to run!!!"
1178 fi
1069} 1179}
1180
1181# if you leave it to the default src_test, it will run make to
1182# find whether test/check targets are present; since "make test"
1183# actually produces a few support files, they are installed even
1184# though the package is binchecks-restricted.
1185#
1186# Avoid this altogether by making the function moot.
1187kernel-2_src_test() { :; }
1070 1188
1071kernel-2_pkg_preinst() { 1189kernel-2_pkg_preinst() {
1072 [[ ${ETYPE} == headers ]] && preinst_headers 1190 [[ ${ETYPE} == headers ]] && preinst_headers
1073} 1191}
1074 1192
1077 [[ ${ETYPE} == headers ]] && install_headers 1195 [[ ${ETYPE} == headers ]] && install_headers
1078 [[ ${ETYPE} == sources ]] && install_sources 1196 [[ ${ETYPE} == sources ]] && install_sources
1079} 1197}
1080 1198
1081kernel-2_pkg_postinst() { 1199kernel-2_pkg_postinst() {
1082 [[ ${ETYPE} == headers ]] && postinst_headers
1083 [[ ${ETYPE} == sources ]] && postinst_sources 1200 [[ ${ETYPE} == sources ]] && postinst_sources
1084} 1201}
1085 1202
1086kernel-2_pkg_setup() { 1203kernel-2_pkg_setup() {
1087 if kernel_is 2 4; then 1204 if kernel_is 2 4; then

Legend:
Removed from v.1.221  
changed lines
  Added in v.1.253

  ViewVC Help
Powered by ViewVC 1.1.20