summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorJakob Stoklund Olesen <stoklund@2pi.dk>2011-09-15 18:22:52 +0000
committerJakob Stoklund Olesen <stoklund@2pi.dk>2011-09-15 18:22:52 +0000
commitc94c967656ebaf14c67ff4159c94acc30c162170 (patch)
tree7b4006728bf8d8a11240595a177ebca64844435d /llvm/lib
parent2d910ba1e59da3927271baf0e03b8a35239008c4 (diff)
downloadbcm5719-llvm-c94c967656ebaf14c67ff4159c94acc30c162170.tar.gz
bcm5719-llvm-c94c967656ebaf14c67ff4159c94acc30c162170.zip
Count correctly when a COPY turns into a spill or reload.
The number of spills could go negative since a folded COPY is just a spill, and it may be eliminated. llvm-svn: 139815
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/CodeGen/InlineSpiller.cpp8
1 files changed, 7 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/InlineSpiller.cpp b/llvm/lib/CodeGen/InlineSpiller.cpp
index 5078f3a4bd0..169a867aa7a 100644
--- a/llvm/lib/CodeGen/InlineSpiller.cpp
+++ b/llvm/lib/CodeGen/InlineSpiller.cpp
@@ -1002,6 +1002,7 @@ bool InlineSpiller::coalesceStackAccess(MachineInstr *MI, unsigned Reg) {
bool InlineSpiller::foldMemoryOperand(MachineBasicBlock::iterator MI,
const SmallVectorImpl<unsigned> &Ops,
MachineInstr *LoadMI) {
+ bool WasCopy = MI->isCopy();
// TargetInstrInfo::foldMemoryOperand only expects explicit, non-tied
// operands.
SmallVector<unsigned, 8> FoldOps;
@@ -1031,7 +1032,12 @@ bool InlineSpiller::foldMemoryOperand(MachineBasicBlock::iterator MI,
VRM.addSpillSlotUse(StackSlot, FoldMI);
MI->eraseFromParent();
DEBUG(dbgs() << "\tfolded: " << *FoldMI);
- ++NumFolded;
+ if (!WasCopy)
+ ++NumFolded;
+ else if (Ops.front() == 0)
+ ++NumSpills;
+ else
+ ++NumReloads;
return true;
}
OpenPOWER on IntegriCloud