summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2003-10-21 16:09:23 +0000
committerChris Lattner <sabre@nondot.org>2003-10-21 16:09:23 +0000
commit4439aee50410a587567b540decfc46b9909e5c95 (patch)
tree817c43fb2d04a37263cee382048574a8d4f5d45d
parent898a42afdecedaecbdf7c2855b12ba86a6ddaee5 (diff)
downloadbcm5719-llvm-4439aee50410a587567b540decfc46b9909e5c95.tar.gz
bcm5719-llvm-4439aee50410a587567b540decfc46b9909e5c95.zip
Pull the PHI special case into it's own visit* method
llvm-svn: 9332
-rw-r--r--llvm/lib/Target/Sparc/PreSelection.cpp21
1 files changed, 12 insertions, 9 deletions
diff --git a/llvm/lib/Target/Sparc/PreSelection.cpp b/llvm/lib/Target/Sparc/PreSelection.cpp
index 014725a73f1..d4f4398b4a3 100644
--- a/llvm/lib/Target/Sparc/PreSelection.cpp
+++ b/llvm/lib/Target/Sparc/PreSelection.cpp
@@ -73,6 +73,7 @@ namespace {
void visitInstruction(Instruction &I); // common work for every instr.
void visitGetElementPtrInst(GetElementPtrInst &I);
void visitCallInst(CallInst &I);
+ void visitPHINode(PHINode &PN);
// Helper functions for visiting operands of every instruction
//
@@ -210,19 +211,21 @@ PreSelection::visitOneOperand(Instruction &I, Value* Op, unsigned opNum,
//
inline void PreSelection::visitOperands(Instruction &I, int firstOp) {
// For any instruction other than PHI, copies go just before the instr.
+ for (unsigned i = firstOp, e = I.getNumOperands(); i != e; ++i)
+ visitOneOperand(I, I.getOperand(i), i, I);
+}
+
+
+void PreSelection::visitPHINode(PHINode &PN) {
// For a PHI, operand copies must be before the terminator of the
// appropriate predecessor basic block. Remaining logic is simple
// so just handle PHIs and other instructions separately.
//
- if (PHINode* phi = dyn_cast<PHINode>(&I)) {
- for (unsigned i=firstOp, N=phi->getNumIncomingValues(); i != N; ++i)
- visitOneOperand(I, phi->getIncomingValue(i),
- phi->getOperandNumForIncomingValue(i),
- * phi->getIncomingBlock(i)->getTerminator());
- } else {
- for (unsigned i=firstOp, N=lastOp; i != I.getNumOperands(); ++i)
- visitOneOperand(I, I.getOperand(i), i, I);
- }
+ for (unsigned i = 0, e = PN.getNumIncomingValues(); i != e; ++i)
+ visitOneOperand(I, PN.getIncomingValue(i),
+ PN.getOperandNumForIncomingValue(i),
+ *PN.getIncomingBlock(i)->getTerminator());
+ // do not call visitOperands!
}
OpenPOWER on IntegriCloud