Files
clang-p2996/llvm/test/Transforms/SimplifyCFG/duplicate-phis.ll
Roman Lebedev aa2009fe78 [NFCI][SimplifyCFG] Mark all the SimplifyCFG tests that already don't invalidate DomTree as such
First step after e113317958,
in these tests, DomTree is valid afterwards, so mark them as such,
so that they don't regress.

In further steps, SimplifyCFG transforms shall taught to preserve DomTree,
in as small steps as possible.
2020-12-17 01:03:49 +03:00

22 lines
522 B
LLVM

; RUN: opt < %s -instcombine -simplifycfg -simplifycfg-require-and-preserve-domtree=1 -S | grep " = phi " | count 1
; instcombine should sort the PHI operands so that simplifycfg can see the
; duplicate and remove it.
define i32 @foo(i1 %t) {
entry:
call void @bar()
br i1 %t, label %true, label %false
true:
call void @bar()
br label %false
false:
%a = phi i32 [ 2, %true ], [ 5, %entry ]
%b = phi i32 [ 5, %entry ], [ 2, %true ]
call void @bar()
%c = add i32 %a, %b
ret i32 %c
}
declare void @bar()