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 11:49:00 +01:00
- // MIR for `FOO` before PromoteTemps
+ // MIR for `FOO` after PromoteTemps
static mut FOO: *const &i32 = {
2022-11-02 14:54:49 -07: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 11:49:00 +01:00
scope 1 {
}
bb0: {
2022-11-02 14:54:49 -07: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 19:09:13 +00:00
- _5 = const {alloc2: *const i32}; // scope 1 at $DIR/const_promotion_extern_static.rs:+0:42: +0:43
2022-11-02 14:54:49 -07:00
+ _6 = const _; // scope 0 at $DIR/const_promotion_extern_static.rs:+0:31: +0:55
2020-03-11 11:49:00 +01:00
// mir::Constant
2022-11-02 14:54:49 -07:00
- // + span: $DIR/const_promotion_extern_static.rs:13:42: 13:43
2023-02-27 19:09:13 +00:00
- // + literal: Const { ty: *const i32, val: Value(Scalar(alloc2)) }
2022-11-02 14:54:49 -07: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 08:10:07 +01:00
+ // + literal: Const { ty: &[&i32; 1], val: Unevaluated(FOO, [], Some(promoted[0])) }
2022-11-02 14:54:49 -07: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 11:49:00 +01:00
// mir::Constant
2022-11-02 14:54:49 -07:00
// + span: $DIR/const_promotion_extern_static.rs:13:47: 13:53
2022-09-21 17:57:30 +02:00
// + literal: Const { ty: for<'a> fn(&'a [&i32]) -> *const &i32 {core::slice::<impl [&i32]>::as_ptr}, val: Value(<ZST>) }
2020-03-11 11:49:00 +01:00
}
2020-10-02 16:11:24 -04:00
bb1: {
2022-11-02 14:54:49 -07: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 11:49:00 +01:00
}
2020-10-02 16:11:24 -04:00
bb2 (cleanup): {
2022-11-02 14:54:49 -07:00
resume; // scope 0 at $DIR/const_promotion_extern_static.rs:+0:1: +0:56
2020-10-02 16:11:24 -04:00
}
2020-03-11 11:49:00 +01:00
}
2022-02-09 14:21:49 +01:00
-
2023-02-27 19:09:13 +00:00
- alloc2 (extern static: X)
2020-03-11 11:49:00 +01:00