summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRichard Purdie <richard.purdie@linuxfoundation.org>2015-01-20 13:01:29 +0000
committerRichard Purdie <richard.purdie@linuxfoundation.org>2015-01-23 14:32:02 +0000
commit11ef55a93bd2bbd95e203fab3aa237322923ffd9 (patch)
tree69c6dbbe850170ae846e419eb1ef964e6769863e
parent46dba263741692d64801ed425e85362fce999d06 (diff)
downloadpoky-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.bbclass2
-rw-r--r--meta/classes/kernel-module-split.bbclass2
-rw-r--r--meta/classes/kernel.bbclass18
-rw-r--r--meta/lib/oe/rootfs.py15
-rw-r--r--meta/recipes-kernel/kmod/depmodwrapper-cross_1.0.bb12
-rw-r--r--meta/recipes-kernel/systemtap/systemtap-uprobes_git.bb2
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}
235do_install[prefuncs] += "package_get_auto_pr" 240do_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
286sysroot_stage_all () { 289sysroot_stage_all () {
290 sysroot_stage_dir ${D}${datadir}/kernel-depmod ${SYSROOT_DESTDIR}${datadir}/kernel-depmod
287} 291}
288 292
289KERNEL_CONFIG_COMMAND ?= "oe_runmake_call -C ${S} O=${B} oldnoconfig || yes '' | oe_runmake -C ${S} O=${B} oldconfig" 293KERNEL_CONFIG_COMMAND ?= "oe_runmake_call -C ${S} O=${B} oldnoconfig || yes '' | oe_runmake -C ${S} O=${B} oldconfig"
290 294
295PACKAGE_PREPROCESS_FUNCS += "kernel_package_preprocess"
296
297kernel_package_preprocess () {
298 rm -rf ${PKGD}${datadir}/kernel-depmod
299 rmdir ${PKGD}${datadir}
300 rmdir ${PKGD}${exec_prefix}
301}
302
291kernel_do_configure() { 303kernel_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
21fi 21fi
22if [ ! -r ${STAGING_KERNEL_BUILDDIR}/kernel-abiversion ]; then 22if [ ! -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
24else 24else
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
30fi 30fi
31 31
32if [ ! -r ${STAGING_KERNEL_BUILDDIR}/System.map-\$4 ]; then 32if [ ! -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"
35else 35else
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"
37fi 37fi
38EOF 38EOF
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.
23do_compile() { 23do_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}" \