[llvm-commits] [llvm] r64383 - /llvm/trunk/lib/Target/PowerPC/PPCISelDAGToDAG.cpp

Chris Lattner sabre at nondot.org
Thu Feb 12 09:37:15 PST 2009


Author: lattner
Date: Thu Feb 12 11:37:15 2009
New Revision: 64383

URL: http://llvm.org/viewvc/llvm-project?rev=64383&view=rev
Log:
fix PR3538 for PPC

Modified:
    llvm/trunk/lib/Target/PowerPC/PPCISelDAGToDAG.cpp

Modified: llvm/trunk/lib/Target/PowerPC/PPCISelDAGToDAG.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/PowerPC/PPCISelDAGToDAG.cpp?rev=64383&r1=64382&r2=64383&view=diff

==============================================================================
--- llvm/trunk/lib/Target/PowerPC/PPCISelDAGToDAG.cpp (original)
+++ llvm/trunk/lib/Target/PowerPC/PPCISelDAGToDAG.cpp Thu Feb 12 11:37:15 2009
@@ -1110,8 +1110,13 @@
     SDValue N1 = N->getOperand(1);
     SDValue N2 = N->getOperand(2);
     FrameIndexSDNode *FINode = dyn_cast<FrameIndexSDNode>(N1);
-    if (!FINode)
-      break;
+    
+    // FIXME: We need to handle this for VLAs.
+    if (!FINode) {
+      ReplaceUses(Op.getValue(0), Chain);
+      return NULL;
+    }
+    
     if (N2.getOpcode() == ISD::ADD) {
       if (N2.getOperand(0).getOpcode() == ISD::ADD &&
           N2.getOperand(0).getOperand(0).getOpcode() == PPCISD::GlobalBaseReg &&
@@ -1127,8 +1132,13 @@
                N2.getOperand(1).getOpcode() == PPCISD::Lo)
         N2 = N2.getOperand(0).getOperand(0);
     }
-    if (!isa<GlobalAddressSDNode>(N2))
-      break;
+    
+    // If we don't have a global address here, the debug info is mangled, just
+    // drop it.
+    if (!isa<GlobalAddressSDNode>(N2)) {
+      ReplaceUses(Op.getValue(0), Chain);
+      return NULL;
+    }
     int FI = cast<FrameIndexSDNode>(N1)->getIndex();
     GlobalValue *GV = cast<GlobalAddressSDNode>(N2)->getGlobal();
     SDValue Tmp1 = CurDAG->getTargetFrameIndex(FI, TLI.getPointerTy());





More information about the llvm-commits mailing list