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 ®_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 ®_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