summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDale Johannesen <dalej@apple.com>2010-02-09 02:01:46 +0000
committerDale Johannesen <dalej@apple.com>2010-02-09 02:01:46 +0000
commitc3adf44885d75326b607b1772c5d3618b7f91ae2 (patch)
tree0a36a1e25d5c476bc400b844f66298c653c403db
parentce25dd74c00d9a8397a7693b1e55bd7b49b1a293 (diff)
downloadbcm5719-llvm-c3adf44885d75326b607b1772c5d3618b7f91ae2.tar.gz
bcm5719-llvm-c3adf44885d75326b607b1772c5d3618b7f91ae2.zip
Skip DEBUG_VALUE in some places where it was affecting codegen.
llvm-svn: 95647
-rw-r--r--llvm/lib/CodeGen/CalcSpillWeights.cpp3
-rw-r--r--llvm/lib/CodeGen/LiveVariables.cpp2
-rw-r--r--llvm/lib/CodeGen/TwoAddressInstructionPass.cpp4
3 files changed, 9 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/CalcSpillWeights.cpp b/llvm/lib/CodeGen/CalcSpillWeights.cpp
index b8ef219bf9c..7da833bbbf8 100644
--- a/llvm/lib/CodeGen/CalcSpillWeights.cpp
+++ b/llvm/lib/CodeGen/CalcSpillWeights.cpp
@@ -64,6 +64,9 @@ bool CalculateSpillWeights::runOnMachineFunction(MachineFunction &fn) {
if (mi->getOpcode() == TargetInstrInfo::IMPLICIT_DEF)
continue;
+ if (mi->getOpcode() == TargetInstrInfo::DEBUG_VALUE)
+ continue;
+
for (unsigned i = 0, e = mi->getNumOperands(); i != e; ++i) {
const MachineOperand &mopi = mi->getOperand(i);
if (!mopi.isReg() || mopi.getReg() == 0)
diff --git a/llvm/lib/CodeGen/LiveVariables.cpp b/llvm/lib/CodeGen/LiveVariables.cpp
index b44a2202e76..23ee8c3eda1 100644
--- a/llvm/lib/CodeGen/LiveVariables.cpp
+++ b/llvm/lib/CodeGen/LiveVariables.cpp
@@ -543,6 +543,8 @@ bool LiveVariables::runOnMachineFunction(MachineFunction &mf) {
for (MachineBasicBlock::iterator I = MBB->begin(), E = MBB->end();
I != E; ++I) {
MachineInstr *MI = I;
+ if (MI->getOpcode()==TargetInstrInfo::DEBUG_VALUE)
+ continue;
DistanceMap.insert(std::make_pair(MI, Dist++));
// Process all of the operands of the instruction...
diff --git a/llvm/lib/CodeGen/TwoAddressInstructionPass.cpp b/llvm/lib/CodeGen/TwoAddressInstructionPass.cpp
index a3f6364aa8e..71d9b83f7bf 100644
--- a/llvm/lib/CodeGen/TwoAddressInstructionPass.cpp
+++ b/llvm/lib/CodeGen/TwoAddressInstructionPass.cpp
@@ -318,6 +318,8 @@ bool TwoAddressInstructionPass::NoUseAfterLastDef(unsigned Reg,
MachineInstr *MI = MO.getParent();
if (MI->getParent() != MBB)
continue;
+ if (MI->getOpcode() == TargetInstrInfo::DEBUG_VALUE)
+ continue;
DenseMap<MachineInstr*, unsigned>::iterator DI = DistanceMap.find(MI);
if (DI == DistanceMap.end())
continue;
@@ -341,6 +343,8 @@ MachineInstr *TwoAddressInstructionPass::FindLastUseInMBB(unsigned Reg,
MachineInstr *MI = MO.getParent();
if (MI->getParent() != MBB)
continue;
+ if (MI->getOpcode() == TargetInstrInfo::DEBUG_VALUE)
+ continue;
DenseMap<MachineInstr*, unsigned>::iterator DI = DistanceMap.find(MI);
if (DI == DistanceMap.end())
continue;
OpenPOWER on IntegriCloud