2023-01-12 20:04:42 +00:00
|
|
|
// This example is interesting because the non-transitive version of `MaybeLiveLocals` would
|
|
|
|
// report that *all* of these stores are live.
|
|
|
|
//
|
|
|
|
// needs-unwind
|
2022-05-09 20:12:03 -04:00
|
|
|
// unit-test: DeadStoreElimination
|
|
|
|
|
2023-01-12 20:04:42 +00:00
|
|
|
#![feature(core_intrinsics, custom_mir)]
|
|
|
|
use std::intrinsics::mir::*;
|
|
|
|
|
2022-05-09 20:12:03 -04:00
|
|
|
#[inline(never)]
|
|
|
|
fn cond() -> bool {
|
|
|
|
false
|
|
|
|
}
|
|
|
|
|
|
|
|
// EMIT_MIR cycle.cycle.DeadStoreElimination.diff
|
2023-01-12 20:04:42 +00:00
|
|
|
#[custom_mir(dialect = "runtime", phase = "post-cleanup")]
|
2022-05-09 20:12:03 -04:00
|
|
|
fn cycle(mut x: i32, mut y: i32, mut z: i32) {
|
2023-01-12 20:04:42 +00:00
|
|
|
// We use custom MIR to avoid generating debuginfo, that would force to preserve writes.
|
|
|
|
mir!(
|
|
|
|
let condition: bool;
|
|
|
|
{
|
|
|
|
Call(condition = cond(), bb1)
|
|
|
|
}
|
|
|
|
bb1 = {
|
|
|
|
match condition { true => bb2, _ => ret }
|
|
|
|
}
|
|
|
|
bb2 = {
|
|
|
|
let temp = z;
|
|
|
|
z = y;
|
|
|
|
y = x;
|
|
|
|
x = temp;
|
|
|
|
Call(condition = cond(), bb1)
|
|
|
|
}
|
|
|
|
ret = {
|
|
|
|
Return()
|
|
|
|
}
|
|
|
|
)
|
2022-05-09 20:12:03 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
cycle(1, 2, 3);
|
|
|
|
}
|