blob: ce502d6e31be4385b198e15048e95590a8f188a4 [file] [log] [blame]
Chris Lattnerc083dcc2003-09-01 20:05:47 +00001//===-- IGNode.cpp --------------------------------------------------------===//
Vikram S. Adve39c94e12002-09-14 23:05:33 +00002//
3// class IGNode for coloring-based register allocation for LLVM.
4//
5//===----------------------------------------------------------------------===//
6
Chris Lattnerc083dcc2003-09-01 20:05:47 +00007#include "IGNode.h"
Chris Lattner697954c2002-01-20 22:54:45 +00008#include <algorithm>
9#include <iostream>
Ruchira Sasanka8e604792001-09-14 21:18:34 +000010
Ruchira Sasanka4f3eb222002-01-07 19:19:18 +000011//-----------------------------------------------------------------------------
Ruchira Sasanka4f3eb222002-01-07 19:19:18 +000012// Sets this IGNode on stack and reduce the degree of neighbors
13//-----------------------------------------------------------------------------
Chris Lattner748697d2002-02-05 04:20:12 +000014
15void IGNode::pushOnStack() {
Ruchira Sasanka8e604792001-09-14 21:18:34 +000016 OnStack = true;
Ruchira Sasankaa9e45c82001-11-03 22:01:09 +000017 int neighs = AdjList.size();
Ruchira Sasanka8e604792001-09-14 21:18:34 +000018
Chris Lattner748697d2002-02-05 04:20:12 +000019 if (neighs < 0) {
Chris Lattnerc083dcc2003-09-01 20:05:47 +000020 std::cerr << "\nAdj List size = " << neighs;
Ruchira Sasankaa9e45c82001-11-03 22:01:09 +000021 assert(0 && "Invalid adj list size");
22 }
23
Chris Lattner697954c2002-01-20 22:54:45 +000024 for(int i=0; i < neighs; i++)
25 AdjList[i]->decCurDegree();
Ruchira Sasanka8e604792001-09-14 21:18:34 +000026}
27
Ruchira Sasanka4f3eb222002-01-07 19:19:18 +000028//-----------------------------------------------------------------------------
29// Deletes an adjacency node. IGNodes are deleted when coalescing merges
30// two IGNodes together.
31//-----------------------------------------------------------------------------
Chris Lattner748697d2002-02-05 04:20:12 +000032
33void IGNode::delAdjIGNode(const IGNode *Node) {
34 std::vector<IGNode *>::iterator It=find(AdjList.begin(), AdjList.end(), Node);
Ruchira Sasanka8e604792001-09-14 21:18:34 +000035 assert( It != AdjList.end() ); // the node must be there
Chris Lattner697954c2002-01-20 22:54:45 +000036 AdjList.erase(It);
Ruchira Sasanka8e604792001-09-14 21:18:34 +000037}
Vikram S. Adve32f81a32002-09-20 00:45:47 +000038
39//-----------------------------------------------------------------------------
40// Get the number of unique neighbors if these two nodes are merged
41//-----------------------------------------------------------------------------
42
43unsigned
44IGNode::getCombinedDegree(const IGNode* otherNode) const
45{
46 std::vector<IGNode*> nbrs(AdjList);
47 nbrs.insert(nbrs.end(), otherNode->AdjList.begin(), otherNode->AdjList.end());
48 sort(nbrs.begin(), nbrs.end());
49 std::vector<IGNode*>::iterator new_end = unique(nbrs.begin(), nbrs.end());
50 return new_end - nbrs.begin();
51}
52
53