diff options
author | Alexander Kanavin <alex.kanavin@gmail.com> | 2020-06-08 09:46:59 +0200 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2020-06-09 13:14:01 +0100 |
commit | fdee2d49fc9139ff7e0b5a8b1b6476224540ca57 (patch) | |
tree | ad9a5e330943e43db79d1e8d1e306d098696e89c /meta/recipes-core | |
parent | b70b4c9bbba9cb5f60d9500acc9ed97112c5a411 (diff) | |
download | poky-fdee2d49fc9139ff7e0b5a8b1b6476224540ca57.tar.gz |
build-sysroots: add sysroot paths with native binaries to PATH
staging_populate_sysroot_dir() collects postinsts from the sysroot
and executes them. These postinsts, in turn, may call binaries that
are only available from the sysroot. This works fine with recipe-specific
sysroots, as all necessary paths are already in PATH, but breaks down
in this recipe which imitates the old global sysroot way but doesn't adjust
the PATH to include the binary paths from global sysroot.
To reproduce the failure:
$ bitbake docbook-xml-dtd4-native
$ bitbake -c build_native_sysroot build-sysroots
...
Exception: subprocess.CalledProcessError: Command '/home/akanavin/build/tmp/sysroots/x86_64/usr/bin/postinst-docbook-xml-dtd4-native-xmlcatalog' returned non-zero exit status 127.
Subprocess output:
/home/akanavin/build/tmp/sysroots/x86_64/usr/bin/postinst-docbook-xml-dtd4-native-xmlcatalog: 5: /home/akanavin/build/tmp/sysroots/x86_64/usr/bin/postinst-docbook-xml-dtd4-native-xmlcatalog: xmlcatalog: not found
/home/akanavin/build/tmp/sysroots/x86_64/usr/bin/postinst-docbook-xml-dtd4-native-xmlcatalog: 8: /home/akanavin/build/tmp/sysroots/x86_64/usr/bin/postinst-docbook-xml-dtd4-native-xmlcatalog: xmlcatalog: not found
(From OE-Core rev: 6b5f7bda4204d45cd29670cefcd53dc5da031095)
Signed-off-by: Alexander Kanavin <alex.kanavin@gmail.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/recipes-core')
-rw-r--r-- | meta/recipes-core/meta/build-sysroots.bb | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/meta/recipes-core/meta/build-sysroots.bb b/meta/recipes-core/meta/build-sysroots.bb index 7a712e2f38..ad22a75eb2 100644 --- a/meta/recipes-core/meta/build-sysroots.bb +++ b/meta/recipes-core/meta/build-sysroots.bb | |||
@@ -20,6 +20,8 @@ deltask populate_sysroot | |||
20 | python do_build_native_sysroot () { | 20 | python do_build_native_sysroot () { |
21 | targetsysroot = d.getVar("STANDALONE_SYSROOT") | 21 | targetsysroot = d.getVar("STANDALONE_SYSROOT") |
22 | nativesysroot = d.getVar("STANDALONE_SYSROOT_NATIVE") | 22 | nativesysroot = d.getVar("STANDALONE_SYSROOT_NATIVE") |
23 | import os | ||
24 | os.environ['PATH'] = "%s/bin:%s/usr/bin:%s" % (nativesysroot, nativesysroot, os.environ['PATH']) | ||
23 | staging_populate_sysroot_dir(targetsysroot, nativesysroot, True, d) | 25 | staging_populate_sysroot_dir(targetsysroot, nativesysroot, True, d) |
24 | } | 26 | } |
25 | do_build_native_sysroot[cleandirs] = "${STANDALONE_SYSROOT_NATIVE}" | 27 | do_build_native_sysroot[cleandirs] = "${STANDALONE_SYSROOT_NATIVE}" |
@@ -29,6 +31,8 @@ addtask do_build_native_sysroot before do_build | |||
29 | python do_build_target_sysroot () { | 31 | python do_build_target_sysroot () { |
30 | targetsysroot = d.getVar("STANDALONE_SYSROOT") | 32 | targetsysroot = d.getVar("STANDALONE_SYSROOT") |
31 | nativesysroot = d.getVar("STANDALONE_SYSROOT_NATIVE") | 33 | nativesysroot = d.getVar("STANDALONE_SYSROOT_NATIVE") |
34 | import os | ||
35 | os.environ['PATH'] = "%s/bin:%s/usr/bin:%s" % (nativesysroot, nativesysroot, os.environ['PATH']) | ||
32 | staging_populate_sysroot_dir(targetsysroot, nativesysroot, False, d) | 36 | staging_populate_sysroot_dir(targetsysroot, nativesysroot, False, d) |
33 | } | 37 | } |
34 | do_build_target_sysroot[cleandirs] = "${STANDALONE_SYSROOT}" | 38 | do_build_target_sysroot[cleandirs] = "${STANDALONE_SYSROOT}" |