-
Notifications
You must be signed in to change notification settings - Fork 12.8k
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
Add -Zfixed-x18
#124655
Add -Zfixed-x18
#124655
Conversation
Signed-off-by: Alice Ryhl <aliceryhl@google.com>
r? @RalfJung It seems like the right person to review this? The changes look reasonable to me. |
Sorry, I can't do reviews outside the interpreter. |
@apiraino is an MCP needed? |
This comment has been minimized.
This comment has been minimized.
// -Zfixed-x18 | ||
if sess.opts.unstable_opts.fixed_x18 { | ||
if sess.target.arch != "aarch64" { | ||
sess.dcx().emit_fatal(FixedX18InvalidArch { arch: &sess.target.arch }); |
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.
I used emit_fatal
here because with emit_err
, the error is printed twice.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
r? @lqd |
The MCP has completed. |
We probably don't need all the blessed expectations compared to e.g. //@ error-pattern: the `-Zfixed-x18` flag is not supported
//@ dont-check-compiler-stderr but it's fine. bsmith mentioned
Does this need to be done soon after merging this PR, or when the full design is finalized for stabilization? On zulip, you, ralf and bjorn were still discussing details, but it's not clear to me whether these mention possible future work, or an approach you three would rather take in this PR? If it's the former, this looks good enough to land unstably to me, and we can iterate from there if need be. |
cc @NobodyXu on the cc-rs question
I would rather land this PR now as unstable and change it later. |
That seems good to me as well if RfL is fine with the possible churn, as I'd expect you to be the only consumers for this flag for a while. Thanks! |
It should be fine, and this way we can start getting some usage/testing out of it, including in the potential/upcoming Rust for Linux CI job here (where churn should not matter, in the sense that we can change the job at the same time in the same PR to adapt). If we really expect a lot of churn, we could consider avoiding to put it in upstream Linux just yet, but I think it would still be fine. Thanks Rémy! |
…iaskrgr Rollup of 7 pull requests Successful merges: - rust-lang#124655 (Add `-Zfixed-x18`) - rust-lang#125693 (Format all source files in `tests/coverage/`) - rust-lang#125700 (coverage: Avoid overflow when the MC/DC condition limit is exceeded) - rust-lang#125705 (Reintroduce name resolution check for trying to access locals from an inline const) - rust-lang#125708 (tier 3 target policy: clarify the point about producing assembly) - rust-lang#125715 (remove unneeded extern crate in rmake test) - rust-lang#125719 (Extract coverage-specific code out of `compiletest::runtest`) r? `@ghost` `@rustbot` modify labels: rollup
Rollup merge of rust-lang#124655 - Darksonn:fixed-x18, r=lqd,estebank Add `-Zfixed-x18` This PR is a follow-up to rust-lang#124323 that proposes a different implementation. Please read the description of that PR for motivation. See the equivalent flag in [the clang docs](https://clang.llvm.org/docs/ClangCommandLineReference.html#cmdoption-clang-ffixed-x18). MCP: rust-lang/compiler-team#748 Fixes rust-lang#121970 r? rust-lang/compiler
bors sleepy @bors r- |
Do you mean:
it sounds alright to me |
@NobodyXu What landed yesterday is a |
Thanks for explanation, currently nobody requested for that feature, but it might be a feature good to have just in case someone needs it. |
This PR is a follow-up to #124323 that proposes a different implementation. Please read the description of that PR for motivation.
See the equivalent flag in the clang docs.
MCP: rust-lang/compiler-team#748
Fixes #121970
r? rust-lang/compiler