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 | |
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>
-rw-r--r-- | meta/classes/image.bbclass | 2 | ||||
-rw-r--r-- | meta/classes/kernel-module-split.bbclass | 2 | ||||
-rw-r--r-- | meta/classes/kernel.bbclass | 18 | ||||
-rw-r--r-- | meta/lib/oe/rootfs.py | 15 | ||||
-rw-r--r-- | meta/recipes-kernel/kmod/depmodwrapper-cross_1.0.bb | 12 | ||||
-rw-r--r-- | meta/recipes-kernel/systemtap/systemtap-uprobes_git.bb | 2 |
6 files changed, 32 insertions, 19 deletions
diff --git a/meta/classes/image.bbclass b/meta/classes/image.bbclass index 07e7f9979c..22b6970344 100644 --- a/meta/classes/image.bbclass +++ b/meta/classes/image.bbclass | |||
@@ -95,7 +95,7 @@ def rootfs_variables(d): | |||
95 | 'SDK_OUTPUT','SDKPATHNATIVE','SDKTARGETSYSROOT','SDK_DIR','SDK_VENDOR','SDKIMAGE_INSTALL_COMPLEMENTARY','SDK_PACKAGE_ARCHS','SDK_OUTPUT','SDKTARGETSYSROOT','MULTILIBRE_ALLOW_REP', | 95 | 'SDK_OUTPUT','SDKPATHNATIVE','SDKTARGETSYSROOT','SDK_DIR','SDK_VENDOR','SDKIMAGE_INSTALL_COMPLEMENTARY','SDK_PACKAGE_ARCHS','SDK_OUTPUT','SDKTARGETSYSROOT','MULTILIBRE_ALLOW_REP', |
96 | 'MULTILIB_TEMP_ROOTFS','MULTILIB_VARIANTS','MULTILIBS','ALL_MULTILIB_PACKAGE_ARCHS','MULTILIB_GLOBAL_VARIANTS','BAD_RECOMMENDATIONS','NO_RECOMMENDATIONS','PACKAGE_ARCHS', | 96 | 'MULTILIB_TEMP_ROOTFS','MULTILIB_VARIANTS','MULTILIBS','ALL_MULTILIB_PACKAGE_ARCHS','MULTILIB_GLOBAL_VARIANTS','BAD_RECOMMENDATIONS','NO_RECOMMENDATIONS','PACKAGE_ARCHS', |
97 | 'PACKAGE_CLASSES','TARGET_VENDOR','TARGET_VENDOR','TARGET_ARCH','TARGET_OS','OVERRIDES','BBEXTENDVARIANT','FEED_DEPLOYDIR_BASE_URI','INTERCEPT_DIR','BUILDNAME','USE_DEVFS', | 97 | 'PACKAGE_CLASSES','TARGET_VENDOR','TARGET_VENDOR','TARGET_ARCH','TARGET_OS','OVERRIDES','BBEXTENDVARIANT','FEED_DEPLOYDIR_BASE_URI','INTERCEPT_DIR','BUILDNAME','USE_DEVFS', |
98 | 'STAGING_KERNEL_DIR','COMPRESSIONTYPES'] | 98 | 'COMPRESSIONTYPES'] |
99 | variables.extend(command_variables(d)) | 99 | variables.extend(command_variables(d)) |
100 | variables.extend(variable_depends(d)) | 100 | variables.extend(variable_depends(d)) |
101 | return " ".join(variables) | 101 | return " ".join(variables) |
diff --git a/meta/classes/kernel-module-split.bbclass b/meta/classes/kernel-module-split.bbclass index 2d43b512df..32b80856e0 100644 --- a/meta/classes/kernel-module-split.bbclass +++ b/meta/classes/kernel-module-split.bbclass | |||
@@ -75,7 +75,7 @@ python split_kernel_module_packages () { | |||
75 | if not os.path.exists(system_map_file): | 75 | if not os.path.exists(system_map_file): |
76 | system_map_file = "%s/System.map-%s" % (staging_kernel_dir, kernelver) | 76 | system_map_file = "%s/System.map-%s" % (staging_kernel_dir, kernelver) |
77 | if not os.path.exists(system_map_file): | 77 | if not os.path.exists(system_map_file): |
78 | bb.fatal("System.map-%s does not exist in '%s/boot' nor STAGING_KERNEL_DIR '%s'" % (kernelver, dvar, staging_kernel_dir)) | 78 | bb.fatal("System.map-%s does not exist in '%s/boot' nor STAGING_KERNEL_BUILDDIR '%s'" % (kernelver, dvar, staging_kernel_dir)) |
79 | 79 | ||
80 | cmd = "depmod -n -a -b %s -F %s %s" % (dvar, system_map_file, kernelver_stripped) | 80 | cmd = "depmod -n -a -b %s -F %s %s" % (dvar, system_map_file, kernelver_stripped) |
81 | f = os.popen(cmd, 'r') | 81 | f = os.popen(cmd, 'r') |
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 . => + |
diff --git a/meta/lib/oe/rootfs.py b/meta/lib/oe/rootfs.py index f2891a7043..72d32f7899 100644 --- a/meta/lib/oe/rootfs.py +++ b/meta/lib/oe/rootfs.py | |||
@@ -209,16 +209,17 @@ class Rootfs(object): | |||
209 | 'new', '-v']) | 209 | 'new', '-v']) |
210 | 210 | ||
211 | def _generate_kernel_module_deps(self): | 211 | def _generate_kernel_module_deps(self): |
212 | kernel_abi_ver_file = os.path.join(self.d.getVar('STAGING_KERNEL_BUILDDIR', True), | 212 | kernel_abi_ver_file = oe.path.join(self.d.getVar('STAGING_DIR_TARGET', True), self.d.getVar('datadir', True), "kernel-depmod", |
213 | 'kernel-abiversion') | 213 | 'kernel-abiversion') |
214 | if os.path.exists(kernel_abi_ver_file): | 214 | if not os.path.exists(kernel_abi_ver_file): |
215 | kernel_ver = open(kernel_abi_ver_file).read().strip(' \n') | 215 | bb.fatal("No kernel-abiversion file found (%s), cannot run depmod, aborting" % kernel_abi_ver_file) |
216 | modules_dir = os.path.join(self.image_rootfs, 'lib', 'modules', kernel_ver) | ||
217 | 216 | ||
218 | bb.utils.mkdirhier(modules_dir) | 217 | kernel_ver = open(kernel_abi_ver_file).read().strip(' \n') |
218 | modules_dir = os.path.join(self.image_rootfs, 'lib', 'modules', kernel_ver) | ||
219 | 219 | ||
220 | self._exec_shell_cmd(['depmodwrapper', '-a', '-b', self.image_rootfs, | 220 | bb.utils.mkdirhier(modules_dir) |
221 | kernel_ver]) | 221 | |
222 | self._exec_shell_cmd(['depmodwrapper', '-a', '-b', self.image_rootfs, kernel_ver]) | ||
222 | 223 | ||
223 | """ | 224 | """ |
224 | Create devfs: | 225 | Create devfs: |
diff --git a/meta/recipes-kernel/kmod/depmodwrapper-cross_1.0.bb b/meta/recipes-kernel/kmod/depmodwrapper-cross_1.0.bb index 7533809f27..83a382a2cd 100644 --- a/meta/recipes-kernel/kmod/depmodwrapper-cross_1.0.bb +++ b/meta/recipes-kernel/kmod/depmodwrapper-cross_1.0.bb | |||
@@ -19,21 +19,21 @@ if [ "\$1" != "-a" -o "\$2" != "-b" ]; then | |||
19 | echo "Usage: depmodwrapper -a -b rootfs KERNEL_VERSION" >&2 | 19 | echo "Usage: depmodwrapper -a -b rootfs KERNEL_VERSION" >&2 |
20 | exit 1 | 20 | exit 1 |
21 | fi | 21 | fi |
22 | if [ ! -r ${STAGING_KERNEL_BUILDDIR}/kernel-abiversion ]; then | 22 | if [ ! -r ${STAGING_DIR_TARGET}${datadir}/kernel-depmod/kernel-abiversion ]; then |
23 | echo "Unable to read: ${STAGING_KERNEL_BUILDDIR}/kernel-abiversion" >&2 | 23 | echo "Unable to read: ${STAGING_DIR_TARGET}${datadir}/kernel-depmod/kernel-abiversion" >&2 |
24 | else | 24 | else |
25 | kernelabi=\$(cat ${STAGING_KERNEL_BUILDDIR}/kernel-abiversion) | 25 | kernelabi=\$(cat ${STAGING_DIR_TARGET}${datadir}/kernel-depmod/kernel-abiversion) |
26 | if [ "\$kernelabi" != "\$4" ]; then | 26 | if [ "\$kernelabi" != "\$4" ]; then |
27 | echo "Error: Kernel version \$4 does not match kernel-abiversion (\$kernelabi)" >&2 | 27 | echo "Error: Kernel version \$4 does not match kernel-abiversion (\$kernelabi)" >&2 |
28 | exit 1 | 28 | exit 1 |
29 | fi | 29 | fi |
30 | fi | 30 | fi |
31 | 31 | ||
32 | if [ ! -r ${STAGING_KERNEL_BUILDDIR}/System.map-\$4 ]; then | 32 | if [ ! -r ${STAGING_DIR_TARHET}${datadir}/kernel-depmod/System.map-\$4 ]; then |
33 | echo "Unable to read: ${STAGING_KERNEL_BUILDDIR}/System.map-\$4" >&2 | 33 | echo "Unable to read: ${STAGING_DIR_TARGET}${datadir}/kernel-depmod/System.map-\$4" >&2 |
34 | exec env depmod "\$1" "\$2" "\$3" "\$4" | 34 | exec env depmod "\$1" "\$2" "\$3" "\$4" |
35 | else | 35 | else |
36 | exec env depmod "\$1" "\$2" "\$3" -F "${STAGING_KERNEL_BUILDDIR}/System.map-\$4" "\$4" | 36 | exec env depmod "\$1" "\$2" "\$3" -F "${STAGING_DIR_TARGET}${datadir}/kernel-depmod/System.map-\$4" "\$4" |
37 | fi | 37 | fi |
38 | EOF | 38 | EOF |
39 | chmod +x ${D}${bindir_crossscripts}/depmodwrapper | 39 | chmod +x ${D}${bindir_crossscripts}/depmodwrapper |
diff --git a/meta/recipes-kernel/systemtap/systemtap-uprobes_git.bb b/meta/recipes-kernel/systemtap/systemtap-uprobes_git.bb index 4d2bec4714..758908bff9 100644 --- a/meta/recipes-kernel/systemtap/systemtap-uprobes_git.bb +++ b/meta/recipes-kernel/systemtap/systemtap-uprobes_git.bb | |||
@@ -21,7 +21,7 @@ EXTRA_OEMAKE = "" | |||
21 | # support. Note that staprun expects it in the systemtap/runtime directory, | 21 | # support. Note that staprun expects it in the systemtap/runtime directory, |
22 | # not in /lib/modules. | 22 | # not in /lib/modules. |
23 | do_compile() { | 23 | do_compile() { |
24 | if grep -q "CONFIG_UTRACE=y" ${STAGING_KERNEL_DIR}/.config | 24 | if grep -q "CONFIG_UTRACE=y" ${STAGING_KERNEL_BUILDDIR}/.config |
25 | then | 25 | then |
26 | unset CFLAGS CPPFLAGS CXXFLAGS LDFLAGS CC LD CPP | 26 | unset CFLAGS CPPFLAGS CXXFLAGS LDFLAGS CC LD CPP |
27 | oe_runmake CC="${KERNEL_CC}" LD="${KERNEL_LD}" \ | 27 | oe_runmake CC="${KERNEL_CC}" LD="${KERNEL_LD}" \ |