diff options
| author | Randy Witt <randy.e.witt@linux.intel.com> | 2016-02-24 15:27:42 -0800 |
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2016-02-28 11:33:03 +0000 |
| commit | 9ca8f30098a2d86d6faa392c97339a87dbc537df (patch) | |
| tree | 9720789b9a0cf775a8342a11bc4d872020e86825 | |
| parent | 07dc765cfe0b87aa200673a71d7c5651dc988621 (diff) | |
| download | poky-9ca8f30098a2d86d6faa392c97339a87dbc537df.tar.gz | |
populate_sdk_ext: Add images to SDK_INSTALL_TARGETS
When running ext-sdk-prepare.py during sdk installation a check is done to
make sure no tasks would run that aren't provided by the "leaf" recipes
specified in SDK_INSTALL_TARGETS.
However sometimes an image recipe can cause other images to be created
such as an initramfs. So make sure those additional images are
recognized by ext-sdk-prepare.py and don't flag an error.
(From OE-Core rev: 6eb75df1000ce1905e83840204adb614659d25cf)
Signed-off-by: Randy Witt <randy.e.witt@linux.intel.com>
Signed-off-by: Ross Burton <ross.burton@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
| -rw-r--r-- | meta/classes/populate_sdk_ext.bbclass | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/meta/classes/populate_sdk_ext.bbclass b/meta/classes/populate_sdk_ext.bbclass index a6badb84c6..9e2fc61699 100644 --- a/meta/classes/populate_sdk_ext.bbclass +++ b/meta/classes/populate_sdk_ext.bbclass | |||
| @@ -40,12 +40,17 @@ def get_sdk_install_targets(d): | |||
| 40 | if d.getVar('SDK_EXT_TYPE', True) != 'minimal': | 40 | if d.getVar('SDK_EXT_TYPE', True) != 'minimal': |
| 41 | sdk_install_targets = d.getVar('SDK_TARGETS', True) | 41 | sdk_install_targets = d.getVar('SDK_TARGETS', True) |
| 42 | 42 | ||
| 43 | depd = d.getVar('BB_TASKDEPDATA', False) | ||
| 44 | for v in depd.itervalues(): | ||
| 45 | if v[1] == 'do_image_complete': | ||
| 46 | if v[0] not in sdk_install_targets: | ||
| 47 | sdk_install_targets += ' {}'.format(v[0]) | ||
| 48 | |||
| 43 | if d.getVar('SDK_INCLUDE_PKGDATA', True) == '1': | 49 | if d.getVar('SDK_INCLUDE_PKGDATA', True) == '1': |
| 44 | sdk_install_targets += ' meta-world-pkgdata:do_allpackagedata' | 50 | sdk_install_targets += ' meta-world-pkgdata:do_allpackagedata' |
| 45 | 51 | ||
| 46 | return sdk_install_targets | 52 | return sdk_install_targets |
| 47 | 53 | ||
| 48 | SDK_INSTALL_TARGETS = "${@get_sdk_install_targets(d)}" | ||
| 49 | OE_INIT_ENV_SCRIPT ?= "oe-init-build-env" | 54 | OE_INIT_ENV_SCRIPT ?= "oe-init-build-env" |
| 50 | 55 | ||
| 51 | # The files from COREBASE that you want preserved in the COREBASE copied | 56 | # The files from COREBASE that you want preserved in the COREBASE copied |
| @@ -344,12 +349,15 @@ SDK_POST_INSTALL_COMMAND_task-populate-sdk-ext = "${sdk_ext_postinst}" | |||
| 344 | 349 | ||
| 345 | SDK_POSTPROCESS_COMMAND_prepend_task-populate-sdk-ext = "copy_buildsystem; install_tools; " | 350 | SDK_POSTPROCESS_COMMAND_prepend_task-populate-sdk-ext = "copy_buildsystem; install_tools; " |
| 346 | 351 | ||
| 352 | SDK_INSTALL_TARGETS = "" | ||
| 347 | fakeroot python do_populate_sdk_ext() { | 353 | fakeroot python do_populate_sdk_ext() { |
| 348 | # FIXME hopefully we can remove this restriction at some point, but uninative | 354 | # FIXME hopefully we can remove this restriction at some point, but uninative |
| 349 | # currently forces this upon us | 355 | # currently forces this upon us |
| 350 | if d.getVar('SDK_ARCH', True) != d.getVar('BUILD_ARCH', True): | 356 | if d.getVar('SDK_ARCH', True) != d.getVar('BUILD_ARCH', True): |
| 351 | bb.fatal('The extensible SDK can currently only be built for the same architecture as the machine being built on - SDK_ARCH is set to %s (likely via setting SDKMACHINE) which is different from the architecture of the build machine (%s). Unable to continue.' % (d.getVar('SDK_ARCH', True), d.getVar('BUILD_ARCH', True))) | 357 | bb.fatal('The extensible SDK can currently only be built for the same architecture as the machine being built on - SDK_ARCH is set to %s (likely via setting SDKMACHINE) which is different from the architecture of the build machine (%s). Unable to continue.' % (d.getVar('SDK_ARCH', True), d.getVar('BUILD_ARCH', True))) |
| 352 | 358 | ||
| 359 | d.setVar('SDK_INSTALL_TARGETS', get_sdk_install_targets(d)) | ||
| 360 | |||
| 353 | bb.build.exec_func("do_populate_sdk", d) | 361 | bb.build.exec_func("do_populate_sdk", d) |
| 354 | } | 362 | } |
| 355 | 363 | ||
