summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
diff options
context:
space:
mode:
authorSjoerd Meijer <sjoerd.meijer@arm.com>2016-07-08 12:54:43 +0000
committerSjoerd Meijer <sjoerd.meijer@arm.com>2016-07-08 12:54:43 +0000
commita625af3febeb12fe14bac61993df81471bfcfb0f (patch)
treee5c7c317c4586b7105640f7529198627b1961318 /llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
parent586e579fe8ffda388207a34bc99fc8fc5a2d26fe (diff)
downloadbcm5719-llvm-a625af3febeb12fe14bac61993df81471bfcfb0f.tar.gz
bcm5719-llvm-a625af3febeb12fe14bac61993df81471bfcfb0f.zip
Code size optimisation: don't expand a div to a mul and and a shift sequence.
As a result, the urem instruction will not be expanded to a sequence of umull, lsrs, muls and sub instructions, but just a call to __aeabi_uidivmod. Differential Revision: http://reviews.llvm.org/D22131 llvm-svn: 274843
Diffstat (limited to 'llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp')
-rw-r--r--llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp5
1 files changed, 5 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
index dc2ff6eb918..456c5498e3c 100644
--- a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
+++ b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
@@ -14516,6 +14516,11 @@ SDValue DAGCombiner::BuildSDIVPow2(SDNode *N) {
/// number.
/// Ref: "Hacker's Delight" or "The PowerPC Compiler Writer's Guide".
SDValue DAGCombiner::BuildUDIV(SDNode *N) {
+ // when optimising for size, we don't want to expand a div to a mul and
+ // and a shift.
+ if (ForCodeSize)
+ return SDValue();
+
ConstantSDNode *C = isConstOrConstSplat(N->getOperand(1));
if (!C)
return SDValue();
OpenPOWER on IntegriCloud