[llvm] r311902 - [InstCombine] Call hasNoSignedWrap instead of hasNoUnsignedWrap to get the NSW flag when handling Add in SimplifyDemandedUseBits.
Craig Topper via llvm-commits
llvm-commits at lists.llvm.org
Mon Aug 28 11:44:28 PDT 2017
Author: ctopper
Date: Mon Aug 28 11:44:28 2017
New Revision: 311902
URL: http://llvm.org/viewvc/llvm-project?rev=311902&view=rev
Log:
[InstCombine] Call hasNoSignedWrap instead of hasNoUnsignedWrap to get the NSW flag when handling Add in SimplifyDemandedUseBits.
This is a typo from r311789.
This should fix PR34349.
Added:
llvm/trunk/test/Transforms/InstCombine/pr34349.ll
Modified:
llvm/trunk/lib/Transforms/InstCombine/InstCombineSimplifyDemanded.cpp
Modified: llvm/trunk/lib/Transforms/InstCombine/InstCombineSimplifyDemanded.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/InstCombine/InstCombineSimplifyDemanded.cpp?rev=311902&r1=311901&r2=311902&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/InstCombine/InstCombineSimplifyDemanded.cpp (original)
+++ llvm/trunk/lib/Transforms/InstCombine/InstCombineSimplifyDemanded.cpp Mon Aug 28 11:44:28 2017
@@ -426,7 +426,7 @@ Value *InstCombiner::SimplifyDemandedUse
return I->getOperand(1);
// Otherwise just compute the known bits of the result.
- bool NSW = cast<OverflowingBinaryOperator>(I)->hasNoUnsignedWrap();
+ bool NSW = cast<OverflowingBinaryOperator>(I)->hasNoSignedWrap();
Known = KnownBits::computeForAddSub(I->getOpcode() == Instruction::Add,
NSW, LHSKnown, RHSKnown);
break;
Added: llvm/trunk/test/Transforms/InstCombine/pr34349.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/InstCombine/pr34349.ll?rev=311902&view=auto
==============================================================================
--- llvm/trunk/test/Transforms/InstCombine/pr34349.ll (added)
+++ llvm/trunk/test/Transforms/InstCombine/pr34349.ll Mon Aug 28 11:44:28 2017
@@ -0,0 +1,27 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
+;RUN: opt -instcombine -S %s | FileCheck %s
+
+define i8 @fast_div_201(i8 %p) {
+; CHECK-LABEL: @fast_div_201(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[V3:%.*]] = zext i8 [[P:%.*]] to i16
+; CHECK-NEXT: [[V4:%.*]] = mul nuw nsw i16 [[V3]], 71
+; CHECK-NEXT: [[V5:%.*]] = lshr i16 [[V4]], 8
+; CHECK-NEXT: [[V6:%.*]] = trunc i16 [[V5]] to i8
+; CHECK-NEXT: [[V7:%.*]] = sub i8 [[P]], [[V6]]
+; CHECK-NEXT: [[V8:%.*]] = lshr i8 [[V7]], 1
+; CHECK-NEXT: [[V13:%.*]] = add nuw i8 [[V8]], [[V6]]
+; CHECK-NEXT: [[V14:%.*]] = lshr i8 [[V13]], 7
+; CHECK-NEXT: ret i8 [[V14]]
+;
+entry:
+ %v3 = zext i8 %p to i16
+ %v4 = mul i16 %v3, 71
+ %v5 = lshr i16 %v4, 8
+ %v6 = trunc i16 %v5 to i8
+ %v7 = sub i8 %p, %v6
+ %v8 = lshr i8 %v7, 1
+ %v13 = add i8 %v6, %v8
+ %v14 = lshr i8 %v13, 7
+ ret i8 %v14
+}
More information about the llvm-commits
mailing list