[DAGCombiner] Add target hook function to decide folding (mul (add x, c1), c2)
[llvm-project.git] / llvm / test / Transforms / Inline / cgscc-cycle-debug.ll
blob21a5ae5247547c576c0032b31272e16c227551ce
1 ; When an SCC got split due to inlining, we have two mechanisms for reprocessing the updated SCC, first is UR.UpdatedC
2 ; that repeatedly rerun the new, current SCC; second is a worklist for all newly split SCCs. We need to avoid rerun of
3 ; the same SCC when the SCC is set to be processed by both mechanisms back to back. In pathological cases, such extra,
4 ; redundant rerun could cause exponential size growth due to inlining along cycles.
6 ; The test cases here illustrates potential redundant rerun and how it's prevented, however there's no extra inlining
7 ; even if we allow the redundant rerun. In real code, when inliner makes different decisions for different call sites
8 ; of the same caller-callee edge, we could end up getting more recursive inlining without SCC mutation.
10 ; REQUIRES: asserts
11 ; RUN: opt < %s -passes='cgscc(inline)' -inline-threshold=500 -debug-only=cgscc -S 2>&1 | FileCheck %s
13 ; CHECK: Running an SCC pass across the RefSCC: [(test1_a, test1_b, test1_c)]
14 ; CHECK: Enqueuing the existing SCC in the worklist:(test1_b)
15 ; CHECK: Enqueuing a newly formed SCC:(test1_c)
16 ; CHECK: Enqueuing a new RefSCC in the update worklist: [(test1_b)]
17 ; CHECK: Switch an internal ref edge to a call edge from 'test1_a' to 'test1_c'
18 ; CHECK: Switch an internal ref edge to a call edge from 'test1_a' to 'test1_a'
19 ; CHECK: Re-running SCC passes after a refinement of the current SCC: (test1_c, test1_a)
20 ; CHECK: Skipping redundant run on SCC: (test1_c, test1_a)
21 ; CHECK: Skipping an SCC that is now part of some other RefSCC...
23 declare void @external(i32 %seed)
25 define void @test1_a(i32 %num) {
26 entry:
27   call void @test1_b(i32 %num)
28   call void @external(i32 %num)
29   ret void
32 define void @test1_b(i32 %num) {
33 entry:
34   call void @test1_c(i32 %num)
35   call void @test1_a(i32 %num)
36   call void @external(i32 %num)
37   ret void
40 define void @test1_c(i32 %num) #0 {
41   call void @test1_a(i32 %num)
42   ret void
45 attributes #0 = { noinline nounwind optnone }