[llvm-commits] [llvm] r46586 - /llvm/trunk/lib/CodeGen/PrologEpilogInserter.cpp

Evan Cheng evan.cheng at apple.com
Wed Jan 30 16:27:49 PST 2008


Author: evancheng
Date: Wed Jan 30 18:27:49 2008
New Revision: 46586

URL: http://llvm.org/viewvc/llvm-project?rev=46586&view=rev
Log:
Also avoid adding callee save code before debug labels.

Modified:
    llvm/trunk/lib/CodeGen/PrologEpilogInserter.cpp

Modified: llvm/trunk/lib/CodeGen/PrologEpilogInserter.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/PrologEpilogInserter.cpp?rev=46586&r1=46585&r2=46586&view=diff

==============================================================================
--- llvm/trunk/lib/CodeGen/PrologEpilogInserter.cpp (original)
+++ llvm/trunk/lib/CodeGen/PrologEpilogInserter.cpp Wed Jan 30 18:27:49 2008
@@ -243,11 +243,19 @@
     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.





More information about the llvm-commits mailing list