2023-04-30 09:53:24 -05:00
|
|
|
// MIR for `checked_shl` after PreCodegen
|
|
|
|
|
|
|
|
fn checked_shl(_1: u32, _2: u32) -> Option<u32> {
|
|
|
|
debug x => _1; // in scope 0 at $DIR/checked_ops.rs:+0:20: +0:21
|
|
|
|
debug rhs => _2; // in scope 0 at $DIR/checked_ops.rs:+0:28: +0:31
|
|
|
|
let mut _0: std::option::Option<u32>; // return place in scope 0 at $DIR/checked_ops.rs:+0:41: +0:52
|
2023-05-17 15:26:11 -05:00
|
|
|
scope 1 (inlined core::num::<impl u32>::checked_shl) { // at $DIR/checked_ops.rs:15:7: 15:23
|
2023-04-30 09:53:24 -05:00
|
|
|
debug self => _1; // in scope 1 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
debug rhs => _2; // in scope 1 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
let mut _13: (u32, bool); // in scope 1 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
let _14: u32; // in scope 1 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
let _15: bool; // in scope 1 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
let mut _16: bool; // in scope 1 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
scope 2 {
|
|
|
|
debug a => _14; // in scope 2 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
debug b => _15; // in scope 2 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
}
|
|
|
|
scope 3 (inlined core::num::<impl u32>::overflowing_shl) { // at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
debug self => _1; // in scope 3 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
debug rhs => _2; // in scope 3 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
let mut _11: u32; // in scope 3 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
let mut _12: bool; // in scope 3 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
scope 4 (inlined core::num::<impl u32>::wrapping_shl) { // at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
debug self => _1; // in scope 4 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
debug rhs => _2; // in scope 4 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
let mut _3: u32; // in scope 4 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
let mut _4: u32; // in scope 4 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
scope 5 {
|
|
|
|
scope 6 (inlined core::num::<impl u32>::unchecked_shl) { // at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
debug self => _1; // in scope 6 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
debug rhs => _4; // in scope 6 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
let mut _5: (u32,); // in scope 6 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
let mut _6: u32; // in scope 6 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
let mut _10: u32; // in scope 6 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
scope 7 {
|
|
|
|
scope 8 (inlined core::num::<impl u32>::unchecked_shl::conv) { // at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
debug x => _6; // in scope 8 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
let mut _7: std::result::Result<u32, std::convert::Infallible>; // in scope 8 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
let mut _9: std::option::Option<u32>; // in scope 8 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
scope 9 {
|
|
|
|
scope 10 (inlined <u32 as TryInto<u32>>::try_into) { // at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
debug self => _6; // in scope 10 at $SRC_DIR/core/src/convert/mod.rs:LL:COL
|
|
|
|
scope 11 (inlined <u32 as TryFrom<u32>>::try_from) { // at $SRC_DIR/core/src/convert/mod.rs:LL:COL
|
|
|
|
debug value => _6; // in scope 11 at $SRC_DIR/core/src/convert/mod.rs:LL:COL
|
|
|
|
scope 21 (inlined <u32 as Into<u32>>::into) { // at $SRC_DIR/core/src/convert/mod.rs:LL:COL
|
|
|
|
debug self => _6; // in scope 21 at $SRC_DIR/core/src/convert/mod.rs:LL:COL
|
|
|
|
scope 22 (inlined <u32 as From<u32>>::from) { // at $SRC_DIR/core/src/convert/mod.rs:LL:COL
|
|
|
|
debug t => _6; // in scope 22 at $SRC_DIR/core/src/convert/mod.rs:LL:COL
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
scope 12 (inlined Result::<u32, Infallible>::ok) { // at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
debug self => _7; // in scope 12 at $SRC_DIR/core/src/result.rs:LL:COL
|
|
|
|
let _8: u32; // in scope 12 at $SRC_DIR/core/src/result.rs:LL:COL
|
|
|
|
scope 13 {
|
|
|
|
debug x => _8; // in scope 13 at $SRC_DIR/core/src/result.rs:LL:COL
|
|
|
|
}
|
|
|
|
}
|
|
|
|
scope 14 (inlined #[track_caller] Option::<u32>::unwrap_unchecked) { // at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
debug self => _9; // in scope 14 at $SRC_DIR/core/src/option.rs:LL:COL
|
|
|
|
let mut _17: &std::option::Option<u32>; // in scope 14 at $SRC_DIR/core/src/option.rs:LL:COL
|
|
|
|
scope 15 {
|
|
|
|
debug val => _10; // in scope 15 at $SRC_DIR/core/src/option.rs:LL:COL
|
|
|
|
}
|
|
|
|
scope 16 {
|
|
|
|
scope 18 (inlined unreachable_unchecked) { // at $SRC_DIR/core/src/option.rs:LL:COL
|
|
|
|
scope 19 {
|
|
|
|
scope 20 (inlined unreachable_unchecked::runtime) { // at $SRC_DIR/core/src/intrinsics.rs:LL:COL
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
scope 17 (inlined Option::<u32>::is_some) { // at $SRC_DIR/core/src/option.rs:LL:COL
|
|
|
|
debug self => _17; // in scope 17 at $SRC_DIR/core/src/option.rs:LL:COL
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
bb0: {
|
|
|
|
StorageLive(_14); // scope 0 at $DIR/checked_ops.rs:+1:7: +1:23
|
|
|
|
StorageLive(_15); // scope 0 at $DIR/checked_ops.rs:+1:7: +1:23
|
|
|
|
StorageLive(_13); // scope 1 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
StorageLive(_11); // scope 3 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
StorageLive(_6); // scope 3 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
StorageLive(_4); // scope 5 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
StorageLive(_3); // scope 5 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
_3 = const 31_u32; // scope 5 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
_4 = BitAnd(_2, move _3); // scope 5 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
StorageDead(_3); // scope 5 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
StorageLive(_10); // scope 7 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
StorageLive(_5); // scope 7 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
_5 = (_4,); // scope 7 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
_6 = move (_5.0: u32); // scope 7 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
StorageLive(_9); // scope 9 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
StorageLive(_7); // scope 9 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
_7 = Result::<u32, Infallible>::Ok(_6); // scope 11 at $SRC_DIR/core/src/convert/mod.rs:LL:COL
|
|
|
|
StorageLive(_8); // scope 9 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
_8 = move ((_7 as Ok).0: u32); // scope 12 at $SRC_DIR/core/src/result.rs:LL:COL
|
|
|
|
_9 = Option::<u32>::Some(move _8); // scope 13 at $SRC_DIR/core/src/result.rs:LL:COL
|
|
|
|
StorageDead(_8); // scope 9 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
StorageDead(_7); // scope 9 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
StorageLive(_17); // scope 9 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
_10 = move ((_9 as Some).0: u32); // scope 14 at $SRC_DIR/core/src/option.rs:LL:COL
|
|
|
|
StorageDead(_17); // scope 9 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
StorageDead(_9); // scope 9 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
StorageDead(_5); // scope 7 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
_11 = unchecked_shl::<u32>(_1, move _10) -> [return: bb1, unwind unreachable]; // scope 7 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
// mir::Constant
|
|
|
|
// + span: $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
// + literal: Const { ty: unsafe extern "rust-intrinsic" fn(u32, u32) -> u32 {unchecked_shl::<u32>}, val: Value(<ZST>) }
|
|
|
|
}
|
|
|
|
|
|
|
|
bb1: {
|
|
|
|
StorageDead(_10); // scope 7 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
StorageDead(_4); // scope 5 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
StorageDead(_6); // scope 3 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
StorageLive(_12); // scope 3 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
_12 = Ge(_2, const _); // scope 3 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
_13 = (move _11, move _12); // scope 3 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
StorageDead(_12); // scope 3 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
StorageDead(_11); // scope 3 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
_14 = (_13.0: u32); // scope 1 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
_15 = (_13.1: bool); // scope 1 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
StorageDead(_13); // scope 1 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
StorageLive(_16); // scope 2 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
_16 = unlikely(_15) -> [return: bb2, unwind unreachable]; // scope 2 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
// mir::Constant
|
|
|
|
// + span: $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
// + literal: Const { ty: extern "rust-intrinsic" fn(bool) -> bool {unlikely}, val: Value(<ZST>) }
|
|
|
|
}
|
|
|
|
|
|
|
|
bb2: {
|
|
|
|
switchInt(move _16) -> [0: bb3, otherwise: bb4]; // scope 2 at $SRC_DIR/core/src/num/mod.rs:LL:COL
|
|
|
|
}
|
|
|
|
|
|
|
|
bb3: {
|
|
|
|
_0 = Option::<u32>::Some(_14); // scope 2 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
goto -> bb5; // scope 2 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
}
|
|
|
|
|
|
|
|
bb4: {
|
|
|
|
_0 = Option::<u32>::None; // scope 2 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
goto -> bb5; // scope 2 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
}
|
|
|
|
|
|
|
|
bb5: {
|
|
|
|
StorageDead(_16); // scope 2 at $SRC_DIR/core/src/num/uint_macros.rs:LL:COL
|
|
|
|
StorageDead(_15); // scope 0 at $DIR/checked_ops.rs:+1:7: +1:23
|
|
|
|
StorageDead(_14); // scope 0 at $DIR/checked_ops.rs:+1:7: +1:23
|
|
|
|
return; // scope 0 at $DIR/checked_ops.rs:+2:2: +2:2
|
|
|
|
}
|
|
|
|
}
|