diff options
Diffstat (limited to 'scripts')
| -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  class RootfsPlugin(SourcePlugin):      name = 'rootfs' +    @staticmethod +    def __get_rootfs_dir(rootfs_dir): +        if os.path.isdir(rootfs_dir): +            return rootfs_dir + +        bitbake_env_lines = find_bitbake_env_lines(rootfs_dir) +        if not bitbake_env_lines: +            msg = "Couldn't get bitbake environment, exiting." +            msger.error(msg) + +        image_rootfs_dir = find_artifact(bitbake_env_lines, "IMAGE_ROOTFS") +        if not os.path.isdir(image_rootfs_dir): +            msg = "No valid artifact IMAGE_ROOTFS from image named" +            msg += " %s has been found at %s, exiting.\n" % \ +                (rootfs_dir, image_rootfs_dir) +            msger.error(msg) + +        return image_rootfs_dir +      @classmethod      def do_prepare_partition(self, part, cr, cr_workdir, oe_builddir, bootimg_dir,                               kernel_dir, krootfs_dir, native_sysroot): @@ -59,13 +78,15 @@ class RootfsPlugin(SourcePlugin):          else:              if part.rootfs in krootfs_dir:                  rootfs_dir = krootfs_dir[part.rootfs] -            elif os.path.isdir(part.rootfs): +            elif part.rootfs:                  rootfs_dir = part.rootfs              else:                  msg = "Couldn't find --rootfs-dir=%s connection"                  msg += " or it is not a valid path, exiting"                  msger.error(msg % part.rootfs) -        part.set_rootfs(rootfs_dir) -        part.prepare_rootfs(cr_workdir, oe_builddir, rootfs_dir, native_sysroot) +        real_rootfs_dir = self.__get_rootfs_dir(rootfs_dir) + +        part.set_rootfs(real_rootfs_dir) +        part.prepare_rootfs(cr_workdir, oe_builddir, real_rootfs_dir, native_sysroot) | 
