diff options
author | Nadav Rotem <nrotem@apple.com> | 2013-02-22 23:33:30 +0000 |
---|---|---|
committer | Nadav Rotem <nrotem@apple.com> | 2013-02-22 23:33:30 +0000 |
commit | d99a5a3ab4d47c6532bcf17a01677b1730599057 (patch) | |
tree | 4b8e23de6181b936d0a9fbc58cd4c0cbfe6b1d91 /lib/CodeGen | |
parent | 606893294095e214f50937e8f8e9770efaab07a7 (diff) | |
download | external_llvm-d99a5a3ab4d47c6532bcf17a01677b1730599057.zip external_llvm-d99a5a3ab4d47c6532bcf17a01677b1730599057.tar.gz external_llvm-d99a5a3ab4d47c6532bcf17a01677b1730599057.tar.bz2 |
SelectionDAG compile time improvement.
One of the phases of SelectionDAG is LegalizeVectors. We don't need to sort the DAG and copy nodes around if there are no vector ops.
Speeds up the compilation time of SelectionDAG on a big scalar workload by ~8%.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@175929 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen')
-rw-r--r-- | lib/CodeGen/SelectionDAG/LegalizeVectorOps.cpp | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/lib/CodeGen/SelectionDAG/LegalizeVectorOps.cpp b/lib/CodeGen/SelectionDAG/LegalizeVectorOps.cpp index 7b28e69..c6e066e 100644 --- a/lib/CodeGen/SelectionDAG/LegalizeVectorOps.cpp +++ b/lib/CodeGen/SelectionDAG/LegalizeVectorOps.cpp @@ -85,6 +85,25 @@ class VectorLegalizer { }; bool VectorLegalizer::Run() { + // Before we start legalizing vector nodes, check if there are any vectors. + bool HasVectors = false; + for (SelectionDAG::allnodes_iterator I = DAG.allnodes_begin(), + E = prior(DAG.allnodes_end()); I != llvm::next(E); ++I) { + // Check if the values of the nodes contain vectors. We don't need to check + // the operands because we are going to check their values at some point. + for (SDNode::value_iterator J = I->value_begin(), E = I->value_end(); + J != E; ++J) + HasVectors |= J->isVector(); + + // If we found a vector node we can start the legalization. + if (HasVectors) + break; + } + + // If this basic block has no vectors then no need to legalize vectors. + if (!HasVectors) + return false; + // The legalize process is inherently a bottom-up recursive process (users // legalize their uses before themselves). Given infinite stack space, we // could just start legalizing on the root and traverse the whole graph. In |