[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