mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 11:13:28 +01:00
ebe25b403e
Prevent `invertCondition` from creating the inversion instruction, in case the given value is an argument which has already been inverted. Note that this approach has already been taken in case the given value is an instruction (and not an argument). Differential Revision: https://reviews.llvm.org/D80399
46 lines
1.4 KiB
LLVM
46 lines
1.4 KiB
LLVM
; RUN: opt -S -structurizecfg %s -o - | FileCheck %s
|
|
|
|
; CHECK-NOT: br i1 true
|
|
|
|
define void @blam(i32 addrspace(1)* nocapture %arg, float %arg1, float %arg2) {
|
|
; CHECK: bb:
|
|
bb:
|
|
br label %bb3
|
|
|
|
; CHECK: bb3:
|
|
; CHECK: %tmp4.inv = xor i1 %tmp4, true
|
|
; CHECK: br i1 %tmp4.inv, label %bb5, label %Flow
|
|
bb3: ; preds = %bb7, %bb
|
|
%tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb7 ]
|
|
%tmp4 = fcmp ult float %arg1, 3.500000e+00
|
|
br i1 %tmp4, label %bb7, label %bb5
|
|
|
|
; CHECK: bb5:
|
|
; CHECK: %tmp6.inv = xor i1 %tmp6, true
|
|
; CHECK: br label %Flow
|
|
bb5: ; preds = %bb3
|
|
%tmp6 = fcmp olt float 0.000000e+00, %arg2
|
|
br i1 %tmp6, label %bb10, label %bb7
|
|
|
|
; CHECK: Flow:
|
|
; CHECK: %0 = phi i1 [ %tmp6.inv, %bb5 ], [ %tmp4, %bb3 ]
|
|
; CHECK: br i1 %0, label %bb7, label %Flow1
|
|
|
|
; CHECK: bb7:
|
|
; CHECK: br label %Flow1
|
|
bb7: ; preds = %bb5, %bb3
|
|
%tmp8 = add nuw nsw i64 %tmp, 1
|
|
%tmp9 = icmp slt i64 %tmp8, 5
|
|
br i1 %tmp9, label %bb3, label %bb10
|
|
|
|
; CHECK: Flow1:
|
|
; CHECK: %3 = phi i1 [ %tmp9.inv, %bb7 ], [ true, %Flow ]
|
|
; CHECK: br i1 %3, label %bb10, label %bb3
|
|
|
|
; CHECK: bb10:
|
|
bb10: ; preds = %bb7, %bb5
|
|
%tmp11 = phi i32 [ 15, %bb5 ], [ 255, %bb7 ]
|
|
store i32 %tmp11, i32 addrspace(1)* %arg, align 4
|
|
ret void
|
|
}
|