1 ; RUN: opt -debugify-each -O3 -S -o /dev/null < %s 2> %t
2 ; RUN: FileCheck %s -input-file=%t -check-prefix=MODULE-PASS
3 ; RUN: FileCheck %s -input-file=%t -check-prefix=FUNCTION-PASS
4 ; RUN: opt -disable-output -debugify-each -passes='default<O3>' %s 2> %t
5 ; RUN: FileCheck %s -input-file=%t -check-prefix=MODULE-PASS
6 ; RUN: FileCheck %s -input-file=%t -check-prefix=FUNCTION-PASS
8 ; RUN: opt -enable-debugify -debugify-each -O3 -S -o /dev/null < %s 2> %t
9 ; RUN: FileCheck %s -input-file=%t -check-prefix=MODULE-PASS
10 ; RUN: FileCheck %s -input-file=%t -check-prefix=FUNCTION-PASS
12 ; RUN: opt -debugify-each -instrprof -instrprof -sroa -sccp -S -o /dev/null < %s 2> %t
13 ; RUN: FileCheck %s -input-file=%t -check-prefix=MODULE-PASS
14 ; RUN: FileCheck %s -input-file=%t -check-prefix=FUNCTION-PASS
16 ; Verify that debugify each can be safely used with piping
17 ; RUN: opt -debugify-each -O1 < %s | opt -O2 -o /dev/null
19 ; Check that the quiet mode emits no messages.
20 ; RUN: opt -disable-output -debugify-quiet -debugify-each -O1 < %s 2>&1 | count 0
22 ; Check that stripped textual IR compares equal before and after applying
24 ; RUN: opt -O1 < %s -S -o %t.before
25 ; RUN: opt -O1 -debugify-each < %s -S -o %t.after
26 ; RUN: diff %t.before %t.after
28 ; Check that stripped IR compares equal before and after applying debugify.
29 ; RUN: opt -O1 < %s | llvm-dis -o %t.before
30 ; RUN: opt -O1 -debugify-each < %s | llvm-dis -o %t.after
31 ; RUN: diff %t.before %t.after
33 ; Check that we only run debugify once per function per function pass.
34 ; This ensures that we don't run it for pass managers/verifiers/printers.
35 ; RUN: opt -debugify-each -passes=instsimplify -S -o /dev/null < %s 2> %t
36 ; RUN: FileCheck %s -input-file=%t -check-prefix=FUNCTION-PASS-ONE
38 ; Check that we only run debugify once per module pass
39 ; (plus the implicitly added begin/end verifier passes).
40 ; RUN: opt -debugify-each -passes=globalopt -S -o /dev/null < %s 2> %t
41 ; RUN: FileCheck %s -input-file=%t -check-prefix=MODULE-PASS-ONE
43 define void @foo(i32 %arg) {
44 call i32 asm "bswap $0", "=r,r"(i32 %arg)
52 ; Verify that the module & function (check-)debugify passes run at least twice.
54 ; MODULE-PASS: CheckModuleDebugify [{{.*}}]
55 ; MODULE-PASS: CheckModuleDebugify [{{.*}}]
57 ; FUNCTION-PASS: CheckFunctionDebugify [{{.*}}]
58 ; FUNCTION-PASS: CheckFunctionDebugify [{{.*}}]
59 ; FUNCTION-PASS: CheckFunctionDebugify [{{.*}}]
60 ; FUNCTION-PASS: CheckFunctionDebugify [{{.*}}]
62 ; MODULE-PASS-ONE: CheckModuleDebugify [{{.*}}]
63 ; MODULE-PASS-ONE-NOT: CheckModuleDebugify [{{.*}}]
65 ; FUNCTION-PASS-ONE: CheckFunctionDebugify [{{.*}}]
66 ; FUNCTION-PASS-ONE: CheckFunctionDebugify [{{.*}}]
67 ; FUNCTION-PASS-ONE-NOT: CheckFunctionDebugify [{{.*}}]