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 (), 510445d8f4SGreg Clayton m_id (cfa, 0), 5230fdc8d8SChris Lattner m_pc (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), 810445d8f4SGreg Clayton m_id (cfa, 0), 8230fdc8d8SChris Lattner m_pc (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), 1170445d8f4SGreg Clayton m_id (cfa, 0), 1181b72fcb7SGreg Clayton m_pc (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 { 16030fdc8d8SChris Lattner // Make sure we have resolved our stack ID's address range before we give 16130fdc8d8SChris Lattner // it out to any external clients 16230fdc8d8SChris Lattner if (m_id.GetStartAddress().IsValid() == 0 && m_flags.IsClear(RESOLVED_FRAME_ID)) 16330fdc8d8SChris Lattner { 16430fdc8d8SChris Lattner m_flags.Set (RESOLVED_FRAME_ID); 16530fdc8d8SChris Lattner 16630fdc8d8SChris Lattner // Resolve our PC to section offset if we haven't alreday done so 16730fdc8d8SChris Lattner // and if we don't have a module. The resolved address section will 16830fdc8d8SChris Lattner // contain the module to which it belongs. 1699da7bd07SGreg Clayton if (!m_sc.module_sp && m_flags.IsClear(RESOLVED_FRAME_ADDR)) 1709da7bd07SGreg Clayton GetFrameCodeAddress(); 17130fdc8d8SChris Lattner 1729da7bd07SGreg Clayton if (GetSymbolContext (eSymbolContextFunction).function) 17330fdc8d8SChris Lattner { 17430fdc8d8SChris Lattner m_id.SetStartAddress (m_sc.function->GetAddressRange().GetBaseAddress()); 17530fdc8d8SChris Lattner } 1769da7bd07SGreg Clayton else if (GetSymbolContext (eSymbolContextSymbol).symbol) 17730fdc8d8SChris Lattner { 17830fdc8d8SChris Lattner AddressRange *symbol_range_ptr = m_sc.symbol->GetAddressRangePtr(); 17930fdc8d8SChris Lattner if (symbol_range_ptr) 18030fdc8d8SChris Lattner m_id.SetStartAddress(symbol_range_ptr->GetBaseAddress()); 18130fdc8d8SChris Lattner } 18230fdc8d8SChris Lattner } 18330fdc8d8SChris Lattner return m_id; 18430fdc8d8SChris Lattner } 18530fdc8d8SChris Lattner 18630fdc8d8SChris Lattner Address& 1879da7bd07SGreg Clayton StackFrame::GetFrameCodeAddress() 18830fdc8d8SChris Lattner { 1899da7bd07SGreg Clayton if (m_flags.IsClear(RESOLVED_FRAME_ADDR) && !m_pc.IsSectionOffset()) 19030fdc8d8SChris Lattner { 1919da7bd07SGreg Clayton m_flags.Set (RESOLVED_FRAME_ADDR); 19230fdc8d8SChris Lattner 19330fdc8d8SChris Lattner // Resolve the PC into a temporary address because if ResolveLoadAddress 19430fdc8d8SChris Lattner // fails to resolve the address, it will clear the address object... 19530fdc8d8SChris Lattner Address resolved_pc; 19630fdc8d8SChris Lattner if (m_thread.GetProcess().ResolveLoadAddress(m_pc.GetOffset(), resolved_pc)) 19730fdc8d8SChris Lattner { 19830fdc8d8SChris Lattner m_pc = resolved_pc; 19930fdc8d8SChris Lattner const Section *section = m_pc.GetSection(); 20030fdc8d8SChris Lattner if (section) 20130fdc8d8SChris Lattner { 20230fdc8d8SChris Lattner Module *module = section->GetModule(); 20330fdc8d8SChris Lattner if (module) 20430fdc8d8SChris Lattner { 20530fdc8d8SChris Lattner m_sc.module_sp = module->GetSP(); 20630fdc8d8SChris Lattner if (m_sc.module_sp) 20730fdc8d8SChris Lattner m_flags.Set(eSymbolContextModule); 20830fdc8d8SChris Lattner } 20930fdc8d8SChris Lattner } 21030fdc8d8SChris Lattner } 21130fdc8d8SChris Lattner } 21230fdc8d8SChris Lattner return m_pc; 21330fdc8d8SChris Lattner } 21430fdc8d8SChris Lattner 21530fdc8d8SChris Lattner void 21630fdc8d8SChris Lattner StackFrame::ChangePC (addr_t pc) 21730fdc8d8SChris Lattner { 21830fdc8d8SChris Lattner m_pc.SetOffset(pc); 21930fdc8d8SChris Lattner m_pc.SetSection(NULL); 22030fdc8d8SChris Lattner m_sc.Clear(); 22130fdc8d8SChris Lattner m_flags.SetAllFlagBits(0); 22230fdc8d8SChris Lattner m_thread.ClearStackFrames (); 22330fdc8d8SChris Lattner } 22430fdc8d8SChris Lattner 22530fdc8d8SChris Lattner const char * 22630fdc8d8SChris Lattner StackFrame::Disassemble () 22730fdc8d8SChris Lattner { 22830fdc8d8SChris Lattner if (m_disassembly.GetSize() == 0) 22930fdc8d8SChris Lattner { 23030fdc8d8SChris Lattner ExecutionContext exe_ctx; 23130fdc8d8SChris Lattner Calculate(exe_ctx); 2326611103cSGreg Clayton Target &target = m_thread.GetProcess().GetTarget(); 2336611103cSGreg Clayton Disassembler::Disassemble (target.GetDebugger(), 2346611103cSGreg Clayton target.GetArchitecture(), 23530fdc8d8SChris Lattner exe_ctx, 23630fdc8d8SChris Lattner 0, 237dda4f7b5SGreg Clayton false, 23830fdc8d8SChris Lattner m_disassembly); 23930fdc8d8SChris Lattner if (m_disassembly.GetSize() == 0) 24030fdc8d8SChris Lattner return NULL; 24130fdc8d8SChris Lattner } 24230fdc8d8SChris Lattner return m_disassembly.GetData(); 24330fdc8d8SChris Lattner } 24430fdc8d8SChris Lattner 24530fdc8d8SChris Lattner //---------------------------------------------------------------------- 24630fdc8d8SChris Lattner // Get the symbol context if we already haven't done so by resolving the 24730fdc8d8SChris Lattner // PC address as much as possible. This way when we pass around a 24830fdc8d8SChris Lattner // StackFrame object, everyone will have as much information as 24930fdc8d8SChris Lattner // possible and no one will ever have to look things up manually. 25030fdc8d8SChris Lattner //---------------------------------------------------------------------- 25130fdc8d8SChris Lattner const SymbolContext& 25230fdc8d8SChris Lattner StackFrame::GetSymbolContext (uint32_t resolve_scope) 25330fdc8d8SChris Lattner { 25430fdc8d8SChris Lattner // Copy our internal symbol context into "sc". 25530fdc8d8SChris Lattner if ((m_flags.GetAllFlagBits() & resolve_scope) != resolve_scope) 25630fdc8d8SChris Lattner { 25730fdc8d8SChris Lattner // Resolve our PC to section offset if we haven't alreday done so 25830fdc8d8SChris Lattner // and if we don't have a module. The resolved address section will 25930fdc8d8SChris Lattner // contain the module to which it belongs 2609da7bd07SGreg Clayton if (!m_sc.module_sp && m_flags.IsClear(RESOLVED_FRAME_ADDR)) 2619da7bd07SGreg Clayton GetFrameCodeAddress(); 26230fdc8d8SChris Lattner 26330fdc8d8SChris Lattner // If this is not frame zero, then we need to subtract 1 from the PC 26430fdc8d8SChris Lattner // value when doing address lookups since the PC will be on the 26530fdc8d8SChris Lattner // instruction following the function call instruction... 26630fdc8d8SChris Lattner 2679da7bd07SGreg Clayton Address lookup_addr(GetFrameCodeAddress()); 2681b72fcb7SGreg Clayton if (m_frame_index > 0 && lookup_addr.IsValid()) 26930fdc8d8SChris Lattner { 27030fdc8d8SChris Lattner addr_t offset = lookup_addr.GetOffset(); 27130fdc8d8SChris Lattner if (offset > 0) 27230fdc8d8SChris Lattner lookup_addr.SetOffset(offset - 1); 27330fdc8d8SChris Lattner } 27430fdc8d8SChris Lattner 2759da7bd07SGreg Clayton 2769da7bd07SGreg Clayton uint32_t resolved = 0; 27730fdc8d8SChris Lattner if (m_sc.module_sp) 27830fdc8d8SChris Lattner { 27930fdc8d8SChris Lattner // We have something in our stack frame symbol context, lets check 28030fdc8d8SChris Lattner // if we haven't already tried to lookup one of those things. If we 28130fdc8d8SChris Lattner // haven't then we will do the query. 2821b72fcb7SGreg Clayton 2831b72fcb7SGreg Clayton uint32_t actual_resolve_scope = 0; 2841b72fcb7SGreg Clayton 2851b72fcb7SGreg Clayton if (resolve_scope & eSymbolContextCompUnit) 2861b72fcb7SGreg Clayton { 2871b72fcb7SGreg Clayton if (m_flags.IsClear (eSymbolContextCompUnit)) 2881b72fcb7SGreg Clayton { 2891b72fcb7SGreg Clayton if (m_sc.comp_unit) 2909da7bd07SGreg Clayton resolved |= eSymbolContextCompUnit; 2911b72fcb7SGreg Clayton else 2921b72fcb7SGreg Clayton actual_resolve_scope |= eSymbolContextCompUnit; 2931b72fcb7SGreg Clayton } 2941b72fcb7SGreg Clayton } 2951b72fcb7SGreg Clayton 2961b72fcb7SGreg Clayton if (resolve_scope & eSymbolContextFunction) 2971b72fcb7SGreg Clayton { 2981b72fcb7SGreg Clayton if (m_flags.IsClear (eSymbolContextFunction)) 2991b72fcb7SGreg Clayton { 3001b72fcb7SGreg Clayton if (m_sc.function) 3019da7bd07SGreg Clayton resolved |= eSymbolContextFunction; 3021b72fcb7SGreg Clayton else 3031b72fcb7SGreg Clayton actual_resolve_scope |= eSymbolContextFunction; 3041b72fcb7SGreg Clayton } 3051b72fcb7SGreg Clayton } 3061b72fcb7SGreg Clayton 3071b72fcb7SGreg Clayton if (resolve_scope & eSymbolContextBlock) 3081b72fcb7SGreg Clayton { 3091b72fcb7SGreg Clayton if (m_flags.IsClear (eSymbolContextBlock)) 3101b72fcb7SGreg Clayton { 3111b72fcb7SGreg Clayton if (m_sc.block) 3129da7bd07SGreg Clayton resolved |= eSymbolContextBlock; 3131b72fcb7SGreg Clayton else 3141b72fcb7SGreg Clayton actual_resolve_scope |= eSymbolContextBlock; 3151b72fcb7SGreg Clayton } 3161b72fcb7SGreg Clayton } 3171b72fcb7SGreg Clayton 3181b72fcb7SGreg Clayton if (resolve_scope & eSymbolContextSymbol) 3191b72fcb7SGreg Clayton { 3201b72fcb7SGreg Clayton if (m_flags.IsClear (eSymbolContextSymbol)) 3211b72fcb7SGreg Clayton { 3221b72fcb7SGreg Clayton if (m_sc.symbol) 3239da7bd07SGreg Clayton resolved |= eSymbolContextSymbol; 3241b72fcb7SGreg Clayton else 3251b72fcb7SGreg Clayton actual_resolve_scope |= eSymbolContextSymbol; 3261b72fcb7SGreg Clayton } 3271b72fcb7SGreg Clayton } 3281b72fcb7SGreg Clayton 3291b72fcb7SGreg Clayton if (resolve_scope & eSymbolContextLineEntry) 3301b72fcb7SGreg Clayton { 3311b72fcb7SGreg Clayton if (m_flags.IsClear (eSymbolContextLineEntry)) 3321b72fcb7SGreg Clayton { 3331b72fcb7SGreg Clayton if (m_sc.line_entry.IsValid()) 3349da7bd07SGreg Clayton resolved |= eSymbolContextLineEntry; 3351b72fcb7SGreg Clayton else 3361b72fcb7SGreg Clayton actual_resolve_scope |= eSymbolContextLineEntry; 3371b72fcb7SGreg Clayton } 3381b72fcb7SGreg Clayton } 3391b72fcb7SGreg Clayton 3401b72fcb7SGreg Clayton if (actual_resolve_scope) 34130fdc8d8SChris Lattner { 34230fdc8d8SChris Lattner // We might be resolving less information than what is already 34330fdc8d8SChris Lattner // in our current symbol context so resolve into a temporary 34430fdc8d8SChris Lattner // symbol context "sc" so we don't clear out data we have 34530fdc8d8SChris Lattner // already found in "m_sc" 34630fdc8d8SChris Lattner SymbolContext sc; 34730fdc8d8SChris Lattner // Set flags that indicate what we have tried to resolve 3489da7bd07SGreg Clayton resolved |= m_sc.module_sp->ResolveSymbolContextForAddress (lookup_addr, actual_resolve_scope, sc); 3491b72fcb7SGreg Clayton // Only replace what we didn't already have as we may have 3501b72fcb7SGreg Clayton // information for an inlined function scope that won't match 3511b72fcb7SGreg Clayton // what a standard lookup by address would match 3529da7bd07SGreg Clayton if ((resolved & eSymbolContextCompUnit) && m_sc.comp_unit == NULL) 3539da7bd07SGreg Clayton m_sc.comp_unit = sc.comp_unit; 3549da7bd07SGreg Clayton if ((resolved & eSymbolContextFunction) && m_sc.function == NULL) 3559da7bd07SGreg Clayton m_sc.function = sc.function; 3569da7bd07SGreg Clayton if ((resolved & eSymbolContextBlock) && m_sc.block == NULL) 3579da7bd07SGreg Clayton m_sc.block = sc.block; 3589da7bd07SGreg Clayton if ((resolved & eSymbolContextSymbol) && m_sc.symbol == NULL) 3599da7bd07SGreg Clayton m_sc.symbol = sc.symbol; 3609da7bd07SGreg Clayton if ((resolved & eSymbolContextLineEntry) && !m_sc.line_entry.IsValid()) 3619da7bd07SGreg Clayton m_sc.line_entry = sc.line_entry; 3629da7bd07SGreg Clayton 36330fdc8d8SChris Lattner } 36430fdc8d8SChris Lattner } 36530fdc8d8SChris Lattner else 36630fdc8d8SChris Lattner { 36730fdc8d8SChris Lattner // If we don't have a module, then we can't have the compile unit, 36830fdc8d8SChris Lattner // function, block, line entry or symbol, so we can safely call 36930fdc8d8SChris Lattner // ResolveSymbolContextForAddress with our symbol context member m_sc. 3709da7bd07SGreg Clayton resolved |= m_thread.GetProcess().GetTarget().GetImages().ResolveSymbolContextForAddress (lookup_addr, resolve_scope, m_sc); 37130fdc8d8SChris Lattner } 37230fdc8d8SChris Lattner 37330fdc8d8SChris Lattner // If the target was requested add that: 37430fdc8d8SChris Lattner if (m_sc.target_sp.get() == NULL) 3759da7bd07SGreg Clayton { 37630fdc8d8SChris Lattner m_sc.target_sp = CalculateProcess()->GetTarget().GetSP(); 3779da7bd07SGreg Clayton if (m_sc.target_sp) 3789da7bd07SGreg Clayton resolved |= eSymbolContextTarget; 3799da7bd07SGreg Clayton } 38030fdc8d8SChris Lattner 38130fdc8d8SChris Lattner // Update our internal flags so we remember what we have tried to locate so 38230fdc8d8SChris Lattner // we don't have to keep trying when more calls to this function are made. 3839da7bd07SGreg Clayton // We might have dug up more information that was requested (for example 3849da7bd07SGreg Clayton // if we were asked to only get the block, we will have gotten the 3859da7bd07SGreg Clayton // compile unit, and function) so set any additional bits that we resolved 3869da7bd07SGreg Clayton m_flags.Set (resolve_scope | resolved); 38730fdc8d8SChris Lattner } 38830fdc8d8SChris Lattner 38930fdc8d8SChris Lattner // Return the symbol context with everything that was possible to resolve 39030fdc8d8SChris Lattner // resolved. 39130fdc8d8SChris Lattner return m_sc; 39230fdc8d8SChris Lattner } 39330fdc8d8SChris Lattner 39430fdc8d8SChris Lattner 39530fdc8d8SChris Lattner VariableList * 39630fdc8d8SChris Lattner StackFrame::GetVariableList () 39730fdc8d8SChris Lattner { 39830fdc8d8SChris Lattner if (m_flags.IsClear(RESOLVED_VARIABLES)) 39930fdc8d8SChris Lattner { 40030fdc8d8SChris Lattner m_flags.Set(RESOLVED_VARIABLES); 40130fdc8d8SChris Lattner 4029da7bd07SGreg Clayton if (GetSymbolContext (eSymbolContextFunction).function) 40330fdc8d8SChris Lattner { 40430fdc8d8SChris Lattner bool get_child_variables = true; 40530fdc8d8SChris Lattner bool can_create = true; 4060b76a2c2SGreg Clayton m_variable_list_sp = m_sc.function->GetBlock (can_create).GetVariableList (get_child_variables, can_create); 40730fdc8d8SChris Lattner } 40830fdc8d8SChris Lattner } 40930fdc8d8SChris Lattner return m_variable_list_sp.get(); 41030fdc8d8SChris Lattner } 41130fdc8d8SChris Lattner 41230fdc8d8SChris Lattner 41330fdc8d8SChris Lattner bool 41430fdc8d8SChris Lattner StackFrame::GetFrameBaseValue (Scalar &frame_base, Error *error_ptr) 41530fdc8d8SChris Lattner { 41630fdc8d8SChris Lattner if (m_flags.IsClear(GOT_FRAME_BASE)) 41730fdc8d8SChris Lattner { 41830fdc8d8SChris Lattner if (m_sc.function) 41930fdc8d8SChris Lattner { 42030fdc8d8SChris Lattner m_frame_base.Clear(); 42130fdc8d8SChris Lattner m_frame_base_error.Clear(); 42230fdc8d8SChris Lattner 42330fdc8d8SChris Lattner m_flags.Set(GOT_FRAME_BASE); 42430fdc8d8SChris Lattner ExecutionContext exe_ctx (&m_thread.GetProcess(), &m_thread, this); 42530fdc8d8SChris Lattner Value expr_value; 42630fdc8d8SChris Lattner if (m_sc.function->GetFrameBaseExpression().Evaluate(&exe_ctx, NULL, NULL, expr_value, &m_frame_base_error) < 0) 42730fdc8d8SChris Lattner { 42830fdc8d8SChris Lattner // We should really have an error if evaluate returns, but in case 42930fdc8d8SChris Lattner // we don't, lets set the error to something at least. 43030fdc8d8SChris Lattner if (m_frame_base_error.Success()) 43130fdc8d8SChris Lattner m_frame_base_error.SetErrorString("Evaluation of the frame base expression failed."); 43230fdc8d8SChris Lattner } 43330fdc8d8SChris Lattner else 43430fdc8d8SChris Lattner { 43530fdc8d8SChris Lattner m_frame_base = expr_value.ResolveValue(&exe_ctx, NULL); 43630fdc8d8SChris Lattner } 43730fdc8d8SChris Lattner } 43830fdc8d8SChris Lattner else 43930fdc8d8SChris Lattner { 44030fdc8d8SChris Lattner m_frame_base_error.SetErrorString ("No function in symbol context."); 44130fdc8d8SChris Lattner } 44230fdc8d8SChris Lattner } 44330fdc8d8SChris Lattner 44430fdc8d8SChris Lattner if (m_frame_base_error.Success()) 44530fdc8d8SChris Lattner frame_base = m_frame_base; 44630fdc8d8SChris Lattner 44730fdc8d8SChris Lattner if (error_ptr) 44830fdc8d8SChris Lattner *error_ptr = m_frame_base_error; 44930fdc8d8SChris Lattner return m_frame_base_error.Success(); 45030fdc8d8SChris Lattner } 45130fdc8d8SChris Lattner 45230fdc8d8SChris Lattner RegisterContext * 45330fdc8d8SChris Lattner StackFrame::GetRegisterContext () 45430fdc8d8SChris Lattner { 45530fdc8d8SChris Lattner if (m_reg_context_sp.get() == NULL) 45630fdc8d8SChris Lattner m_reg_context_sp.reset (m_thread.CreateRegisterContextForFrame (this)); 45730fdc8d8SChris Lattner return m_reg_context_sp.get(); 45830fdc8d8SChris Lattner } 45930fdc8d8SChris Lattner 46030fdc8d8SChris Lattner bool 46130fdc8d8SChris Lattner StackFrame::HasDebugInformation () 46230fdc8d8SChris Lattner { 46330fdc8d8SChris Lattner GetSymbolContext (eSymbolContextLineEntry); 46430fdc8d8SChris Lattner return m_sc.line_entry.IsValid(); 46530fdc8d8SChris Lattner } 46630fdc8d8SChris Lattner 46730fdc8d8SChris Lattner ValueObjectList & 46830fdc8d8SChris Lattner StackFrame::GetValueObjectList() 46930fdc8d8SChris Lattner { 47030fdc8d8SChris Lattner return m_value_object_list; 47130fdc8d8SChris Lattner } 47230fdc8d8SChris Lattner 473*6b8379c4SJim Ingham bool 474*6b8379c4SJim Ingham StackFrame::IsInlined () 475*6b8379c4SJim Ingham { 476*6b8379c4SJim Ingham Block *block = GetSymbolContext (eSymbolContextBlock).block; 477*6b8379c4SJim Ingham if (block) 478*6b8379c4SJim Ingham return block->GetContainingInlinedBlock() != NULL; 479*6b8379c4SJim Ingham else 480*6b8379c4SJim Ingham return false; 481*6b8379c4SJim Ingham } 482*6b8379c4SJim Ingham 48330fdc8d8SChris Lattner Target * 48430fdc8d8SChris Lattner StackFrame::CalculateTarget () 48530fdc8d8SChris Lattner { 48630fdc8d8SChris Lattner return m_thread.CalculateTarget(); 48730fdc8d8SChris Lattner } 48830fdc8d8SChris Lattner 48930fdc8d8SChris Lattner Process * 49030fdc8d8SChris Lattner StackFrame::CalculateProcess () 49130fdc8d8SChris Lattner { 49230fdc8d8SChris Lattner return m_thread.CalculateProcess(); 49330fdc8d8SChris Lattner } 49430fdc8d8SChris Lattner 49530fdc8d8SChris Lattner Thread * 49630fdc8d8SChris Lattner StackFrame::CalculateThread () 49730fdc8d8SChris Lattner { 49830fdc8d8SChris Lattner return &m_thread; 49930fdc8d8SChris Lattner } 50030fdc8d8SChris Lattner 50130fdc8d8SChris Lattner StackFrame * 50230fdc8d8SChris Lattner StackFrame::CalculateStackFrame () 50330fdc8d8SChris Lattner { 50430fdc8d8SChris Lattner return this; 50530fdc8d8SChris Lattner } 50630fdc8d8SChris Lattner 50730fdc8d8SChris Lattner 50830fdc8d8SChris Lattner void 50930fdc8d8SChris Lattner StackFrame::Calculate (ExecutionContext &exe_ctx) 51030fdc8d8SChris Lattner { 51130fdc8d8SChris Lattner m_thread.Calculate (exe_ctx); 51230fdc8d8SChris Lattner exe_ctx.frame = this; 51330fdc8d8SChris Lattner } 51430fdc8d8SChris Lattner 51530fdc8d8SChris Lattner void 51630fdc8d8SChris Lattner StackFrame::Dump (Stream *strm, bool show_frame_index) 51730fdc8d8SChris Lattner { 51830fdc8d8SChris Lattner if (strm == NULL) 51930fdc8d8SChris Lattner return; 52030fdc8d8SChris Lattner 52130fdc8d8SChris Lattner if (show_frame_index) 5221b72fcb7SGreg Clayton strm->Printf("frame #%u: ", m_frame_index); 5239da7bd07SGreg Clayton strm->Printf("0x%0*llx", m_thread.GetProcess().GetAddressByteSize() * 2, GetFrameCodeAddress().GetLoadAddress(&m_thread.GetProcess())); 5249da7bd07SGreg Clayton GetSymbolContext(eSymbolContextEverything); 52530fdc8d8SChris Lattner strm->PutCString(", where = "); 5261b72fcb7SGreg Clayton // TODO: need to get the 5271b72fcb7SGreg Clayton const bool show_module = true; 5281b72fcb7SGreg Clayton const bool show_inline = true; 5299da7bd07SGreg Clayton m_sc.DumpStopContext(strm, &m_thread.GetProcess(), GetFrameCodeAddress(), show_module, show_inline); 53030fdc8d8SChris Lattner } 53130fdc8d8SChris Lattner 532