2020-09-20 12:02:04 +02:00
|
|
|
// This should fail even without validation, but some MIR opts mask the error
|
|
|
|
// compile-flags: -Zmiri-disable-validation -Zmir-opt-level=0
|
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) {
|
|
|
|
unsafe { LEAK = v as *mut _ as usize; }
|
|
|
|
}
|
|
|
|
|
|
|
|
fn evil() {
|
2020-03-08 23:34:54 +01:00
|
|
|
unsafe { &mut *(LEAK as *mut i32) }; //~ ERROR dereferenced after this allocation got freed
|
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
|
|
|
|
// `main` stack frame still exists).
|
2018-07-31 20:27:36 +02:00
|
|
|
evil();
|
|
|
|
}
|