diff options
| author | Richard Purdie <richard.purdie@linuxfoundation.org> | 2022-08-08 15:33:41 +0100 |
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2022-08-09 22:42:04 +0100 |
| commit | 7275846f45db90bdb35c75eec83e7e4c62f8ad0d (patch) | |
| tree | ae2d992c4b7f84f4b07d473790aee72592d74266 /meta/recipes-devtools | |
| parent | e53b3008b30f45cf8ba12ad3547109aefbdd88ae (diff) | |
| download | poky-7275846f45db90bdb35c75eec83e7e4c62f8ad0d.tar.gz | |
cargo: Work around host system library conflicts
cargo ends up running target-rust-ccld with LD_LIBRARY_PATH set to libdir but not
base_libdir which breaks the SDK. You see errors like:
/bin/sh: error while loading shared libraries: libncurses.so.5: cannot open shared object file: No such file or directory
On such a system, this would fail:
LD_LIBRARY_PATH="<path>/testimage-sdk/sysroots/x86_64-pokysdk-linux/usr/lib" cargo build
but this would work:
LD_LIBRARY_PATH="<path>/testimage-sdk/sysroots/x86_64-pokysdk-linux/usr/lib:<path>/testimage-sdk/sysroots/x86_64-pokysdk-linux/lib" cargo build
so wrap cargo with both paths in LD_LIBRARY_PATH.
The error depends on the versions of the host system, it reproduced on tumbleweed-ty-3.
(From OE-Core rev: 388e7cac9f90e79ce8c3c1683d8ee0f4df1bc907)
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/recipes-devtools')
| -rw-r--r-- | meta/recipes-devtools/cargo/cargo.inc | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/meta/recipes-devtools/cargo/cargo.inc b/meta/recipes-devtools/cargo/cargo.inc index e34554a9d7..636e9c4fe5 100644 --- a/meta/recipes-devtools/cargo/cargo.inc +++ b/meta/recipes-devtools/cargo/cargo.inc | |||
| @@ -43,6 +43,14 @@ do_install () { | |||
| 43 | install -m 755 "${B}/target/${CARGO_TARGET_SUBDIR}/cargo" "${D}${bindir}" | 43 | install -m 755 "${B}/target/${CARGO_TARGET_SUBDIR}/cargo" "${D}${bindir}" |
| 44 | } | 44 | } |
| 45 | 45 | ||
| 46 | do_install:append:class-nativesdk() { | ||
| 47 | # To quote the cargo docs, "Cargo also sets the dynamic library path when compiling | ||
| 48 | # and running binaries with commands like `cargo run` and `cargo test`". Sadly it | ||
| 49 | # sets to libdir but not base_libdir leading to symbol mismatches depending on the | ||
| 50 | # host OS. Fully set LD_LIBRARY_PATH to contain both to avoid this. | ||
| 51 | create_wrapper ${D}/${bindir}/cargo LD_LIBRARY_PATH=${libdir}:${base_libdir} | ||
| 52 | } | ||
| 53 | |||
| 46 | # Disabled due to incompatibility with libgit2 0.28.x (https://github.com/rust-lang/git2-rs/issues/458, https://bugs.gentoo.org/707746#c1) | 54 | # Disabled due to incompatibility with libgit2 0.28.x (https://github.com/rust-lang/git2-rs/issues/458, https://bugs.gentoo.org/707746#c1) |
| 47 | # as shipped by Yocto Dunfell. | 55 | # as shipped by Yocto Dunfell. |
| 48 | # According to https://github.com/rust-lang/git2-rs/issues/458#issuecomment-522567539, there are no compatibility guarantees between | 56 | # According to https://github.com/rust-lang/git2-rs/issues/458#issuecomment-522567539, there are no compatibility guarantees between |
