mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	Eliminate unnecessary ->get calls that are now automatically handled.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@6397 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -15,15 +15,13 @@ | ||||
| // The MemoryDepAnalysis does build an explicit graph, which is used internally | ||||
| // here.  That graph could be augmented with the other dependences above if | ||||
| // desired, but for most uses there will be little need to do that. | ||||
| // | ||||
| //===----------------------------------------------------------------------===// | ||||
|  | ||||
| #include "llvm/Analysis/PgmDependenceGraph.h" | ||||
| #include "llvm/Analysis/MemoryDepAnalysis.h" | ||||
| #include "llvm/Analysis/PostDominators.h" | ||||
| #include "llvm/Function.h" | ||||
| #include "llvm/BasicBlock.h" | ||||
| #include "llvm/Instruction.h" | ||||
|  | ||||
|  | ||||
|  | ||||
| //---------------------------------------------------------------------------- | ||||
| @@ -78,7 +76,7 @@ bool DepIterState::SetFirstSSADep() | ||||
|   if (doIncomingDeps) | ||||
|     for (Instruction::op_iterator E = depNode->getInstr().op_end(); | ||||
|          ssaInEdgeIter != E && | ||||
|            (firstTarget = dyn_cast<Instruction>(ssaInEdgeIter->get()))== NULL; ) | ||||
|            (firstTarget = dyn_cast<Instruction>(ssaInEdgeIter))== NULL; ) | ||||
|       ++ssaInEdgeIter; | ||||
|   else | ||||
|     for (Value::use_iterator E = depNode->getInstr().use_end(); | ||||
|   | ||||
| @@ -15,15 +15,13 @@ | ||||
| // The MemoryDepAnalysis does build an explicit graph, which is used internally | ||||
| // here.  That graph could be augmented with the other dependences above if | ||||
| // desired, but for most uses there will be little need to do that. | ||||
| // | ||||
| //===----------------------------------------------------------------------===// | ||||
|  | ||||
| #include "llvm/Analysis/PgmDependenceGraph.h" | ||||
| #include "llvm/Analysis/MemoryDepAnalysis.h" | ||||
| #include "llvm/Analysis/PostDominators.h" | ||||
| #include "llvm/Function.h" | ||||
| #include "llvm/BasicBlock.h" | ||||
| #include "llvm/Instruction.h" | ||||
|  | ||||
|  | ||||
|  | ||||
| //---------------------------------------------------------------------------- | ||||
| @@ -78,7 +76,7 @@ bool DepIterState::SetFirstSSADep() | ||||
|   if (doIncomingDeps) | ||||
|     for (Instruction::op_iterator E = depNode->getInstr().op_end(); | ||||
|          ssaInEdgeIter != E && | ||||
|            (firstTarget = dyn_cast<Instruction>(ssaInEdgeIter->get()))== NULL; ) | ||||
|            (firstTarget = dyn_cast<Instruction>(ssaInEdgeIter))== NULL; ) | ||||
|       ++ssaInEdgeIter; | ||||
|   else | ||||
|     for (Value::use_iterator E = depNode->getInstr().use_end(); | ||||
|   | ||||
| @@ -694,7 +694,7 @@ void CWriter::printContainedStructs(const Type *Ty, | ||||
|              E = STy->getElementTypes().end(); I != E; ++I) { | ||||
|         const Type *Ty1 = I->get(); | ||||
|         if (isa<StructType>(Ty1) || isa<ArrayType>(Ty1)) | ||||
|           printContainedStructs(Ty1, StructPrinted); | ||||
|           printContainedStructs(*I, StructPrinted); | ||||
|       } | ||||
|        | ||||
|       //Print structure type out.. | ||||
| @@ -1121,7 +1121,7 @@ void CWriter::printIndexingExpression(Value *Ptr, User::op_iterator I, | ||||
|     return; | ||||
|   } | ||||
|  | ||||
|   const Constant *CI = dyn_cast<Constant>(I->get()); | ||||
|   const Constant *CI = dyn_cast<Constant>(I); | ||||
|   if (HasImplicitAddress && (!CI || !CI->isNullValue())) | ||||
|     Out << "(&"; | ||||
|  | ||||
|   | ||||
| @@ -694,7 +694,7 @@ void CWriter::printContainedStructs(const Type *Ty, | ||||
|              E = STy->getElementTypes().end(); I != E; ++I) { | ||||
|         const Type *Ty1 = I->get(); | ||||
|         if (isa<StructType>(Ty1) || isa<ArrayType>(Ty1)) | ||||
|           printContainedStructs(Ty1, StructPrinted); | ||||
|           printContainedStructs(*I, StructPrinted); | ||||
|       } | ||||
|        | ||||
|       //Print structure type out.. | ||||
| @@ -1121,7 +1121,7 @@ void CWriter::printIndexingExpression(Value *Ptr, User::op_iterator I, | ||||
|     return; | ||||
|   } | ||||
|  | ||||
|   const Constant *CI = dyn_cast<Constant>(I->get()); | ||||
|   const Constant *CI = dyn_cast<Constant>(I); | ||||
|   if (HasImplicitAddress && (!CI || !CI->isNullValue())) | ||||
|     Out << "(&"; | ||||
|  | ||||
|   | ||||
| @@ -1257,7 +1257,7 @@ static void RecursiveDelete(ValueMapCache &Cache, Instruction *I) { | ||||
|  | ||||
|   for (User::op_iterator OI = I->op_begin(), OE = I->op_end();  | ||||
|        OI != OE; ++OI) | ||||
|     if (Instruction *U = dyn_cast<Instruction>(OI->get())) { | ||||
|     if (Instruction *U = dyn_cast<Instruction>(OI)) { | ||||
|       *OI = 0; | ||||
|       RecursiveDelete(Cache, U); | ||||
|     } | ||||
|   | ||||
| @@ -1,14 +1,14 @@ | ||||
| //===- DemoteRegToStack.cpp - Move a virtual reg. to stack ------*- C++ -*-===// | ||||
| //  | ||||
| // This file provide the function DemoteRegToStack(). | ||||
| // This function takes a virtual register computed by an | ||||
| // Instruction& X and replaces it with a slot in the stack frame, | ||||
| // allocated via alloca. It returns the pointer to the AllocaInst inserted. | ||||
| // This file provide the function DemoteRegToStack().  This function takes a | ||||
| // virtual register computed by an Instruction& X and replaces it with a slot in | ||||
| // the stack frame, allocated via alloca. It returns the pointer to the | ||||
| // AllocaInst inserted. | ||||
| // | ||||
| //===----------------------------------------------------------------------===// | ||||
|  | ||||
| #include "llvm/Transforms/Utils/DemoteRegToStack.h" | ||||
| #include "llvm/Function.h" | ||||
| #include "llvm/BasicBlock.h" | ||||
| #include "llvm/iMemory.h" | ||||
| #include "llvm/iPHINode.h" | ||||
| #include "llvm/iTerminators.h" | ||||
| @@ -16,7 +16,6 @@ | ||||
| #include "Support/hash_set" | ||||
| #include <stack> | ||||
|  | ||||
|  | ||||
| //----------------------------------------------------------------------------  | ||||
| // function DemoteRegToStack() | ||||
| // | ||||
| @@ -28,11 +27,10 @@ typedef hash_set<PHINode*>::iterator PhiSetIterator; | ||||
| // Helper function to push a phi *and* all its operands to the worklist! | ||||
| // Do not push an instruction if it is already in the result set of Phis to go. | ||||
| inline void PushOperandsOnWorkList(std::stack<Instruction*>& workList, | ||||
|                                    PhiSet& phisToGo, PHINode* phiN) | ||||
| { | ||||
|   for (User::op_iterator OI=phiN->op_begin(), OE=phiN->op_end(); | ||||
|                                    PhiSet& phisToGo, PHINode* phiN) { | ||||
|   for (User::op_iterator OI = phiN->op_begin(), OE = phiN->op_end(); | ||||
|        OI != OE; ++OI) | ||||
|     if (Instruction* opI = dyn_cast<Instruction>(OI->get())) | ||||
|     if (Instruction* opI = dyn_cast<Instruction>(OI)) | ||||
|       if (!isa<PHINode>(opI) || | ||||
|           phisToGo.find(cast<PHINode>(opI)) == phisToGo.end()) | ||||
|         workList.push(opI); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user