[llvm] 149a698 - [InstCombine] Pre-commit test for D158915

Bryan Chan via llvm-commits llvm-commits at lists.llvm.org
Thu Sep 7 07:19:29 PDT 2023


Author: Qi Hu
Date: 2023-09-07T10:28:53-04:00
New Revision: 149a698589900a41ac21354b6400ca0e8d214cbf

URL: https://github.com/llvm/llvm-project/commit/149a698589900a41ac21354b6400ca0e8d214cbf
DIFF: https://github.com/llvm/llvm-project/commit/149a698589900a41ac21354b6400ca0e8d214cbf.diff

LOG: [InstCombine] Pre-commit test for D158915

Differential Revision: https://reviews.llvm.org/D159129

Added: 
    llvm/test/Transforms/InstCombine/fold-minmax-i1.ll

Modified: 
    

Removed: 
    


################################################################################
diff  --git a/llvm/test/Transforms/InstCombine/fold-minmax-i1.ll b/llvm/test/Transforms/InstCombine/fold-minmax-i1.ll
new file mode 100644
index 000000000000000..44d913d3bb608fc
--- /dev/null
+++ b/llvm/test/Transforms/InstCombine/fold-minmax-i1.ll
@@ -0,0 +1,99 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
+; RUN: opt < %s -passes=instcombine -S | FileCheck %s
+
+;------------------------------------------------------------------------------;
+; Scalar tests
+;------------------------------------------------------------------------------;
+
+define i1 @umin_scalar(i1 %0, i1 %1) {
+; CHECK-LABEL: define i1 @umin_scalar
+; CHECK-SAME: (i1 [[TMP0:%.*]], i1 [[TMP1:%.*]]) {
+; CHECK-NEXT:    [[TMP3:%.*]] = call i1 @llvm.umin.i1(i1 [[TMP0]], i1 [[TMP1]])
+; CHECK-NEXT:    ret i1 [[TMP3]]
+;
+  %3 = call i1 @llvm.umin.i1(i1 %0, i1 %1)
+  ret i1 %3
+}
+
+define i1 @smin_scalar(i1 %0, i1 %1) {
+; CHECK-LABEL: define i1 @smin_scalar
+; CHECK-SAME: (i1 [[TMP0:%.*]], i1 [[TMP1:%.*]]) {
+; CHECK-NEXT:    [[TMP3:%.*]] = call i1 @llvm.smin.i1(i1 [[TMP0]], i1 [[TMP1]])
+; CHECK-NEXT:    ret i1 [[TMP3]]
+;
+  %3 = call i1 @llvm.smin.i1(i1 %0, i1 %1)
+  ret i1 %3
+}
+
+define i1 @umax_scalar(i1 %0, i1 %1) {
+; CHECK-LABEL: define i1 @umax_scalar
+; CHECK-SAME: (i1 [[TMP0:%.*]], i1 [[TMP1:%.*]]) {
+; CHECK-NEXT:    [[TMP3:%.*]] = call i1 @llvm.umax.i1(i1 [[TMP0]], i1 [[TMP1]])
+; CHECK-NEXT:    ret i1 [[TMP3]]
+;
+  %3 = call i1 @llvm.umax.i1(i1 %0, i1 %1)
+  ret i1 %3
+}
+
+define i1 @smax_scalar(i1 %0, i1 %1) {
+; CHECK-LABEL: define i1 @smax_scalar
+; CHECK-SAME: (i1 [[TMP0:%.*]], i1 [[TMP1:%.*]]) {
+; CHECK-NEXT:    [[TMP3:%.*]] = call i1 @llvm.smax.i1(i1 [[TMP0]], i1 [[TMP1]])
+; CHECK-NEXT:    ret i1 [[TMP3]]
+;
+  %3 = call i1 @llvm.smax.i1(i1 %0, i1 %1)
+  ret i1 %3
+}
+
+;------------------------------------------------------------------------------;
+; Vector tests
+;------------------------------------------------------------------------------;
+
+define <4 x i1> @umin_vector(<4 x i1> %0, <4 x i1> %1) {
+; CHECK-LABEL: define <4 x i1> @umin_vector
+; CHECK-SAME: (<4 x i1> [[TMP0:%.*]], <4 x i1> [[TMP1:%.*]]) {
+; CHECK-NEXT:    [[TMP3:%.*]] = call <4 x i1> @llvm.umin.v4i1(<4 x i1> [[TMP0]], <4 x i1> [[TMP1]])
+; CHECK-NEXT:    ret <4 x i1> [[TMP3]]
+;
+  %3 = call <4 x i1> @llvm.umin.v4i1(<4 x i1> %0, <4 x i1> %1)
+  ret <4 x i1> %3
+}
+
+define <4 x i1> @smin_vector(<4 x i1> %0, <4 x i1> %1) {
+; CHECK-LABEL: define <4 x i1> @smin_vector
+; CHECK-SAME: (<4 x i1> [[TMP0:%.*]], <4 x i1> [[TMP1:%.*]]) {
+; CHECK-NEXT:    [[TMP3:%.*]] = call <4 x i1> @llvm.smin.v4i1(<4 x i1> [[TMP0]], <4 x i1> [[TMP1]])
+; CHECK-NEXT:    ret <4 x i1> [[TMP3]]
+;
+  %3 = call <4 x i1> @llvm.smin.v4i1(<4 x i1> %0, <4 x i1> %1)
+  ret <4 x i1> %3
+}
+
+define <4 x i1> @umax_vector(<4 x i1> %0, <4 x i1> %1) {
+; CHECK-LABEL: define <4 x i1> @umax_vector
+; CHECK-SAME: (<4 x i1> [[TMP0:%.*]], <4 x i1> [[TMP1:%.*]]) {
+; CHECK-NEXT:    [[TMP3:%.*]] = call <4 x i1> @llvm.umax.v4i1(<4 x i1> [[TMP0]], <4 x i1> [[TMP1]])
+; CHECK-NEXT:    ret <4 x i1> [[TMP3]]
+;
+  %3 = call <4 x i1> @llvm.umax.v4i1(<4 x i1> %0, <4 x i1> %1)
+  ret <4 x i1> %3
+}
+
+define <4 x i1> @smax_vector(<4 x i1> %0, <4 x i1> %1) {
+; CHECK-LABEL: define <4 x i1> @smax_vector
+; CHECK-SAME: (<4 x i1> [[TMP0:%.*]], <4 x i1> [[TMP1:%.*]]) {
+; CHECK-NEXT:    [[TMP3:%.*]] = call <4 x i1> @llvm.smax.v4i1(<4 x i1> [[TMP0]], <4 x i1> [[TMP1]])
+; CHECK-NEXT:    ret <4 x i1> [[TMP3]]
+;
+  %3 = call <4 x i1> @llvm.smax.v4i1(<4 x i1> %0, <4 x i1> %1)
+  ret <4 x i1> %3
+}
+
+declare i1 @llvm.umin.i1(i1, i1)
+declare i1 @llvm.smin.i1(i1, i1)
+declare i1 @llvm.umax.i1(i1, i1)
+declare i1 @llvm.smax.i1(i1, i1)
+declare <4 x i1> @llvm.umin.v4i1(<4 x i1>, <4 x i1>)
+declare <4 x i1> @llvm.smin.v4i1(<4 x i1>, <4 x i1>)
+declare <4 x i1> @llvm.umax.v4i1(<4 x i1>, <4 x i1>)
+declare <4 x i1> @llvm.smax.v4i1(<4 x i1>, <4 x i1>)


        


More information about the llvm-commits mailing list