Skip to content
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

Unstably allow assume intrinsic in const contexts #76973

Merged
merged 3 commits into from
Sep 25, 2020

Conversation

tesuji
Copy link
Contributor

@tesuji tesuji commented Sep 20, 2020

Not sure much about this usage because there are concerns
about blocking optimization and slowing down LLVM when using assme intrinsic
in inline functions.
But since Oli suggested in #76960 (comment),
here we are.

@rust-highfive rust-highfive added the S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. label Sep 20, 2020
@tesuji tesuji force-pushed the unstably-const-assume branch from 4bb75dd to a3f87fc Compare September 20, 2020 14:01
@tesuji tesuji force-pushed the unstably-const-assume branch from a3f87fc to c2390c9 Compare September 20, 2020 14:03
pub const unsafe fn foo(x: usize, y: usize) -> usize {
assume(y != 0);
x / y
}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Isn't this the kind of test that should be made a unit test instead (#76268)?

Copy link
Contributor Author

@tesuji tesuji Sep 20, 2020

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I only saw const_slice_from_raw_parts and const_raw_ptr_deref in library/core/tests/lib.rs.
Not really sure about this.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah, I think this should be a unit-test.

Copy link
Contributor Author

@tesuji tesuji Sep 24, 2020

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's kind of weird since most intrinsics not tested in library/core/tests.
Anyway, I moved it.

@tesuji
Copy link
Contributor Author

tesuji commented Sep 20, 2020

Not sure the block optimization concerns about adding assume to NonZero*::get still hold: #54995 (comment)

@tesuji
Copy link
Contributor Author

tesuji commented Sep 20, 2020

Because the above concern isn't resolved, I will move the assume part in NonZero*::get to another PR
or just drop it.

@oli-obk
Copy link
Contributor

oli-obk commented Sep 20, 2020

Yea they probably do :( I don't think there's any point in summoning nagisa or hanna, I don't think anything changed over the last two years that woudl affect this.

@oli-obk
Copy link
Contributor

oli-obk commented Sep 24, 2020

@bors r+

@bors
Copy link
Contributor

bors commented Sep 24, 2020

📌 Commit 382d724 has been approved by oli-obk

@bors 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 Sep 24, 2020
@RalfJung
Copy link
Member

@bors rollup

RalfJung added a commit to RalfJung/rust that referenced this pull request Sep 25, 2020
…-obk

Unstably allow assume intrinsic in const contexts

Not sure much about this usage because there are concerns
about [blocking  optimization][1] and [slowing down LLVM][2] when using `assme` intrinsic
in inline functions.
But since Oli suggested in rust-lang#76960 (comment),
here we are.

[1]: rust-lang#54995 (comment)
[2]: rust-lang#49572 (comment)
RalfJung added a commit to RalfJung/rust that referenced this pull request Sep 25, 2020
…-obk

Unstably allow assume intrinsic in const contexts

Not sure much about this usage because there are concerns
about [blocking  optimization][1] and [slowing down LLVM][2] when using `assme` intrinsic
in inline functions.
But since Oli suggested in rust-lang#76960 (comment),
here we are.

[1]: rust-lang#54995 (comment)
[2]: rust-lang#49572 (comment)
bors added a commit to rust-lang-ci/rust that referenced this pull request Sep 25, 2020
…as-schievink

Rollup of 15 pull requests

Successful merges:

 - rust-lang#76932 (Relax promises about condition variable.)
 - rust-lang#76973 (Unstably allow assume intrinsic in const contexts)
 - rust-lang#77005 (BtreeMap: refactoring around edges)
 - rust-lang#77066 (Fix dest prop miscompilation around references)
 - rust-lang#77073 (dead_code: look at trait impls even if they don't contain items)
 - rust-lang#77086 (Include libunwind in the rust-src component.)
 - rust-lang#77097 (Make [].as_[mut_]ptr_range() (unstably) const.)
 - rust-lang#77106 (clarify that `changelog-seen = 1` goes to the beginning of config.toml)
 - rust-lang#77120 (Add `--keep-stage-std` to `x.py` for keeping only standard library artifacts)
 - rust-lang#77126 (Invalidate local LLVM cache less often)
 - rust-lang#77146 (Install std for non-host targets)
 - rust-lang#77155 (remove enum name from ImplSource variants)
 - rust-lang#77176 (Removing erroneous semicolon in transmute documentation)
 - rust-lang#77183 (Allow multiple allow_internal_unstable attributes)
 - rust-lang#77189 (Remove extra space from vec drawing)

Failed merges:

r? `@ghost`
@bors bors merged commit 1b8c939 into rust-lang:master Sep 25, 2020
@rustbot rustbot added this to the 1.48.0 milestone Sep 25, 2020
@tesuji tesuji deleted the unstably-const-assume branch September 26, 2020 03:05
bors added a commit to rust-lang/miri that referenced this pull request Sep 27, 2020
Remove assume intrinsic from EvalContextExt

Waiting for rust-lang/rust#76973 merged.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
S-waiting-on-bors Status: Waiting on bors to run and complete tests. Bors will change the label on completion.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants