diff options
author | Devang Patel <dpatel@apple.com> | 2010-11-02 17:19:03 +0000 |
---|---|---|
committer | Devang Patel <dpatel@apple.com> | 2010-11-02 17:19:03 +0000 |
commit | bc741405a77ead95cca6c819ca9e01802c78d2b4 (patch) | |
tree | 7f6e1e283250d54f6b10b8042b991d06fd16ab3f /llvm | |
parent | 9a4c23635b8cfdaaf510c2a3519e786c54502908 (diff) | |
download | bcm5719-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
Diffstat (limited to 'llvm')
-rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp | 13 |
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)) |