blob: 5e3e38ef1d945fd0ca4db15a0bec8350e5067f0e [file] [log] [blame]
Chandler Carruth1aff0222016-02-19 04:09:40 +00001; Test the particular pass pipelines have the expected structure. This is
2; particularly important in order to check that the implicit scheduling of the
3; legacy pass manager doesn't introduce unexpected structural changes in the
4; pass pipeline.
5;
6; RUN: opt -disable-output -disable-verify -debug-pass=Structure \
7; RUN: -O2 %s 2>&1 \
8; RUN: | FileCheck %s --check-prefix=CHECK-O2
9;
10; In the first pipeline there should just be a function pass manager, no other
11; pass managers.
12; CHECK-O2: Pass Arguments:
13; CHECK-O2-NOT: Manager
14; CHECK-O2: FunctionPass Manager
15; CHECK-O2-NOT: Manager
16;
17; CHECK-O2: Pass Arguments:
18; CHECK-O2: ModulePass Manager
19; CHECK-O2-NOT: Manager
20; First function pass pipeline just does early opts.
21; CHECK-O2: FunctionPass Manager
22; CHECK-O2-NOT: Manager
23; FIXME: It's a bit odd to do dead arg elim in the middle of early opts...
24; CHECK-O2: Dead Argument Elimination
25; CHECK-O2-NEXT: FunctionPass Manager
26; CHECK-O2-NOT: Manager
27; Very carefully asert the CGSCC pass pipeline as it is fragile and unusually
28; susceptible to phase ordering issues.
29; CHECK-O2: CallGraph Construction
30; CHECK-O2-NEXT: Globals Alias Analysis
31; CHECK-O2-NEXT: Call Graph SCC Pass Manager
32; CHECK-O2-NEXT: Remove unused exception handling info
33; CHECK-O2-NEXT: Function Integration/Inlining
34; CHECK-O2-NEXT: Deduce function attributes
35; Next up is the main function pass pipeline. It shouldn't be split up and
36; should contain the main loop pass pipeline as well.
37; CHECK-O2-NEXT: FunctionPass Manager
38; CHECK-O2-NOT: Manager
39; CHECK-O2: Loop Pass Manager
40; CHECK-O2-NOT: Manager
Chandler Carruth1aff0222016-02-19 04:09:40 +000041; FIXME: We shouldn't be pulling out to simplify-cfg and instcombine and
42; causing new loop pass managers.
43; CHECK-O2: Simplify the CFG
44; CHECK-O2-NOT: Manager
45; CHECK-O2: Combine redundant instructions
46; CHECK-O2-NOT: Manager
47; CHECK-O2: Loop Pass Manager
48; CHECK-O2-NOT: Manager
Chandler Carruth1aff0222016-02-19 04:09:40 +000049; FIXME: It isn't clear that we need yet another loop pass pipeline
50; and run of LICM here.
51; CHECK-O2-NOT: Manager
52; CHECK-O2: Loop Pass Manager
53; CHECK-O2-NEXT: Loop Invariant Code Motion
54; CHECK-O2-NOT: Manager
55; Next we break out of the main Function passes inside the CGSCC pipeline with
56; a barrier pass.
57; CHECK-O2: A No-Op Barrier Pass
Mehdi Amini45c7b3e2016-05-02 16:53:16 +000058; Inferring function attribute should be immediately after the CGSCC pipeline.
59; CHECK-O2-NEXT: CallGraph
60; CHECK-O2-NEXT: Deduce function attributes in RPO
Chandler Carruth1aff0222016-02-19 04:09:40 +000061; CHECK-O2-NOT: Manager
62; Next is the late function pass pipeline.
63; CHECK-O2: FunctionPass Manager
64; CHECK-O2-NOT: Manager
65; We rotate loops prior to vectorization.
66; CHECK-O2: Loop Pass Manager
67; CHECK-O2-NEXT: Rotate Loops
68; CHECK-O2-NOT: Manager
69; CHECK-O2: Loop Vectorization
70; CHECK-O2-NOT: Manager
71; CHECK-O2: SLP Vectorizer
72; CHECK-O2-NOT: Manager
73; After vectorization we do partial unrolling.
74; CHECK-O2: Loop Pass Manager
75; CHECK-O2-NEXT: Unroll loops
76; CHECK-O2-NOT: Manager
77; After vectorization and unrolling we try to do any cleanup of inserted code,
78; including a run of LICM. This shouldn't run in the same loop pass manager as
79; the runtime unrolling though.
80; CHECK-O2: Loop Pass Manager
81; CHECK-O2-NEXT: Loop Invariant Code Motion
82; CHECK-O2-NOT: Manager
83;
84; FIXME: There really shouldn't be another pass manager, especially one that
85; just builds the domtree. It doesn't even run the verifier.
86; CHECK-O2: Pass Arguments:
87; CHECK-O2-NEXT: FunctionPass Manager
88; CHECK-O2-NEXT: Dominator Tree Construction
89
90define void @foo() {
91 ret void
92}