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/lib | |
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/lib')
-rw-r--r-- | meta/lib/oe/rootfs.py | 15 |
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: |