-
Notifications
You must be signed in to change notification settings - Fork 13.4k
Add -Z hint-mostly-unused
to tell rustc that most of a crate will go unused
#135656
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
base: master
Are you sure you want to change the base?
Conversation
rustbot has assigned @GuillaumeGomez. Use |
Some changes occurred to MIR optimizations cc @rust-lang/wg-mir-opt |
r? compiler |
This should be added as an unstable option first? |
This comment was marked as outdated.
This comment was marked as outdated.
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
I see. I suppose that makes sense, though it brings these thoughts to mind:
As a result, I am curious if the rest of T-compiler believes changing the behavior with respect to Perhaps this should land with a test that demonstrates that it respects |
( I'm also kinda curious if we should adjust how we handle cross-crate inlining by default, tbh. ) |
You may have missed it Jubilee, so hop on to https://rust-lang.zulipchat.com/#narrow/stream/233931-xxx/topic/Add.20.60-C.20hint-mostly-unused.60.20option.20compiler-team.23829 to ask your cool questions and comments :) |
4d1b2cb
to
e96e15f
Compare
r? compiler |
Discussed in T-compiler triage on Zulip. MCP#829 still needs to be seconded and there seems to be still a few open design questions. Also, do we have some numbers about the real world impact (both positive and negative)?. Maybe it makes sense to nominate again once design and scope are clearer. By the way @saethlin do you think you have some capacity to dedicate here? @rustbot label -I-compiler-nominated |
d3f3a68
to
0e58964
Compare
-C hint-mostly-unused
to tell rustc that most of a crate will go unused-Z hint-mostly-unused
to tell rustc that most of a crate will go unused
…o unused This hint allows the compiler to optimize its operation based on this assumption, in order to compile faster. This is a hint, and does not guarantee any particular behavior. This option can substantially speed up compilation if applied to a large dependency where the majority of the dependency does not get used. This flag may slow down compilation in other cases. Currently, this option makes the compiler defer as much code generation as possible from functions in the crate, until later crates invoke those functions. Functions that never get invoked will never have code generated for them. For instance, if a crate provides thousands of functions, but only a few of them will get called, this flag will result in the compiler only doing code generation for the called functions. (This uses the same mechanisms as cross-crate inlining of functions.) This does not affect `extern` functions, or functions marked as `#[inline(never)]`. Some performance numbers, based on a crate with many dependencies having just *one* large dependency set to `-Z hint-mostly-unused` (using Cargo's `profile-rustflags` option): A release build went from 4m07s to 2m04s. A non-release build went from 2m26s to 1m28s.
0e58964
to
1b23b64
Compare
Based on discussion about this at RustWeek, it sounded like this proposal had given the impression of wanting to rush stabilization, rather than being an unstable option to test and gather experience reports. Based on that discussion, I've reworked this PR and opened a new MCP to make it explicitly clear that this is an unstable option intended for a call for testing and for plumbing as a nightly Cargo option. I've updated the implementation of this to be a I've also rebased it, re-tested it, and re-benchmarked it. |
This hint allows the compiler to optimize its operation based on this assumption, in order to compile faster. This is a hint, and does not guarantee any particular behavior.
This option can substantially speed up compilation if applied to a large dependency where the majority of the dependency does not get used. This flag may slow down compilation in other cases.
Currently, this option makes the compiler defer as much code generation as possible from functions in the crate, until later crates invoke those functions. Functions that never get invoked will never have code generated for them. For instance, if a crate provides thousands of functions, but only a few of them will get called, this flag will result in the compiler only doing code generation for the called functions. (This uses the same mechanisms as cross-crate inlining of functions.) This does not affect
extern
functions, or functions marked as#[inline(never)]
.This option has already existed in nightly as
-Zcross-crate-inline-threshold=always
for some time, and has gotten testing in that form. However, this option is still unstable, to give an opportunity for wider testing in this form.Some performance numbers, based on a crate with many dependencies having just one large dependency set to
-Z hint-mostly-unused
(using Cargo'sprofile-rustflags
option):A release build went from 4m07s to 2m04s.
A non-release build went from 2m26s to 1m28s.