[llvm] 0cbd5d3 - [InstCombine] Add more tests for shl+lshr transforms; NFC

via llvm-commits llvm-commits at lists.llvm.org
Sun Jun 5 19:01:09 PDT 2022


Author: chenglin.bi
Date: 2022-06-06T09:59:41+08:00
New Revision: 0cbd5d3ded6c1d6c5a0f9a874f755b09e7a238b7

URL: https://github.com/llvm/llvm-project/commit/0cbd5d3ded6c1d6c5a0f9a874f755b09e7a238b7
DIFF: https://github.com/llvm/llvm-project/commit/0cbd5d3ded6c1d6c5a0f9a874f755b09e7a238b7.diff

LOG: [InstCombine] Add more tests for shl+lshr transforms; NFC

Added: 
    

Modified: 
    llvm/test/Transforms/InstCombine/and.ll

Removed: 
    


################################################################################
diff  --git a/llvm/test/Transforms/InstCombine/and.ll b/llvm/test/Transforms/InstCombine/and.ll
index 2617ac1eb6de..b9cad04d73ea 100644
--- a/llvm/test/Transforms/InstCombine/and.ll
+++ b/llvm/test/Transforms/InstCombine/and.ll
@@ -1622,8 +1622,8 @@ define i8 @not_lshr_bitwidth_mask(i8 %x, i8 %y) {
   ret i8 %r
 }
 
-define i16 @shl_lshr_pow2_const(i16 %x) {
-; CHECK-LABEL: @shl_lshr_pow2_const(
+define i16 @shl_lshr_pow2_const_case1(i16 %x) {
+; CHECK-LABEL: @shl_lshr_pow2_const_case1(
 ; CHECK-NEXT:    [[SHL:%.*]] = shl i16 4, [[X:%.*]]
 ; CHECK-NEXT:    [[LSHR:%.*]] = lshr i16 [[SHL]], 6
 ; CHECK-NEXT:    [[R:%.*]] = and i16 [[LSHR]], 8
@@ -1635,6 +1635,32 @@ define i16 @shl_lshr_pow2_const(i16 %x) {
   ret i16 %r
 }
 
+define i16 @shl_lshr_pow2_const_case2(i16 %x) {
+; CHECK-LABEL: @shl_lshr_pow2_const_case2(
+; CHECK-NEXT:    [[SHL:%.*]] = shl i16 4, [[X:%.*]]
+; CHECK-NEXT:    [[LSHR:%.*]] = lshr i16 [[SHL]], 6
+; CHECK-NEXT:    [[R:%.*]] = or i16 [[LSHR]], -9
+; CHECK-NEXT:    ret i16 [[R]]
+;
+  %shl = shl i16 4, %x
+  %lshr = lshr i16 %shl, 6
+  %r = or i16 %lshr, 65527 ; ~8
+  ret i16 %r
+}
+
+define i13 @shl_lshr_pow2_const_case3(i16 %x) {
+; CHECK-LABEL: @shl_lshr_pow2_const_case3(
+; CHECK-NEXT:    [[SHL:%.*]] = shl i16 4, [[X:%.*]]
+; CHECK-NEXT:    [[LSHR:%.*]] = lshr i16 [[SHL]], 6
+; CHECK-NEXT:    [[R:%.*]] = trunc i16 [[LSHR]] to i13
+; CHECK-NEXT:    ret i13 [[R]]
+;
+  %shl = shl i16 4, %x
+  %lshr = lshr i16 %shl, 6
+  %r = trunc i16 %lshr to i13
+  ret i13 %r
+}
+
 define i16 @shl_lshr_pow2_const_negative_oneuse(i16 %x) {
 ; CHECK-LABEL: @shl_lshr_pow2_const_negative_oneuse(
 ; CHECK-NEXT:    [[SHL:%.*]] = shl i16 4, [[X:%.*]]


        


More information about the llvm-commits mailing list