summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen/PrologEpilogInserter.cpp
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2008-01-31 00:27:49 +0000
committerEvan Cheng <evan.cheng@apple.com>2008-01-31 00:27:49 +0000
commit4863fcc3eb86f82bad2794403198019630e6977e (patch)
treeb372b7e500902a6d3ecdc01abfbf955a60992c7a /llvm/lib/CodeGen/PrologEpilogInserter.cpp
parent3646fdda6707fbb34ea65eb399bac3f90362cd53 (diff)
downloadbcm5719-llvm-4863fcc3eb86f82bad2794403198019630e6977e.tar.gz
bcm5719-llvm-4863fcc3eb86f82bad2794403198019630e6977e.zip
Also avoid adding callee save code before debug labels.
llvm-svn: 46586
Diffstat (limited to 'llvm/lib/CodeGen/PrologEpilogInserter.cpp')
-rw-r--r--llvm/lib/CodeGen/PrologEpilogInserter.cpp10
1 files changed, 9 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/PrologEpilogInserter.cpp b/llvm/lib/CodeGen/PrologEpilogInserter.cpp
index 0280318bb7e..c990ba4776f 100644
--- a/llvm/lib/CodeGen/PrologEpilogInserter.cpp
+++ b/llvm/lib/CodeGen/PrologEpilogInserter.cpp
@@ -243,11 +243,19 @@ void PEI::saveCalleeSavedRegisters(MachineFunction &Fn) {
return;
const TargetInstrInfo &TII = *Fn.getTarget().getInstrInfo();
-
+
// Now that we have a stack slot for each register to be saved, insert spill
// code into the entry block.
MachineBasicBlock *MBB = Fn.begin();
MachineBasicBlock::iterator I = MBB->begin();
+
+ // Do not insert prologue code before debug LABELs at the start of the
+ // entry block.
+ MachineModuleInfo *MMI = FFI->getMachineModuleInfo();
+ if (MMI && MMI->hasDebugInfo())
+ while (I != MBB->end() && I->getOpcode() == TargetInstrInfo::LABEL)
+ ++I;
+
if (!TII.spillCalleeSavedRegisters(*MBB, I, CSI)) {
for (unsigned i = 0, e = CSI.size(); i != e; ++i) {
// Add the callee-saved register as live-in. It's killed at the spill.
OpenPOWER on IntegriCloud