rust/tests/mir-opt/const_promotion_extern_static.FOO.PromoteTemps.diff

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

55 lines
4.0 KiB
Diff
Raw Normal View History

2020-03-11 05:49:00 -05:00
- // MIR for `FOO` before PromoteTemps
+ // MIR for `FOO` after PromoteTemps
static mut FOO: *const &i32 = {
2022-11-02 16:54:49 -05:00
let mut _0: *const &i32; // return place in scope 0 at $DIR/const_promotion_extern_static.rs:+0:17: +0:28
let mut _1: &[&i32]; // in scope 0 at $DIR/const_promotion_extern_static.rs:+0:31: +0:55
let mut _2: &[&i32; 1]; // in scope 0 at $DIR/const_promotion_extern_static.rs:+0:31: +0:55
let _3: [&i32; 1]; // in scope 0 at $DIR/const_promotion_extern_static.rs:+0:31: +0:46
let mut _4: &i32; // in scope 0 at $DIR/const_promotion_extern_static.rs:+0:32: +0:45
let _5: *const i32; // in scope 0 at $DIR/const_promotion_extern_static.rs:+0:42: +0:43
+ let mut _6: &[&i32; 1]; // in scope 0 at $DIR/const_promotion_extern_static.rs:+0:31: +0:55
2020-03-11 05:49:00 -05:00
scope 1 {
}
bb0: {
2022-11-02 16:54:49 -05:00
StorageLive(_1); // scope 0 at $DIR/const_promotion_extern_static.rs:+0:31: +0:55
StorageLive(_2); // scope 0 at $DIR/const_promotion_extern_static.rs:+0:31: +0:55
- StorageLive(_3); // scope 0 at $DIR/const_promotion_extern_static.rs:+0:31: +0:46
- StorageLive(_4); // scope 0 at $DIR/const_promotion_extern_static.rs:+0:32: +0:45
- StorageLive(_5); // scope 1 at $DIR/const_promotion_extern_static.rs:+0:42: +0:43
2023-02-27 13:09:13 -06:00
- _5 = const {alloc2: *const i32}; // scope 1 at $DIR/const_promotion_extern_static.rs:+0:42: +0:43
2022-11-02 16:54:49 -05:00
+ _6 = const _; // scope 0 at $DIR/const_promotion_extern_static.rs:+0:31: +0:55
2020-03-11 05:49:00 -05:00
// mir::Constant
2022-11-02 16:54:49 -05:00
- // + span: $DIR/const_promotion_extern_static.rs:13:42: 13:43
2023-02-27 13:09:13 -06:00
- // + literal: Const { ty: *const i32, val: Value(Scalar(alloc2)) }
2022-11-02 16:54:49 -05:00
- _4 = &(*_5); // scope 1 at $DIR/const_promotion_extern_static.rs:+0:41: +0:43
- _3 = [move _4]; // scope 0 at $DIR/const_promotion_extern_static.rs:+0:31: +0:46
- _2 = &_3; // scope 0 at $DIR/const_promotion_extern_static.rs:+0:31: +0:55
+ // + span: $DIR/const_promotion_extern_static.rs:13:31: 13:55
2022-02-21 01:10:07 -06:00
+ // + literal: Const { ty: &[&i32; 1], val: Unevaluated(FOO, [], Some(promoted[0])) }
2022-11-02 16:54:49 -05:00
+ _2 = &(*_6); // scope 0 at $DIR/const_promotion_extern_static.rs:+0:31: +0:55
_1 = move _2 as &[&i32] (Pointer(Unsize)); // scope 0 at $DIR/const_promotion_extern_static.rs:+0:31: +0:55
- StorageDead(_4); // scope 0 at $DIR/const_promotion_extern_static.rs:+0:45: +0:46
StorageDead(_2); // scope 0 at $DIR/const_promotion_extern_static.rs:+0:45: +0:46
_0 = core::slice::<impl [&i32]>::as_ptr(move _1) -> [return: bb1, unwind: bb2]; // scope 0 at $DIR/const_promotion_extern_static.rs:+0:31: +0:55
2020-03-11 05:49:00 -05:00
// mir::Constant
2022-11-02 16:54:49 -05:00
// + span: $DIR/const_promotion_extern_static.rs:13:47: 13:53
2022-09-21 10:57:30 -05:00
// + literal: Const { ty: for<'a> fn(&'a [&i32]) -> *const &i32 {core::slice::<impl [&i32]>::as_ptr}, val: Value(<ZST>) }
2020-03-11 05:49:00 -05:00
}
2020-10-02 15:11:24 -05:00
bb1: {
2022-11-02 16:54:49 -05:00
- StorageDead(_5); // scope 0 at $DIR/const_promotion_extern_static.rs:+0:54: +0:55
- StorageDead(_3); // scope 0 at $DIR/const_promotion_extern_static.rs:+0:54: +0:55
StorageDead(_1); // scope 0 at $DIR/const_promotion_extern_static.rs:+0:54: +0:55
return; // scope 0 at $DIR/const_promotion_extern_static.rs:+0:1: +0:56
2020-03-11 05:49:00 -05:00
}
2020-10-02 15:11:24 -05:00
bb2 (cleanup): {
2022-11-02 16:54:49 -05:00
resume; // scope 0 at $DIR/const_promotion_extern_static.rs:+0:1: +0:56
2020-10-02 15:11:24 -05:00
}
2020-03-11 05:49:00 -05:00
}
2022-02-09 07:21:49 -06:00
-
2023-02-27 13:09:13 -06:00
- alloc2 (extern static: X)
2020-03-11 05:49:00 -05:00