mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-15 23:31:37 +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:
parent
ca398dc398
commit
ab2b328c78
@ -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)
|
||||
{
|
||||
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);
|
||||
|
Loading…
x
Reference in New Issue
Block a user