summaryrefslogtreecommitdiffstats
path: root/tests/mir-opt/copy-prop/mutate_through_pointer.rs
blob: e36a10846a625d663906eec70674f7e471b58a64 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
// skip-filecheck
// unit-test: CopyProp
//
// This attempts to mutate `a` via a pointer derived from `addr_of!(a)`. That is UB
// according to Miri. However, the decision to make this UB - and to allow
// rustc to rely on that fact for the purpose of optimizations - has not been
// finalized.
//
// As such, we include this test to ensure that copy prop does not rely on that
// fact. Specifically, if `addr_of!(a)` could not be used to modify a, it would
// be correct for CopyProp to replace all occurrences of `a` with `c` - but that
// would cause `f(true)` to output `false` instead of `true`.

#![feature(custom_mir, core_intrinsics)]
#![allow(unused_assignments)]
extern crate core;
use core::intrinsics::mir::*;

#[custom_mir(dialect = "analysis", phase = "post-cleanup")]
fn f(c: bool) -> bool {
    mir!({
        let a = c;
        let p = core::ptr::addr_of!(a);
        let p2 = core::ptr::addr_of_mut!(*p);
        *p2 = false;
        RET = c;
        Return()
    })
}

fn main() {
    assert_eq!(true, f(true));
}

// EMIT_MIR mutate_through_pointer.f.CopyProp.diff