Revert "store ScalarPair via memset when one side is undef and the other side can be memset" by compiler-errors · Pull Request #137894 · rust-lang/rust (original) (raw)
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 andprivacy statement. We’ll occasionally send you account related emails.
Already on GitHub?Sign in to your account
Conversation9 Commits2 Checks6 Files changed
Conversation
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.Learn more about bidirectional Unicode characters
[ Show hidden characters]({{ revealButtonHref }})
…=saethlin"
This reverts commit a7a6c64, reversing changes made to ebbe638.
rustbot added S-waiting-on-review
Status: Awaiting review from the assignee but also interested parties.
Relevant to the compiler team, which will review and decide on the PR/issue.
labels
compiler-errors changed the title
No scalar pair opt Revert "store ScalarPair via memset when one side is undef and the other side can be memset"
| return; |
|---|
| } |
| } |
| OperandValue::Pair(a, b) => { |
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For future reference, on line 104:
The try_init_all_same tries to access a value that should be size u128, but since scalar pairs can be twice the size of u128 it ends up indexing out of bounds.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This code will need to both check that the initialized half of the scalarpair is the same value, then emit another memset for the uninitialized part, and be a bit more careful to use the correct size of the value being passed into the function.
| // CHECK-NOT: select |
|---|
| // CHECK: br label %repeat_loop_header{{.*}} |
| // CHECK-NOT: switch |
| // CHECK: icmp |
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I copied all this from above :clueless:
@bors r+ rollup
Has a really tiny effect on binary sizes, but that's not worth separating out of a rollup
📌 Commit 5f575bc has been approved by oli-obk
It is now in the queue for this repository.
bors added S-waiting-on-bors
Status: Waiting on bors to run and complete tests. Bors will change the label on completion.
and removed S-waiting-on-review
Status: Awaiting review from the assignee but also interested parties.
labels
bors added a commit to rust-lang-ci/rust that referenced this pull request
…iaskrgr
Rollup of 12 pull requests
Successful merges:
- rust-lang#135767 (Future incompatibility warning
unsupported_fn_ptr_calling_conventions: Also warn in dependencies) - rust-lang#137852 (Remove layouting dead code for non-array SIMD types.)
- rust-lang#137863 (Fix pretty printing of unsafe binders)
- rust-lang#137882 (do not build additional stage on compiler paths)
- rust-lang#137894 (Revert "store ScalarPair via memset when one side is undef and the other side can be memset")
- rust-lang#137902 (Make
ast::TokenKindmore likelexer::TokenKind) - rust-lang#137921 (Subtree update of
rust-analyzer) - rust-lang#137922 (A few cleanups after the removal of
cfg(not(parallel))) - rust-lang#137939 (fix order on shl impl)
- rust-lang#137946 (Fix docker run-local docs)
- rust-lang#137955 (Always allow rustdoc-json tests to contain long lines)
- rust-lang#137958 (triagebot.toml: Don't label
test/rustdoc-jsonas A-rustdoc-search)
r? @ghost
@rustbot modify labels: rollup
rust-timer added a commit to rust-lang-ci/rust that referenced this pull request
lqd commented
• Loading
We need this on beta to fix #137892
@rustbot label +beta-nominated cc @apiraino for late meeting addition (no rush, and no worries if it slips: 1.86 is a month away)
lqd added the beta-nominated
Nominated for backporting to the compiler in the beta channel.
label
This comment was marked as outdated.
Beta backport accepted as per compiler team on Zulip. A backport PR will be authored by the release team at the end of the current development cycle. Backport labels handled by them.
@rustbot label +beta-accepted
bors added a commit to rust-lang-ci/rust that referenced this pull request
[beta] backports
- Don't infer attributes of virtual calls based on the function body rust-lang#137669
- Revert "store ScalarPair via memset when one side is undef and the other side can be memset" rust-lang#137894
r? cuviper
bors added a commit to rust-lang-ci/rust that referenced this pull request
[beta] backports
- Don't infer attributes of virtual calls based on the function body rust-lang#137669
- Revert "store ScalarPair via memset when one side is undef and the other side can be memset" rust-lang#137894
- Do not install rustup on Rust for Linux job rust-lang#137947
r? cuviper
github-actions bot pushed a commit to model-checking/verify-rust-std that referenced this pull request
…iaskrgr
Rollup of 12 pull requests
Successful merges:
- rust-lang#135767 (Future incompatibility warning
unsupported_fn_ptr_calling_conventions: Also warn in dependencies) - rust-lang#137852 (Remove layouting dead code for non-array SIMD types.)
- rust-lang#137863 (Fix pretty printing of unsafe binders)
- rust-lang#137882 (do not build additional stage on compiler paths)
- rust-lang#137894 (Revert "store ScalarPair via memset when one side is undef and the other side can be memset")
- rust-lang#137902 (Make
ast::TokenKindmore likelexer::TokenKind) - rust-lang#137921 (Subtree update of
rust-analyzer) - rust-lang#137922 (A few cleanups after the removal of
cfg(not(parallel))) - rust-lang#137939 (fix order on shl impl)
- rust-lang#137946 (Fix docker run-local docs)
- rust-lang#137955 (Always allow rustdoc-json tests to contain long lines)
- rust-lang#137958 (triagebot.toml: Don't label
test/rustdoc-jsonas A-rustdoc-search)
r? @ghost
@rustbot modify labels: rollup
flip1995 pushed a commit to flip1995/rust that referenced this pull request
…iaskrgr
Rollup of 12 pull requests
Successful merges:
- rust-lang#135767 (Future incompatibility warning
unsupported_fn_ptr_calling_conventions: Also warn in dependencies) - rust-lang#137852 (Remove layouting dead code for non-array SIMD types.)
- rust-lang#137863 (Fix pretty printing of unsafe binders)
- rust-lang#137882 (do not build additional stage on compiler paths)
- rust-lang#137894 (Revert "store ScalarPair via memset when one side is undef and the other side can be memset")
- rust-lang#137902 (Make
ast::TokenKindmore likelexer::TokenKind) - rust-lang#137921 (Subtree update of
rust-analyzer) - rust-lang#137922 (A few cleanups after the removal of
cfg(not(parallel))) - rust-lang#137939 (fix order on shl impl)
- rust-lang#137946 (Fix docker run-local docs)
- rust-lang#137955 (Always allow rustdoc-json tests to contain long lines)
- rust-lang#137958 (triagebot.toml: Don't label
test/rustdoc-jsonas A-rustdoc-search)
r? @ghost
@rustbot modify labels: rollup
GuillaumeGomez pushed a commit to GuillaumeGomez/rust that referenced this pull request
…, r=oli-obk
Revert "store ScalarPair via memset when one side is undef and the other side can be memset"
cc rust-lang#137892 reverts rust-lang#135335
r? oli-obk
GuillaumeGomez pushed a commit to GuillaumeGomez/rust that referenced this pull request
…iaskrgr
Rollup of 12 pull requests
Successful merges:
- rust-lang#135767 (Future incompatibility warning
unsupported_fn_ptr_calling_conventions: Also warn in dependencies) - rust-lang#137852 (Remove layouting dead code for non-array SIMD types.)
- rust-lang#137863 (Fix pretty printing of unsafe binders)
- rust-lang#137882 (do not build additional stage on compiler paths)
- rust-lang#137894 (Revert "store ScalarPair via memset when one side is undef and the other side can be memset")
- rust-lang#137902 (Make
ast::TokenKindmore likelexer::TokenKind) - rust-lang#137921 (Subtree update of
rust-analyzer) - rust-lang#137922 (A few cleanups after the removal of
cfg(not(parallel))) - rust-lang#137939 (fix order on shl impl)
- rust-lang#137946 (Fix docker run-local docs)
- rust-lang#137955 (Always allow rustdoc-json tests to contain long lines)
- rust-lang#137958 (triagebot.toml: Don't label
test/rustdoc-jsonas A-rustdoc-search)
r? @ghost
@rustbot modify labels: rollup
Labels
Accepted for backporting to the compiler in the beta channel.
Status: Waiting on bors to run and complete tests. Bors will change the label on completion.
Relevant to the compiler team, which will review and decide on the PR/issue.