130fdc8d8SChris Lattner //===-- Module.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/Core/Module.h" 11c9660546SGreg Clayton #include "lldb/Core/DataBuffer.h" 12c9660546SGreg Clayton #include "lldb/Core/DataBufferHeap.h" 1330fdc8d8SChris Lattner #include "lldb/Core/Log.h" 1430fdc8d8SChris Lattner #include "lldb/Core/ModuleList.h" 1530fdc8d8SChris Lattner #include "lldb/Core/RegularExpression.h" 16c982b3d6SGreg Clayton #include "lldb/Core/StreamString.h" 1730fdc8d8SChris Lattner #include "lldb/Core/Timer.h" 18e38a5eddSGreg Clayton #include "lldb/Host/Host.h" 1930fdc8d8SChris Lattner #include "lldb/lldb-private-log.h" 2030fdc8d8SChris Lattner #include "lldb/Symbol/ObjectFile.h" 2130fdc8d8SChris Lattner #include "lldb/Symbol/SymbolContext.h" 2230fdc8d8SChris Lattner #include "lldb/Symbol/SymbolVendor.h" 23c9660546SGreg Clayton #include "lldb/Target/Process.h" 24c9660546SGreg Clayton #include "lldb/Target/Target.h" 2530fdc8d8SChris Lattner 2630fdc8d8SChris Lattner using namespace lldb; 2730fdc8d8SChris Lattner using namespace lldb_private; 2830fdc8d8SChris Lattner 2965a03991SGreg Clayton // Shared pointers to modules track module lifetimes in 3065a03991SGreg Clayton // targets and in the global module, but this collection 3165a03991SGreg Clayton // will track all module objects that are still alive 3265a03991SGreg Clayton typedef std::vector<Module *> ModuleCollection; 3365a03991SGreg Clayton 3465a03991SGreg Clayton static ModuleCollection & 3565a03991SGreg Clayton GetModuleCollection() 3665a03991SGreg Clayton { 37549f7374SJim Ingham // This module collection needs to live past any module, so we could either make it a 38549f7374SJim Ingham // shared pointer in each module or just leak is. Since it is only an empty vector by 39549f7374SJim Ingham // the time all the modules have gone away, we just leak it for now. If we decide this 40549f7374SJim Ingham // is a big problem we can introduce a Finalize method that will tear everything down in 41549f7374SJim Ingham // a predictable order. 42549f7374SJim Ingham 43549f7374SJim Ingham static ModuleCollection *g_module_collection = NULL; 44549f7374SJim Ingham if (g_module_collection == NULL) 45549f7374SJim Ingham g_module_collection = new ModuleCollection(); 46549f7374SJim Ingham 47549f7374SJim Ingham return *g_module_collection; 4865a03991SGreg Clayton } 4965a03991SGreg Clayton 50b26e6bebSGreg Clayton Mutex * 5165a03991SGreg Clayton Module::GetAllocationModuleCollectionMutex() 5265a03991SGreg Clayton { 53b26e6bebSGreg Clayton // NOTE: The mutex below must be leaked since the global module list in 54b26e6bebSGreg Clayton // the ModuleList class will get torn at some point, and we can't know 55b26e6bebSGreg Clayton // if it will tear itself down before the "g_module_collection_mutex" below 56b26e6bebSGreg Clayton // will. So we leak a Mutex object below to safeguard against that 57b26e6bebSGreg Clayton 58b26e6bebSGreg Clayton static Mutex *g_module_collection_mutex = NULL; 59b26e6bebSGreg Clayton if (g_module_collection_mutex == NULL) 60b26e6bebSGreg Clayton g_module_collection_mutex = new Mutex (Mutex::eMutexTypeRecursive); // NOTE: known leak 6165a03991SGreg Clayton return g_module_collection_mutex; 6265a03991SGreg Clayton } 6365a03991SGreg Clayton 6465a03991SGreg Clayton size_t 6565a03991SGreg Clayton Module::GetNumberAllocatedModules () 6665a03991SGreg Clayton { 6765a03991SGreg Clayton Mutex::Locker locker (GetAllocationModuleCollectionMutex()); 6865a03991SGreg Clayton return GetModuleCollection().size(); 6965a03991SGreg Clayton } 7065a03991SGreg Clayton 7165a03991SGreg Clayton Module * 7265a03991SGreg Clayton Module::GetAllocatedModuleAtIndex (size_t idx) 7365a03991SGreg Clayton { 7465a03991SGreg Clayton Mutex::Locker locker (GetAllocationModuleCollectionMutex()); 7565a03991SGreg Clayton ModuleCollection &modules = GetModuleCollection(); 7665a03991SGreg Clayton if (idx < modules.size()) 7765a03991SGreg Clayton return modules[idx]; 7865a03991SGreg Clayton return NULL; 7965a03991SGreg Clayton } 8029ad7b91SGreg Clayton #if 0 8165a03991SGreg Clayton 8229ad7b91SGreg Clayton // These functions help us to determine if modules are still loaded, yet don't require that 8329ad7b91SGreg Clayton // you have a command interpreter and can easily be called from an external debugger. 8429ad7b91SGreg Clayton namespace lldb { 8565a03991SGreg Clayton 8629ad7b91SGreg Clayton void 8729ad7b91SGreg Clayton ClearModuleInfo (void) 8829ad7b91SGreg Clayton { 8929ad7b91SGreg Clayton ModuleList::RemoveOrphanSharedModules(); 9029ad7b91SGreg Clayton } 9129ad7b91SGreg Clayton 9229ad7b91SGreg Clayton void 9329ad7b91SGreg Clayton DumpModuleInfo (void) 9429ad7b91SGreg Clayton { 9529ad7b91SGreg Clayton Mutex::Locker locker (Module::GetAllocationModuleCollectionMutex()); 9629ad7b91SGreg Clayton ModuleCollection &modules = GetModuleCollection(); 9729ad7b91SGreg Clayton const size_t count = modules.size(); 9829ad7b91SGreg Clayton printf ("%s: %zu modules:\n", __PRETTY_FUNCTION__, count); 9929ad7b91SGreg Clayton for (size_t i=0; i<count; ++i) 10029ad7b91SGreg Clayton { 10129ad7b91SGreg Clayton 10229ad7b91SGreg Clayton StreamString strm; 10329ad7b91SGreg Clayton Module *module = modules[i]; 10429ad7b91SGreg Clayton const bool in_shared_module_list = ModuleList::ModuleIsInCache (module); 10529ad7b91SGreg Clayton module->GetDescription(&strm, eDescriptionLevelFull); 10629ad7b91SGreg Clayton printf ("%p: shared = %i, ref_count = %3u, module = %s\n", 10729ad7b91SGreg Clayton module, 10829ad7b91SGreg Clayton in_shared_module_list, 10929ad7b91SGreg Clayton (uint32_t)module->use_count(), 11029ad7b91SGreg Clayton strm.GetString().c_str()); 11129ad7b91SGreg Clayton } 11229ad7b91SGreg Clayton } 11329ad7b91SGreg Clayton } 11429ad7b91SGreg Clayton 11529ad7b91SGreg Clayton #endif 11665a03991SGreg Clayton 11765a03991SGreg Clayton 118c9660546SGreg Clayton Module::Module(const FileSpec& file_spec, const lldb::ProcessSP &process_sp, lldb::addr_t header_addr) : 119c9660546SGreg Clayton m_mutex (Mutex::eMutexTypeRecursive), 120c9660546SGreg Clayton m_mod_time (), 121c9660546SGreg Clayton m_arch (), 122c9660546SGreg Clayton m_uuid (), 123c9660546SGreg Clayton m_file (file_spec), 124c9660546SGreg Clayton m_platform_file(), 125*e72dfb32SGreg Clayton m_symfile_spec (), 126c9660546SGreg Clayton m_object_name (), 127c9660546SGreg Clayton m_object_offset (), 128c9660546SGreg Clayton m_objfile_sp (), 129c9660546SGreg Clayton m_symfile_ap (), 130c9660546SGreg Clayton m_ast (), 131c9660546SGreg Clayton m_did_load_objfile (false), 132c9660546SGreg Clayton m_did_load_symbol_vendor (false), 133c9660546SGreg Clayton m_did_parse_uuid (false), 134c9660546SGreg Clayton m_did_init_ast (false), 135c9660546SGreg Clayton m_is_dynamic_loader_module (false), 136c9660546SGreg Clayton m_was_modified (false) 137c9660546SGreg Clayton { 138c9660546SGreg Clayton // Scope for locker below... 139c9660546SGreg Clayton { 140c9660546SGreg Clayton Mutex::Locker locker (GetAllocationModuleCollectionMutex()); 141c9660546SGreg Clayton GetModuleCollection().push_back(this); 142c9660546SGreg Clayton } 143c9660546SGreg Clayton StreamString s; 144c9660546SGreg Clayton if (m_file.GetFilename()) 145c9660546SGreg Clayton s << m_file.GetFilename(); 146c9660546SGreg Clayton s.Printf("[0x%16.16llx]", header_addr); 147c9660546SGreg Clayton m_file.GetFilename().SetCString (s.GetData()); 148c9660546SGreg Clayton Mutex::Locker locker (m_mutex); 149c9660546SGreg Clayton DataBufferSP data_sp; 150c9660546SGreg Clayton if (process_sp) 151c9660546SGreg Clayton { 152c9660546SGreg Clayton m_did_load_objfile = true; 153c9660546SGreg Clayton std::auto_ptr<DataBufferHeap> data_ap (new DataBufferHeap (512, 0)); 154c9660546SGreg Clayton Error error; 155c9660546SGreg Clayton const size_t bytes_read = process_sp->ReadMemory (header_addr, 156c9660546SGreg Clayton data_ap->GetBytes(), 157c9660546SGreg Clayton data_ap->GetByteSize(), 158c9660546SGreg Clayton error); 159c9660546SGreg Clayton if (bytes_read == 512) 160c9660546SGreg Clayton { 161c9660546SGreg Clayton data_sp.reset (data_ap.release()); 162*e72dfb32SGreg Clayton m_objfile_sp = ObjectFile::FindPlugin(shared_from_this(), process_sp, header_addr, data_sp); 163c9660546SGreg Clayton if (m_objfile_sp) 164c9660546SGreg Clayton { 165c9660546SGreg Clayton // Once we get the object file, update our module with the object file's 166c9660546SGreg Clayton // architecture since it might differ in vendor/os if some parts were 167c9660546SGreg Clayton // unknown. 168c9660546SGreg Clayton m_objfile_sp->GetArchitecture (m_arch); 169c9660546SGreg Clayton } 170c9660546SGreg Clayton } 171c9660546SGreg Clayton } 172c9660546SGreg Clayton } 173c9660546SGreg Clayton 174*e72dfb32SGreg Clayton Module::Module(const FileSpec& file_spec, 175*e72dfb32SGreg Clayton const ArchSpec& arch, 176*e72dfb32SGreg Clayton const ConstString *object_name, 177*e72dfb32SGreg Clayton off_t object_offset) : 17830fdc8d8SChris Lattner m_mutex (Mutex::eMutexTypeRecursive), 17930fdc8d8SChris Lattner m_mod_time (file_spec.GetModificationTime()), 18030fdc8d8SChris Lattner m_arch (arch), 18130fdc8d8SChris Lattner m_uuid (), 18230fdc8d8SChris Lattner m_file (file_spec), 18332e0a750SGreg Clayton m_platform_file(), 184*e72dfb32SGreg Clayton m_symfile_spec (), 18530fdc8d8SChris Lattner m_object_name (), 1868b82f087SGreg Clayton m_object_offset (object_offset), 187762f7135SGreg Clayton m_objfile_sp (), 188e83e731eSGreg Clayton m_symfile_ap (), 1896beaaa68SGreg Clayton m_ast (), 190e83e731eSGreg Clayton m_did_load_objfile (false), 191e83e731eSGreg Clayton m_did_load_symbol_vendor (false), 192e83e731eSGreg Clayton m_did_parse_uuid (false), 1936beaaa68SGreg Clayton m_did_init_ast (false), 194e38a5eddSGreg Clayton m_is_dynamic_loader_module (false), 195e38a5eddSGreg Clayton m_was_modified (false) 19630fdc8d8SChris Lattner { 19765a03991SGreg Clayton // Scope for locker below... 19865a03991SGreg Clayton { 19965a03991SGreg Clayton Mutex::Locker locker (GetAllocationModuleCollectionMutex()); 20065a03991SGreg Clayton GetModuleCollection().push_back(this); 20165a03991SGreg Clayton } 20265a03991SGreg Clayton 20330fdc8d8SChris Lattner if (object_name) 20430fdc8d8SChris Lattner m_object_name = *object_name; 2052d4edfbcSGreg Clayton LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_OBJECT)); 20630fdc8d8SChris Lattner if (log) 20730fdc8d8SChris Lattner log->Printf ("%p Module::Module((%s) '%s/%s%s%s%s')", 20830fdc8d8SChris Lattner this, 20964195a2cSGreg Clayton m_arch.GetArchitectureName(), 21030fdc8d8SChris Lattner m_file.GetDirectory().AsCString(""), 21130fdc8d8SChris Lattner m_file.GetFilename().AsCString(""), 21230fdc8d8SChris Lattner m_object_name.IsEmpty() ? "" : "(", 21330fdc8d8SChris Lattner m_object_name.IsEmpty() ? "" : m_object_name.AsCString(""), 21430fdc8d8SChris Lattner m_object_name.IsEmpty() ? "" : ")"); 21530fdc8d8SChris Lattner } 21630fdc8d8SChris Lattner 21730fdc8d8SChris Lattner Module::~Module() 21830fdc8d8SChris Lattner { 21965a03991SGreg Clayton // Scope for locker below... 22065a03991SGreg Clayton { 22165a03991SGreg Clayton Mutex::Locker locker (GetAllocationModuleCollectionMutex()); 22265a03991SGreg Clayton ModuleCollection &modules = GetModuleCollection(); 22365a03991SGreg Clayton ModuleCollection::iterator end = modules.end(); 22465a03991SGreg Clayton ModuleCollection::iterator pos = std::find(modules.begin(), end, this); 22565a03991SGreg Clayton if (pos != end) 22665a03991SGreg Clayton modules.erase(pos); 22765a03991SGreg Clayton } 2282d4edfbcSGreg Clayton LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_OBJECT)); 22930fdc8d8SChris Lattner if (log) 23030fdc8d8SChris Lattner log->Printf ("%p Module::~Module((%s) '%s/%s%s%s%s')", 23130fdc8d8SChris Lattner this, 23264195a2cSGreg Clayton m_arch.GetArchitectureName(), 23330fdc8d8SChris Lattner m_file.GetDirectory().AsCString(""), 23430fdc8d8SChris Lattner m_file.GetFilename().AsCString(""), 23530fdc8d8SChris Lattner m_object_name.IsEmpty() ? "" : "(", 23630fdc8d8SChris Lattner m_object_name.IsEmpty() ? "" : m_object_name.AsCString(""), 23730fdc8d8SChris Lattner m_object_name.IsEmpty() ? "" : ")"); 2386beaaa68SGreg Clayton // Release any auto pointers before we start tearing down our member 2396beaaa68SGreg Clayton // variables since the object file and symbol files might need to make 2406beaaa68SGreg Clayton // function calls back into this module object. The ordering is important 2416beaaa68SGreg Clayton // here because symbol files can require the module object file. So we tear 2426beaaa68SGreg Clayton // down the symbol file first, then the object file. 2436beaaa68SGreg Clayton m_symfile_ap.reset(); 244762f7135SGreg Clayton m_objfile_sp.reset(); 24530fdc8d8SChris Lattner } 24630fdc8d8SChris Lattner 24730fdc8d8SChris Lattner 24860830268SGreg Clayton const lldb_private::UUID& 24930fdc8d8SChris Lattner Module::GetUUID() 25030fdc8d8SChris Lattner { 25130fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 252e83e731eSGreg Clayton if (m_did_parse_uuid == false) 25330fdc8d8SChris Lattner { 25430fdc8d8SChris Lattner ObjectFile * obj_file = GetObjectFile (); 25530fdc8d8SChris Lattner 25630fdc8d8SChris Lattner if (obj_file != NULL) 25730fdc8d8SChris Lattner { 25830fdc8d8SChris Lattner obj_file->GetUUID(&m_uuid); 259e83e731eSGreg Clayton m_did_parse_uuid = true; 26030fdc8d8SChris Lattner } 26130fdc8d8SChris Lattner } 26230fdc8d8SChris Lattner return m_uuid; 26330fdc8d8SChris Lattner } 26430fdc8d8SChris Lattner 2656beaaa68SGreg Clayton ClangASTContext & 2666beaaa68SGreg Clayton Module::GetClangASTContext () 2676beaaa68SGreg Clayton { 2686beaaa68SGreg Clayton Mutex::Locker locker (m_mutex); 2696beaaa68SGreg Clayton if (m_did_init_ast == false) 2706beaaa68SGreg Clayton { 2716beaaa68SGreg Clayton ObjectFile * objfile = GetObjectFile(); 272514487e8SGreg Clayton ArchSpec object_arch; 273514487e8SGreg Clayton if (objfile && objfile->GetArchitecture(object_arch)) 2746beaaa68SGreg Clayton { 2756beaaa68SGreg Clayton m_did_init_ast = true; 276514487e8SGreg Clayton m_ast.SetArchitecture (object_arch); 2776beaaa68SGreg Clayton } 2786beaaa68SGreg Clayton } 2796beaaa68SGreg Clayton return m_ast; 2806beaaa68SGreg Clayton } 2816beaaa68SGreg Clayton 28230fdc8d8SChris Lattner void 28330fdc8d8SChris Lattner Module::ParseAllDebugSymbols() 28430fdc8d8SChris Lattner { 28530fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 28630fdc8d8SChris Lattner uint32_t num_comp_units = GetNumCompileUnits(); 28730fdc8d8SChris Lattner if (num_comp_units == 0) 28830fdc8d8SChris Lattner return; 28930fdc8d8SChris Lattner 290a2eee184SGreg Clayton SymbolContext sc; 291e1cd1be6SGreg Clayton sc.module_sp = shared_from_this(); 29230fdc8d8SChris Lattner uint32_t cu_idx; 29330fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 29430fdc8d8SChris Lattner 29530fdc8d8SChris Lattner for (cu_idx = 0; cu_idx < num_comp_units; cu_idx++) 29630fdc8d8SChris Lattner { 29730fdc8d8SChris Lattner sc.comp_unit = symbols->GetCompileUnitAtIndex(cu_idx).get(); 29830fdc8d8SChris Lattner if (sc.comp_unit) 29930fdc8d8SChris Lattner { 30030fdc8d8SChris Lattner sc.function = NULL; 30130fdc8d8SChris Lattner symbols->ParseVariablesForContext(sc); 30230fdc8d8SChris Lattner 30330fdc8d8SChris Lattner symbols->ParseCompileUnitFunctions(sc); 30430fdc8d8SChris Lattner 30530fdc8d8SChris Lattner uint32_t func_idx; 30630fdc8d8SChris Lattner for (func_idx = 0; (sc.function = sc.comp_unit->GetFunctionAtIndex(func_idx).get()) != NULL; ++func_idx) 30730fdc8d8SChris Lattner { 30830fdc8d8SChris Lattner symbols->ParseFunctionBlocks(sc); 30930fdc8d8SChris Lattner 31030fdc8d8SChris Lattner // Parse the variables for this function and all its blocks 31130fdc8d8SChris Lattner symbols->ParseVariablesForContext(sc); 31230fdc8d8SChris Lattner } 31330fdc8d8SChris Lattner 31430fdc8d8SChris Lattner 31530fdc8d8SChris Lattner // Parse all types for this compile unit 31630fdc8d8SChris Lattner sc.function = NULL; 31730fdc8d8SChris Lattner symbols->ParseTypes(sc); 31830fdc8d8SChris Lattner } 31930fdc8d8SChris Lattner } 32030fdc8d8SChris Lattner } 32130fdc8d8SChris Lattner 32230fdc8d8SChris Lattner void 32330fdc8d8SChris Lattner Module::CalculateSymbolContext(SymbolContext* sc) 32430fdc8d8SChris Lattner { 325e1cd1be6SGreg Clayton sc->module_sp = shared_from_this(); 32630fdc8d8SChris Lattner } 32730fdc8d8SChris Lattner 328*e72dfb32SGreg Clayton ModuleSP 3297e9b1fd0SGreg Clayton Module::CalculateSymbolContextModule () 3307e9b1fd0SGreg Clayton { 331*e72dfb32SGreg Clayton return shared_from_this(); 3327e9b1fd0SGreg Clayton } 3337e9b1fd0SGreg Clayton 33430fdc8d8SChris Lattner void 33530fdc8d8SChris Lattner Module::DumpSymbolContext(Stream *s) 33630fdc8d8SChris Lattner { 337fd54b368SJason Molenda s->Printf(", Module{%p}", this); 33830fdc8d8SChris Lattner } 33930fdc8d8SChris Lattner 34030fdc8d8SChris Lattner uint32_t 34130fdc8d8SChris Lattner Module::GetNumCompileUnits() 34230fdc8d8SChris Lattner { 34330fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 34430fdc8d8SChris Lattner Timer scoped_timer(__PRETTY_FUNCTION__, "Module::GetNumCompileUnits (module = %p)", this); 34530fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 34630fdc8d8SChris Lattner if (symbols) 34730fdc8d8SChris Lattner return symbols->GetNumCompileUnits(); 34830fdc8d8SChris Lattner return 0; 34930fdc8d8SChris Lattner } 35030fdc8d8SChris Lattner 35130fdc8d8SChris Lattner CompUnitSP 35230fdc8d8SChris Lattner Module::GetCompileUnitAtIndex (uint32_t index) 35330fdc8d8SChris Lattner { 35430fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 35530fdc8d8SChris Lattner uint32_t num_comp_units = GetNumCompileUnits (); 35630fdc8d8SChris Lattner CompUnitSP cu_sp; 35730fdc8d8SChris Lattner 35830fdc8d8SChris Lattner if (index < num_comp_units) 35930fdc8d8SChris Lattner { 36030fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 36130fdc8d8SChris Lattner if (symbols) 36230fdc8d8SChris Lattner cu_sp = symbols->GetCompileUnitAtIndex(index); 36330fdc8d8SChris Lattner } 36430fdc8d8SChris Lattner return cu_sp; 36530fdc8d8SChris Lattner } 36630fdc8d8SChris Lattner 36730fdc8d8SChris Lattner bool 36830fdc8d8SChris Lattner Module::ResolveFileAddress (lldb::addr_t vm_addr, Address& so_addr) 36930fdc8d8SChris Lattner { 37030fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 37130fdc8d8SChris Lattner Timer scoped_timer(__PRETTY_FUNCTION__, "Module::ResolveFileAddress (vm_addr = 0x%llx)", vm_addr); 37230fdc8d8SChris Lattner ObjectFile* ofile = GetObjectFile(); 37330fdc8d8SChris Lattner if (ofile) 37430fdc8d8SChris Lattner return so_addr.ResolveAddressUsingFileSections(vm_addr, ofile->GetSectionList()); 37530fdc8d8SChris Lattner return false; 37630fdc8d8SChris Lattner } 37730fdc8d8SChris Lattner 37830fdc8d8SChris Lattner uint32_t 37930fdc8d8SChris Lattner Module::ResolveSymbolContextForAddress (const Address& so_addr, uint32_t resolve_scope, SymbolContext& sc) 38030fdc8d8SChris Lattner { 38130fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 38230fdc8d8SChris Lattner uint32_t resolved_flags = 0; 38330fdc8d8SChris Lattner 38430fdc8d8SChris Lattner // Clear the result symbol context in case we don't find anything 38530fdc8d8SChris Lattner sc.Clear(); 38630fdc8d8SChris Lattner 38730fdc8d8SChris Lattner // Get the section from the section/offset address. 388*e72dfb32SGreg Clayton SectionSP section_sp (so_addr.GetSection()); 38930fdc8d8SChris Lattner 39030fdc8d8SChris Lattner // Make sure the section matches this module before we try and match anything 391*e72dfb32SGreg Clayton if (section_sp && section_sp->GetModule().get() == this) 39230fdc8d8SChris Lattner { 39330fdc8d8SChris Lattner // If the section offset based address resolved itself, then this 39430fdc8d8SChris Lattner // is the right module. 395e1cd1be6SGreg Clayton sc.module_sp = shared_from_this(); 39630fdc8d8SChris Lattner resolved_flags |= eSymbolContextModule; 39730fdc8d8SChris Lattner 39830fdc8d8SChris Lattner // Resolve the compile unit, function, block, line table or line 39930fdc8d8SChris Lattner // entry if requested. 40030fdc8d8SChris Lattner if (resolve_scope & eSymbolContextCompUnit || 40130fdc8d8SChris Lattner resolve_scope & eSymbolContextFunction || 40230fdc8d8SChris Lattner resolve_scope & eSymbolContextBlock || 40330fdc8d8SChris Lattner resolve_scope & eSymbolContextLineEntry ) 40430fdc8d8SChris Lattner { 40530fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 40630fdc8d8SChris Lattner if (symbols) 40730fdc8d8SChris Lattner resolved_flags |= symbols->ResolveSymbolContext (so_addr, resolve_scope, sc); 40830fdc8d8SChris Lattner } 40930fdc8d8SChris Lattner 410680e1778SJim Ingham // Resolve the symbol if requested, but don't re-look it up if we've already found it. 411680e1778SJim Ingham if (resolve_scope & eSymbolContextSymbol && !(resolved_flags & eSymbolContextSymbol)) 41230fdc8d8SChris Lattner { 41330fdc8d8SChris Lattner ObjectFile* ofile = GetObjectFile(); 41430fdc8d8SChris Lattner if (ofile) 41530fdc8d8SChris Lattner { 41630fdc8d8SChris Lattner Symtab *symtab = ofile->GetSymtab(); 41730fdc8d8SChris Lattner if (symtab) 41830fdc8d8SChris Lattner { 41930fdc8d8SChris Lattner if (so_addr.IsSectionOffset()) 42030fdc8d8SChris Lattner { 42130fdc8d8SChris Lattner sc.symbol = symtab->FindSymbolContainingFileAddress(so_addr.GetFileAddress()); 42230fdc8d8SChris Lattner if (sc.symbol) 42330fdc8d8SChris Lattner resolved_flags |= eSymbolContextSymbol; 42430fdc8d8SChris Lattner } 42530fdc8d8SChris Lattner } 42630fdc8d8SChris Lattner } 42730fdc8d8SChris Lattner } 42830fdc8d8SChris Lattner } 42930fdc8d8SChris Lattner return resolved_flags; 43030fdc8d8SChris Lattner } 43130fdc8d8SChris Lattner 43230fdc8d8SChris Lattner uint32_t 433274060b6SGreg Clayton Module::ResolveSymbolContextForFilePath 434274060b6SGreg Clayton ( 435274060b6SGreg Clayton const char *file_path, 436274060b6SGreg Clayton uint32_t line, 437274060b6SGreg Clayton bool check_inlines, 438274060b6SGreg Clayton uint32_t resolve_scope, 439274060b6SGreg Clayton SymbolContextList& sc_list 440274060b6SGreg Clayton ) 44130fdc8d8SChris Lattner { 442274060b6SGreg Clayton FileSpec file_spec(file_path, false); 44330fdc8d8SChris Lattner return ResolveSymbolContextsForFileSpec (file_spec, line, check_inlines, resolve_scope, sc_list); 44430fdc8d8SChris Lattner } 44530fdc8d8SChris Lattner 44630fdc8d8SChris Lattner uint32_t 44730fdc8d8SChris Lattner Module::ResolveSymbolContextsForFileSpec (const FileSpec &file_spec, uint32_t line, bool check_inlines, uint32_t resolve_scope, SymbolContextList& sc_list) 44830fdc8d8SChris Lattner { 44930fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 45030fdc8d8SChris Lattner Timer scoped_timer(__PRETTY_FUNCTION__, 45130fdc8d8SChris Lattner "Module::ResolveSymbolContextForFilePath (%s%s%s:%u, check_inlines = %s, resolve_scope = 0x%8.8x)", 45230fdc8d8SChris Lattner file_spec.GetDirectory().AsCString(""), 45330fdc8d8SChris Lattner file_spec.GetDirectory() ? "/" : "", 45430fdc8d8SChris Lattner file_spec.GetFilename().AsCString(""), 45530fdc8d8SChris Lattner line, 45630fdc8d8SChris Lattner check_inlines ? "yes" : "no", 45730fdc8d8SChris Lattner resolve_scope); 45830fdc8d8SChris Lattner 45930fdc8d8SChris Lattner const uint32_t initial_count = sc_list.GetSize(); 46030fdc8d8SChris Lattner 46130fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 46230fdc8d8SChris Lattner if (symbols) 46330fdc8d8SChris Lattner symbols->ResolveSymbolContext (file_spec, line, check_inlines, resolve_scope, sc_list); 46430fdc8d8SChris Lattner 46530fdc8d8SChris Lattner return sc_list.GetSize() - initial_count; 46630fdc8d8SChris Lattner } 46730fdc8d8SChris Lattner 46830fdc8d8SChris Lattner 46930fdc8d8SChris Lattner uint32_t 470b6d70ebcSSean Callanan Module::FindGlobalVariables(const ConstString &name, const ClangNamespaceDecl *namespace_decl, bool append, uint32_t max_matches, VariableList& variables) 47130fdc8d8SChris Lattner { 47230fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 47330fdc8d8SChris Lattner if (symbols) 474213fdb8bSSean Callanan return symbols->FindGlobalVariables(name, namespace_decl, append, max_matches, variables); 47530fdc8d8SChris Lattner return 0; 47630fdc8d8SChris Lattner } 47730fdc8d8SChris Lattner uint32_t 47830fdc8d8SChris Lattner Module::FindGlobalVariables(const RegularExpression& regex, bool append, uint32_t max_matches, VariableList& variables) 47930fdc8d8SChris Lattner { 48030fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 48130fdc8d8SChris Lattner if (symbols) 48230fdc8d8SChris Lattner return symbols->FindGlobalVariables(regex, append, max_matches, variables); 48330fdc8d8SChris Lattner return 0; 48430fdc8d8SChris Lattner } 48530fdc8d8SChris Lattner 48630fdc8d8SChris Lattner uint32_t 487644247c1SGreg Clayton Module::FindCompileUnits (const FileSpec &path, 488644247c1SGreg Clayton bool append, 489644247c1SGreg Clayton SymbolContextList &sc_list) 490644247c1SGreg Clayton { 491644247c1SGreg Clayton if (!append) 492644247c1SGreg Clayton sc_list.Clear(); 493644247c1SGreg Clayton 494644247c1SGreg Clayton const uint32_t start_size = sc_list.GetSize(); 495644247c1SGreg Clayton const uint32_t num_compile_units = GetNumCompileUnits(); 496644247c1SGreg Clayton SymbolContext sc; 497e1cd1be6SGreg Clayton sc.module_sp = shared_from_this(); 498644247c1SGreg Clayton const bool compare_directory = path.GetDirectory(); 499644247c1SGreg Clayton for (uint32_t i=0; i<num_compile_units; ++i) 500644247c1SGreg Clayton { 501644247c1SGreg Clayton sc.comp_unit = GetCompileUnitAtIndex(i).get(); 502644247c1SGreg Clayton if (FileSpec::Equal (*sc.comp_unit, path, compare_directory)) 503644247c1SGreg Clayton sc_list.Append(sc); 504644247c1SGreg Clayton } 505644247c1SGreg Clayton return sc_list.GetSize() - start_size; 506644247c1SGreg Clayton } 507644247c1SGreg Clayton 508644247c1SGreg Clayton uint32_t 509931180e6SGreg Clayton Module::FindFunctions (const ConstString &name, 510b6d70ebcSSean Callanan const ClangNamespaceDecl *namespace_decl, 511931180e6SGreg Clayton uint32_t name_type_mask, 512931180e6SGreg Clayton bool include_symbols, 5139df05fbbSSean Callanan bool include_inlines, 514931180e6SGreg Clayton bool append, 515931180e6SGreg Clayton SymbolContextList& sc_list) 51630fdc8d8SChris Lattner { 517931180e6SGreg Clayton if (!append) 518931180e6SGreg Clayton sc_list.Clear(); 519931180e6SGreg Clayton 520931180e6SGreg Clayton const uint32_t start_size = sc_list.GetSize(); 521931180e6SGreg Clayton 522931180e6SGreg Clayton // Find all the functions (not symbols, but debug information functions... 52330fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 52430fdc8d8SChris Lattner if (symbols) 5259df05fbbSSean Callanan symbols->FindFunctions(name, namespace_decl, name_type_mask, include_inlines, append, sc_list); 526931180e6SGreg Clayton 527931180e6SGreg Clayton // Now check our symbol table for symbols that are code symbols if requested 528931180e6SGreg Clayton if (include_symbols) 529931180e6SGreg Clayton { 530931180e6SGreg Clayton ObjectFile *objfile = GetObjectFile(); 531931180e6SGreg Clayton if (objfile) 532931180e6SGreg Clayton { 533931180e6SGreg Clayton Symtab *symtab = objfile->GetSymtab(); 534931180e6SGreg Clayton if (symtab) 535931180e6SGreg Clayton { 536931180e6SGreg Clayton std::vector<uint32_t> symbol_indexes; 537931180e6SGreg Clayton symtab->FindAllSymbolsWithNameAndType (name, eSymbolTypeCode, Symtab::eDebugAny, Symtab::eVisibilityAny, symbol_indexes); 538931180e6SGreg Clayton const uint32_t num_matches = symbol_indexes.size(); 539931180e6SGreg Clayton if (num_matches) 540931180e6SGreg Clayton { 541357132ebSGreg Clayton const bool merge_symbol_into_function = true; 542931180e6SGreg Clayton SymbolContext sc(this); 543931180e6SGreg Clayton for (uint32_t i=0; i<num_matches; i++) 544931180e6SGreg Clayton { 545931180e6SGreg Clayton sc.symbol = symtab->SymbolAtIndex(symbol_indexes[i]); 546357132ebSGreg Clayton sc_list.AppendIfUnique (sc, merge_symbol_into_function); 547931180e6SGreg Clayton } 548931180e6SGreg Clayton } 549931180e6SGreg Clayton } 550931180e6SGreg Clayton } 551931180e6SGreg Clayton } 552931180e6SGreg Clayton return sc_list.GetSize() - start_size; 55330fdc8d8SChris Lattner } 55430fdc8d8SChris Lattner 55530fdc8d8SChris Lattner uint32_t 556931180e6SGreg Clayton Module::FindFunctions (const RegularExpression& regex, 557931180e6SGreg Clayton bool include_symbols, 5589df05fbbSSean Callanan bool include_inlines, 559931180e6SGreg Clayton bool append, 560931180e6SGreg Clayton SymbolContextList& sc_list) 56130fdc8d8SChris Lattner { 562931180e6SGreg Clayton if (!append) 563931180e6SGreg Clayton sc_list.Clear(); 564931180e6SGreg Clayton 565931180e6SGreg Clayton const uint32_t start_size = sc_list.GetSize(); 566931180e6SGreg Clayton 56730fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 56830fdc8d8SChris Lattner if (symbols) 5699df05fbbSSean Callanan symbols->FindFunctions(regex, include_inlines, append, sc_list); 570931180e6SGreg Clayton // Now check our symbol table for symbols that are code symbols if requested 571931180e6SGreg Clayton if (include_symbols) 572931180e6SGreg Clayton { 573931180e6SGreg Clayton ObjectFile *objfile = GetObjectFile(); 574931180e6SGreg Clayton if (objfile) 575931180e6SGreg Clayton { 576931180e6SGreg Clayton Symtab *symtab = objfile->GetSymtab(); 577931180e6SGreg Clayton if (symtab) 578931180e6SGreg Clayton { 579931180e6SGreg Clayton std::vector<uint32_t> symbol_indexes; 580931180e6SGreg Clayton symtab->AppendSymbolIndexesMatchingRegExAndType (regex, eSymbolTypeCode, Symtab::eDebugAny, Symtab::eVisibilityAny, symbol_indexes); 581931180e6SGreg Clayton const uint32_t num_matches = symbol_indexes.size(); 582931180e6SGreg Clayton if (num_matches) 583931180e6SGreg Clayton { 584357132ebSGreg Clayton const bool merge_symbol_into_function = true; 585931180e6SGreg Clayton SymbolContext sc(this); 586931180e6SGreg Clayton for (uint32_t i=0; i<num_matches; i++) 587931180e6SGreg Clayton { 588931180e6SGreg Clayton sc.symbol = symtab->SymbolAtIndex(symbol_indexes[i]); 589357132ebSGreg Clayton sc_list.AppendIfUnique (sc, merge_symbol_into_function); 590931180e6SGreg Clayton } 591931180e6SGreg Clayton } 592931180e6SGreg Clayton } 593931180e6SGreg Clayton } 594931180e6SGreg Clayton } 595931180e6SGreg Clayton return sc_list.GetSize() - start_size; 59630fdc8d8SChris Lattner } 59730fdc8d8SChris Lattner 5983504eee8SGreg Clayton uint32_t 599213fdb8bSSean Callanan Module::FindTypes_Impl (const SymbolContext& sc, const ConstString &name, const ClangNamespaceDecl *namespace_decl, bool append, uint32_t max_matches, TypeList& types) 6003504eee8SGreg Clayton { 6013504eee8SGreg Clayton Timer scoped_timer(__PRETTY_FUNCTION__, __PRETTY_FUNCTION__); 6023504eee8SGreg Clayton if (sc.module_sp.get() == NULL || sc.module_sp.get() == this) 6033504eee8SGreg Clayton { 6043504eee8SGreg Clayton SymbolVendor *symbols = GetSymbolVendor (); 6053504eee8SGreg Clayton if (symbols) 606213fdb8bSSean Callanan return symbols->FindTypes(sc, name, namespace_decl, append, max_matches, types); 6073504eee8SGreg Clayton } 6083504eee8SGreg Clayton return 0; 6093504eee8SGreg Clayton } 6103504eee8SGreg Clayton 6116f3533fbSEnrico Granata // depending on implementation details, type lookup might fail because of 6126f3533fbSEnrico Granata // embedded spurious namespace:: prefixes. this call strips them, paying 6136f3533fbSEnrico Granata // attention to the fact that a type might have namespace'd type names as 6146f3533fbSEnrico Granata // arguments to templates, and those must not be stripped off 6156f3533fbSEnrico Granata static const char* 6166f3533fbSEnrico Granata StripTypeName(const char* name_cstr) 6176f3533fbSEnrico Granata { 618c6770763SJohnny Chen // Protect against null c string. 619c6770763SJohnny Chen if (!name_cstr) 620c6770763SJohnny Chen return name_cstr; 6216f3533fbSEnrico Granata const char* skip_namespace = strstr(name_cstr, "::"); 6226f3533fbSEnrico Granata const char* template_arg_char = strchr(name_cstr, '<'); 6236f3533fbSEnrico Granata while (skip_namespace != NULL) 6246f3533fbSEnrico Granata { 6256f3533fbSEnrico Granata if (template_arg_char != NULL && 6266f3533fbSEnrico Granata skip_namespace > template_arg_char) // but namespace'd template arguments are still good to go 6276f3533fbSEnrico Granata break; 6286f3533fbSEnrico Granata name_cstr = skip_namespace+2; 6296f3533fbSEnrico Granata skip_namespace = strstr(name_cstr, "::"); 6306f3533fbSEnrico Granata } 6316f3533fbSEnrico Granata return name_cstr; 6326f3533fbSEnrico Granata } 6336f3533fbSEnrico Granata 6346f3533fbSEnrico Granata uint32_t 635b6d70ebcSSean Callanan Module::FindTypes (const SymbolContext& sc, const ConstString &name, const ClangNamespaceDecl *namespace_decl, bool append, uint32_t max_matches, TypeList& types) 6366f3533fbSEnrico Granata { 637213fdb8bSSean Callanan uint32_t retval = FindTypes_Impl(sc, name, namespace_decl, append, max_matches, types); 6386f3533fbSEnrico Granata 6396f3533fbSEnrico Granata if (retval == 0) 6406f3533fbSEnrico Granata { 64150b3d507SJim Ingham const char *orig_name = name.GetCString(); 64250b3d507SJim Ingham const char *stripped = StripTypeName(orig_name); 64350b3d507SJim Ingham // Only do this lookup if StripTypeName has stripped the name: 64450b3d507SJim Ingham if (stripped != orig_name) 645213fdb8bSSean Callanan return FindTypes_Impl(sc, ConstString(stripped), namespace_decl, append, max_matches, types); 64650b3d507SJim Ingham else 64750b3d507SJim Ingham return 0; 6486f3533fbSEnrico Granata } 6496f3533fbSEnrico Granata else 6506f3533fbSEnrico Granata return retval; 6516f3533fbSEnrico Granata 6526f3533fbSEnrico Granata } 6536f3533fbSEnrico Granata 65430fdc8d8SChris Lattner //uint32_t 65530fdc8d8SChris Lattner //Module::FindTypes(const SymbolContext& sc, const RegularExpression& regex, bool append, uint32_t max_matches, Type::Encoding encoding, const char *udt_name, TypeList& types) 65630fdc8d8SChris Lattner //{ 65730fdc8d8SChris Lattner // Timer scoped_timer(__PRETTY_FUNCTION__); 65830fdc8d8SChris Lattner // SymbolVendor *symbols = GetSymbolVendor (); 65930fdc8d8SChris Lattner // if (symbols) 66030fdc8d8SChris Lattner // return symbols->FindTypes(sc, regex, append, max_matches, encoding, udt_name, types); 66130fdc8d8SChris Lattner // return 0; 66230fdc8d8SChris Lattner // 66330fdc8d8SChris Lattner //} 66430fdc8d8SChris Lattner 66530fdc8d8SChris Lattner SymbolVendor* 66630fdc8d8SChris Lattner Module::GetSymbolVendor (bool can_create) 66730fdc8d8SChris Lattner { 66830fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 669e83e731eSGreg Clayton if (m_did_load_symbol_vendor == false && can_create) 67030fdc8d8SChris Lattner { 67130fdc8d8SChris Lattner ObjectFile *obj_file = GetObjectFile (); 67230fdc8d8SChris Lattner if (obj_file != NULL) 67330fdc8d8SChris Lattner { 67430fdc8d8SChris Lattner Timer scoped_timer(__PRETTY_FUNCTION__, __PRETTY_FUNCTION__); 675*e72dfb32SGreg Clayton m_symfile_ap.reset(SymbolVendor::FindPlugin(shared_from_this())); 676e83e731eSGreg Clayton m_did_load_symbol_vendor = true; 67730fdc8d8SChris Lattner } 67830fdc8d8SChris Lattner } 67930fdc8d8SChris Lattner return m_symfile_ap.get(); 68030fdc8d8SChris Lattner } 68130fdc8d8SChris Lattner 68230fdc8d8SChris Lattner void 68330fdc8d8SChris Lattner Module::SetFileSpecAndObjectName (const FileSpec &file, const ConstString &object_name) 68430fdc8d8SChris Lattner { 68530fdc8d8SChris Lattner // Container objects whose paths do not specify a file directly can call 68630fdc8d8SChris Lattner // this function to correct the file and object names. 68730fdc8d8SChris Lattner m_file = file; 68830fdc8d8SChris Lattner m_mod_time = file.GetModificationTime(); 68930fdc8d8SChris Lattner m_object_name = object_name; 69030fdc8d8SChris Lattner } 69130fdc8d8SChris Lattner 69230fdc8d8SChris Lattner const ArchSpec& 69330fdc8d8SChris Lattner Module::GetArchitecture () const 69430fdc8d8SChris Lattner { 69530fdc8d8SChris Lattner return m_arch; 69630fdc8d8SChris Lattner } 69730fdc8d8SChris Lattner 69830fdc8d8SChris Lattner void 699c982b3d6SGreg Clayton Module::GetDescription (Stream *s, lldb::DescriptionLevel level) 700ceb6b139SCaroline Tice { 701ceb6b139SCaroline Tice Mutex::Locker locker (m_mutex); 702ceb6b139SCaroline Tice 703c982b3d6SGreg Clayton if (level >= eDescriptionLevelFull) 704c982b3d6SGreg Clayton { 705cfd1acedSGreg Clayton if (m_arch.IsValid()) 70664195a2cSGreg Clayton s->Printf("(%s) ", m_arch.GetArchitectureName()); 707c982b3d6SGreg Clayton } 708ceb6b139SCaroline Tice 709c982b3d6SGreg Clayton if (level == eDescriptionLevelBrief) 710c982b3d6SGreg Clayton { 711c982b3d6SGreg Clayton const char *filename = m_file.GetFilename().GetCString(); 712c982b3d6SGreg Clayton if (filename) 713c982b3d6SGreg Clayton s->PutCString (filename); 714c982b3d6SGreg Clayton } 715c982b3d6SGreg Clayton else 716c982b3d6SGreg Clayton { 717cfd1acedSGreg Clayton char path[PATH_MAX]; 718cfd1acedSGreg Clayton if (m_file.GetPath(path, sizeof(path))) 719cfd1acedSGreg Clayton s->PutCString(path); 720c982b3d6SGreg Clayton } 721cfd1acedSGreg Clayton 722cfd1acedSGreg Clayton const char *object_name = m_object_name.GetCString(); 723cfd1acedSGreg Clayton if (object_name) 724cfd1acedSGreg Clayton s->Printf("(%s)", object_name); 725ceb6b139SCaroline Tice } 726ceb6b139SCaroline Tice 727ceb6b139SCaroline Tice void 728c982b3d6SGreg Clayton Module::ReportError (const char *format, ...) 729c982b3d6SGreg Clayton { 730e38a5eddSGreg Clayton if (format && format[0]) 731e38a5eddSGreg Clayton { 732e38a5eddSGreg Clayton StreamString strm; 733e38a5eddSGreg Clayton strm.PutCString("error: "); 734e38a5eddSGreg Clayton GetDescription(&strm, lldb::eDescriptionLevelBrief); 7358b35334eSGreg Clayton strm.PutChar (' '); 736c982b3d6SGreg Clayton va_list args; 737c982b3d6SGreg Clayton va_start (args, format); 738e38a5eddSGreg Clayton strm.PrintfVarArg(format, args); 739c982b3d6SGreg Clayton va_end (args); 740e38a5eddSGreg Clayton 741e38a5eddSGreg Clayton const int format_len = strlen(format); 742e38a5eddSGreg Clayton if (format_len > 0) 743e38a5eddSGreg Clayton { 744e38a5eddSGreg Clayton const char last_char = format[format_len-1]; 745e38a5eddSGreg Clayton if (last_char != '\n' || last_char != '\r') 746e38a5eddSGreg Clayton strm.EOL(); 747e38a5eddSGreg Clayton } 748e38a5eddSGreg Clayton Host::SystemLog (Host::eSystemLogError, "%s", strm.GetString().c_str()); 749e38a5eddSGreg Clayton 750e38a5eddSGreg Clayton } 751e38a5eddSGreg Clayton } 752e38a5eddSGreg Clayton 753e38a5eddSGreg Clayton void 754e38a5eddSGreg Clayton Module::ReportErrorIfModifyDetected (const char *format, ...) 755e38a5eddSGreg Clayton { 756e38a5eddSGreg Clayton if (!GetModified(true) && GetModified(false)) 757e38a5eddSGreg Clayton { 758e38a5eddSGreg Clayton if (format) 759e38a5eddSGreg Clayton { 760e38a5eddSGreg Clayton StreamString strm; 761e38a5eddSGreg Clayton strm.PutCString("error: the object file "); 762e38a5eddSGreg Clayton GetDescription(&strm, lldb::eDescriptionLevelFull); 763e38a5eddSGreg Clayton strm.PutCString (" has been modified\n"); 764e38a5eddSGreg Clayton 765e38a5eddSGreg Clayton va_list args; 766e38a5eddSGreg Clayton va_start (args, format); 767e38a5eddSGreg Clayton strm.PrintfVarArg(format, args); 768e38a5eddSGreg Clayton va_end (args); 769e38a5eddSGreg Clayton 770e38a5eddSGreg Clayton const int format_len = strlen(format); 771e38a5eddSGreg Clayton if (format_len > 0) 772e38a5eddSGreg Clayton { 773e38a5eddSGreg Clayton const char last_char = format[format_len-1]; 774e38a5eddSGreg Clayton if (last_char != '\n' || last_char != '\r') 775e38a5eddSGreg Clayton strm.EOL(); 776e38a5eddSGreg Clayton } 777e38a5eddSGreg Clayton strm.PutCString("The debug session should be aborted as the original debug information has been overwritten.\n"); 778e38a5eddSGreg Clayton Host::SystemLog (Host::eSystemLogError, "%s", strm.GetString().c_str()); 779e38a5eddSGreg Clayton } 780e38a5eddSGreg Clayton } 781c982b3d6SGreg Clayton } 782c982b3d6SGreg Clayton 783c982b3d6SGreg Clayton void 784c982b3d6SGreg Clayton Module::ReportWarning (const char *format, ...) 785c982b3d6SGreg Clayton { 786e38a5eddSGreg Clayton if (format && format[0]) 787e38a5eddSGreg Clayton { 788e38a5eddSGreg Clayton StreamString strm; 789e38a5eddSGreg Clayton strm.PutCString("warning: "); 7908b35334eSGreg Clayton GetDescription(&strm, lldb::eDescriptionLevelFull); 7918b35334eSGreg Clayton strm.PutChar (' '); 792c982b3d6SGreg Clayton 793c982b3d6SGreg Clayton va_list args; 794c982b3d6SGreg Clayton va_start (args, format); 795e38a5eddSGreg Clayton strm.PrintfVarArg(format, args); 796c982b3d6SGreg Clayton va_end (args); 797e38a5eddSGreg Clayton 798e38a5eddSGreg Clayton const int format_len = strlen(format); 799e38a5eddSGreg Clayton if (format_len > 0) 800e38a5eddSGreg Clayton { 801e38a5eddSGreg Clayton const char last_char = format[format_len-1]; 802e38a5eddSGreg Clayton if (last_char != '\n' || last_char != '\r') 803e38a5eddSGreg Clayton strm.EOL(); 804e38a5eddSGreg Clayton } 805e38a5eddSGreg Clayton Host::SystemLog (Host::eSystemLogWarning, "%s", strm.GetString().c_str()); 806e38a5eddSGreg Clayton } 807c982b3d6SGreg Clayton } 808c982b3d6SGreg Clayton 809c982b3d6SGreg Clayton void 810c982b3d6SGreg Clayton Module::LogMessage (Log *log, const char *format, ...) 811c982b3d6SGreg Clayton { 812c982b3d6SGreg Clayton if (log) 813c982b3d6SGreg Clayton { 814c982b3d6SGreg Clayton StreamString log_message; 8158b35334eSGreg Clayton GetDescription(&log_message, lldb::eDescriptionLevelFull); 816c982b3d6SGreg Clayton log_message.PutCString (": "); 817c982b3d6SGreg Clayton va_list args; 818c982b3d6SGreg Clayton va_start (args, format); 819c982b3d6SGreg Clayton log_message.PrintfVarArg (format, args); 820c982b3d6SGreg Clayton va_end (args); 821c982b3d6SGreg Clayton log->PutCString(log_message.GetString().c_str()); 822c982b3d6SGreg Clayton } 823c982b3d6SGreg Clayton } 824c982b3d6SGreg Clayton 825e38a5eddSGreg Clayton bool 826e38a5eddSGreg Clayton Module::GetModified (bool use_cached_only) 827e38a5eddSGreg Clayton { 828e38a5eddSGreg Clayton if (m_was_modified == false && use_cached_only == false) 829e38a5eddSGreg Clayton { 830e38a5eddSGreg Clayton TimeValue curr_mod_time (m_file.GetModificationTime()); 831e38a5eddSGreg Clayton m_was_modified = curr_mod_time != m_mod_time; 832e38a5eddSGreg Clayton } 833e38a5eddSGreg Clayton return m_was_modified; 834e38a5eddSGreg Clayton } 835e38a5eddSGreg Clayton 836e38a5eddSGreg Clayton bool 837e38a5eddSGreg Clayton Module::SetModified (bool b) 838e38a5eddSGreg Clayton { 839e38a5eddSGreg Clayton const bool prev_value = m_was_modified; 840e38a5eddSGreg Clayton m_was_modified = b; 841e38a5eddSGreg Clayton return prev_value; 842e38a5eddSGreg Clayton } 843e38a5eddSGreg Clayton 844e38a5eddSGreg Clayton 845c982b3d6SGreg Clayton void 84630fdc8d8SChris Lattner Module::Dump(Stream *s) 84730fdc8d8SChris Lattner { 84830fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 8498941142aSGreg Clayton //s->Printf("%.*p: ", (int)sizeof(void*) * 2, this); 85030fdc8d8SChris Lattner s->Indent(); 85130fdc8d8SChris Lattner s->Printf("Module %s/%s%s%s%s\n", 85230fdc8d8SChris Lattner m_file.GetDirectory().AsCString(), 85330fdc8d8SChris Lattner m_file.GetFilename().AsCString(), 85430fdc8d8SChris Lattner m_object_name ? "(" : "", 85530fdc8d8SChris Lattner m_object_name ? m_object_name.GetCString() : "", 85630fdc8d8SChris Lattner m_object_name ? ")" : ""); 85730fdc8d8SChris Lattner 85830fdc8d8SChris Lattner s->IndentMore(); 85930fdc8d8SChris Lattner ObjectFile *objfile = GetObjectFile (); 86030fdc8d8SChris Lattner 86130fdc8d8SChris Lattner if (objfile) 86230fdc8d8SChris Lattner objfile->Dump(s); 86330fdc8d8SChris Lattner 86430fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 86530fdc8d8SChris Lattner 86630fdc8d8SChris Lattner if (symbols) 86730fdc8d8SChris Lattner symbols->Dump(s); 86830fdc8d8SChris Lattner 86930fdc8d8SChris Lattner s->IndentLess(); 87030fdc8d8SChris Lattner } 87130fdc8d8SChris Lattner 87230fdc8d8SChris Lattner 87330fdc8d8SChris Lattner TypeList* 87430fdc8d8SChris Lattner Module::GetTypeList () 87530fdc8d8SChris Lattner { 87630fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 87730fdc8d8SChris Lattner if (symbols) 87830fdc8d8SChris Lattner return &symbols->GetTypeList(); 87930fdc8d8SChris Lattner return NULL; 88030fdc8d8SChris Lattner } 88130fdc8d8SChris Lattner 88230fdc8d8SChris Lattner const ConstString & 88330fdc8d8SChris Lattner Module::GetObjectName() const 88430fdc8d8SChris Lattner { 88530fdc8d8SChris Lattner return m_object_name; 88630fdc8d8SChris Lattner } 88730fdc8d8SChris Lattner 88830fdc8d8SChris Lattner ObjectFile * 88930fdc8d8SChris Lattner Module::GetObjectFile() 89030fdc8d8SChris Lattner { 89130fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 892e83e731eSGreg Clayton if (m_did_load_objfile == false) 89330fdc8d8SChris Lattner { 894e83e731eSGreg Clayton m_did_load_objfile = true; 89530fdc8d8SChris Lattner Timer scoped_timer(__PRETTY_FUNCTION__, 89630fdc8d8SChris Lattner "Module::GetObjectFile () module = %s", GetFileSpec().GetFilename().AsCString("")); 89744435ed0SGreg Clayton DataBufferSP file_data_sp; 898*e72dfb32SGreg Clayton m_objfile_sp = ObjectFile::FindPlugin (shared_from_this(), 899*e72dfb32SGreg Clayton &m_file, 900*e72dfb32SGreg Clayton m_object_offset, 901*e72dfb32SGreg Clayton m_file.GetByteSize(), 902*e72dfb32SGreg Clayton file_data_sp); 903593577a1SGreg Clayton if (m_objfile_sp) 904593577a1SGreg Clayton { 905593577a1SGreg Clayton // Once we get the object file, update our module with the object file's 906593577a1SGreg Clayton // architecture since it might differ in vendor/os if some parts were 907593577a1SGreg Clayton // unknown. 908593577a1SGreg Clayton m_objfile_sp->GetArchitecture (m_arch); 909593577a1SGreg Clayton } 91030fdc8d8SChris Lattner } 911762f7135SGreg Clayton return m_objfile_sp.get(); 91230fdc8d8SChris Lattner } 91330fdc8d8SChris Lattner 91430fdc8d8SChris Lattner 91530fdc8d8SChris Lattner const Symbol * 91630fdc8d8SChris Lattner Module::FindFirstSymbolWithNameAndType (const ConstString &name, SymbolType symbol_type) 91730fdc8d8SChris Lattner { 91830fdc8d8SChris Lattner Timer scoped_timer(__PRETTY_FUNCTION__, 91930fdc8d8SChris Lattner "Module::FindFirstSymbolWithNameAndType (name = %s, type = %i)", 92030fdc8d8SChris Lattner name.AsCString(), 92130fdc8d8SChris Lattner symbol_type); 92230fdc8d8SChris Lattner ObjectFile *objfile = GetObjectFile(); 92330fdc8d8SChris Lattner if (objfile) 92430fdc8d8SChris Lattner { 92530fdc8d8SChris Lattner Symtab *symtab = objfile->GetSymtab(); 92630fdc8d8SChris Lattner if (symtab) 927bcf2cfbdSGreg Clayton return symtab->FindFirstSymbolWithNameAndType (name, symbol_type, Symtab::eDebugAny, Symtab::eVisibilityAny); 92830fdc8d8SChris Lattner } 92930fdc8d8SChris Lattner return NULL; 93030fdc8d8SChris Lattner } 93130fdc8d8SChris Lattner void 93230fdc8d8SChris Lattner Module::SymbolIndicesToSymbolContextList (Symtab *symtab, std::vector<uint32_t> &symbol_indexes, SymbolContextList &sc_list) 93330fdc8d8SChris Lattner { 93430fdc8d8SChris Lattner // No need to protect this call using m_mutex all other method calls are 93530fdc8d8SChris Lattner // already thread safe. 93630fdc8d8SChris Lattner 93730fdc8d8SChris Lattner size_t num_indices = symbol_indexes.size(); 93830fdc8d8SChris Lattner if (num_indices > 0) 93930fdc8d8SChris Lattner { 94030fdc8d8SChris Lattner SymbolContext sc; 94130fdc8d8SChris Lattner CalculateSymbolContext (&sc); 94230fdc8d8SChris Lattner for (size_t i = 0; i < num_indices; i++) 94330fdc8d8SChris Lattner { 94430fdc8d8SChris Lattner sc.symbol = symtab->SymbolAtIndex (symbol_indexes[i]); 94530fdc8d8SChris Lattner if (sc.symbol) 94630fdc8d8SChris Lattner sc_list.Append (sc); 94730fdc8d8SChris Lattner } 94830fdc8d8SChris Lattner } 94930fdc8d8SChris Lattner } 95030fdc8d8SChris Lattner 95130fdc8d8SChris Lattner size_t 952b96ff33bSSean Callanan Module::FindSymbolsWithNameAndType (const ConstString &name, SymbolType symbol_type, SymbolContextList &sc_list) 95330fdc8d8SChris Lattner { 95430fdc8d8SChris Lattner // No need to protect this call using m_mutex all other method calls are 95530fdc8d8SChris Lattner // already thread safe. 95630fdc8d8SChris Lattner 95730fdc8d8SChris Lattner 95830fdc8d8SChris Lattner Timer scoped_timer(__PRETTY_FUNCTION__, 95930fdc8d8SChris Lattner "Module::FindSymbolsWithNameAndType (name = %s, type = %i)", 96030fdc8d8SChris Lattner name.AsCString(), 96130fdc8d8SChris Lattner symbol_type); 96230fdc8d8SChris Lattner const size_t initial_size = sc_list.GetSize(); 96330fdc8d8SChris Lattner ObjectFile *objfile = GetObjectFile (); 96430fdc8d8SChris Lattner if (objfile) 96530fdc8d8SChris Lattner { 96630fdc8d8SChris Lattner Symtab *symtab = objfile->GetSymtab(); 96730fdc8d8SChris Lattner if (symtab) 96830fdc8d8SChris Lattner { 96930fdc8d8SChris Lattner std::vector<uint32_t> symbol_indexes; 97030fdc8d8SChris Lattner symtab->FindAllSymbolsWithNameAndType (name, symbol_type, symbol_indexes); 97130fdc8d8SChris Lattner SymbolIndicesToSymbolContextList (symtab, symbol_indexes, sc_list); 97230fdc8d8SChris Lattner } 97330fdc8d8SChris Lattner } 97430fdc8d8SChris Lattner return sc_list.GetSize() - initial_size; 97530fdc8d8SChris Lattner } 97630fdc8d8SChris Lattner 97730fdc8d8SChris Lattner size_t 97830fdc8d8SChris Lattner Module::FindSymbolsMatchingRegExAndType (const RegularExpression ®ex, SymbolType symbol_type, SymbolContextList &sc_list) 97930fdc8d8SChris Lattner { 98030fdc8d8SChris Lattner // No need to protect this call using m_mutex all other method calls are 98130fdc8d8SChris Lattner // already thread safe. 98230fdc8d8SChris Lattner 98330fdc8d8SChris Lattner Timer scoped_timer(__PRETTY_FUNCTION__, 98430fdc8d8SChris Lattner "Module::FindSymbolsMatchingRegExAndType (regex = %s, type = %i)", 98530fdc8d8SChris Lattner regex.GetText(), 98630fdc8d8SChris Lattner symbol_type); 98730fdc8d8SChris Lattner const size_t initial_size = sc_list.GetSize(); 98830fdc8d8SChris Lattner ObjectFile *objfile = GetObjectFile (); 98930fdc8d8SChris Lattner if (objfile) 99030fdc8d8SChris Lattner { 99130fdc8d8SChris Lattner Symtab *symtab = objfile->GetSymtab(); 99230fdc8d8SChris Lattner if (symtab) 99330fdc8d8SChris Lattner { 99430fdc8d8SChris Lattner std::vector<uint32_t> symbol_indexes; 995bcf2cfbdSGreg Clayton symtab->FindAllSymbolsMatchingRexExAndType (regex, symbol_type, Symtab::eDebugAny, Symtab::eVisibilityAny, symbol_indexes); 99630fdc8d8SChris Lattner SymbolIndicesToSymbolContextList (symtab, symbol_indexes, sc_list); 99730fdc8d8SChris Lattner } 99830fdc8d8SChris Lattner } 99930fdc8d8SChris Lattner return sc_list.GetSize() - initial_size; 100030fdc8d8SChris Lattner } 100130fdc8d8SChris Lattner 100230fdc8d8SChris Lattner const TimeValue & 100330fdc8d8SChris Lattner Module::GetModificationTime () const 100430fdc8d8SChris Lattner { 100530fdc8d8SChris Lattner return m_mod_time; 100630fdc8d8SChris Lattner } 10075aee162fSJim Ingham 10085aee162fSJim Ingham bool 10095aee162fSJim Ingham Module::IsExecutable () 10105aee162fSJim Ingham { 10115aee162fSJim Ingham if (GetObjectFile() == NULL) 10125aee162fSJim Ingham return false; 10135aee162fSJim Ingham else 10145aee162fSJim Ingham return GetObjectFile()->IsExecutable(); 10155aee162fSJim Ingham } 10165aee162fSJim Ingham 10175aee162fSJim Ingham bool 1018b53cb271SJim Ingham Module::IsLoadedInTarget (Target *target) 1019b53cb271SJim Ingham { 1020b53cb271SJim Ingham ObjectFile *obj_file = GetObjectFile(); 1021b53cb271SJim Ingham if (obj_file) 1022b53cb271SJim Ingham { 1023b53cb271SJim Ingham SectionList *sections = obj_file->GetSectionList(); 1024b53cb271SJim Ingham if (sections != NULL) 1025b53cb271SJim Ingham { 1026b53cb271SJim Ingham size_t num_sections = sections->GetSize(); 1027b53cb271SJim Ingham for (size_t sect_idx = 0; sect_idx < num_sections; sect_idx++) 1028b53cb271SJim Ingham { 1029b53cb271SJim Ingham SectionSP section_sp = sections->GetSectionAtIndex(sect_idx); 1030b53cb271SJim Ingham if (section_sp->GetLoadBaseAddress(target) != LLDB_INVALID_ADDRESS) 1031b53cb271SJim Ingham { 1032b53cb271SJim Ingham return true; 1033b53cb271SJim Ingham } 1034b53cb271SJim Ingham } 1035b53cb271SJim Ingham } 1036b53cb271SJim Ingham } 1037b53cb271SJim Ingham return false; 1038b53cb271SJim Ingham } 1039b53cb271SJim Ingham bool 10405aee162fSJim Ingham Module::SetArchitecture (const ArchSpec &new_arch) 10415aee162fSJim Ingham { 104264195a2cSGreg Clayton if (!m_arch.IsValid()) 10435aee162fSJim Ingham { 10445aee162fSJim Ingham m_arch = new_arch; 10455aee162fSJim Ingham return true; 10465aee162fSJim Ingham } 104764195a2cSGreg Clayton return m_arch == new_arch; 10485aee162fSJim Ingham } 10495aee162fSJim Ingham 1050c9660546SGreg Clayton bool 1051c9660546SGreg Clayton Module::SetLoadAddress (Target &target, lldb::addr_t offset, bool &changed) 1052c9660546SGreg Clayton { 1053c9660546SGreg Clayton changed = false; 1054c9660546SGreg Clayton ObjectFile *image_object_file = GetObjectFile(); 1055c9660546SGreg Clayton if (image_object_file) 1056c9660546SGreg Clayton { 1057c9660546SGreg Clayton SectionList *section_list = image_object_file->GetSectionList (); 1058c9660546SGreg Clayton if (section_list) 1059c9660546SGreg Clayton { 1060c9660546SGreg Clayton const size_t num_sections = section_list->GetSize(); 1061c9660546SGreg Clayton size_t sect_idx = 0; 1062c9660546SGreg Clayton for (sect_idx = 0; sect_idx < num_sections; ++sect_idx) 1063c9660546SGreg Clayton { 1064c9660546SGreg Clayton // Iterate through the object file sections to find the 1065c9660546SGreg Clayton // first section that starts of file offset zero and that 1066c9660546SGreg Clayton // has bytes in the file... 1067c9660546SGreg Clayton Section *section = section_list->GetSectionAtIndex (sect_idx).get(); 1068c9660546SGreg Clayton if (section) 1069c9660546SGreg Clayton { 1070c9660546SGreg Clayton if (target.GetSectionLoadList().SetSectionLoadAddress (section, section->GetFileAddress() + offset)) 1071c9660546SGreg Clayton changed = true; 1072c9660546SGreg Clayton } 1073c9660546SGreg Clayton } 1074c9660546SGreg Clayton return sect_idx > 0; 1075c9660546SGreg Clayton } 1076c9660546SGreg Clayton } 1077c9660546SGreg Clayton return false; 1078c9660546SGreg Clayton } 1079c9660546SGreg Clayton 1080