diff options
Diffstat (limited to 'llvm/test/Transforms/InstCombine/adjust-for-sminmax.ll')
-rw-r--r-- | llvm/test/Transforms/InstCombine/adjust-for-sminmax.ll | 181 |
1 files changed, 0 insertions, 181 deletions
diff --git a/llvm/test/Transforms/InstCombine/adjust-for-sminmax.ll b/llvm/test/Transforms/InstCombine/adjust-for-sminmax.ll deleted file mode 100644 index 643f1fd3d68..00000000000 --- a/llvm/test/Transforms/InstCombine/adjust-for-sminmax.ll +++ /dev/null @@ -1,181 +0,0 @@ -; NOTE: Assertions have been autogenerated by utils/update_test_checks.py -; RUN: opt < %s -instcombine -S | FileCheck %s - -; Instcombine should recognize that this code can be adjusted -; to fit the canonical smax/smin pattern. - -define i32 @floor_a(i32 %n) { -; CHECK-LABEL: @floor_a( -; CHECK-NEXT: [[T:%.*]] = icmp slt i32 %n, 0 -; CHECK-NEXT: [[M:%.*]] = select i1 [[T]], i32 0, i32 %n -; CHECK-NEXT: ret i32 [[M]] -; - %t = icmp sgt i32 %n, -1 - %m = select i1 %t, i32 %n, i32 0 - ret i32 %m -} - -define i32 @ceil_a(i32 %n) { -; CHECK-LABEL: @ceil_a( -; CHECK-NEXT: [[T:%.*]] = icmp sgt i32 %n, 0 -; CHECK-NEXT: [[M:%.*]] = select i1 [[T]], i32 0, i32 %n -; CHECK-NEXT: ret i32 [[M]] -; - %t = icmp slt i32 %n, 1 - %m = select i1 %t, i32 %n, i32 0 - ret i32 %m -} - -define i32 @floor_b(i32 %n) { -; CHECK-LABEL: @floor_b( -; CHECK-NEXT: [[T:%.*]] = icmp sgt i32 %n, 0 -; CHECK-NEXT: [[M:%.*]] = select i1 [[T]], i32 %n, i32 0 -; CHECK-NEXT: ret i32 [[M]] -; - %t = icmp sgt i32 %n, 0 - %m = select i1 %t, i32 %n, i32 0 - ret i32 %m -} - -define i32 @ceil_b(i32 %n) { -; CHECK-LABEL: @ceil_b( -; CHECK-NEXT: [[T:%.*]] = icmp slt i32 %n, 0 -; CHECK-NEXT: [[M:%.*]] = select i1 [[T]], i32 %n, i32 0 -; CHECK-NEXT: ret i32 [[M]] -; - %t = icmp slt i32 %n, 0 - %m = select i1 %t, i32 %n, i32 0 - ret i32 %m -} - -define i32 @floor_c(i32 %n) { -; CHECK-LABEL: @floor_c( -; CHECK-NEXT: [[T:%.*]] = icmp slt i32 %n, 0 -; CHECK-NEXT: [[M:%.*]] = select i1 [[T]], i32 0, i32 %n -; CHECK-NEXT: ret i32 [[M]] -; - %t = icmp sge i32 %n, 0 - %m = select i1 %t, i32 %n, i32 0 - ret i32 %m -} - -define i32 @ceil_c(i32 %n) { -; CHECK-LABEL: @ceil_c( -; CHECK-NEXT: [[T:%.*]] = icmp sgt i32 %n, 0 -; CHECK-NEXT: [[M:%.*]] = select i1 [[T]], i32 0, i32 %n -; CHECK-NEXT: ret i32 [[M]] -; - %t = icmp sle i32 %n, 0 - %m = select i1 %t, i32 %n, i32 0 - ret i32 %m -} - -define i32 @floor_d(i32 %n) { -; CHECK-LABEL: @floor_d( -; CHECK-NEXT: [[T:%.*]] = icmp sgt i32 %n, 0 -; CHECK-NEXT: [[M:%.*]] = select i1 [[T]], i32 %n, i32 0 -; CHECK-NEXT: ret i32 [[M]] -; - %t = icmp sge i32 %n, 1 - %m = select i1 %t, i32 %n, i32 0 - ret i32 %m -} - -define i32 @ceil_d(i32 %n) { -; CHECK-LABEL: @ceil_d( -; CHECK-NEXT: [[T:%.*]] = icmp slt i32 %n, 0 -; CHECK-NEXT: [[M:%.*]] = select i1 [[T]], i32 %n, i32 0 -; CHECK-NEXT: ret i32 [[M]] -; - %t = icmp sle i32 %n, -1 - %m = select i1 %t, i32 %n, i32 0 - ret i32 %m -} - -define i32 @floor_e(i32 %n) { -; CHECK-LABEL: @floor_e( -; CHECK-NEXT: [[T:%.*]] = icmp slt i32 %n, 0 -; CHECK-NEXT: [[M:%.*]] = select i1 [[T]], i32 0, i32 %n -; CHECK-NEXT: ret i32 [[M]] -; - %t = icmp sgt i32 %n, -1 - %m = select i1 %t, i32 %n, i32 0 - ret i32 %m -} - -define i32 @ceil_e(i32 %n) { -; CHECK-LABEL: @ceil_e( -; CHECK-NEXT: [[T:%.*]] = icmp sgt i32 %n, 0 -; CHECK-NEXT: [[M:%.*]] = select i1 [[T]], i32 0, i32 %n -; CHECK-NEXT: ret i32 [[M]] -; - %t = icmp slt i32 %n, 1 - %m = select i1 %t, i32 %n, i32 0 - ret i32 %m -} - -define i32 @floor_f(i32 %n) { -; CHECK-LABEL: @floor_f( -; CHECK-NEXT: [[T:%.*]] = icmp sgt i32 %n, 0 -; CHECK-NEXT: [[M:%.*]] = select i1 [[T]], i32 %n, i32 0 -; CHECK-NEXT: ret i32 [[M]] -; - %t = icmp sgt i32 %n, 0 - %m = select i1 %t, i32 %n, i32 0 - ret i32 %m -} - -define i32 @ceil_f(i32 %n) { -; CHECK-LABEL: @ceil_f( -; CHECK-NEXT: [[T:%.*]] = icmp slt i32 %n, 0 -; CHECK-NEXT: [[M:%.*]] = select i1 [[T]], i32 %n, i32 0 -; CHECK-NEXT: ret i32 [[M]] -; - %t = icmp slt i32 %n, 0 - %m = select i1 %t, i32 %n, i32 0 - ret i32 %m -} - -define i32 @floor_g(i32 %n) { -; CHECK-LABEL: @floor_g( -; CHECK-NEXT: [[T:%.*]] = icmp slt i32 %n, 0 -; CHECK-NEXT: [[M:%.*]] = select i1 [[T]], i32 0, i32 %n -; CHECK-NEXT: ret i32 [[M]] -; - %t = icmp sge i32 %n, 0 - %m = select i1 %t, i32 %n, i32 0 - ret i32 %m -} - -define i32 @ceil_g(i32 %n) { -; CHECK-LABEL: @ceil_g( -; CHECK-NEXT: [[T:%.*]] = icmp sgt i32 %n, 0 -; CHECK-NEXT: [[M:%.*]] = select i1 [[T]], i32 0, i32 %n -; CHECK-NEXT: ret i32 [[M]] -; - %t = icmp sle i32 %n, 0 - %m = select i1 %t, i32 %n, i32 0 - ret i32 %m -} - -define i32 @floor_h(i32 %n) { -; CHECK-LABEL: @floor_h( -; CHECK-NEXT: [[T:%.*]] = icmp sgt i32 %n, 0 -; CHECK-NEXT: [[M:%.*]] = select i1 [[T]], i32 %n, i32 0 -; CHECK-NEXT: ret i32 [[M]] -; - %t = icmp sge i32 %n, 1 - %m = select i1 %t, i32 %n, i32 0 - ret i32 %m -} - -define i32 @ceil_h(i32 %n) { -; CHECK-LABEL: @ceil_h( -; CHECK-NEXT: [[T:%.*]] = icmp slt i32 %n, 0 -; CHECK-NEXT: [[M:%.*]] = select i1 [[T]], i32 %n, i32 0 -; CHECK-NEXT: ret i32 [[M]] -; - %t = icmp sle i32 %n, -1 - %m = select i1 %t, i32 %n, i32 0 - ret i32 %m -} |