mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	Don't try to create PHIs of struct types. Fallout
from x86-64 calling convention work. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@50545 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -249,14 +249,37 @@ bool LoopRotate::rotateLoop(Loop *Lp, LPPassManager &LPM) { | ||||
|     // create new PHINode for this instruction. | ||||
|     Instruction *NewHeaderReplacement = NULL; | ||||
|     if (usedOutsideOriginalHeader(In)) { | ||||
|       PHINode *PN = PHINode::Create(In->getType(), In->getName()); | ||||
|       PN->addIncoming(In, OrigHeader); | ||||
|       PN->addIncoming(C, OrigPreHeader); | ||||
|       NewHeader->getInstList().push_front(PN); | ||||
|       NewHeaderReplacement = PN; | ||||
|     }  | ||||
|      | ||||
|     // "In" can be replaced by NPH or NH at various places. | ||||
|       const StructType *STy = dyn_cast<StructType>(In->getType()); | ||||
|       if (STy) { | ||||
|         // Can't create PHI nodes for this type.  If there are any getResults | ||||
|         // not defined in this block, move them back to this block.  PHI | ||||
|         // nodes will be created for all getResults later. | ||||
|         BasicBlock::iterator InsertPoint; | ||||
|         if (InvokeInst *II = dyn_cast<InvokeInst>(In)) { | ||||
|           InsertPoint = II->getNormalDest()->begin(); | ||||
|           while (isa<PHINode>(InsertPoint))  | ||||
|             ++InsertPoint; | ||||
|         } else { | ||||
|           InsertPoint = I;  // call | ||||
|           InsertPoint++; | ||||
|         } | ||||
|         for (Value::use_iterator UI = In->use_begin(), UE = In->use_end(); | ||||
|              UI != UE; ++UI) { | ||||
|           GetResultInst *InGR = cast<GetResultInst>(UI); | ||||
|           if (InGR->getParent() != OrigHeader) { | ||||
|             // move InGR to immediately follow call.  It will be picked | ||||
|             // up, cloned and PHI'd on the next iteration. | ||||
|             InGR->moveBefore(InsertPoint); | ||||
|           } | ||||
|         } | ||||
|       } else { | ||||
|         PHINode *PN = PHINode::Create(In->getType(), In->getName()); | ||||
|         PN->addIncoming(In, OrigHeader); | ||||
|         PN->addIncoming(C, OrigPreHeader); | ||||
|         NewHeader->getInstList().push_front(PN); | ||||
|         NewHeaderReplacement = PN; | ||||
|       } | ||||
|     } | ||||
|     LoopHeaderInfo.push_back(RenameData(In, C, NewHeaderReplacement)); | ||||
|   } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user