rust/tests/mir-opt/building/shifts.shift_unsigned.built.after.mir

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

136 lines
9.5 KiB
Rust
Raw Normal View History

// MIR for `shift_unsigned` after built
fn shift_unsigned(_1: u8, _2: i128, _3: u8, _4: u32, _5: u128) -> ([u8; 3], [i128; 3]) {
debug small => _1; // in scope 0 at $DIR/shifts.rs:+0:19: +0:24
debug big => _2; // in scope 0 at $DIR/shifts.rs:+0:30: +0:33
debug a => _3; // in scope 0 at $DIR/shifts.rs:+0:41: +0:42
debug b => _4; // in scope 0 at $DIR/shifts.rs:+0:48: +0:49
debug c => _5; // in scope 0 at $DIR/shifts.rs:+0:56: +0:57
let mut _0: ([u8; 3], [i128; 3]); // return place in scope 0 at $DIR/shifts.rs:+0:68: +0:88
let mut _6: [u8; 3]; // in scope 0 at $DIR/shifts.rs:+2:9: +2:45
let mut _7: u8; // in scope 0 at $DIR/shifts.rs:+2:10: +2:20
let mut _8: u8; // in scope 0 at $DIR/shifts.rs:+2:10: +2:15
let mut _9: u8; // in scope 0 at $DIR/shifts.rs:+2:19: +2:20
2023-03-22 03:06:19 -05:00
let mut _10: bool; // in scope 0 at $DIR/shifts.rs:+2:10: +2:20
let mut _11: u8; // in scope 0 at $DIR/shifts.rs:+2:22: +2:32
let mut _12: u8; // in scope 0 at $DIR/shifts.rs:+2:22: +2:27
let mut _13: u32; // in scope 0 at $DIR/shifts.rs:+2:31: +2:32
let mut _14: bool; // in scope 0 at $DIR/shifts.rs:+2:22: +2:32
let mut _15: u8; // in scope 0 at $DIR/shifts.rs:+2:34: +2:44
let mut _16: u8; // in scope 0 at $DIR/shifts.rs:+2:34: +2:39
let mut _17: u128; // in scope 0 at $DIR/shifts.rs:+2:43: +2:44
let mut _18: bool; // in scope 0 at $DIR/shifts.rs:+2:34: +2:44
let mut _19: [i128; 3]; // in scope 0 at $DIR/shifts.rs:+3:9: +3:39
let mut _20: i128; // in scope 0 at $DIR/shifts.rs:+3:10: +3:18
let mut _21: i128; // in scope 0 at $DIR/shifts.rs:+3:10: +3:13
let mut _22: u8; // in scope 0 at $DIR/shifts.rs:+3:17: +3:18
let mut _23: bool; // in scope 0 at $DIR/shifts.rs:+3:10: +3:18
let mut _24: i128; // in scope 0 at $DIR/shifts.rs:+3:20: +3:28
let mut _25: i128; // in scope 0 at $DIR/shifts.rs:+3:20: +3:23
let mut _26: u32; // in scope 0 at $DIR/shifts.rs:+3:27: +3:28
let mut _27: bool; // in scope 0 at $DIR/shifts.rs:+3:20: +3:28
let mut _28: i128; // in scope 0 at $DIR/shifts.rs:+3:30: +3:38
let mut _29: i128; // in scope 0 at $DIR/shifts.rs:+3:30: +3:33
let mut _30: u128; // in scope 0 at $DIR/shifts.rs:+3:37: +3:38
let mut _31: bool; // in scope 0 at $DIR/shifts.rs:+3:30: +3:38
bb0: {
StorageLive(_6); // scope 0 at $DIR/shifts.rs:+2:9: +2:45
StorageLive(_7); // scope 0 at $DIR/shifts.rs:+2:10: +2:20
StorageLive(_8); // scope 0 at $DIR/shifts.rs:+2:10: +2:15
_8 = _1; // scope 0 at $DIR/shifts.rs:+2:10: +2:15
StorageLive(_9); // scope 0 at $DIR/shifts.rs:+2:19: +2:20
_9 = _3; // scope 0 at $DIR/shifts.rs:+2:19: +2:20
2023-03-22 03:06:19 -05:00
_10 = Lt(_9, const 8_u8); // scope 0 at $DIR/shifts.rs:+2:10: +2:20
assert(move _10, "attempt to shift right by `{}`, which would overflow", _9) -> [success: bb1, unwind: bb7]; // scope 0 at $DIR/shifts.rs:+2:10: +2:20
}
bb1: {
_7 = Shr(move _8, move _9); // scope 0 at $DIR/shifts.rs:+2:10: +2:20
StorageDead(_9); // scope 0 at $DIR/shifts.rs:+2:19: +2:20
StorageDead(_8); // scope 0 at $DIR/shifts.rs:+2:19: +2:20
2023-03-22 03:06:19 -05:00
StorageLive(_11); // scope 0 at $DIR/shifts.rs:+2:22: +2:32
StorageLive(_12); // scope 0 at $DIR/shifts.rs:+2:22: +2:27
_12 = _1; // scope 0 at $DIR/shifts.rs:+2:22: +2:27
StorageLive(_13); // scope 0 at $DIR/shifts.rs:+2:31: +2:32
_13 = _4; // scope 0 at $DIR/shifts.rs:+2:31: +2:32
_14 = Lt(_13, const 8_u32); // scope 0 at $DIR/shifts.rs:+2:22: +2:32
assert(move _14, "attempt to shift right by `{}`, which would overflow", _13) -> [success: bb2, unwind: bb7]; // scope 0 at $DIR/shifts.rs:+2:22: +2:32
}
bb2: {
2023-03-22 03:06:19 -05:00
_11 = Shr(move _12, move _13); // scope 0 at $DIR/shifts.rs:+2:22: +2:32
StorageDead(_13); // scope 0 at $DIR/shifts.rs:+2:31: +2:32
2023-03-22 03:06:19 -05:00
StorageDead(_12); // scope 0 at $DIR/shifts.rs:+2:31: +2:32
StorageLive(_15); // scope 0 at $DIR/shifts.rs:+2:34: +2:44
StorageLive(_16); // scope 0 at $DIR/shifts.rs:+2:34: +2:39
_16 = _1; // scope 0 at $DIR/shifts.rs:+2:34: +2:39
StorageLive(_17); // scope 0 at $DIR/shifts.rs:+2:43: +2:44
_17 = _5; // scope 0 at $DIR/shifts.rs:+2:43: +2:44
_18 = Lt(_17, const 8_u128); // scope 0 at $DIR/shifts.rs:+2:34: +2:44
assert(move _18, "attempt to shift right by `{}`, which would overflow", _17) -> [success: bb3, unwind: bb7]; // scope 0 at $DIR/shifts.rs:+2:34: +2:44
}
bb3: {
2023-03-22 03:06:19 -05:00
_15 = Shr(move _16, move _17); // scope 0 at $DIR/shifts.rs:+2:34: +2:44
StorageDead(_17); // scope 0 at $DIR/shifts.rs:+2:43: +2:44
StorageDead(_16); // scope 0 at $DIR/shifts.rs:+2:43: +2:44
_6 = [move _7, move _11, move _15]; // scope 0 at $DIR/shifts.rs:+2:9: +2:45
StorageDead(_15); // scope 0 at $DIR/shifts.rs:+2:44: +2:45
StorageDead(_11); // scope 0 at $DIR/shifts.rs:+2:44: +2:45
StorageDead(_7); // scope 0 at $DIR/shifts.rs:+2:44: +2:45
2023-03-22 03:06:19 -05:00
StorageLive(_19); // scope 0 at $DIR/shifts.rs:+3:9: +3:39
StorageLive(_20); // scope 0 at $DIR/shifts.rs:+3:10: +3:18
StorageLive(_21); // scope 0 at $DIR/shifts.rs:+3:10: +3:13
_21 = _2; // scope 0 at $DIR/shifts.rs:+3:10: +3:13
StorageLive(_22); // scope 0 at $DIR/shifts.rs:+3:17: +3:18
_22 = _3; // scope 0 at $DIR/shifts.rs:+3:17: +3:18
_23 = Lt(_22, const 128_u8); // scope 0 at $DIR/shifts.rs:+3:10: +3:18
assert(move _23, "attempt to shift left by `{}`, which would overflow", _22) -> [success: bb4, unwind: bb7]; // scope 0 at $DIR/shifts.rs:+3:10: +3:18
}
bb4: {
2023-03-22 03:06:19 -05:00
_20 = Shl(move _21, move _22); // scope 0 at $DIR/shifts.rs:+3:10: +3:18
StorageDead(_22); // scope 0 at $DIR/shifts.rs:+3:17: +3:18
StorageDead(_21); // scope 0 at $DIR/shifts.rs:+3:17: +3:18
StorageLive(_24); // scope 0 at $DIR/shifts.rs:+3:20: +3:28
StorageLive(_25); // scope 0 at $DIR/shifts.rs:+3:20: +3:23
_25 = _2; // scope 0 at $DIR/shifts.rs:+3:20: +3:23
StorageLive(_26); // scope 0 at $DIR/shifts.rs:+3:27: +3:28
_26 = _4; // scope 0 at $DIR/shifts.rs:+3:27: +3:28
_27 = Lt(_26, const 128_u32); // scope 0 at $DIR/shifts.rs:+3:20: +3:28
assert(move _27, "attempt to shift left by `{}`, which would overflow", _26) -> [success: bb5, unwind: bb7]; // scope 0 at $DIR/shifts.rs:+3:20: +3:28
}
bb5: {
2023-03-22 03:06:19 -05:00
_24 = Shl(move _25, move _26); // scope 0 at $DIR/shifts.rs:+3:20: +3:28
StorageDead(_26); // scope 0 at $DIR/shifts.rs:+3:27: +3:28
StorageDead(_25); // scope 0 at $DIR/shifts.rs:+3:27: +3:28
StorageLive(_28); // scope 0 at $DIR/shifts.rs:+3:30: +3:38
StorageLive(_29); // scope 0 at $DIR/shifts.rs:+3:30: +3:33
_29 = _2; // scope 0 at $DIR/shifts.rs:+3:30: +3:33
StorageLive(_30); // scope 0 at $DIR/shifts.rs:+3:37: +3:38
_30 = _5; // scope 0 at $DIR/shifts.rs:+3:37: +3:38
_31 = Lt(_30, const 128_u128); // scope 0 at $DIR/shifts.rs:+3:30: +3:38
assert(move _31, "attempt to shift left by `{}`, which would overflow", _30) -> [success: bb6, unwind: bb7]; // scope 0 at $DIR/shifts.rs:+3:30: +3:38
}
bb6: {
2023-03-22 03:06:19 -05:00
_28 = Shl(move _29, move _30); // scope 0 at $DIR/shifts.rs:+3:30: +3:38
StorageDead(_30); // scope 0 at $DIR/shifts.rs:+3:37: +3:38
StorageDead(_29); // scope 0 at $DIR/shifts.rs:+3:37: +3:38
_19 = [move _20, move _24, move _28]; // scope 0 at $DIR/shifts.rs:+3:9: +3:39
StorageDead(_28); // scope 0 at $DIR/shifts.rs:+3:38: +3:39
2023-03-22 03:06:19 -05:00
StorageDead(_24); // scope 0 at $DIR/shifts.rs:+3:38: +3:39
StorageDead(_20); // scope 0 at $DIR/shifts.rs:+3:38: +3:39
_0 = (move _6, move _19); // scope 0 at $DIR/shifts.rs:+1:5: +4:6
StorageDead(_19); // scope 0 at $DIR/shifts.rs:+4:5: +4:6
StorageDead(_6); // scope 0 at $DIR/shifts.rs:+4:5: +4:6
return; // scope 0 at $DIR/shifts.rs:+5:2: +5:2
}
bb7 (cleanup): {
resume; // scope 0 at $DIR/shifts.rs:+0:1: +5:2
}
}