- // MIR for `do_not_miscompile` before InstCombine + // MIR for `do_not_miscompile` after InstCombine fn do_not_miscompile() -> () { let mut _0: (); // return place in scope 0 at $DIR/inst_combine_deref.rs:54:24: 54:24 let _1: i32; // in scope 0 at $DIR/inst_combine_deref.rs:55:9: 55:10 let mut _5: &i32; // in scope 0 at $DIR/inst_combine_deref.rs:59:10: 59:12 let _6: &i32; // in scope 0 at $DIR/inst_combine_deref.rs:59:10: 59:12 let _7: (); // in scope 0 at $DIR/inst_combine_deref.rs:60:5: 60:23 let mut _8: bool; // in scope 0 at $DIR/inst_combine_deref.rs:60:5: 60:23 let mut _9: bool; // in scope 0 at $DIR/inst_combine_deref.rs:60:13: 60:21 let mut _10: i32; // in scope 0 at $DIR/inst_combine_deref.rs:60:13: 60:15 let mut _11: !; // in scope 0 at $DIR/inst_combine_deref.rs:60:5: 60:23 scope 1 { debug x => _1; // in scope 1 at $DIR/inst_combine_deref.rs:55:9: 55:10 let _2: i32; // in scope 1 at $DIR/inst_combine_deref.rs:56:9: 56:10 scope 2 { debug a => _2; // in scope 2 at $DIR/inst_combine_deref.rs:56:9: 56:10 let mut _3: &i32; // in scope 2 at $DIR/inst_combine_deref.rs:57:9: 57:14 scope 3 { debug y => _3; // in scope 3 at $DIR/inst_combine_deref.rs:57:9: 57:14 let _4: &mut &i32; // in scope 3 at $DIR/inst_combine_deref.rs:58:9: 58:10 scope 4 { debug z => _4; // in scope 4 at $DIR/inst_combine_deref.rs:58:9: 58:10 } } } } bb0: { StorageLive(_1); // scope 0 at $DIR/inst_combine_deref.rs:55:9: 55:10 _1 = const 42_i32; // scope 0 at $DIR/inst_combine_deref.rs:55:13: 55:15 StorageLive(_2); // scope 1 at $DIR/inst_combine_deref.rs:56:9: 56:10 _2 = const 99_i32; // scope 1 at $DIR/inst_combine_deref.rs:56:13: 56:15 StorageLive(_3); // scope 2 at $DIR/inst_combine_deref.rs:57:9: 57:14 _3 = &_1; // scope 2 at $DIR/inst_combine_deref.rs:57:17: 57:19 StorageLive(_4); // scope 3 at $DIR/inst_combine_deref.rs:58:9: 58:10 _4 = &mut _3; // scope 3 at $DIR/inst_combine_deref.rs:58:13: 58:19 StorageLive(_5); // scope 4 at $DIR/inst_combine_deref.rs:59:10: 59:12 StorageLive(_6); // scope 4 at $DIR/inst_combine_deref.rs:59:10: 59:12 _6 = &_2; // scope 4 at $DIR/inst_combine_deref.rs:59:10: 59:12 - _5 = &(*_6); // scope 4 at $DIR/inst_combine_deref.rs:59:10: 59:12 + _5 = _6; // scope 4 at $DIR/inst_combine_deref.rs:59:10: 59:12 (*_4) = move _5; // scope 4 at $DIR/inst_combine_deref.rs:59:5: 59:12 StorageDead(_5); // scope 4 at $DIR/inst_combine_deref.rs:59:11: 59:12 StorageDead(_6); // scope 4 at $DIR/inst_combine_deref.rs:59:12: 59:13 StorageLive(_7); // scope 4 at $DIR/inst_combine_deref.rs:60:5: 60:23 StorageLive(_8); // scope 4 at $DIR/inst_combine_deref.rs:60:5: 60:23 StorageLive(_9); // scope 4 at $DIR/inst_combine_deref.rs:60:13: 60:21 StorageLive(_10); // scope 4 at $DIR/inst_combine_deref.rs:60:13: 60:15 _10 = (*_3); // scope 4 at $DIR/inst_combine_deref.rs:60:13: 60:15 _9 = Eq(move _10, const 99_i32); // scope 4 at $DIR/inst_combine_deref.rs:60:13: 60:21 StorageDead(_10); // scope 4 at $DIR/inst_combine_deref.rs:60:20: 60:21 _8 = Not(move _9); // scope 4 at $DIR/inst_combine_deref.rs:60:5: 60:23 StorageDead(_9); // scope 4 at $DIR/inst_combine_deref.rs:60:22: 60:23 switchInt(move _8) -> [false: bb2, otherwise: bb1]; // scope 4 at $DIR/inst_combine_deref.rs:60:5: 60:23 } bb1: { StorageLive(_11); // scope 4 at $DIR/inst_combine_deref.rs:60:5: 60:23 core::panicking::panic(const "assertion failed: *y == 99"); // scope 4 at $DIR/inst_combine_deref.rs:60:5: 60:23 // mir::Constant // + span: $DIR/inst_combine_deref.rs:60:5: 60:23 // + literal: Const { ty: fn(&'static str) -> ! {core::panicking::panic}, val: Value(Scalar()) } // ty::Const // + ty: &str // + val: Value(Slice { data: Allocation { bytes: [97, 115, 115, 101, 114, 116, 105, 111, 110, 32, 102, 97, 105, 108, 101, 100, 58, 32, 42, 121, 32, 61, 61, 32, 57, 57], relocations: Relocations(SortedMap { data: [] }), init_mask: InitMask { blocks: [67108863], len: Size { raw: 26 } }, size: Size { raw: 26 }, align: Align { pow2: 0 }, mutability: Not, extra: () }, start: 0, end: 26 }) // mir::Constant // + span: $DIR/inst_combine_deref.rs:1:1: 1:1 // + literal: Const { ty: &str, val: Value(Slice { data: Allocation { bytes: [97, 115, 115, 101, 114, 116, 105, 111, 110, 32, 102, 97, 105, 108, 101, 100, 58, 32, 42, 121, 32, 61, 61, 32, 57, 57], relocations: Relocations(SortedMap { data: [] }), init_mask: InitMask { blocks: [67108863], len: Size { raw: 26 } }, size: Size { raw: 26 }, align: Align { pow2: 0 }, mutability: Not, extra: () }, start: 0, end: 26 }) } } bb2: { _7 = const (); // scope 4 at $DIR/inst_combine_deref.rs:60:23: 60:23 StorageDead(_8); // scope 4 at $DIR/inst_combine_deref.rs:60:22: 60:23 StorageDead(_7); // scope 4 at $DIR/inst_combine_deref.rs:60:22: 60:23 _0 = const (); // scope 0 at $DIR/inst_combine_deref.rs:54:24: 61:2 StorageDead(_4); // scope 3 at $DIR/inst_combine_deref.rs:61:1: 61:2 StorageDead(_3); // scope 2 at $DIR/inst_combine_deref.rs:61:1: 61:2 StorageDead(_2); // scope 1 at $DIR/inst_combine_deref.rs:61:1: 61:2 StorageDead(_1); // scope 0 at $DIR/inst_combine_deref.rs:61:1: 61:2 return; // scope 0 at $DIR/inst_combine_deref.rs:61:2: 61:2 } }