diff options
author | Chris Lattner <sabre@nondot.org> | 2005-03-17 23:45:54 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2005-03-17 23:45:54 +0000 |
commit | 4ffe5d80383d492e00864162c8c51be4b4d3e04e (patch) | |
tree | 585d8f87c5d806ef0c814ab194cda564eed10d98 /lib/Analysis/DataStructure/DataStructure.cpp | |
parent | 0f344122938a9a6c8e026542ac741540a5d04f99 (diff) |
implement a new method.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@20668 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/DataStructure/DataStructure.cpp')
-rw-r--r-- | lib/Analysis/DataStructure/DataStructure.cpp | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/lib/Analysis/DataStructure/DataStructure.cpp b/lib/Analysis/DataStructure/DataStructure.cpp index 4c48a86d39..0e59841e09 100644 --- a/lib/Analysis/DataStructure/DataStructure.cpp +++ b/lib/Analysis/DataStructure/DataStructure.cpp @@ -2141,3 +2141,39 @@ void DSGraph::computeGGToGMapping(InvNodeMapTy &InvNodeMap) { } } + +/// computeCalleeCallerMapping - Given a call from a function in the current +/// graph to the 'Callee' function (which lives in 'CalleeGraph'), compute the +/// mapping of nodes from the callee to nodes in the caller. +void DSGraph::computeCalleeCallerMapping(DSCallSite CS, const Function &Callee, + DSGraph &CalleeGraph, + NodeMapTy &NodeMap) { + + DSCallSite CalleeArgs = + CalleeGraph.getCallSiteForArguments(const_cast<Function&>(Callee)); + + computeNodeMapping(CalleeArgs.getRetVal(), CS.getRetVal(), NodeMap); + + unsigned NumArgs = CS.getNumPtrArgs(); + if (NumArgs > CalleeArgs.getNumPtrArgs()) + NumArgs = CalleeArgs.getNumPtrArgs(); + + for (unsigned i = 0; i != NumArgs; ++i) + computeNodeMapping(CalleeArgs.getPtrArg(i), CS.getPtrArg(i), NodeMap); + + // Map the nodes that are pointed to by globals. + DSScalarMap &CalleeSM = CalleeGraph.getScalarMap(); + DSScalarMap &CallerSM = getScalarMap(); + + if (CalleeSM.global_size() >= CallerSM.global_size()) { + for (DSScalarMap::global_iterator GI = CallerSM.global_begin(), + E = CallerSM.global_end(); GI != E; ++GI) + if (CalleeSM.global_count(*GI)) + computeNodeMapping(CalleeSM[*GI], CallerSM[*GI], NodeMap); + } else { + for (DSScalarMap::global_iterator GI = CalleeSM.global_begin(), + E = CalleeSM.global_end(); GI != E; ++GI) + if (CallerSM.global_count(*GI)) + computeNodeMapping(CalleeSM[*GI], CallerSM[*GI], NodeMap); + } +} |