2022-06-24 16:21:47 -04:00
|
|
|
// compile-flags: -Zmiri-permissive-provenance
|
|
|
|
#![feature(strict_provenance)]
|
|
|
|
|
|
|
|
// If we have only exposed read-only pointers, doing a write through a wildcard ptr should fail.
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let mut x = 0;
|
|
|
|
let _fool = &mut x as *mut i32; // this would have fooled the old untagged pointer logic
|
|
|
|
let addr = (&x as *const i32).expose_addr();
|
|
|
|
let ptr = std::ptr::from_exposed_addr_mut::<i32>(addr);
|
2022-06-24 18:02:25 -04:00
|
|
|
unsafe { *ptr = 0 }; //~ ERROR: borrow stack
|
2022-06-24 16:21:47 -04:00
|
|
|
}
|