-
Notifications
You must be signed in to change notification settings - Fork 13.2k
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
Revert "store ScalarPair via memset when one side is undef and the other side can be memset" #137894
Conversation
match cg_elem.val { | ||
OperandValue::Immediate(v) => { | ||
if try_init_all_same(bx, v) { | ||
return; | ||
} | ||
} | ||
OperandValue::Pair(a, b) => { |
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.
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.
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 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 |
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 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 |
…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::TokenKind` more like `lexer::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-json` as A-rustdoc-search) r? `@ghost` `@rustbot` modify labels: rollup
Rollup merge of rust-lang#137894 - compiler-errors:no-scalar-pair-opt, 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
This comment was marked as outdated.
This comment was marked as outdated.
[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
[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
cc #137892
reverts #135335
r? oli-obk