-
Notifications
You must be signed in to change notification settings - Fork 356
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
Enable permissive provenance by default #2275
Enable permissive provenance by default #2275
Conversation
// #[cfg(all(target_arch = "x86_64", target_pointer_width = "64"))] | ||
// static_assert_size!(Pointer<Option<Tag>>, 24); | ||
//static_assert_size!(Pointer<Option<Tag>>, 24); |
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 am quite bummed by this... Tag
now has two NonZeroU64
, so we could use one to indicate Wildcard
and one to indicate None
, but it seems rustc is not smart enough for that. :(
I wonder if it's worth implementing the packing by hand, or if having the extra 8 bytes is just not such a big deal...
dd69890
to
1a5dfbe
Compare
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'm a bit surprised about all the behaviour changes. I would have expected this to just change the defaults. I guess the subsequent cleanups are the cause here?
I wish we had a good way to run perf. Maybe we could figure out a way to run a separate perfbot suite via the same infrastructure... I'll check that out
755bee9
to
923d912
Compare
The change to check liveness of the allocation in intptrcast.rs is something I just discovered while working on this. I can factor it into a separate PR if you want. The change I just added to make allocations adjacent again could be made dependent on the provenance mode on master already, I guess. It doesn't work with legacy provenance though. I can factor it into a separate PR if you want. And that should be all the behavior changes I think? The remaining output changes come from the fact that we now enable raw pointer tagging by default. This also means we have to adjust some tests that inadvertantly relied on raw pointers being untagged. A bunch of tests were using int2ptr casts unnecessarily so I made them not do that. And finally I killed the 'untagged' support from Stacked Borrows since I cannot wait to see it go away. :) |
yea I got that part. the rest seems ok to include here, I was just surprised, as the PR title and description did not make me think of anything beyond the test changes due to changes in defaults. |
That test failure is very strange, I cannot reproduce it locally
|
Ah, got it.
Seems to need the "adjacent allocation" change to reproduce. Interesting... |
The function pointer lacks provenance. Maybe I didn't think this part about adjacent allocations through carefully enough... I think I'll back that part out again. |
81cde64
to
d9e7a3a
Compare
Ah bummer, getrandom 1 still needs permissive provenance on macOS... |
f6a1692
to
d9e7a3a
Compare
When running
Amusingly, one of the doctests runs into the same sort of issue, but in that case the ptr-int cast warning is displayed before the UB error. EDIT: Hm actually I have no idea what's going on here, this could just be a me problem. |
src/intptrcast.rs
Outdated
use std::sync::atomic::{AtomicBool, Ordering}; | ||
static FIRST_WARNING: AtomicBool = AtomicBool::new(true); | ||
if FIRST_WARNING.swap(false, Ordering::Relaxed) { | ||
register_diagnostic(NonHaltingDiagnostic::Int2Ptr); |
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.
--> /root/.cargo/registry/src/github.com-1ecc6299db9ec823/tendril-0.4.3/src/tendril.rs:1073:9
|
1073 | (self.ptr.get().get() & !1) as *mut Header<A>
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ pointer-to-integer cast
|
= help: this program is using integer-to-pointer casts or (equivalently) `from_exposed_addr`,
The diagnostic says pointer-to-integer, but the span is an int-to-pointer cast. Similarly, this diagnostic is called Int2Ptr
but it is in the function called ptr_from_addr_cast
. Which direction are we trying to highlight?
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.
oops int2ptr is right
I have seen the warning in
|
One thing I was wondering about: currently we only print the warning on the first cast. |
That may be useful to have behind a flag. What I am thinking of for diagnostics, is that when we encounter a problem we should be able to report what Miri knows about what offsets and with what permissions have been exposed in an allocation. I'd have to actually get to implementing this to know how useful it is, but for example in |
So many flags.^^ For now I'd like to have a reasonable default.
Provenances (AllocId + SbTag) are exposed, not addresses. And if the AllocId had not been exposed we would not even have gotten to the Stacked Borrows part. But likely the tag that was exposed is already invalid, or never was valid for this location. |
In real code, especially from a test suite, you can expect 1-2 backtraces to fit on a screen. I think if Miri emits 10, people will rapidly decide to always silence them, just like how people learn to always disable isolation. |
Many of the int2ptr warnings I've seen are for |
If they are not interested in removing these casts, that's fine.
Well, I do want to make sure people are aware that such a precision-losing cast happens -- even if they cannot do anything about it, IMO it is important that they can know that Miri might miss some bugs here. This warning is load-bearing, in a sense. We could prune the backtrace but I doubt that would help much... |
1b38a9a
to
c1eddbc
Compare
I'm going to land this for now, we can always fine-tune it later. @bors r+ |
📌 Commit c1eddbc has been approved by |
☀️ Test successful - checks-actions |
This completes the plan laid out in #2133:
-Zmiri-permissive-provenance
suppresses the warning;-Zmiri-strict-provenance
turns it into a hard error.-Zmiri-tag-raw-pointers
flag and the code for untagged pointers. (Passing the flag still works, for compatibility -- but we just ignore it, with a warning.)We also fix an intptrcast issue:
So, finally, Miri has a good story for ptr2int2ptr roundtrips and no weird false negatives when doing raw pointer stuff with Stacked Borrows. :-) 🎉 Thanks a lot to everyone who helped with this, in particular @carbotaniuman who convinced me this is even possible.
Fixes #2133
Fixes #1866
Fixes #1993