mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-13 04:38:24 +00:00
[LCG] Add the really, *really* boring edge insertion case: adding an
edge entirely within an existing SCC. Shockingly, making the connected component more connected is ... a total snooze fest. =] Anyways, its wired up, and I even added a test case to make sure it pretty much sorta works. =D git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@207631 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -76,11 +76,16 @@ LazyCallGraph::Node::Node(LazyCallGraph &G, Function &F)
|
||||
}
|
||||
|
||||
void LazyCallGraph::Node::insertEdgeInternal(Function &Callee) {
|
||||
CalleeIndexMap.insert(std::make_pair(&Callee, Callees.size()));
|
||||
if (Node *N = G->lookup(Callee))
|
||||
Callees.push_back(N);
|
||||
else
|
||||
Callees.push_back(&Callee);
|
||||
return insertEdgeInternal(*N);
|
||||
|
||||
CalleeIndexMap.insert(std::make_pair(&Callee, Callees.size()));
|
||||
Callees.push_back(&Callee);
|
||||
}
|
||||
|
||||
void LazyCallGraph::Node::insertEdgeInternal(Node &CalleeN) {
|
||||
CalleeIndexMap.insert(std::make_pair(&CalleeN.getFunction(), Callees.size()));
|
||||
Callees.push_back(&CalleeN);
|
||||
}
|
||||
|
||||
void LazyCallGraph::Node::removeEdgeInternal(Function &Callee) {
|
||||
@ -157,6 +162,16 @@ void LazyCallGraph::SCC::insert(Node &N) {
|
||||
G->SCCMap[&N] = this;
|
||||
}
|
||||
|
||||
void LazyCallGraph::SCC::insertIntraSCCEdge(Node &CallerN, Node &CalleeN) {
|
||||
// First insert it into the caller.
|
||||
CallerN.insertEdgeInternal(CalleeN);
|
||||
|
||||
assert(G->SCCMap.lookup(&CallerN) == this && "Caller must be in this SCC.");
|
||||
assert(G->SCCMap.lookup(&CalleeN) == this && "Callee must be in this SCC.");
|
||||
|
||||
// Nothing changes about this SCC or any other.
|
||||
}
|
||||
|
||||
void LazyCallGraph::SCC::removeInterSCCEdge(Node &CallerN, Node &CalleeN) {
|
||||
// First remove it from the node.
|
||||
CallerN.removeEdgeInternal(CalleeN.getFunction());
|
||||
|
Reference in New Issue
Block a user