mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	use moveBefore instead of remove+insert, it avoids some
symtab manipulation, so its faster (in addition to being more elegant) git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@112450 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -474,9 +474,7 @@ void LICM::sink(Instruction &I) { | ||||
|     } else { | ||||
|       // Move the instruction to the start of the exit block, after any PHI | ||||
|       // nodes in it. | ||||
|       I.removeFromParent(); | ||||
|       BasicBlock::iterator InsertPt = ExitBlocks[0]->getFirstNonPHI(); | ||||
|       ExitBlocks[0]->getInstList().insert(InsertPt, &I); | ||||
|       I.moveBefore(ExitBlocks[0]->getFirstNonPHI()); | ||||
|  | ||||
|       // This instruction is no longer in the AST for the current loop, because | ||||
|       // we just sunk it out of the loop.  If we just sunk it into an outer | ||||
| @@ -574,12 +572,8 @@ void LICM::hoist(Instruction &I) { | ||||
|   DEBUG(dbgs() << "LICM hoisting to " << Preheader->getName() << ": " | ||||
|         << I << "\n"); | ||||
|  | ||||
|   // Remove the instruction from its current basic block... but don't delete the | ||||
|   // instruction. | ||||
|   I.removeFromParent(); | ||||
|  | ||||
|   // Insert the new node in Preheader, before the terminator. | ||||
|   Preheader->getInstList().insert(Preheader->getTerminator(), &I); | ||||
|   // Move the new node to the Preheader, before its terminator. | ||||
|   I.moveBefore(Preheader->getTerminator()); | ||||
|  | ||||
|   if (isa<LoadInst>(I)) ++NumMovedLoads; | ||||
|   else if (isa<CallInst>(I)) ++NumMovedCalls; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user