summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDevang Patel <dpatel@apple.com>2010-11-02 17:19:03 +0000
committerDevang Patel <dpatel@apple.com>2010-11-02 17:19:03 +0000
commitbc741405a77ead95cca6c819ca9e01802c78d2b4 (patch)
tree7f6e1e283250d54f6b10b8042b991d06fd16ab3f
parent9a4c23635b8cfdaaf510c2a3519e786c54502908 (diff)
downloadbcm5719-llvm-bc741405a77ead95cca6c819ca9e01802c78d2b4.tar.gz
bcm5719-llvm-bc741405a77ead95cca6c819ca9e01802c78d2b4.zip
If value map does not have register for an argument then try to find frame index before giving up.
llvm-svn: 118022
-rw-r--r--llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp13
1 files changed, 8 insertions, 5 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp
index eb149e1dfb5..667cac7be9d 100644
--- a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp
+++ b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp
@@ -3980,12 +3980,11 @@ SelectionDAGBuilder::EmitFuncArgumentDbgValue(const Value *V, MDNode *Variable,
if (!Reg) {
// Check if ValueMap has reg number.
DenseMap<const Value *, unsigned>::iterator VMI = FuncInfo.ValueMap.find(V);
- if (VMI == FuncInfo.ValueMap.end())
- return false;
- Reg = VMI->second;
+ if (VMI != FuncInfo.ValueMap.end())
+ Reg = VMI->second;
}
-
- if (!Reg && N.getNode())
+
+ if (!Reg && N.getNode()) {
// Check if frame index is available.
if (LoadSDNode *LNode = dyn_cast<LoadSDNode>(N.getNode()))
if (FrameIndexSDNode *FINode =
@@ -3993,6 +3992,10 @@ SelectionDAGBuilder::EmitFuncArgumentDbgValue(const Value *V, MDNode *Variable,
Reg = TRI->getFrameRegister(MF);
Offset = FINode->getIndex();
}
+ }
+
+ if (!Reg)
+ return false;
MachineInstrBuilder MIB = BuildMI(MF, getCurDebugLoc(),
TII->get(TargetOpcode::DBG_VALUE))
OpenPOWER on IntegriCloud