mirror of
https://github.com/RPCS3/llvm.git
synced 2024-11-27 05:30:29 +00:00
99b6a1f72d
Patch by Diego Treviño! Differential Revision: https://reviews.llvm.org/D66320 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@372264 91177308-0d34-0410-b5e6-96231b3b80d8
30 lines
981 B
LLVM
30 lines
981 B
LLVM
; Test that llvm-reduce can remove uninteresting Basic Blocks, and remove them from instructions (i.e. SwitchInst, BranchInst and IndirectBrInst)
|
|
; Note: if an uninteresting BB is the default case for a switch, the instruction is removed altogether (since the default case cannot be replaced)
|
|
;
|
|
; RUN: llvm-reduce --test %python --test-arg %p/Inputs/remove-bbs.py %s -o %t
|
|
; RUN: cat %t | FileCheck -implicit-check-not=uninteresting %s
|
|
|
|
define void @main() {
|
|
interesting:
|
|
; CHECK-NOT: switch i32 0, label %uninteresting
|
|
switch i32 0, label %uninteresting [
|
|
i32 0, label %uninteresting
|
|
]
|
|
|
|
uninteresting:
|
|
ret void
|
|
|
|
interesting2:
|
|
; CHECK: switch i32 1, label %interesting3
|
|
switch i32 1, label %interesting3 [
|
|
; CHECK-NOT: i32 0, label %uninteresting
|
|
i32 0, label %uninteresting
|
|
; CHECK: i32 1, label %interesting3
|
|
i32 1, label %interesting3
|
|
]
|
|
|
|
interesting3:
|
|
; CHECK: br label %interesting2
|
|
br i1 true, label %interesting2, label %uninteresting
|
|
}
|