mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	Change CallGraphNode to maintain it's Function as an AssertingVH
for sanity. This didn't turn up any bugs. Change CallGraphNode to maintain its "callsite" information in the call edges list as a WeakVH instead of as an instruction*. This fixes a broad class of dangling pointer bugs, and makes CallGraph have a number of useful invariants again. This fixes the class of problem indicated by PR4029 and PR3601. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@80663 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -165,9 +165,6 @@ bool PruneEH::runOnSCC(std::vector<CallGraphNode *> &SCC) { | ||||
| // function if we have invokes to non-unwinding functions or code after calls to | ||||
| // no-return functions. | ||||
| bool PruneEH::SimplifyFunction(Function *F) { | ||||
|   CallGraph &CG = getAnalysis<CallGraph>(); | ||||
|   CallGraphNode *CGN = CG[F]; | ||||
|  | ||||
|   bool MadeChange = false; | ||||
|   for (Function::iterator BB = F->begin(), E = F->end(); BB != E; ++BB) { | ||||
|     if (InvokeInst *II = dyn_cast<InvokeInst>(BB->getTerminator())) | ||||
| @@ -181,14 +178,13 @@ bool PruneEH::SimplifyFunction(Function *F) { | ||||
|         Call->setAttributes(II->getAttributes()); | ||||
|  | ||||
|         // Anything that used the value produced by the invoke instruction | ||||
|         // now uses the value produced by the call instruction. | ||||
|         // now uses the value produced by the call instruction.  Note that we | ||||
|         // do this even for void functions and calls with no uses so that the | ||||
|         // callgraph edge is updated. | ||||
|         II->replaceAllUsesWith(Call); | ||||
|         BasicBlock *UnwindBlock = II->getUnwindDest(); | ||||
|         UnwindBlock->removePredecessor(II->getParent()); | ||||
|  | ||||
|         // Fix up the call graph. | ||||
|         CGN->replaceCallSite(II, Call, 0/*keep callee*/); | ||||
|  | ||||
|         // Insert a branch to the normal destination right before the | ||||
|         // invoke. | ||||
|         BranchInst::Create(II->getNormalDest(), II); | ||||
|   | ||||
| @@ -212,7 +212,7 @@ static void UpdateCallGraphAfterInlining(CallSite CS, | ||||
|   } | ||||
|  | ||||
|   for (; I != E; ++I) { | ||||
|     const Instruction *OrigCall = I->first.getInstruction(); | ||||
|     const Value *OrigCall = I->first; | ||||
|  | ||||
|     DenseMap<const Value*, Value*>::iterator VMI = ValueMap.find(OrigCall); | ||||
|     // Only copy the edge if the call was inlined! | ||||
|   | ||||
		Reference in New Issue
	
	Block a user