2020-09-20 12:02:04 +02:00
|
|
|
// This should fail even without validation, but some MIR opts mask the error
|
2022-06-26 21:26:14 -04:00
|
|
|
// compile-flags: -Zmiri-disable-validation -Zmir-opt-level=0 -Zmiri-permissive-provenance
|
2018-10-12 10:54:37 +02:00
|
|
|
|
2018-07-31 20:27:36 +02:00
|
|
|
static mut LEAK: usize = 0;
|
|
|
|
|
|
|
|
fn fill(v: &mut i32) {
|
2022-06-19 20:33:59 -07:00
|
|
|
unsafe {
|
|
|
|
LEAK = v as *mut _ as usize;
|
|
|
|
}
|
2018-07-31 20:27:36 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
fn evil() {
|
2022-06-26 21:26:14 -04:00
|
|
|
unsafe { &mut *(LEAK as *mut i32) }; //~ ERROR is not a valid pointer
|
2018-07-31 20:27:36 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let _y;
|
|
|
|
{
|
|
|
|
let mut x = 0i32;
|
|
|
|
fill(&mut x);
|
|
|
|
_y = x;
|
|
|
|
}
|
2021-03-22 12:35:30 +01:00
|
|
|
// Now we use a pointer to `x` which is no longer in scope, and thus dead (even though the
|
2022-06-26 21:26:14 -04:00
|
|
|
// `main` stack frame still exists). We even try going through a `usize` for extra sneakiness!
|
2018-07-31 20:27:36 +02:00
|
|
|
evil();
|
|
|
|
}
|