diff options
| author | Richard Purdie <richard.purdie@linuxfoundation.org> | 2015-01-20 13:01:29 +0000 |
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2015-01-23 14:32:02 +0000 |
| commit | 11ef55a93bd2bbd95e203fab3aa237322923ffd9 (patch) | |
| tree | 69c6dbbe850170ae846e419eb1ef964e6769863e /meta/classes/kernel.bbclass | |
| parent | 46dba263741692d64801ed425e85362fce999d06 (diff) | |
| download | poky-11ef55a93bd2bbd95e203fab3aa237322923ffd9.tar.gz | |
kernel/image/depmodwrapper: Fixups for depmod
With the rpm package backend enabled, running:
bitbake <image>
bitbake virtual/kernel -c clean
bitbake <image> -c rootfs -f
results in an image with incorrect kernel module dependency information.
The problem is that the System.map and kernel-abiversion files are needed
for depmod and after the recent kernel changes, these are no longer in
sstate.
Its reasonable to require the kernel to unpack/build if you're
about to build a module against it. It is not reasonable to require this
just to build a rootfs.
Therefore stash the needed files specifically for depmod.
Also fix some STAGING_KERNEL_DIR references which were incorrect, found
whilst sorting through his change.
(From OE-Core rev: b851504dcf5e147c9efb1c7b6a4d22c1a1a87cd7)
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/classes/kernel.bbclass')
| -rw-r--r-- | meta/classes/kernel.bbclass | 18 |
1 files changed, 15 insertions, 3 deletions
diff --git a/meta/classes/kernel.bbclass b/meta/classes/kernel.bbclass index 183769316b..29498b4faf 100644 --- a/meta/classes/kernel.bbclass +++ b/meta/classes/kernel.bbclass | |||
| @@ -231,6 +231,11 @@ kernel_do_install() { | |||
| 231 | [ -e Module.symvers ] && install -m 0644 Module.symvers ${D}/boot/Module.symvers-${KERNEL_VERSION} | 231 | [ -e Module.symvers ] && install -m 0644 Module.symvers ${D}/boot/Module.symvers-${KERNEL_VERSION} |
| 232 | install -d ${D}${sysconfdir}/modules-load.d | 232 | install -d ${D}${sysconfdir}/modules-load.d |
| 233 | install -d ${D}${sysconfdir}/modprobe.d | 233 | install -d ${D}${sysconfdir}/modprobe.d |
| 234 | |||
| 235 | # Stash data for depmod | ||
| 236 | install -d ${D}${datadir}/kernel-depmod/ | ||
| 237 | echo "${KERNEL_VERSION}" > ${D}${datadir}/kernel-depmod/kernel-abiversion | ||
| 238 | cp System.map ${D}${datadir}/kernel-depmod/System.map-${KERNEL_VERSION} | ||
| 234 | } | 239 | } |
| 235 | do_install[prefuncs] += "package_get_auto_pr" | 240 | do_install[prefuncs] += "package_get_auto_pr" |
| 236 | 241 | ||
| @@ -280,14 +285,21 @@ do_shared_workdir () { | |||
| 280 | fi | 285 | fi |
| 281 | } | 286 | } |
| 282 | 287 | ||
| 283 | # We have an empty sysroot_stage_all to keep the default routine from | 288 | # Only stage the files we need for depmod, not the modules/firmware |
| 284 | # package.bbclass from expanding the kernel source into the sysroot and | ||
| 285 | # colliding with linux-firmware files | ||
| 286 | sysroot_stage_all () { | 289 | sysroot_stage_all () { |
| 290 | sysroot_stage_dir ${D}${datadir}/kernel-depmod ${SYSROOT_DESTDIR}${datadir}/kernel-depmod | ||
| 287 | } | 291 | } |
| 288 | 292 | ||
| 289 | KERNEL_CONFIG_COMMAND ?= "oe_runmake_call -C ${S} O=${B} oldnoconfig || yes '' | oe_runmake -C ${S} O=${B} oldconfig" | 293 | KERNEL_CONFIG_COMMAND ?= "oe_runmake_call -C ${S} O=${B} oldnoconfig || yes '' | oe_runmake -C ${S} O=${B} oldconfig" |
| 290 | 294 | ||
| 295 | PACKAGE_PREPROCESS_FUNCS += "kernel_package_preprocess" | ||
| 296 | |||
| 297 | kernel_package_preprocess () { | ||
| 298 | rm -rf ${PKGD}${datadir}/kernel-depmod | ||
| 299 | rmdir ${PKGD}${datadir} | ||
| 300 | rmdir ${PKGD}${exec_prefix} | ||
| 301 | } | ||
| 302 | |||
| 291 | kernel_do_configure() { | 303 | kernel_do_configure() { |
| 292 | # fixes extra + in /lib/modules/2.6.37+ | 304 | # fixes extra + in /lib/modules/2.6.37+ |
| 293 | # $ scripts/setlocalversion . => + | 305 | # $ scripts/setlocalversion . => + |
