summaryrefslogtreecommitdiffstats
path: root/llvm/test/Transforms/StructurizeCFG/invert-constantexpr.ll
diff options
context:
space:
mode:
Diffstat (limited to 'llvm/test/Transforms/StructurizeCFG/invert-constantexpr.ll')
-rw-r--r--llvm/test/Transforms/StructurizeCFG/invert-constantexpr.ll50
1 files changed, 50 insertions, 0 deletions
diff --git a/llvm/test/Transforms/StructurizeCFG/invert-constantexpr.ll b/llvm/test/Transforms/StructurizeCFG/invert-constantexpr.ll
new file mode 100644
index 00000000000..61482bb73ad
--- /dev/null
+++ b/llvm/test/Transforms/StructurizeCFG/invert-constantexpr.ll
@@ -0,0 +1,50 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
+; RUN: opt -S -o - -structurizecfg < %s | FileCheck %s
+
+@g = global i32 0
+
+define void @invert_constantexpr_condition(i32 %arg, i32 %arg1) #0 {
+; CHECK-LABEL: @invert_constantexpr_condition(
+; CHECK-NEXT: bb:
+; CHECK-NEXT: [[TMP:%.*]] = icmp eq i32 [[ARG:%.*]], 0
+; CHECK-NEXT: [[TMP0:%.*]] = xor i1 [[TMP]], true
+; CHECK-NEXT: br i1 icmp eq (i32 ptrtoint (i32* @g to i32), i32 0), label [[BB2:%.*]], label [[FLOW:%.*]]
+; CHECK: bb2:
+; CHECK-NEXT: br label [[FLOW]]
+; CHECK: bb3:
+; CHECK-NEXT: [[TMP4:%.*]] = phi i1 [ undef, [[FLOW]] ], [ [[TMP7:%.*]], [[BB6:%.*]] ]
+; CHECK-NEXT: [[TMP5:%.*]] = or i1 [[TMP4]], icmp eq (i32 ptrtoint (i32* @g to i32), i32 0)
+; CHECK-NEXT: br label [[BB8:%.*]]
+; CHECK: Flow:
+; CHECK-NEXT: [[TMP1:%.*]] = phi i1 [ [[TMP0]], [[BB2]] ], [ icmp ne (i32 ptrtoint (i32* @g to i32), i32 0), [[BB:%.*]] ]
+; CHECK-NEXT: br i1 [[TMP1]], label [[BB6]], label [[BB3:%.*]]
+; CHECK: bb6:
+; CHECK-NEXT: [[TMP7]] = icmp slt i32 [[ARG]], [[ARG1:%.*]]
+; CHECK-NEXT: br label [[BB3]]
+; CHECK: bb8:
+; CHECK-NEXT: ret void
+;
+bb:
+ %tmp = icmp eq i32 %arg, 0
+ br i1 icmp eq (i32 ptrtoint (i32* @g to i32), i32 0), label %bb2, label %bb6
+
+bb2:
+ br i1 %tmp, label %bb3, label %bb6
+
+bb3:
+ %tmp4 = phi i1 [ %tmp7, %bb6 ], [ undef, %bb2 ]
+ %tmp5 = or i1 %tmp4, icmp eq (i32 ptrtoint (i32* @g to i32), i32 0)
+ br i1 %tmp5, label %bb8, label %bb8
+
+bb6:
+ %tmp7 = icmp slt i32 %arg, %arg1
+ br label %bb3
+
+bb8:
+ ret void
+}
+
+declare i32 @llvm.amdgcn.workitem.id.x() #1
+
+attributes #0 = { nounwind }
+attributes #1 = { nounwind readnone }
OpenPOWER on IntegriCloud