summaryrefslogtreecommitdiffstats
path: root/scripts
diff options
context:
space:
mode:
authorJoão Henrique Ferreira de Freitas <joaohf@gmail.com>2014-04-04 23:14:11 -0300
committerRichard Purdie <richard.purdie@linuxfoundation.org>2014-05-13 19:35:11 +0100
commitd6900a5fe7670cb4514969d60e0ca65372121c87 (patch)
tree19ef7a18d67f4d1f53cd12c45810ef61965e9b9e /scripts
parentbc10da01f35ade81b68533ef5015a6def7c88d7c (diff)
downloadpoky-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')
-rw-r--r--scripts/lib/mic/plugins/source/rootfs.py27
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
43class RootfsPlugin(SourcePlugin): 43class 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