summaryrefslogtreecommitdiff
path: root/test/Transforms/InstCombine/mul-masked-bits.ll
diff options
context:
space:
mode:
Diffstat (limited to 'test/Transforms/InstCombine/mul-masked-bits.ll')
-rw-r--r--test/Transforms/InstCombine/mul-masked-bits.ll11
1 files changed, 10 insertions, 1 deletions
diff --git a/test/Transforms/InstCombine/mul-masked-bits.ll b/test/Transforms/InstCombine/mul-masked-bits.ll
index a43d5f20beaae..fcff725cdf6f1 100644
--- a/test/Transforms/InstCombine/mul-masked-bits.ll
+++ b/test/Transforms/InstCombine/mul-masked-bits.ll
@@ -1,6 +1,15 @@
-; RUN: opt < %s -instcombine -S | grep ashr
+; NOTE: Assertions have been autogenerated by update_test_checks.py
+; RUN: opt < %s -instcombine -S | FileCheck %s
define i32 @foo(i32 %x, i32 %y) {
+; CHECK-LABEL: @foo(
+; CHECK-NEXT: [[A:%.*]] = and i32 %x, 7
+; CHECK-NEXT: [[B:%.*]] = and i32 %y, 7
+; CHECK-NEXT: [[C:%.*]] = mul nuw nsw i32 [[A]], [[B]]
+; CHECK-NEXT: [[D:%.*]] = shl nuw i32 [[C]], 26
+; CHECK-NEXT: [[E:%.*]] = ashr exact i32 [[D]], 26
+; CHECK-NEXT: ret i32 [[E]]
+;
%a = and i32 %x, 7
%b = and i32 %y, 7
%c = mul i32 %a, %b