From 327bfd6b829fbac6ff9a050745f4e10b48c79ac5 Mon Sep 17 00:00:00 2001 From: Brad Bishop Date: Mon, 29 Feb 2016 10:21:51 -0500 Subject: Don't inherit image-overlay by default This attempts to address a race condition in the build where we attempt to build a complete flash image before all the sub-images are available (specifically the initramfs image). Any classes in IMAGE_CLASSES are inherited by all image recipes, including the initramfs image. OE-Core's live/hddimg recipes address this by pulling in the class configuration in recipe scope, rather than global scope. Copy that behavior here. --- meta-phosphor/classes/image-overlay.bbclass | 8 +++++--- meta-phosphor/classes/obmc-phosphor-image.bbclass | 7 +++++++ 2 files changed, 12 insertions(+), 3 deletions(-) (limited to 'meta-phosphor/classes') diff --git a/meta-phosphor/classes/image-overlay.bbclass b/meta-phosphor/classes/image-overlay.bbclass index 8997aaea1..71768a628 100644 --- a/meta-phosphor/classes/image-overlay.bbclass +++ b/meta-phosphor/classes/image-overlay.bbclass @@ -1,3 +1,5 @@ +PACKAGES = " " +EXCLUDE_FROM_WORLD = "1" INITRD_IMAGE ?= "core-image-minimal-initramfs" INITRD ?= "${DEPLOY_DIR_IMAGE}/${INITRD_IMAGE}-${MACHINE}.cpio.${INITRD_CTYPE}${uboot}" @@ -5,9 +7,9 @@ INITRD ?= "${DEPLOY_DIR_IMAGE}/${INITRD_IMAGE}-${MACHINE}.cpio.${INITRD_CTYPE}${ IMAGE_BASETYPE ?= "squashfs-xz" OVERLAY_BASETYPE ?= "jffs2" -IMAGE_TYPES_${PN} += "${IMAGE_BASETYPE}" +IMAGE_TYPES += "overlay" -IMAGE_TYPEDEP_overlay = "${IMAGE_BASETYPE} ${OVERLAY_BASETYPE}" +IMAGE_TYPEDEP_overlay = "${IMAGE_BASETYPE}" IMAGE_TYPES_MASKED += "overlay" ROOTFS ?= "${DEPLOY_DIR_IMAGE}/${IMAGE_BASENAME}-${MACHINE}.${IMAGE_BASETYPE}" @@ -15,4 +17,4 @@ ROOTFS ?= "${DEPLOY_DIR_IMAGE}/${IMAGE_BASENAME}-${MACHINE}.${IMAGE_BASETYPE}" do_generate_flash[depends] += "${INITRD_IMAGE}:do_rootfs" do_generate_flash[depends] += "${PN}:do_rootfs" -addtask generate_flash after do_rootfs before do_build +addtask generate_flash before do_build diff --git a/meta-phosphor/classes/obmc-phosphor-image.bbclass b/meta-phosphor/classes/obmc-phosphor-image.bbclass index 811bbd3da..0d4a0d06d 100644 --- a/meta-phosphor/classes/obmc-phosphor-image.bbclass +++ b/meta-phosphor/classes/obmc-phosphor-image.bbclass @@ -42,3 +42,10 @@ IMAGE_INSTALL += " \ i2c-tools \ screen \ " + +def build_overlay(d): + if bb.utils.contains("IMAGE_FSTYPES", "overlay", "overlay", "0", d) != "0": + return "image-overlay" + return "" + +inherit ${@build_overlay(d)} -- cgit v1.2.1