diff options
| author | João Henrique Ferreira de Freitas <joaohf@gmail.com> | 2014-04-04 23:14:11 -0300 | 
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2014-05-13 19:35:11 +0100 | 
| commit | d6900a5fe7670cb4514969d60e0ca65372121c87 (patch) | |
| tree | 19ef7a18d67f4d1f53cd12c45810ef61965e9b9e /scripts/lib/mic/plugins/source/rootfs.py | |
| parent | bc10da01f35ade81b68533ef5015a6def7c88d7c (diff) | |
| download | poky-d6900a5fe7670cb4514969d60e0ca65372121c87.tar.gz | |
wic: Extend indirect string connection to support image names and rootfs
The wic command-line param --rootfs-dir gets extended to support
multiple directories and image names. Each '--rootfs-dir' could be
connected using a special string. This special string is a image
name which gets expanded by bitbake to get 'IMAGE_ROOTFS' or
a rootfs-dir path pointing to rootfs directory. Like this:
  wic create ... --rootfs-dir rootfs1=core-image-minimal \
    --rootfs-dir rootfs2=core-image-minimal-dev
.wks:
  part / --source rootfs --rootfs-dir="rootfs1" --ondisk sda --fstype=ext3 \
    --label primary --align 1024
  part /standby --source rootfs --rootfs-dir="rootfs2" \
    --ondisk sda --fstype=ext3 --label secondary --align 1024
(From OE-Core rev: 58417093d7ce83c8a2f683a356fddc23aaee5e8e)
Signed-off-by: João Henrique Ferreira de Freitas <joaohf@gmail.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'scripts/lib/mic/plugins/source/rootfs.py')
| -rw-r--r-- | scripts/lib/mic/plugins/source/rootfs.py | 27 | 
1 files changed, 24 insertions, 3 deletions
diff --git a/scripts/lib/mic/plugins/source/rootfs.py b/scripts/lib/mic/plugins/source/rootfs.py index 75999e03d2..a4d4547318 100644 --- a/scripts/lib/mic/plugins/source/rootfs.py +++ b/scripts/lib/mic/plugins/source/rootfs.py  | |||
| @@ -43,6 +43,25 @@ from mic.imager.direct import DirectImageCreator | |||
| 43 | class RootfsPlugin(SourcePlugin): | 43 | class RootfsPlugin(SourcePlugin): | 
| 44 | name = 'rootfs' | 44 | name = 'rootfs' | 
| 45 | 45 | ||
| 46 | @staticmethod | ||
| 47 | def __get_rootfs_dir(rootfs_dir): | ||
| 48 | if os.path.isdir(rootfs_dir): | ||
| 49 | return rootfs_dir | ||
| 50 | |||
| 51 | bitbake_env_lines = find_bitbake_env_lines(rootfs_dir) | ||
| 52 | if not bitbake_env_lines: | ||
| 53 | msg = "Couldn't get bitbake environment, exiting." | ||
| 54 | msger.error(msg) | ||
| 55 | |||
| 56 | image_rootfs_dir = find_artifact(bitbake_env_lines, "IMAGE_ROOTFS") | ||
| 57 | if not os.path.isdir(image_rootfs_dir): | ||
| 58 | msg = "No valid artifact IMAGE_ROOTFS from image named" | ||
| 59 | msg += " %s has been found at %s, exiting.\n" % \ | ||
| 60 | (rootfs_dir, image_rootfs_dir) | ||
| 61 | msger.error(msg) | ||
| 62 | |||
| 63 | return image_rootfs_dir | ||
| 64 | |||
| 46 | @classmethod | 65 | @classmethod | 
| 47 | def do_prepare_partition(self, part, cr, cr_workdir, oe_builddir, bootimg_dir, | 66 | def do_prepare_partition(self, part, cr, cr_workdir, oe_builddir, bootimg_dir, | 
| 48 | kernel_dir, krootfs_dir, native_sysroot): | 67 | kernel_dir, krootfs_dir, native_sysroot): | 
| @@ -59,13 +78,15 @@ class RootfsPlugin(SourcePlugin): | |||
| 59 | else: | 78 | else: | 
| 60 | if part.rootfs in krootfs_dir: | 79 | if part.rootfs in krootfs_dir: | 
| 61 | rootfs_dir = krootfs_dir[part.rootfs] | 80 | rootfs_dir = krootfs_dir[part.rootfs] | 
| 62 | elif os.path.isdir(part.rootfs): | 81 | elif part.rootfs: | 
| 63 | rootfs_dir = part.rootfs | 82 | rootfs_dir = part.rootfs | 
| 64 | else: | 83 | else: | 
| 65 | msg = "Couldn't find --rootfs-dir=%s connection" | 84 | msg = "Couldn't find --rootfs-dir=%s connection" | 
| 66 | msg += " or it is not a valid path, exiting" | 85 | msg += " or it is not a valid path, exiting" | 
| 67 | msger.error(msg % part.rootfs) | 86 | msger.error(msg % part.rootfs) | 
| 68 | 87 | ||
| 69 | part.set_rootfs(rootfs_dir) | 88 | real_rootfs_dir = self.__get_rootfs_dir(rootfs_dir) | 
| 70 | part.prepare_rootfs(cr_workdir, oe_builddir, rootfs_dir, native_sysroot) | 89 | |
| 90 | part.set_rootfs(real_rootfs_dir) | ||
| 91 | part.prepare_rootfs(cr_workdir, oe_builddir, real_rootfs_dir, native_sysroot) | ||
| 71 | 92 | ||
