Skip to content

Commit

Permalink
Move test to mir-opt so we actually see that no inlining is happening
Browse files Browse the repository at this point in the history
  • Loading branch information
oli-obk committed Jan 23, 2021
1 parent 209889d commit 03c6364
Show file tree
Hide file tree
Showing 4 changed files with 95 additions and 4 deletions.
42 changes: 42 additions & 0 deletions src/test/mir-opt/inline/cycle.f.Inline.diff
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
- // MIR for `f` before Inline
+ // MIR for `f` after Inline

fn f(_1: impl Fn()) -> () {
debug g => _1; // in scope 0 at $DIR/cycle.rs:3:6: 3:7
let mut _0: (); // return place in scope 0 at $DIR/cycle.rs:3:20: 3:20
let _2: (); // in scope 0 at $DIR/cycle.rs:4:5: 4:8
let mut _3: &impl Fn(); // in scope 0 at $DIR/cycle.rs:4:5: 4:6
let mut _4: (); // in scope 0 at $DIR/cycle.rs:4:5: 4:8

bb0: {
StorageLive(_2); // scope 0 at $DIR/cycle.rs:4:5: 4:8
StorageLive(_3); // scope 0 at $DIR/cycle.rs:4:5: 4:6
_3 = &_1; // scope 0 at $DIR/cycle.rs:4:5: 4:6
StorageLive(_4); // scope 0 at $DIR/cycle.rs:4:5: 4:8
_2 = <impl Fn() as Fn<()>>::call(move _3, move _4) -> [return: bb1, unwind: bb3]; // scope 0 at $DIR/cycle.rs:4:5: 4:8
// mir::Constant
// + span: $DIR/cycle.rs:4:5: 4:6
// + literal: Const { ty: for<'r> extern "rust-call" fn(&'r impl Fn(), ()) -> <impl Fn() as std::ops::FnOnce<()>>::Output {<impl Fn() as std::ops::Fn<()>>::call}, val: Value(Scalar(<ZST>)) }
}

bb1: {
StorageDead(_4); // scope 0 at $DIR/cycle.rs:4:7: 4:8
StorageDead(_3); // scope 0 at $DIR/cycle.rs:4:7: 4:8
StorageDead(_2); // scope 0 at $DIR/cycle.rs:4:8: 4:9
_0 = const (); // scope 0 at $DIR/cycle.rs:3:20: 5:2
drop(_1) -> [return: bb2, unwind: bb4]; // scope 0 at $DIR/cycle.rs:5:1: 5:2
}

bb2: {
return; // scope 0 at $DIR/cycle.rs:5:2: 5:2
}

bb3 (cleanup): {
drop(_1) -> bb4; // scope 0 at $DIR/cycle.rs:5:1: 5:2
}

bb4 (cleanup): {
resume; // scope 0 at $DIR/cycle.rs:3:1: 5:2
}
}

25 changes: 25 additions & 0 deletions src/test/mir-opt/inline/cycle.g.Inline.diff
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
- // MIR for `g` before Inline
+ // MIR for `g` after Inline

fn g() -> () {
let mut _0: (); // return place in scope 0 at $DIR/cycle.rs:9:8: 9:8
let _1: (); // in scope 0 at $DIR/cycle.rs:10:5: 10:12

bb0: {
StorageLive(_1); // scope 0 at $DIR/cycle.rs:10:5: 10:12
_1 = f::<fn() {main}>(main) -> bb1; // scope 0 at $DIR/cycle.rs:10:5: 10:12
// mir::Constant
// + span: $DIR/cycle.rs:10:5: 10:6
// + literal: Const { ty: fn(fn() {main}) {f::<fn() {main}>}, val: Value(Scalar(<ZST>)) }
// mir::Constant
// + span: $DIR/cycle.rs:10:7: 10:11
// + literal: Const { ty: fn() {main}, val: Value(Scalar(<ZST>)) }
}

bb1: {
StorageDead(_1); // scope 0 at $DIR/cycle.rs:10:12: 10:13
_0 = const (); // scope 0 at $DIR/cycle.rs:9:8: 11:2
return; // scope 0 at $DIR/cycle.rs:11:2: 11:2
}
}

25 changes: 25 additions & 0 deletions src/test/mir-opt/inline/cycle.main.Inline.diff
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
- // MIR for `main` before Inline
+ // MIR for `main` after Inline

fn main() -> () {
let mut _0: (); // return place in scope 0 at $DIR/cycle.rs:14:11: 14:11
let _1: (); // in scope 0 at $DIR/cycle.rs:15:5: 15:9

bb0: {
StorageLive(_1); // scope 0 at $DIR/cycle.rs:15:5: 15:9
_1 = f::<fn() {g}>(g) -> bb1; // scope 0 at $DIR/cycle.rs:15:5: 15:9
// mir::Constant
// + span: $DIR/cycle.rs:15:5: 15:6
// + literal: Const { ty: fn(fn() {g}) {f::<fn() {g}>}, val: Value(Scalar(<ZST>)) }
// mir::Constant
// + span: $DIR/cycle.rs:15:7: 15:8
// + literal: Const { ty: fn() {g}, val: Value(Scalar(<ZST>)) }
}

bb1: {
StorageDead(_1); // scope 0 at $DIR/cycle.rs:15:9: 15:10
_0 = const (); // scope 0 at $DIR/cycle.rs:14:11: 16:2
return; // scope 0 at $DIR/cycle.rs:16:2: 16:2
}
}

Original file line number Diff line number Diff line change
@@ -1,17 +1,16 @@
// Needs build-pass to trigger `optimized_mir` on all mir bodies
// build-pass
// compile-flags: -Zmir-opt-level=2

// EMIT_MIR cycle.f.Inline.diff
#[inline(always)]
fn f(g: impl Fn()) {
g();
}

// EMIT_MIR cycle.g.Inline.diff
#[inline(always)]
fn g() {
f(main);
}

// EMIT_MIR cycle.main.Inline.diff
fn main() {
f(g);
}

0 comments on commit 03c6364

Please sign in to comment.