summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorAmaury Sechet <deadalnix@gmail.com>2017-03-01 23:44:17 +0000
committerAmaury Sechet <deadalnix@gmail.com>2017-03-01 23:44:17 +0000
commit71f511fd1ec9ad96dd048b438ef8cf3546bccab1 (patch)
tree839dbd4931b51bfd4097a9236ab04a711b698b5a /llvm/lib
parent120ae22d703834d453cb0a775b24daf46d5d5eeb (diff)
downloadbcm5719-llvm-71f511fd1ec9ad96dd048b438ef8cf3546bccab1.tar.gz
bcm5719-llvm-71f511fd1ec9ad96dd048b438ef8cf3546bccab1.zip
[DAGCombiner] mulhi + 1 never overflow.
Summary: This can be used to optimize large multiplications after legalization. Depends on D29565 Reviewers: mkuper, spatel, RKSimon, zvi, bkramer, aaboud, craig.topper Subscribers: llvm-commits Differential Revision: https://reviews.llvm.org/D29587 llvm-svn: 296711
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp13
1 files changed, 13 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp b/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp
index 16425a08200..5d7bf27ae64 100644
--- a/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp
+++ b/llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp
@@ -2775,6 +2775,19 @@ SelectionDAG::OverflowKind SelectionDAG::computeOverflowKind(SDValue N0,
return OFK_Never;
}
+ // mulhi + 1 never overflow
+ if (N0.getOpcode() == ISD::UMUL_LOHI && N0.getResNo() == 1 &&
+ (~N1Zero & 0x01) == ~N1Zero)
+ return OFK_Never;
+
+ if (N1.getOpcode() == ISD::UMUL_LOHI && N1.getResNo() == 1) {
+ APInt N0Zero, N0One;
+ computeKnownBits(N0, N0Zero, N0One);
+
+ if ((~N0Zero & 0x01) == ~N0Zero)
+ return OFK_Never;
+ }
+
return OFK_Sometime;
}
OpenPOWER on IntegriCloud