-
Notifications
You must be signed in to change notification settings - Fork 13.9k
Apple: Fix direct linking with +verbatim #132394
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
This PR modifies cc @jieyouxu |
//@ ignore-apple | ||
// Reason: linking fails due to the unusual ".ext" staticlib name. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This ignore was added in #101806, and only later rationalized when converting to rmake.
The changes itself looks reasonable to me, but I don't know the implications of |
This comment was marked as outdated.
This comment was marked as outdated.
…try> Apple: Fix direct linking with +verbatim Linking with `+verbatim` somewhat worked before, but only when the library was included as part of an rlib. Fixes rust-lang#132264. CC `@petrochenkov,` since you've worked on `+verbatim` before. `@rustbot` label O-apple A-linkage try-job: aarch64-apple try-job: x86_64-apple-2
This comment was marked as outdated.
This comment was marked as outdated.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment was marked as resolved.
This comment was marked as resolved.
Linking with +verbatim somewhat worked before, but only when the library was included as part of an rlib.
3cb4340
to
71a8af9
Compare
Fixed the tidy error now |
@bors try |
…try> Apple: Fix direct linking with +verbatim Linking with `+verbatim` somewhat worked before, but only when the library was included as part of an rlib. Fixes rust-lang#132264. CC `@petrochenkov,` since you've worked on `+verbatim` before. `@rustbot` label O-apple A-linkage try-job: aarch64-apple try-job: x86_64-apple-2
☀️ Try build successful - checks-actions |
Try job passed, feel free to r=me if petrochenkov has no further concerns. |
Please, don't merge this yet, I'll look. |
I'm tentatively against doing this, otherwise I'd merge this quickly. |
There's no haste from my side, I don't need this myself. |
I think we should either
I'll close this PR to maintain the status quo for now, but I'm also trying to make a step towards the second alternative in #138273 by making the search directory list for native libs consistent between rustc and linker. |
metadata: Ignore sysroot when doing the manual native lib search in rustc This is the opposite alternative to rust-lang#138170 and another way to make native library search consistent between rustc and linker. This way the directory list searched by rustc is still a prefix of the directory list considered by linker, but it's a shorter prefix than in rust-lang#138170. We can include the sysroot directories into rustc's search again later if the issues with rust-lang#138170 are resolved, it will be a backward compatible change. This may break some code doing weird things on unstable rustc, or tier 2-3 targets, like bundling `libunwind.a` or sanitizers into something. Note that this doesn't affect shipped `libc.a`, because it lives in `self-contained` directories in sysroot, and `self-contained` sysroot is already not included into the rustc's search. All libunwind and sanitizer libs should be moved to `self-contained` sysroot too eventually. With the consistent search directory list between rustc and linker we can make rustc own the native library search (at least for static libs) and use linker search only as a fallback (like in rust-lang#123436). This will allow addressing issues like rust-lang#132394 once and for all on all targets. r? `@bjorn3`
metadata: Ignore sysroot when doing the manual native lib search in rustc This is the opposite alternative to rust-lang#138170 and another way to make native library search consistent between rustc and linker. This way the directory list searched by rustc is still a prefix of the directory list considered by linker, but it's a shorter prefix than in rust-lang#138170. We can include the sysroot directories into rustc's search again later if the issues with rust-lang#138170 are resolved, it will be a backward compatible change. This may break some code doing weird things on unstable rustc, or tier 2-3 targets, like bundling `libunwind.a` or sanitizers into something. Note that this doesn't affect shipped `libc.a`, because it lives in `self-contained` directories in sysroot, and `self-contained` sysroot is already not included into the rustc's search. All libunwind and sanitizer libs should be moved to `self-contained` sysroot too eventually. With the consistent search directory list between rustc and linker we can make rustc own the native library search (at least for static libs) and use linker search only as a fallback (like in rust-lang#123436). This will allow addressing issues like rust-lang#132394 once and for all on all targets. r? ``@bjorn3``
Rollup merge of rust-lang#138273 - petrochenkov:nonatroot, r=bjorn3 metadata: Ignore sysroot when doing the manual native lib search in rustc This is the opposite alternative to rust-lang#138170 and another way to make native library search consistent between rustc and linker. This way the directory list searched by rustc is still a prefix of the directory list considered by linker, but it's a shorter prefix than in rust-lang#138170. We can include the sysroot directories into rustc's search again later if the issues with rust-lang#138170 are resolved, it will be a backward compatible change. This may break some code doing weird things on unstable rustc, or tier 2-3 targets, like bundling `libunwind.a` or sanitizers into something. Note that this doesn't affect shipped `libc.a`, because it lives in `self-contained` directories in sysroot, and `self-contained` sysroot is already not included into the rustc's search. All libunwind and sanitizer libs should be moved to `self-contained` sysroot too eventually. With the consistent search directory list between rustc and linker we can make rustc own the native library search (at least for static libs) and use linker search only as a fallback (like in rust-lang#123436). This will allow addressing issues like rust-lang#132394 once and for all on all targets. r? ``@bjorn3``
Done in #138753. |
Linking with
+verbatim
somewhat worked before, but only when the library was included as part of an rlib.Fixes #132264.
CC @petrochenkov, since you've worked on
+verbatim
before.@rustbot label O-apple A-linkage
try-job: aarch64-apple
try-job: x86_64-apple-2