diff options
| -rw-r--r-- | meta/classes/rust-common.bbclass | 5 | ||||
| -rw-r--r-- | meta/files/rust-ccld-wrapper.c | 29 |
2 files changed, 34 insertions, 0 deletions
diff --git a/meta/classes/rust-common.bbclass b/meta/classes/rust-common.bbclass index e1bc0193c3..a8803d61b6 100644 --- a/meta/classes/rust-common.bbclass +++ b/meta/classes/rust-common.bbclass | |||
| @@ -169,6 +169,11 @@ do_rust_create_wrappers () { | |||
| 169 | # Yocto Target / Rust Target archiver | 169 | # Yocto Target / Rust Target archiver |
| 170 | create_wrapper "${RUST_TARGET_AR}" "${WRAPPER_TARGET_AR}" | 170 | create_wrapper "${RUST_TARGET_AR}" "${WRAPPER_TARGET_AR}" |
| 171 | 171 | ||
| 172 | # Need to filter out LD_LIBRARY_PATH from the linker without using shell | ||
| 173 | mv ${RUST_BUILD_CCLD} ${RUST_BUILD_CCLD}.real | ||
| 174 | ${BUILD_CC} ${COREBASE}/meta/files/rust-ccld-wrapper.c -o ${RUST_BUILD_CCLD} | ||
| 175 | mv ${RUST_TARGET_CCLD} ${RUST_TARGET_CCLD}.real | ||
| 176 | ${BUILD_CC} ${COREBASE}/meta/files/rust-ccld-wrapper.c -o ${RUST_TARGET_CCLD} | ||
| 172 | } | 177 | } |
| 173 | 178 | ||
| 174 | addtask rust_create_wrappers before do_configure after do_patch | 179 | addtask rust_create_wrappers before do_configure after do_patch |
diff --git a/meta/files/rust-ccld-wrapper.c b/meta/files/rust-ccld-wrapper.c new file mode 100644 index 0000000000..6bc9958b90 --- /dev/null +++ b/meta/files/rust-ccld-wrapper.c | |||
| @@ -0,0 +1,29 @@ | |||
| 1 | /* | ||
| 2 | * Copyright 2021 Richard Purdie | ||
| 3 | * | ||
| 4 | * SPDX-License-Identifier: GPL-2.0-only | ||
| 5 | */ | ||
| 6 | |||
| 7 | #include <errno.h> | ||
| 8 | #include <stdio.h> | ||
| 9 | #include <stdlib.h> | ||
| 10 | #include <string.h> | ||
| 11 | #include <unistd.h> | ||
| 12 | |||
| 13 | /* | ||
| 14 | * Run the original script (argv[0] + ".real") with LD_LIBRARY_PATH unset | ||
| 15 | * This avoids issues where cargo is running a wrapper script using /bin/sh from the host | ||
| 16 | * which links to something which has an incompatible version in in recipe-sysroot-native | ||
| 17 | * such as libtinfo on centos 7. | ||
| 18 | */ | ||
| 19 | |||
| 20 | int main(int argc, char* argv[]) { | ||
| 21 | char *real = malloc(strlen(argv[0] + 5)); | ||
| 22 | strcpy(real, argv[0]); | ||
| 23 | strcpy(real + strlen(argv[0]), ".real"); | ||
| 24 | putenv("LD_LIBRARY_PATH="); | ||
| 25 | if(execv(real, argv) == -1) { | ||
| 26 | printf("Wrapper failed to execute, error: %s\n", strerror(errno)); | ||
| 27 | return -1; | ||
| 28 | } | ||
| 29 | } | ||
