diff options
| author | Arnaud A. de Grandmaison <arnaud.degrandmaison@arm.com> | 2015-03-05 09:12:59 +0000 | 
|---|---|---|
| committer | Arnaud A. de Grandmaison <arnaud.degrandmaison@arm.com> | 2015-03-05 09:12:59 +0000 | 
| commit | d8ed0d372ce671cd09795914c1448570538650c2 (patch) | |
| tree | 12dc6b8f598890b83127a0438f7d4ff57e07eaaf /llvm/lib/CodeGen | |
| parent | bcb26d6880b246d29ec716e5cd6aabbb4703bfac (diff) | |
| download | bcm5719-llvm-d8ed0d372ce671cd09795914c1448570538650c2.tar.gz bcm5719-llvm-d8ed0d372ce671cd09795914c1448570538650c2.zip | |
[PBQP] Use a local bit-matrix to speedup searching an edge in the graph.
Build time (user time) for building llvm+clang+lldb in release mode:
 - default allocator: 9086 seconds
 - with PBQP: 9126 seconds
 - with PBQP + local bit matrix cache: 9097 seconds
llvm-svn: 231360
Diffstat (limited to 'llvm/lib/CodeGen')
| -rw-r--r-- | llvm/lib/CodeGen/RegAllocPBQP.cpp | 13 | 
1 files changed, 10 insertions, 3 deletions
| diff --git a/llvm/lib/CodeGen/RegAllocPBQP.cpp b/llvm/lib/CodeGen/RegAllocPBQP.cpp index 54b67abd7df..eeff73d0f2a 100644 --- a/llvm/lib/CodeGen/RegAllocPBQP.cpp +++ b/llvm/lib/CodeGen/RegAllocPBQP.cpp @@ -181,6 +181,8 @@ private:    typedef std::pair<AllowedRegVecPtr, AllowedRegVecPtr> IKey;    typedef DenseMap<IKey, PBQPRAGraph::MatrixPtr> IMatrixCache;    typedef DenseSet<IKey> DisjointAllowedRegsCache; +  typedef std::pair<PBQP::GraphBase::NodeId, PBQP::GraphBase::NodeId> IEdgeKey; +  typedef DenseSet<IEdgeKey> IEdgeCache;    bool haveDisjointAllowedRegs(const PBQPRAGraph &G, PBQPRAGraph::NodeId NId,                                 PBQPRAGraph::NodeId MId, @@ -277,6 +279,10 @@ public:      // and uniquing them.      IMatrixCache C; +    // Finding an edge is expensive in the worst case (O(max_clique(G))). So +    // cache locally edges we have already seen. +    IEdgeCache EC; +      // Cache known disjoint allowed registers pairs      DisjointAllowedRegsCache D; @@ -329,14 +335,15 @@ public:            continue;          // Check that we haven't already added this edge -        // FIXME: findEdge is expensive in the worst case (O(max_clique(G))). -        //        It might be better to replace this with a local bit-matrix. -        if (G.findEdge(NId, MId) != PBQPRAGraph::invalidEdgeId()) +        IEdgeKey EK(std::min(NId, MId), std::max(NId, MId)); +        if (EC.count(EK))            continue;          // This is a new edge - add it to the graph.          if (!createInterferenceEdge(G, NId, MId, C))            setDisjointAllowedRegs(G, NId, MId, D); +        else +          EC.insert(EK);        }        // Finally, add Cur to the Active set. | 

