130fdc8d8SChris Lattner //===-- StackFrame.cpp ------------------------------------------*- C++ -*-===//
230fdc8d8SChris Lattner //
330fdc8d8SChris Lattner //                     The LLVM Compiler Infrastructure
430fdc8d8SChris Lattner //
530fdc8d8SChris Lattner // This file is distributed under the University of Illinois Open Source
630fdc8d8SChris Lattner // License. See LICENSE.TXT for details.
730fdc8d8SChris Lattner //
830fdc8d8SChris Lattner //===----------------------------------------------------------------------===//
930fdc8d8SChris Lattner 
1030fdc8d8SChris Lattner #include "lldb/Target/StackFrame.h"
1130fdc8d8SChris Lattner 
1230fdc8d8SChris Lattner // C Includes
1330fdc8d8SChris Lattner // C++ Includes
1430fdc8d8SChris Lattner // Other libraries and framework includes
1530fdc8d8SChris Lattner // Project includes
1630fdc8d8SChris Lattner #include "lldb/Core/Module.h"
1730fdc8d8SChris Lattner #include "lldb/Core/Disassembler.h"
1830fdc8d8SChris Lattner #include "lldb/Core/Value.h"
1930fdc8d8SChris Lattner #include "lldb/Symbol/Function.h"
2030fdc8d8SChris Lattner #include "lldb/Target/ExecutionContext.h"
2130fdc8d8SChris Lattner #include "lldb/Target/Process.h"
2230fdc8d8SChris Lattner #include "lldb/Target/RegisterContext.h"
2330fdc8d8SChris Lattner #include "lldb/Target/Target.h"
2430fdc8d8SChris Lattner #include "lldb/Target/Thread.h"
2530fdc8d8SChris Lattner 
2630fdc8d8SChris Lattner using namespace lldb;
2730fdc8d8SChris Lattner using namespace lldb_private;
2830fdc8d8SChris Lattner 
2930fdc8d8SChris Lattner // The first bits in the flags are reserved for the SymbolContext::Scope bits
3030fdc8d8SChris Lattner // so we know if we have tried to look up information in our internal symbol
3130fdc8d8SChris Lattner // context (m_sc) already.
329da7bd07SGreg Clayton #define RESOLVED_FRAME_ADDR (uint32_t(eSymbolContextEverything + 1))
339da7bd07SGreg Clayton #define RESOLVED_FRAME_ID   (RESOLVED_FRAME_ADDR << 1)
3430fdc8d8SChris Lattner #define GOT_FRAME_BASE      (RESOLVED_FRAME_ID << 1)
3530fdc8d8SChris Lattner #define FRAME_IS_OBSOLETE   (GOT_FRAME_BASE << 1)
3630fdc8d8SChris Lattner #define RESOLVED_VARIABLES  (FRAME_IS_OBSOLETE << 1)
3730fdc8d8SChris Lattner 
381b72fcb7SGreg Clayton StackFrame::StackFrame
391b72fcb7SGreg Clayton (
401b72fcb7SGreg Clayton     lldb::user_id_t frame_idx,
411b72fcb7SGreg Clayton     lldb::user_id_t concrete_frame_index,
421b72fcb7SGreg Clayton     Thread &thread,
431b72fcb7SGreg Clayton     lldb::addr_t cfa,
441b72fcb7SGreg Clayton     lldb::addr_t pc,
451b72fcb7SGreg Clayton     const SymbolContext *sc_ptr
461b72fcb7SGreg Clayton ) :
471b72fcb7SGreg Clayton     m_frame_index (frame_idx),
481b72fcb7SGreg Clayton     m_concrete_frame_index (concrete_frame_index),
4930fdc8d8SChris Lattner     m_thread (thread),
5030fdc8d8SChris Lattner     m_reg_context_sp (),
51*12fc3e0fSGreg Clayton     m_id (LLDB_INVALID_UID, cfa, LLDB_INVALID_UID),
52*12fc3e0fSGreg Clayton     m_frame_code_addr (NULL, pc),
5330fdc8d8SChris Lattner     m_sc (),
5430fdc8d8SChris Lattner     m_flags (),
5530fdc8d8SChris Lattner     m_frame_base (),
5630fdc8d8SChris Lattner     m_frame_base_error (),
5730fdc8d8SChris Lattner     m_variable_list_sp (),
5830fdc8d8SChris Lattner     m_value_object_list ()
5930fdc8d8SChris Lattner {
6030fdc8d8SChris Lattner     if (sc_ptr != NULL)
611b72fcb7SGreg Clayton     {
6230fdc8d8SChris Lattner         m_sc = *sc_ptr;
631b72fcb7SGreg Clayton         m_flags.Set(m_sc.GetResolvedMask ());
641b72fcb7SGreg Clayton     }
6530fdc8d8SChris Lattner }
6630fdc8d8SChris Lattner 
671b72fcb7SGreg Clayton StackFrame::StackFrame
681b72fcb7SGreg Clayton (
691b72fcb7SGreg Clayton     lldb::user_id_t frame_idx,
701b72fcb7SGreg Clayton     lldb::user_id_t concrete_frame_index,
711b72fcb7SGreg Clayton     Thread &thread,
721b72fcb7SGreg Clayton     const RegisterContextSP &reg_context_sp,
731b72fcb7SGreg Clayton     lldb::addr_t cfa,
741b72fcb7SGreg Clayton     lldb::addr_t pc,
751b72fcb7SGreg Clayton     const SymbolContext *sc_ptr
761b72fcb7SGreg Clayton ) :
771b72fcb7SGreg Clayton     m_frame_index (frame_idx),
781b72fcb7SGreg Clayton     m_concrete_frame_index (concrete_frame_index),
7930fdc8d8SChris Lattner     m_thread (thread),
8030fdc8d8SChris Lattner     m_reg_context_sp (reg_context_sp),
81*12fc3e0fSGreg Clayton     m_id (LLDB_INVALID_UID, cfa, LLDB_INVALID_UID),
82*12fc3e0fSGreg Clayton     m_frame_code_addr (NULL, pc),
8330fdc8d8SChris Lattner     m_sc (),
8430fdc8d8SChris Lattner     m_flags (),
8530fdc8d8SChris Lattner     m_frame_base (),
8630fdc8d8SChris Lattner     m_frame_base_error (),
8730fdc8d8SChris Lattner     m_variable_list_sp (),
8830fdc8d8SChris Lattner     m_value_object_list ()
8930fdc8d8SChris Lattner {
9030fdc8d8SChris Lattner     if (sc_ptr != NULL)
911b72fcb7SGreg Clayton     {
9230fdc8d8SChris Lattner         m_sc = *sc_ptr;
931b72fcb7SGreg Clayton         m_flags.Set(m_sc.GetResolvedMask ());
941b72fcb7SGreg Clayton     }
951b72fcb7SGreg Clayton 
961b72fcb7SGreg Clayton     if (reg_context_sp && !m_sc.target_sp)
971b72fcb7SGreg Clayton     {
981b72fcb7SGreg Clayton         m_sc.target_sp = reg_context_sp->GetThread().GetProcess().GetTarget().GetSP();
991b72fcb7SGreg Clayton         m_flags.Set (eSymbolContextTarget);
1001b72fcb7SGreg Clayton     }
1011b72fcb7SGreg Clayton }
1021b72fcb7SGreg Clayton 
1031b72fcb7SGreg Clayton StackFrame::StackFrame
1041b72fcb7SGreg Clayton (
1051b72fcb7SGreg Clayton     lldb::user_id_t frame_idx,
1061b72fcb7SGreg Clayton     lldb::user_id_t concrete_frame_index,
1071b72fcb7SGreg Clayton     Thread &thread,
1081b72fcb7SGreg Clayton     const RegisterContextSP &reg_context_sp,
1091b72fcb7SGreg Clayton     lldb::addr_t cfa,
1101b72fcb7SGreg Clayton     const Address& pc_addr,
1111b72fcb7SGreg Clayton     const SymbolContext *sc_ptr
1121b72fcb7SGreg Clayton ) :
1131b72fcb7SGreg Clayton     m_frame_index (frame_idx),
1141b72fcb7SGreg Clayton     m_concrete_frame_index (concrete_frame_index),
1151b72fcb7SGreg Clayton     m_thread (thread),
1161b72fcb7SGreg Clayton     m_reg_context_sp (reg_context_sp),
117*12fc3e0fSGreg Clayton     m_id (LLDB_INVALID_UID, cfa, LLDB_INVALID_UID),
118*12fc3e0fSGreg Clayton     m_frame_code_addr (pc_addr),
1191b72fcb7SGreg Clayton     m_sc (),
1201b72fcb7SGreg Clayton     m_flags (),
1211b72fcb7SGreg Clayton     m_frame_base (),
1221b72fcb7SGreg Clayton     m_frame_base_error (),
1231b72fcb7SGreg Clayton     m_variable_list_sp (),
1241b72fcb7SGreg Clayton     m_value_object_list ()
1251b72fcb7SGreg Clayton {
1261b72fcb7SGreg Clayton     if (sc_ptr != NULL)
1271b72fcb7SGreg Clayton     {
1281b72fcb7SGreg Clayton         m_sc = *sc_ptr;
1291b72fcb7SGreg Clayton         m_flags.Set(m_sc.GetResolvedMask ());
1301b72fcb7SGreg Clayton     }
1311b72fcb7SGreg Clayton 
1321b72fcb7SGreg Clayton     if (m_sc.target_sp.get() == NULL && reg_context_sp)
1331b72fcb7SGreg Clayton     {
1341b72fcb7SGreg Clayton         m_sc.target_sp = reg_context_sp->GetThread().GetProcess().GetTarget().GetSP();
1351b72fcb7SGreg Clayton         m_flags.Set (eSymbolContextTarget);
1361b72fcb7SGreg Clayton     }
1371b72fcb7SGreg Clayton 
1381b72fcb7SGreg Clayton     if (m_sc.module_sp.get() == NULL && pc_addr.GetSection())
1391b72fcb7SGreg Clayton     {
1401b72fcb7SGreg Clayton         Module *pc_module = pc_addr.GetSection()->GetModule();
1411b72fcb7SGreg Clayton         if (pc_module)
1421b72fcb7SGreg Clayton         {
1431b72fcb7SGreg Clayton             m_sc.module_sp = pc_module->GetSP();
1441b72fcb7SGreg Clayton             m_flags.Set (eSymbolContextModule);
1451b72fcb7SGreg Clayton         }
1461b72fcb7SGreg Clayton     }
14730fdc8d8SChris Lattner }
14830fdc8d8SChris Lattner 
14930fdc8d8SChris Lattner 
15030fdc8d8SChris Lattner //----------------------------------------------------------------------
15130fdc8d8SChris Lattner // Destructor
15230fdc8d8SChris Lattner //----------------------------------------------------------------------
15330fdc8d8SChris Lattner StackFrame::~StackFrame()
15430fdc8d8SChris Lattner {
15530fdc8d8SChris Lattner }
15630fdc8d8SChris Lattner 
15730fdc8d8SChris Lattner StackID&
15830fdc8d8SChris Lattner StackFrame::GetStackID()
15930fdc8d8SChris Lattner {
160*12fc3e0fSGreg Clayton     // Make sure we have resolved our stack ID's start PC before we give
161*12fc3e0fSGreg Clayton     // it out to any external clients. This allows us to not have to lookup
162*12fc3e0fSGreg Clayton     // this information if it is never asked for.
163*12fc3e0fSGreg Clayton     if (m_flags.IsClear(RESOLVED_FRAME_ID) && m_id.GetStartAddress() == LLDB_INVALID_ADDRESS)
16430fdc8d8SChris Lattner     {
16530fdc8d8SChris Lattner         m_flags.Set (RESOLVED_FRAME_ID);
16630fdc8d8SChris Lattner 
16730fdc8d8SChris Lattner         // Resolve our PC to section offset if we haven't alreday done so
16830fdc8d8SChris Lattner         // and if we don't have a module. The resolved address section will
16930fdc8d8SChris Lattner         // contain the module to which it belongs.
1709da7bd07SGreg Clayton         if (!m_sc.module_sp && m_flags.IsClear(RESOLVED_FRAME_ADDR))
1719da7bd07SGreg Clayton             GetFrameCodeAddress();
17230fdc8d8SChris Lattner 
1739da7bd07SGreg Clayton         if (GetSymbolContext (eSymbolContextFunction).function)
17430fdc8d8SChris Lattner         {
175*12fc3e0fSGreg Clayton             m_id.SetStartAddress (m_sc.function->GetAddressRange().GetBaseAddress().GetLoadAddress (&m_thread.GetProcess()));
17630fdc8d8SChris Lattner         }
1779da7bd07SGreg Clayton         else if (GetSymbolContext (eSymbolContextSymbol).symbol)
17830fdc8d8SChris Lattner         {
17930fdc8d8SChris Lattner             AddressRange *symbol_range_ptr = m_sc.symbol->GetAddressRangePtr();
18030fdc8d8SChris Lattner             if (symbol_range_ptr)
181*12fc3e0fSGreg Clayton                 m_id.SetStartAddress(symbol_range_ptr->GetBaseAddress().GetLoadAddress (&m_thread.GetProcess()));
18230fdc8d8SChris Lattner         }
183*12fc3e0fSGreg Clayton 
184*12fc3e0fSGreg Clayton         // We didn't find a function or symbol, just use the frame code address
185*12fc3e0fSGreg Clayton         // which will be the same as the PC in the frame.
186*12fc3e0fSGreg Clayton         if (m_id.GetStartAddress() == LLDB_INVALID_ADDRESS)
187*12fc3e0fSGreg Clayton             m_id.SetStartAddress (m_frame_code_addr.GetLoadAddress (&m_thread.GetProcess()));
18830fdc8d8SChris Lattner     }
18930fdc8d8SChris Lattner     return m_id;
19030fdc8d8SChris Lattner }
19130fdc8d8SChris Lattner 
19230fdc8d8SChris Lattner Address&
1939da7bd07SGreg Clayton StackFrame::GetFrameCodeAddress()
19430fdc8d8SChris Lattner {
195*12fc3e0fSGreg Clayton     if (m_flags.IsClear(RESOLVED_FRAME_ADDR) && !m_frame_code_addr.IsSectionOffset())
19630fdc8d8SChris Lattner     {
1979da7bd07SGreg Clayton         m_flags.Set (RESOLVED_FRAME_ADDR);
19830fdc8d8SChris Lattner 
19930fdc8d8SChris Lattner         // Resolve the PC into a temporary address because if ResolveLoadAddress
20030fdc8d8SChris Lattner         // fails to resolve the address, it will clear the address object...
20130fdc8d8SChris Lattner         Address resolved_pc;
202*12fc3e0fSGreg Clayton         if (m_thread.GetProcess().ResolveLoadAddress(m_frame_code_addr.GetOffset(), resolved_pc))
20330fdc8d8SChris Lattner         {
204*12fc3e0fSGreg Clayton             m_frame_code_addr = resolved_pc;
205*12fc3e0fSGreg Clayton             const Section *section = m_frame_code_addr.GetSection();
20630fdc8d8SChris Lattner             if (section)
20730fdc8d8SChris Lattner             {
20830fdc8d8SChris Lattner                 Module *module = section->GetModule();
20930fdc8d8SChris Lattner                 if (module)
21030fdc8d8SChris Lattner                 {
21130fdc8d8SChris Lattner                     m_sc.module_sp = module->GetSP();
21230fdc8d8SChris Lattner                     if (m_sc.module_sp)
21330fdc8d8SChris Lattner                         m_flags.Set(eSymbolContextModule);
21430fdc8d8SChris Lattner                 }
21530fdc8d8SChris Lattner             }
21630fdc8d8SChris Lattner         }
21730fdc8d8SChris Lattner     }
218*12fc3e0fSGreg Clayton     return m_frame_code_addr;
21930fdc8d8SChris Lattner }
22030fdc8d8SChris Lattner 
22130fdc8d8SChris Lattner void
22230fdc8d8SChris Lattner StackFrame::ChangePC (addr_t pc)
22330fdc8d8SChris Lattner {
224*12fc3e0fSGreg Clayton     m_frame_code_addr.SetOffset(pc);
225*12fc3e0fSGreg Clayton     m_frame_code_addr.SetSection(NULL);
22630fdc8d8SChris Lattner     m_sc.Clear();
22730fdc8d8SChris Lattner     m_flags.SetAllFlagBits(0);
22830fdc8d8SChris Lattner     m_thread.ClearStackFrames ();
22930fdc8d8SChris Lattner }
23030fdc8d8SChris Lattner 
23130fdc8d8SChris Lattner const char *
23230fdc8d8SChris Lattner StackFrame::Disassemble ()
23330fdc8d8SChris Lattner {
23430fdc8d8SChris Lattner     if (m_disassembly.GetSize() == 0)
23530fdc8d8SChris Lattner     {
23630fdc8d8SChris Lattner         ExecutionContext exe_ctx;
23730fdc8d8SChris Lattner         Calculate(exe_ctx);
2386611103cSGreg Clayton         Target &target = m_thread.GetProcess().GetTarget();
2396611103cSGreg Clayton         Disassembler::Disassemble (target.GetDebugger(),
2406611103cSGreg Clayton                                    target.GetArchitecture(),
24130fdc8d8SChris Lattner                                    exe_ctx,
24230fdc8d8SChris Lattner                                    0,
243dda4f7b5SGreg Clayton                                    false,
24430fdc8d8SChris Lattner                                    m_disassembly);
24530fdc8d8SChris Lattner         if (m_disassembly.GetSize() == 0)
24630fdc8d8SChris Lattner             return NULL;
24730fdc8d8SChris Lattner     }
24830fdc8d8SChris Lattner     return m_disassembly.GetData();
24930fdc8d8SChris Lattner }
25030fdc8d8SChris Lattner 
25130fdc8d8SChris Lattner //----------------------------------------------------------------------
25230fdc8d8SChris Lattner // Get the symbol context if we already haven't done so by resolving the
25330fdc8d8SChris Lattner // PC address as much as possible. This way when we pass around a
25430fdc8d8SChris Lattner // StackFrame object, everyone will have as much information as
25530fdc8d8SChris Lattner // possible and no one will ever have to look things up manually.
25630fdc8d8SChris Lattner //----------------------------------------------------------------------
25730fdc8d8SChris Lattner const SymbolContext&
25830fdc8d8SChris Lattner StackFrame::GetSymbolContext (uint32_t resolve_scope)
25930fdc8d8SChris Lattner {
26030fdc8d8SChris Lattner     // Copy our internal symbol context into "sc".
26130fdc8d8SChris Lattner     if ((m_flags.GetAllFlagBits() & resolve_scope) != resolve_scope)
26230fdc8d8SChris Lattner     {
26330fdc8d8SChris Lattner         // Resolve our PC to section offset if we haven't alreday done so
26430fdc8d8SChris Lattner         // and if we don't have a module. The resolved address section will
26530fdc8d8SChris Lattner         // contain the module to which it belongs
2669da7bd07SGreg Clayton         if (!m_sc.module_sp && m_flags.IsClear(RESOLVED_FRAME_ADDR))
2679da7bd07SGreg Clayton             GetFrameCodeAddress();
26830fdc8d8SChris Lattner 
26930fdc8d8SChris Lattner         // If this is not frame zero, then we need to subtract 1 from the PC
27030fdc8d8SChris Lattner         // value when doing address lookups since the PC will be on the
27130fdc8d8SChris Lattner         // instruction following the function call instruction...
27230fdc8d8SChris Lattner 
2739da7bd07SGreg Clayton         Address lookup_addr(GetFrameCodeAddress());
2741b72fcb7SGreg Clayton         if (m_frame_index > 0 && lookup_addr.IsValid())
27530fdc8d8SChris Lattner         {
27630fdc8d8SChris Lattner             addr_t offset = lookup_addr.GetOffset();
27730fdc8d8SChris Lattner             if (offset > 0)
27830fdc8d8SChris Lattner                 lookup_addr.SetOffset(offset - 1);
27930fdc8d8SChris Lattner         }
28030fdc8d8SChris Lattner 
2819da7bd07SGreg Clayton 
2829da7bd07SGreg Clayton         uint32_t resolved = 0;
28330fdc8d8SChris Lattner         if (m_sc.module_sp)
28430fdc8d8SChris Lattner         {
28530fdc8d8SChris Lattner             // We have something in our stack frame symbol context, lets check
28630fdc8d8SChris Lattner             // if we haven't already tried to lookup one of those things. If we
28730fdc8d8SChris Lattner             // haven't then we will do the query.
2881b72fcb7SGreg Clayton 
2891b72fcb7SGreg Clayton             uint32_t actual_resolve_scope = 0;
2901b72fcb7SGreg Clayton 
2911b72fcb7SGreg Clayton             if (resolve_scope & eSymbolContextCompUnit)
2921b72fcb7SGreg Clayton             {
2931b72fcb7SGreg Clayton                 if (m_flags.IsClear (eSymbolContextCompUnit))
2941b72fcb7SGreg Clayton                 {
2951b72fcb7SGreg Clayton                     if (m_sc.comp_unit)
2969da7bd07SGreg Clayton                         resolved |= eSymbolContextCompUnit;
2971b72fcb7SGreg Clayton                     else
2981b72fcb7SGreg Clayton                         actual_resolve_scope |= eSymbolContextCompUnit;
2991b72fcb7SGreg Clayton                 }
3001b72fcb7SGreg Clayton             }
3011b72fcb7SGreg Clayton 
3021b72fcb7SGreg Clayton             if (resolve_scope & eSymbolContextFunction)
3031b72fcb7SGreg Clayton             {
3041b72fcb7SGreg Clayton                 if (m_flags.IsClear (eSymbolContextFunction))
3051b72fcb7SGreg Clayton                 {
3061b72fcb7SGreg Clayton                     if (m_sc.function)
3079da7bd07SGreg Clayton                         resolved |= eSymbolContextFunction;
3081b72fcb7SGreg Clayton                     else
3091b72fcb7SGreg Clayton                         actual_resolve_scope |= eSymbolContextFunction;
3101b72fcb7SGreg Clayton                 }
3111b72fcb7SGreg Clayton             }
3121b72fcb7SGreg Clayton 
3131b72fcb7SGreg Clayton             if (resolve_scope & eSymbolContextBlock)
3141b72fcb7SGreg Clayton             {
3151b72fcb7SGreg Clayton                 if (m_flags.IsClear (eSymbolContextBlock))
3161b72fcb7SGreg Clayton                 {
3171b72fcb7SGreg Clayton                     if (m_sc.block)
3189da7bd07SGreg Clayton                         resolved |= eSymbolContextBlock;
3191b72fcb7SGreg Clayton                     else
3201b72fcb7SGreg Clayton                         actual_resolve_scope |= eSymbolContextBlock;
3211b72fcb7SGreg Clayton                 }
3221b72fcb7SGreg Clayton             }
3231b72fcb7SGreg Clayton 
3241b72fcb7SGreg Clayton             if (resolve_scope & eSymbolContextSymbol)
3251b72fcb7SGreg Clayton             {
3261b72fcb7SGreg Clayton                 if (m_flags.IsClear (eSymbolContextSymbol))
3271b72fcb7SGreg Clayton                 {
3281b72fcb7SGreg Clayton                     if (m_sc.symbol)
3299da7bd07SGreg Clayton                         resolved |= eSymbolContextSymbol;
3301b72fcb7SGreg Clayton                     else
3311b72fcb7SGreg Clayton                         actual_resolve_scope |= eSymbolContextSymbol;
3321b72fcb7SGreg Clayton                 }
3331b72fcb7SGreg Clayton             }
3341b72fcb7SGreg Clayton 
3351b72fcb7SGreg Clayton             if (resolve_scope & eSymbolContextLineEntry)
3361b72fcb7SGreg Clayton             {
3371b72fcb7SGreg Clayton                 if (m_flags.IsClear (eSymbolContextLineEntry))
3381b72fcb7SGreg Clayton                 {
3391b72fcb7SGreg Clayton                     if (m_sc.line_entry.IsValid())
3409da7bd07SGreg Clayton                         resolved |= eSymbolContextLineEntry;
3411b72fcb7SGreg Clayton                     else
3421b72fcb7SGreg Clayton                         actual_resolve_scope |= eSymbolContextLineEntry;
3431b72fcb7SGreg Clayton                 }
3441b72fcb7SGreg Clayton             }
3451b72fcb7SGreg Clayton 
3461b72fcb7SGreg Clayton             if (actual_resolve_scope)
34730fdc8d8SChris Lattner             {
34830fdc8d8SChris Lattner                 // We might be resolving less information than what is already
34930fdc8d8SChris Lattner                 // in our current symbol context so resolve into a temporary
35030fdc8d8SChris Lattner                 // symbol context "sc" so we don't clear out data we have
35130fdc8d8SChris Lattner                 // already found in "m_sc"
35230fdc8d8SChris Lattner                 SymbolContext sc;
35330fdc8d8SChris Lattner                 // Set flags that indicate what we have tried to resolve
3549da7bd07SGreg Clayton                 resolved |= m_sc.module_sp->ResolveSymbolContextForAddress (lookup_addr, actual_resolve_scope, sc);
3551b72fcb7SGreg Clayton                 // Only replace what we didn't already have as we may have
3561b72fcb7SGreg Clayton                 // information for an inlined function scope that won't match
3571b72fcb7SGreg Clayton                 // what a standard lookup by address would match
3589da7bd07SGreg Clayton                 if ((resolved & eSymbolContextCompUnit)  && m_sc.comp_unit == NULL)
3599da7bd07SGreg Clayton                     m_sc.comp_unit = sc.comp_unit;
3609da7bd07SGreg Clayton                 if ((resolved & eSymbolContextFunction)  && m_sc.function == NULL)
3619da7bd07SGreg Clayton                     m_sc.function = sc.function;
3629da7bd07SGreg Clayton                 if ((resolved & eSymbolContextBlock)     && m_sc.block == NULL)
3639da7bd07SGreg Clayton                     m_sc.block = sc.block;
3649da7bd07SGreg Clayton                 if ((resolved & eSymbolContextSymbol)    && m_sc.symbol == NULL)
3659da7bd07SGreg Clayton                     m_sc.symbol = sc.symbol;
3669da7bd07SGreg Clayton                 if ((resolved & eSymbolContextLineEntry) && !m_sc.line_entry.IsValid())
3679da7bd07SGreg Clayton                     m_sc.line_entry = sc.line_entry;
3689da7bd07SGreg Clayton 
36930fdc8d8SChris Lattner             }
37030fdc8d8SChris Lattner         }
37130fdc8d8SChris Lattner         else
37230fdc8d8SChris Lattner         {
37330fdc8d8SChris Lattner             // If we don't have a module, then we can't have the compile unit,
37430fdc8d8SChris Lattner             // function, block, line entry or symbol, so we can safely call
37530fdc8d8SChris Lattner             // ResolveSymbolContextForAddress with our symbol context member m_sc.
3769da7bd07SGreg Clayton             resolved |= m_thread.GetProcess().GetTarget().GetImages().ResolveSymbolContextForAddress (lookup_addr, resolve_scope, m_sc);
37730fdc8d8SChris Lattner         }
37830fdc8d8SChris Lattner 
37930fdc8d8SChris Lattner         // If the target was requested add that:
38030fdc8d8SChris Lattner         if (m_sc.target_sp.get() == NULL)
3819da7bd07SGreg Clayton         {
38230fdc8d8SChris Lattner             m_sc.target_sp = CalculateProcess()->GetTarget().GetSP();
3839da7bd07SGreg Clayton             if (m_sc.target_sp)
3849da7bd07SGreg Clayton                 resolved |= eSymbolContextTarget;
3859da7bd07SGreg Clayton         }
38630fdc8d8SChris Lattner 
38730fdc8d8SChris Lattner         // Update our internal flags so we remember what we have tried to locate so
38830fdc8d8SChris Lattner         // we don't have to keep trying when more calls to this function are made.
3899da7bd07SGreg Clayton         // We might have dug up more information that was requested (for example
3909da7bd07SGreg Clayton         // if we were asked to only get the block, we will have gotten the
3919da7bd07SGreg Clayton         // compile unit, and function) so set any additional bits that we resolved
3929da7bd07SGreg Clayton         m_flags.Set (resolve_scope | resolved);
39330fdc8d8SChris Lattner     }
39430fdc8d8SChris Lattner 
39530fdc8d8SChris Lattner     // Return the symbol context with everything that was possible to resolve
39630fdc8d8SChris Lattner     // resolved.
39730fdc8d8SChris Lattner     return m_sc;
39830fdc8d8SChris Lattner }
39930fdc8d8SChris Lattner 
40030fdc8d8SChris Lattner 
40130fdc8d8SChris Lattner VariableList *
40230fdc8d8SChris Lattner StackFrame::GetVariableList ()
40330fdc8d8SChris Lattner {
40430fdc8d8SChris Lattner     if (m_flags.IsClear(RESOLVED_VARIABLES))
40530fdc8d8SChris Lattner     {
40630fdc8d8SChris Lattner         m_flags.Set(RESOLVED_VARIABLES);
40730fdc8d8SChris Lattner 
4089da7bd07SGreg Clayton         if (GetSymbolContext (eSymbolContextFunction).function)
40930fdc8d8SChris Lattner         {
41030fdc8d8SChris Lattner             bool get_child_variables = true;
41130fdc8d8SChris Lattner             bool can_create = true;
4120b76a2c2SGreg Clayton             m_variable_list_sp = m_sc.function->GetBlock (can_create).GetVariableList (get_child_variables, can_create);
41330fdc8d8SChris Lattner         }
41430fdc8d8SChris Lattner     }
41530fdc8d8SChris Lattner     return m_variable_list_sp.get();
41630fdc8d8SChris Lattner }
41730fdc8d8SChris Lattner 
41830fdc8d8SChris Lattner 
41930fdc8d8SChris Lattner bool
42030fdc8d8SChris Lattner StackFrame::GetFrameBaseValue (Scalar &frame_base, Error *error_ptr)
42130fdc8d8SChris Lattner {
42230fdc8d8SChris Lattner     if (m_flags.IsClear(GOT_FRAME_BASE))
42330fdc8d8SChris Lattner     {
42430fdc8d8SChris Lattner         if (m_sc.function)
42530fdc8d8SChris Lattner         {
42630fdc8d8SChris Lattner             m_frame_base.Clear();
42730fdc8d8SChris Lattner             m_frame_base_error.Clear();
42830fdc8d8SChris Lattner 
42930fdc8d8SChris Lattner             m_flags.Set(GOT_FRAME_BASE);
43030fdc8d8SChris Lattner             ExecutionContext exe_ctx (&m_thread.GetProcess(), &m_thread, this);
43130fdc8d8SChris Lattner             Value expr_value;
43230fdc8d8SChris Lattner             if (m_sc.function->GetFrameBaseExpression().Evaluate(&exe_ctx, NULL, NULL, expr_value, &m_frame_base_error) < 0)
43330fdc8d8SChris Lattner             {
43430fdc8d8SChris Lattner                 // We should really have an error if evaluate returns, but in case
43530fdc8d8SChris Lattner                 // we don't, lets set the error to something at least.
43630fdc8d8SChris Lattner                 if (m_frame_base_error.Success())
43730fdc8d8SChris Lattner                     m_frame_base_error.SetErrorString("Evaluation of the frame base expression failed.");
43830fdc8d8SChris Lattner             }
43930fdc8d8SChris Lattner             else
44030fdc8d8SChris Lattner             {
44130fdc8d8SChris Lattner                 m_frame_base = expr_value.ResolveValue(&exe_ctx, NULL);
44230fdc8d8SChris Lattner             }
44330fdc8d8SChris Lattner         }
44430fdc8d8SChris Lattner         else
44530fdc8d8SChris Lattner         {
44630fdc8d8SChris Lattner             m_frame_base_error.SetErrorString ("No function in symbol context.");
44730fdc8d8SChris Lattner         }
44830fdc8d8SChris Lattner     }
44930fdc8d8SChris Lattner 
45030fdc8d8SChris Lattner     if (m_frame_base_error.Success())
45130fdc8d8SChris Lattner         frame_base = m_frame_base;
45230fdc8d8SChris Lattner 
45330fdc8d8SChris Lattner     if (error_ptr)
45430fdc8d8SChris Lattner         *error_ptr = m_frame_base_error;
45530fdc8d8SChris Lattner     return m_frame_base_error.Success();
45630fdc8d8SChris Lattner }
45730fdc8d8SChris Lattner 
45830fdc8d8SChris Lattner RegisterContext *
45930fdc8d8SChris Lattner StackFrame::GetRegisterContext ()
46030fdc8d8SChris Lattner {
46130fdc8d8SChris Lattner     if (m_reg_context_sp.get() == NULL)
46230fdc8d8SChris Lattner         m_reg_context_sp.reset (m_thread.CreateRegisterContextForFrame (this));
46330fdc8d8SChris Lattner     return m_reg_context_sp.get();
46430fdc8d8SChris Lattner }
46530fdc8d8SChris Lattner 
46630fdc8d8SChris Lattner bool
46730fdc8d8SChris Lattner StackFrame::HasDebugInformation ()
46830fdc8d8SChris Lattner {
46930fdc8d8SChris Lattner     GetSymbolContext (eSymbolContextLineEntry);
47030fdc8d8SChris Lattner     return m_sc.line_entry.IsValid();
47130fdc8d8SChris Lattner }
47230fdc8d8SChris Lattner 
47330fdc8d8SChris Lattner ValueObjectList &
47430fdc8d8SChris Lattner StackFrame::GetValueObjectList()
47530fdc8d8SChris Lattner {
47630fdc8d8SChris Lattner     return m_value_object_list;
47730fdc8d8SChris Lattner }
47830fdc8d8SChris Lattner 
4796b8379c4SJim Ingham bool
4806b8379c4SJim Ingham StackFrame::IsInlined ()
4816b8379c4SJim Ingham {
482*12fc3e0fSGreg Clayton     return m_id.GetInlineBlockID() != LLDB_INVALID_UID;
4836b8379c4SJim Ingham }
4846b8379c4SJim Ingham 
48530fdc8d8SChris Lattner Target *
48630fdc8d8SChris Lattner StackFrame::CalculateTarget ()
48730fdc8d8SChris Lattner {
48830fdc8d8SChris Lattner     return m_thread.CalculateTarget();
48930fdc8d8SChris Lattner }
49030fdc8d8SChris Lattner 
49130fdc8d8SChris Lattner Process *
49230fdc8d8SChris Lattner StackFrame::CalculateProcess ()
49330fdc8d8SChris Lattner {
49430fdc8d8SChris Lattner     return m_thread.CalculateProcess();
49530fdc8d8SChris Lattner }
49630fdc8d8SChris Lattner 
49730fdc8d8SChris Lattner Thread *
49830fdc8d8SChris Lattner StackFrame::CalculateThread ()
49930fdc8d8SChris Lattner {
50030fdc8d8SChris Lattner     return &m_thread;
50130fdc8d8SChris Lattner }
50230fdc8d8SChris Lattner 
50330fdc8d8SChris Lattner StackFrame *
50430fdc8d8SChris Lattner StackFrame::CalculateStackFrame ()
50530fdc8d8SChris Lattner {
50630fdc8d8SChris Lattner     return this;
50730fdc8d8SChris Lattner }
50830fdc8d8SChris Lattner 
50930fdc8d8SChris Lattner 
51030fdc8d8SChris Lattner void
51130fdc8d8SChris Lattner StackFrame::Calculate (ExecutionContext &exe_ctx)
51230fdc8d8SChris Lattner {
51330fdc8d8SChris Lattner     m_thread.Calculate (exe_ctx);
51430fdc8d8SChris Lattner     exe_ctx.frame = this;
51530fdc8d8SChris Lattner }
51630fdc8d8SChris Lattner 
51730fdc8d8SChris Lattner void
51830fdc8d8SChris Lattner StackFrame::Dump (Stream *strm, bool show_frame_index)
51930fdc8d8SChris Lattner {
52030fdc8d8SChris Lattner     if (strm == NULL)
52130fdc8d8SChris Lattner         return;
52230fdc8d8SChris Lattner 
52330fdc8d8SChris Lattner     if (show_frame_index)
5241b72fcb7SGreg Clayton         strm->Printf("frame #%u: ", m_frame_index);
5259da7bd07SGreg Clayton     strm->Printf("0x%0*llx", m_thread.GetProcess().GetAddressByteSize() * 2, GetFrameCodeAddress().GetLoadAddress(&m_thread.GetProcess()));
5269da7bd07SGreg Clayton     GetSymbolContext(eSymbolContextEverything);
52730fdc8d8SChris Lattner     strm->PutCString(", where = ");
5281b72fcb7SGreg Clayton     // TODO: need to get the
5291b72fcb7SGreg Clayton     const bool show_module = true;
5301b72fcb7SGreg Clayton     const bool show_inline = true;
5319da7bd07SGreg Clayton     m_sc.DumpStopContext(strm, &m_thread.GetProcess(), GetFrameCodeAddress(), show_module, show_inline);
53230fdc8d8SChris Lattner }
53330fdc8d8SChris Lattner 
534