; 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 = fcmp uge float 0.000000e+00, %arg2 ; 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, %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, %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 }