summaryrefslogtreecommitdiffstats
path: root/meta/lib/oe/rootfs.py
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 /meta/lib/oe/rootfs.py
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>
Diffstat (limited to 'meta/lib/oe/rootfs.py')
-rw-r--r--meta/lib/oe/rootfs.py15
1 files changed, 8 insertions, 7 deletions
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: