aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/Other/opt-disable.ll
blob: 4506042215cbfa8964eb8ba2c47d8be762c8929b (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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
; This test uses the same IR functions of the opt-bisect test
; but it checks the correctness of the -opt-disable flag.
; -opt-disable-enable-verbosity is required to have output.

; RUN: opt -disable-output -disable-verify \
; RUN:     -opt-disable-enable-verbosity \
; RUN:     -passes=inferattrs -opt-disable=inferattrs %s 2>&1 \
; RUN:     | FileCheck %s --check-prefix=CHECK-MODULE-PASS
; CHECK-MODULE-PASS: OptDisable: NOT running pass inferattrs on [module]

; RUN: opt -disable-output -disable-verify \
; RUN:     -opt-disable-enable-verbosity \
; RUN:     -passes=sroa -opt-disable=sroa %s 2>&1 \
; RUN:     | FileCheck %s --check-prefix=CHECK-FUNCTION-PASS
; CHECK-FUNCTION-PASS: OptDisable: NOT running pass sroa on f1
; CHECK-FUNCTION-PASS: OptDisable: NOT running pass sroa on f2
; CHECK-FUNCTION-PASS: OptDisable: NOT running pass sroa on f3
; CHECK-FUNCTION-PASS: OptDisable: NOT running pass sroa on f4

; RUN: opt -disable-output -disable-verify \
; RUN:     -opt-disable=inferattrs,function-attrs  \
; RUN:     -opt-disable-enable-verbosity \
; RUN:     -passes='inferattrs,cgscc(function-attrs,function(early-cse))' %s 2>&1 \
; RUN:     | FileCheck %s --check-prefix=CHECK-MULTI-PASS
; CHECK-MULTI-PASS: OptDisable: NOT running pass inferattrs on [module]
; CHECK-MULTI-PASS: OptDisable: NOT running pass function-attrs on (f1)
; CHECK-MULTI-PASS: OptDisable: running pass early-cse on f1
; CHECK-MULTI-PASS: OptDisable: NOT running pass function-attrs on (f2)
; CHECK-MULTI-PASS: OptDisable: running pass early-cse on f2
; CHECK-MULTI-PASS: OptDisable: NOT running pass function-attrs on (f3)
; CHECK-MULTI-PASS: OptDisable: running pass early-cse on f3
; CHECK-MULTI-PASS: OptDisable: NOT running pass function-attrs on (f4)
; CHECK-MULTI-PASS: OptDisable: running pass early-cse on f4

declare i32 @g()

define void @f1(i1 %arg) {
entry:
  br label %loop.0
loop.0:
  br i1 %arg, label %loop.0.0, label %loop.1
loop.0.0:
  br i1 %arg, label %loop.0.0, label %loop.0.1
loop.0.1:
  br i1 %arg, label %loop.0.1, label %loop.0
loop.1:
  br i1 %arg, label %loop.1, label %loop.1.bb1
loop.1.bb1:
  br i1 %arg, label %loop.1, label %loop.1.bb2
loop.1.bb2:
  br i1 %arg, label %end, label %loop.1.0
loop.1.0:
  br i1 %arg, label %loop.1.0, label %loop.1
end:
  ret void
}

define i32 @f2() {
entry:
  ret i32 0
}

define i32 @f3() {
entry:
  %temp = call i32 @g()
  %icmp = icmp ugt i32 %temp, 2
  br i1 %icmp, label %bb.true, label %bb.false
bb.true:
  %temp2 = call i32 @f2()
  ret i32 %temp2
bb.false:
  ret i32 0
}

define void @f4(i1 %arg) {
entry:
  %i = alloca i32, align 4
  call void @llvm.lifetime.start(i64 4, ptr %i)
  br label %for.cond

for.cond:
  br i1 %arg, label %for.body, label %for.end

for.body:
  br label %for.cond

for.end:
  ret void
}

declare void @llvm.lifetime.start(i64, ptr nocapture)