about summary refs log tree commit diff
path: root/tests/mir-opt/inline/unchecked_shifts.unchecked_shl_unsigned_smaller.Inline.panic-unwind.diff
blob: 61fdb69f74b700e25fff2455512ccb6cc5e6c97e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
- // MIR for `unchecked_shl_unsigned_smaller` before Inline
+ // MIR for `unchecked_shl_unsigned_smaller` after Inline
  
  fn unchecked_shl_unsigned_smaller(_1: u16, _2: u32) -> u16 {
      debug a => _1;
      debug b => _2;
      let mut _0: u16;
      let mut _3: u16;
      let mut _4: u32;
+     scope 1 (inlined #[track_caller] core::num::<impl u16>::unchecked_shl) {
+         let _5: ();
+         scope 2 (inlined core::ub_checks::check_language_ub) {
+             let mut _6: bool;
+             scope 3 (inlined core::ub_checks::check_language_ub::runtime) {
+             }
+         }
+     }
  
      bb0: {
          StorageLive(_3);
          _3 = copy _1;
          StorageLive(_4);
          _4 = copy _2;
-         _0 = core::num::<impl u16>::unchecked_shl(move _3, move _4) -> [return: bb1, unwind continue];
+         StorageLive(_5);
+         StorageLive(_6);
+         _6 = UbChecks();
+         switchInt(copy _6) -> [0: bb2, otherwise: bb1];
      }
  
      bb1: {
+         _5 = core::num::<impl u16>::unchecked_shl::precondition_check(copy _4) -> [return: bb2, unwind unreachable];
+     }
+ 
+     bb2: {
+         _0 = ShlUnchecked(copy _3, copy _4);
+         StorageDead(_6);
+         StorageDead(_5);
          StorageDead(_4);
          StorageDead(_3);
          return;
      }
  }