[llvm] 325896d - [PhaseOrdering] add tests for cmp + boolean/bitwise logic; NFC
Sanjay Patel via llvm-commits
llvm-commits at lists.llvm.org
Mon May 16 07:35:23 PDT 2022
Author: Sanjay Patel
Date: 2022-05-16T10:35:10-04:00
New Revision: 325896d82339d7328bdaf54b23f2f26cc289d597
URL: https://github.com/llvm/llvm-project/commit/325896d82339d7328bdaf54b23f2f26cc289d597
DIFF: https://github.com/llvm/llvm-project/commit/325896d82339d7328bdaf54b23f2f26cc289d597.diff
LOG: [PhaseOrdering] add tests for cmp + boolean/bitwise logic; NFC
The tests (see C++ source in #54692) have multiple potential
optimizations/canonicalizations, but we should be consistent
since they are logically identical.
Added:
llvm/test/Transforms/PhaseOrdering/cmp-logic.ll
Modified:
Removed:
################################################################################
diff --git a/llvm/test/Transforms/PhaseOrdering/cmp-logic.ll b/llvm/test/Transforms/PhaseOrdering/cmp-logic.ll
new file mode 100644
index 000000000000..3ffa28ff2a82
--- /dev/null
+++ b/llvm/test/Transforms/PhaseOrdering/cmp-logic.ll
@@ -0,0 +1,112 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
+; RUN: opt -passes='default<O1>' -S < %s | FileCheck %s
+
+define i32 @PR38781(i32 noundef %a, i32 noundef %b) {
+; CHECK-LABEL: @PR38781(
+; CHECK-NEXT: [[A_LOBIT_NOT1_DEMORGAN:%.*]] = or i32 [[B:%.*]], [[A:%.*]]
+; CHECK-NEXT: [[A_LOBIT_NOT1:%.*]] = xor i32 [[A_LOBIT_NOT1_DEMORGAN]], -1
+; CHECK-NEXT: [[AND:%.*]] = lshr i32 [[A_LOBIT_NOT1]], 31
+; CHECK-NEXT: ret i32 [[AND]]
+;
+ %cmp = icmp sge i32 %a, 0
+ %conv = zext i1 %cmp to i32
+ %cmp1 = icmp sge i32 %b, 0
+ %conv2 = zext i1 %cmp1 to i32
+ %and = and i32 %conv, %conv2
+ ret i32 %and
+}
+
+define i1 @PR54692_a(i8 noundef signext %c) #0 {
+; CHECK-LABEL: @PR54692_a(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[TMP0:%.*]] = icmp ult i8 [[C:%.*]], 32
+; CHECK-NEXT: [[CMP5:%.*]] = icmp eq i8 [[C]], 127
+; CHECK-NEXT: [[OR1:%.*]] = or i1 [[TMP0]], [[CMP5]]
+; CHECK-NEXT: ret i1 [[OR1]]
+;
+entry:
+ %conv = sext i8 %c to i32
+ %cmp = icmp sge i32 %conv, 0
+ br i1 %cmp, label %land.rhs, label %land.end
+
+land.rhs:
+ %conv1 = sext i8 %c to i32
+ %cmp2 = icmp sle i32 %conv1, 31
+ br label %land.end
+
+land.end:
+ %0 = phi i1 [ false, %entry ], [ %cmp2, %land.rhs ]
+ %conv3 = zext i1 %0 to i32
+ %conv4 = sext i8 %c to i32
+ %cmp5 = icmp eq i32 %conv4, 127
+ %conv6 = zext i1 %cmp5 to i32
+ %or = or i32 %conv3, %conv6
+ %tobool = icmp ne i32 %or, 0
+ ret i1 %tobool
+}
+
+define i1 @PR54692_b(i8 noundef signext %c) {
+; CHECK-LABEL: @PR54692_b(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[TMP0:%.*]] = xor i8 [[C:%.*]], -1
+; CHECK-NEXT: [[TMP1:%.*]] = lshr i8 [[TMP0]], 7
+; CHECK-NEXT: [[DOTNOT:%.*]] = zext i8 [[TMP1]] to i32
+; CHECK-NEXT: [[CMP3:%.*]] = icmp slt i8 [[C]], 32
+; CHECK-NEXT: [[CONV4:%.*]] = zext i1 [[CMP3]] to i32
+; CHECK-NEXT: [[AND:%.*]] = and i32 [[DOTNOT]], [[CONV4]]
+; CHECK-NEXT: [[CMP6:%.*]] = icmp eq i8 [[C]], 127
+; CHECK-NEXT: [[CONV7:%.*]] = zext i1 [[CMP6]] to i32
+; CHECK-NEXT: [[OR:%.*]] = or i32 [[AND]], [[CONV7]]
+; CHECK-NEXT: [[TOBOOL:%.*]] = icmp ne i32 [[OR]], 0
+; CHECK-NEXT: ret i1 [[TOBOOL]]
+;
+entry:
+ %conv = sext i8 %c to i32
+ %cmp = icmp sge i32 %conv, 0
+ %conv1 = zext i1 %cmp to i32
+ %conv2 = sext i8 %c to i32
+ %cmp3 = icmp sle i32 %conv2, 31
+ %conv4 = zext i1 %cmp3 to i32
+ %and = and i32 %conv1, %conv4
+ %conv5 = sext i8 %c to i32
+ %cmp6 = icmp eq i32 %conv5, 127
+ %conv7 = zext i1 %cmp6 to i32
+ %or = or i32 %and, %conv7
+ %tobool = icmp ne i32 %or, 0
+ ret i1 %tobool
+}
+
+define i1 @PR54692_c(i8 noundef signext %c) {
+; CHECK-LABEL: @PR54692_c(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[TMP0:%.*]] = xor i8 [[C:%.*]], -1
+; CHECK-NEXT: [[TMP1:%.*]] = lshr i8 [[TMP0]], 7
+; CHECK-NEXT: [[DOTNOT:%.*]] = zext i8 [[TMP1]] to i32
+; CHECK-NEXT: [[CMP3:%.*]] = icmp slt i8 [[C]], 32
+; CHECK-NEXT: [[CONV4:%.*]] = zext i1 [[CMP3]] to i32
+; CHECK-NEXT: [[AND:%.*]] = and i32 [[DOTNOT]], [[CONV4]]
+; CHECK-NEXT: [[TOBOOL:%.*]] = icmp ne i32 [[AND]], 0
+; CHECK-NEXT: [[CMP6:%.*]] = icmp eq i8 [[C]], 127
+; CHECK-NEXT: [[T0:%.*]] = or i1 [[CMP6]], [[TOBOOL]]
+; CHECK-NEXT: ret i1 [[T0]]
+;
+entry:
+ %conv = sext i8 %c to i32
+ %cmp = icmp sge i32 %conv, 0
+ %conv1 = zext i1 %cmp to i32
+ %conv2 = sext i8 %c to i32
+ %cmp3 = icmp sle i32 %conv2, 31
+ %conv4 = zext i1 %cmp3 to i32
+ %and = and i32 %conv1, %conv4
+ %tobool = icmp ne i32 %and, 0
+ br i1 %tobool, label %lor.end, label %lor.rhs
+
+lor.rhs:
+ %conv5 = sext i8 %c to i32
+ %cmp6 = icmp eq i32 %conv5, 127
+ br label %lor.end
+
+lor.end:
+ %t0 = phi i1 [ true, %entry ], [ %cmp6, %lor.rhs ]
+ ret i1 %t0
+}
More information about the llvm-commits
mailing list