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 | b8d85c1a7448608445b24402e62f5231d1435332 (patch) | |
| tree | 66bc31e265e24acaca8e1eb338f7365af28e9863 /llvm/lib/Analysis/DataStructure | |
| parent | 49ec9eeedeffa9924e3ccc2e06f8a579089e67b0 (diff) | |
| download | bcm5719-llvm-b8d85c1a7448608445b24402e62f5231d1435332.tar.gz bcm5719-llvm-b8d85c1a7448608445b24402e62f5231d1435332.zip  | |
implement a new method.
llvm-svn: 20668
Diffstat (limited to 'llvm/lib/Analysis/DataStructure')
| -rw-r--r-- | llvm/lib/Analysis/DataStructure/DataStructure.cpp | 36 | 
1 files changed, 36 insertions, 0 deletions
diff --git a/llvm/lib/Analysis/DataStructure/DataStructure.cpp b/llvm/lib/Analysis/DataStructure/DataStructure.cpp index 4c48a86d395..0e59841e099 100644 --- a/llvm/lib/Analysis/DataStructure/DataStructure.cpp +++ b/llvm/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); +  } +}  | 

