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 10f86248d9SRichard Mitton #include "lldb/Core/AddressResolverFileLine.h" 111759848bSEnrico Granata #include "lldb/Core/Error.h" 1230fdc8d8SChris Lattner #include "lldb/Core/Module.h" 13c9660546SGreg Clayton #include "lldb/Core/DataBuffer.h" 14c9660546SGreg Clayton #include "lldb/Core/DataBufferHeap.h" 1530fdc8d8SChris Lattner #include "lldb/Core/Log.h" 1630fdc8d8SChris Lattner #include "lldb/Core/ModuleList.h" 171f746071SGreg Clayton #include "lldb/Core/ModuleSpec.h" 1856939cb3SGreg Clayton #include "lldb/Core/PluginManager.h" 1930fdc8d8SChris Lattner #include "lldb/Core/RegularExpression.h" 201f746071SGreg Clayton #include "lldb/Core/Section.h" 21c982b3d6SGreg Clayton #include "lldb/Core/StreamString.h" 2230fdc8d8SChris Lattner #include "lldb/Core/Timer.h" 23e38a5eddSGreg Clayton #include "lldb/Host/Host.h" 241759848bSEnrico Granata #include "lldb/Host/Symbols.h" 251759848bSEnrico Granata #include "lldb/Interpreter/CommandInterpreter.h" 261759848bSEnrico Granata #include "lldb/Interpreter/ScriptInterpreter.h" 271f746071SGreg Clayton #include "lldb/Symbol/CompileUnit.h" 2830fdc8d8SChris Lattner #include "lldb/Symbol/ObjectFile.h" 2930fdc8d8SChris Lattner #include "lldb/Symbol/SymbolContext.h" 3056939cb3SGreg Clayton #include "lldb/Symbol/SymbolFile.h" 3130fdc8d8SChris Lattner #include "lldb/Symbol/SymbolVendor.h" 3256939cb3SGreg Clayton #include "lldb/Symbol/TypeSystem.h" 330e0984eeSJim Ingham #include "lldb/Target/Language.h" 34c9660546SGreg Clayton #include "lldb/Target/Process.h" 35d5944cd1SGreg Clayton #include "lldb/Target/SectionLoadList.h" 36c9660546SGreg Clayton #include "lldb/Target/Target.h" 37aa816b8fSJim Ingham #include "Plugins/Language/CPlusPlus/CPlusPlusLanguage.h" 38aa816b8fSJim Ingham #include "Plugins/Language/ObjC/ObjCLanguage.h" 394069730cSRavitheja Addepally #include "lldb/Symbol/TypeMap.h" 4030fdc8d8SChris Lattner 4123f8c95aSGreg Clayton #include "Plugins/ObjectFile/JIT/ObjectFileJIT.h" 4223f8c95aSGreg Clayton 43a893d301SZachary Turner #include "llvm/Support/raw_os_ostream.h" 44a893d301SZachary Turner #include "llvm/Support/Signals.h" 45a893d301SZachary Turner 4630fdc8d8SChris Lattner using namespace lldb; 4730fdc8d8SChris Lattner using namespace lldb_private; 4830fdc8d8SChris Lattner 4965a03991SGreg Clayton // Shared pointers to modules track module lifetimes in 5065a03991SGreg Clayton // targets and in the global module, but this collection 5165a03991SGreg Clayton // will track all module objects that are still alive 5265a03991SGreg Clayton typedef std::vector<Module *> ModuleCollection; 5365a03991SGreg Clayton 5465a03991SGreg Clayton static ModuleCollection & 5565a03991SGreg Clayton GetModuleCollection() 5665a03991SGreg Clayton { 57549f7374SJim Ingham // This module collection needs to live past any module, so we could either make it a 58549f7374SJim Ingham // shared pointer in each module or just leak is. Since it is only an empty vector by 59549f7374SJim Ingham // the time all the modules have gone away, we just leak it for now. If we decide this 60549f7374SJim Ingham // is a big problem we can introduce a Finalize method that will tear everything down in 61549f7374SJim Ingham // a predictable order. 62549f7374SJim Ingham 63549f7374SJim Ingham static ModuleCollection *g_module_collection = NULL; 64549f7374SJim Ingham if (g_module_collection == NULL) 65549f7374SJim Ingham g_module_collection = new ModuleCollection(); 66549f7374SJim Ingham 67549f7374SJim Ingham return *g_module_collection; 6865a03991SGreg Clayton } 6965a03991SGreg Clayton 70b26e6bebSGreg Clayton Mutex * 7165a03991SGreg Clayton Module::GetAllocationModuleCollectionMutex() 7265a03991SGreg Clayton { 73b26e6bebSGreg Clayton // NOTE: The mutex below must be leaked since the global module list in 74b26e6bebSGreg Clayton // the ModuleList class will get torn at some point, and we can't know 75b26e6bebSGreg Clayton // if it will tear itself down before the "g_module_collection_mutex" below 76b26e6bebSGreg Clayton // will. So we leak a Mutex object below to safeguard against that 77b26e6bebSGreg Clayton 78b26e6bebSGreg Clayton static Mutex *g_module_collection_mutex = NULL; 79b26e6bebSGreg Clayton if (g_module_collection_mutex == NULL) 80b26e6bebSGreg Clayton g_module_collection_mutex = new Mutex (Mutex::eMutexTypeRecursive); // NOTE: known leak 8165a03991SGreg Clayton return g_module_collection_mutex; 8265a03991SGreg Clayton } 8365a03991SGreg Clayton 8465a03991SGreg Clayton size_t 8565a03991SGreg Clayton Module::GetNumberAllocatedModules () 8665a03991SGreg Clayton { 8765a03991SGreg Clayton Mutex::Locker locker (GetAllocationModuleCollectionMutex()); 8865a03991SGreg Clayton return GetModuleCollection().size(); 8965a03991SGreg Clayton } 9065a03991SGreg Clayton 9165a03991SGreg Clayton Module * 9265a03991SGreg Clayton Module::GetAllocatedModuleAtIndex (size_t idx) 9365a03991SGreg Clayton { 9465a03991SGreg Clayton Mutex::Locker locker (GetAllocationModuleCollectionMutex()); 9565a03991SGreg Clayton ModuleCollection &modules = GetModuleCollection(); 9665a03991SGreg Clayton if (idx < modules.size()) 9765a03991SGreg Clayton return modules[idx]; 9865a03991SGreg Clayton return NULL; 9965a03991SGreg Clayton } 10029ad7b91SGreg Clayton #if 0 10165a03991SGreg Clayton 10229ad7b91SGreg Clayton // These functions help us to determine if modules are still loaded, yet don't require that 10329ad7b91SGreg Clayton // you have a command interpreter and can easily be called from an external debugger. 10429ad7b91SGreg Clayton namespace lldb { 10565a03991SGreg Clayton 10629ad7b91SGreg Clayton void 10729ad7b91SGreg Clayton ClearModuleInfo (void) 10829ad7b91SGreg Clayton { 1090cd70866SGreg Clayton const bool mandatory = true; 1100cd70866SGreg Clayton ModuleList::RemoveOrphanSharedModules(mandatory); 11129ad7b91SGreg Clayton } 11229ad7b91SGreg Clayton 11329ad7b91SGreg Clayton void 11429ad7b91SGreg Clayton DumpModuleInfo (void) 11529ad7b91SGreg Clayton { 11629ad7b91SGreg Clayton Mutex::Locker locker (Module::GetAllocationModuleCollectionMutex()); 11729ad7b91SGreg Clayton ModuleCollection &modules = GetModuleCollection(); 11829ad7b91SGreg Clayton const size_t count = modules.size(); 119d01b2953SDaniel Malea printf ("%s: %" PRIu64 " modules:\n", __PRETTY_FUNCTION__, (uint64_t)count); 12029ad7b91SGreg Clayton for (size_t i=0; i<count; ++i) 12129ad7b91SGreg Clayton { 12229ad7b91SGreg Clayton 12329ad7b91SGreg Clayton StreamString strm; 12429ad7b91SGreg Clayton Module *module = modules[i]; 12529ad7b91SGreg Clayton const bool in_shared_module_list = ModuleList::ModuleIsInCache (module); 12629ad7b91SGreg Clayton module->GetDescription(&strm, eDescriptionLevelFull); 12729ad7b91SGreg Clayton printf ("%p: shared = %i, ref_count = %3u, module = %s\n", 12829ad7b91SGreg Clayton module, 12929ad7b91SGreg Clayton in_shared_module_list, 13029ad7b91SGreg Clayton (uint32_t)module->use_count(), 13129ad7b91SGreg Clayton strm.GetString().c_str()); 13229ad7b91SGreg Clayton } 13329ad7b91SGreg Clayton } 13429ad7b91SGreg Clayton } 13529ad7b91SGreg Clayton 13629ad7b91SGreg Clayton #endif 13765a03991SGreg Clayton 138b9a01b39SGreg Clayton Module::Module (const ModuleSpec &module_spec) : 139b9a01b39SGreg Clayton m_mutex (Mutex::eMutexTypeRecursive), 14034f1159bSGreg Clayton m_mod_time (), 14134f1159bSGreg Clayton m_arch (), 142b9a01b39SGreg Clayton m_uuid (), 14334f1159bSGreg Clayton m_file (), 14434f1159bSGreg Clayton m_platform_file(), 145fbb76349SGreg Clayton m_remote_install_file(), 14634f1159bSGreg Clayton m_symfile_spec (), 14734f1159bSGreg Clayton m_object_name (), 14834f1159bSGreg Clayton m_object_offset (), 14934f1159bSGreg Clayton m_object_mod_time (), 150b9a01b39SGreg Clayton m_objfile_sp (), 151b9a01b39SGreg Clayton m_symfile_ap (), 15256939cb3SGreg Clayton m_type_system_map(), 153d804d285SGreg Clayton m_source_mappings (), 15423f8c95aSGreg Clayton m_sections_ap(), 155b9a01b39SGreg Clayton m_did_load_objfile (false), 156b9a01b39SGreg Clayton m_did_load_symbol_vendor (false), 157b9a01b39SGreg Clayton m_did_parse_uuid (false), 1581d60909eSGreg Clayton m_file_has_changed (false), 1591d60909eSGreg Clayton m_first_file_changed_log (false) 160b9a01b39SGreg Clayton { 161b9a01b39SGreg Clayton // Scope for locker below... 162b9a01b39SGreg Clayton { 163b9a01b39SGreg Clayton Mutex::Locker locker (GetAllocationModuleCollectionMutex()); 164b9a01b39SGreg Clayton GetModuleCollection().push_back(this); 165b9a01b39SGreg Clayton } 166b9a01b39SGreg Clayton 1675160ce5cSGreg Clayton Log *log(lldb_private::GetLogIfAnyCategoriesSet (LIBLLDB_LOG_OBJECT|LIBLLDB_LOG_MODULES)); 168b9a01b39SGreg Clayton if (log) 169b5ad4ec7SGreg Clayton log->Printf ("%p Module::Module((%s) '%s%s%s%s')", 170324a1036SSaleem Abdulrasool static_cast<void*>(this), 17134f1159bSGreg Clayton module_spec.GetArchitecture().GetArchitectureName(), 17234f1159bSGreg Clayton module_spec.GetFileSpec().GetPath().c_str(), 17334f1159bSGreg Clayton module_spec.GetObjectName().IsEmpty() ? "" : "(", 17434f1159bSGreg Clayton module_spec.GetObjectName().IsEmpty() ? "" : module_spec.GetObjectName().AsCString(""), 17534f1159bSGreg Clayton module_spec.GetObjectName().IsEmpty() ? "" : ")"); 17634f1159bSGreg Clayton 17734f1159bSGreg Clayton // First extract all module specifications from the file using the local 17834f1159bSGreg Clayton // file path. If there are no specifications, then don't fill anything in 17934f1159bSGreg Clayton ModuleSpecList modules_specs; 18034f1159bSGreg Clayton if (ObjectFile::GetModuleSpecifications(module_spec.GetFileSpec(), 0, 0, modules_specs) == 0) 18134f1159bSGreg Clayton return; 18234f1159bSGreg Clayton 18334f1159bSGreg Clayton // Now make sure that one of the module specifications matches what we just 18434f1159bSGreg Clayton // extract. We might have a module specification that specifies a file "/usr/lib/dyld" 18534f1159bSGreg Clayton // with UUID XXX, but we might have a local version of "/usr/lib/dyld" that has 18634f1159bSGreg Clayton // UUID YYY and we don't want those to match. If they don't match, just don't 18734f1159bSGreg Clayton // fill any ivars in so we don't accidentally grab the wrong file later since 18834f1159bSGreg Clayton // they don't match... 18934f1159bSGreg Clayton ModuleSpec matching_module_spec; 19034f1159bSGreg Clayton if (modules_specs.FindMatchingModuleSpec(module_spec, matching_module_spec) == 0) 19134f1159bSGreg Clayton return; 1927ab7f89aSGreg Clayton 1937ab7f89aSGreg Clayton if (module_spec.GetFileSpec()) 19434f1159bSGreg Clayton m_mod_time = module_spec.GetFileSpec().GetModificationTime(); 1957ab7f89aSGreg Clayton else if (matching_module_spec.GetFileSpec()) 1967ab7f89aSGreg Clayton m_mod_time = matching_module_spec.GetFileSpec().GetModificationTime(); 1977ab7f89aSGreg Clayton 1987ab7f89aSGreg Clayton // Copy the architecture from the actual spec if we got one back, else use the one that was specified 1997ab7f89aSGreg Clayton if (matching_module_spec.GetArchitecture().IsValid()) 20034f1159bSGreg Clayton m_arch = matching_module_spec.GetArchitecture(); 2017ab7f89aSGreg Clayton else if (module_spec.GetArchitecture().IsValid()) 2027ab7f89aSGreg Clayton m_arch = module_spec.GetArchitecture(); 2037ab7f89aSGreg Clayton 204d93c4a33SBruce Mitchener // Copy the file spec over and use the specified one (if there was one) so we 2057ab7f89aSGreg Clayton // don't use a path that might have gotten resolved a path in 'matching_module_spec' 2067ab7f89aSGreg Clayton if (module_spec.GetFileSpec()) 20734f1159bSGreg Clayton m_file = module_spec.GetFileSpec(); 2087ab7f89aSGreg Clayton else if (matching_module_spec.GetFileSpec()) 2097ab7f89aSGreg Clayton m_file = matching_module_spec.GetFileSpec(); 2107ab7f89aSGreg Clayton 2117ab7f89aSGreg Clayton // Copy the platform file spec over 2127ab7f89aSGreg Clayton if (module_spec.GetPlatformFileSpec()) 21334f1159bSGreg Clayton m_platform_file = module_spec.GetPlatformFileSpec(); 2147ab7f89aSGreg Clayton else if (matching_module_spec.GetPlatformFileSpec()) 2157ab7f89aSGreg Clayton m_platform_file = matching_module_spec.GetPlatformFileSpec(); 2167ab7f89aSGreg Clayton 2177ab7f89aSGreg Clayton // Copy the symbol file spec over 2187ab7f89aSGreg Clayton if (module_spec.GetSymbolFileSpec()) 21934f1159bSGreg Clayton m_symfile_spec = module_spec.GetSymbolFileSpec(); 2207ab7f89aSGreg Clayton else if (matching_module_spec.GetSymbolFileSpec()) 2217ab7f89aSGreg Clayton m_symfile_spec = matching_module_spec.GetSymbolFileSpec(); 2227ab7f89aSGreg Clayton 2237ab7f89aSGreg Clayton // Copy the object name over 2247ab7f89aSGreg Clayton if (matching_module_spec.GetObjectName()) 2257ab7f89aSGreg Clayton m_object_name = matching_module_spec.GetObjectName(); 2267ab7f89aSGreg Clayton else 22734f1159bSGreg Clayton m_object_name = module_spec.GetObjectName(); 2287ab7f89aSGreg Clayton 2297ab7f89aSGreg Clayton // Always trust the object offset (file offset) and object modification 2307ab7f89aSGreg Clayton // time (for mod time in a BSD static archive) of from the matching 2317ab7f89aSGreg Clayton // module specification 23236d7c894SGreg Clayton m_object_offset = matching_module_spec.GetObjectOffset(); 23336d7c894SGreg Clayton m_object_mod_time = matching_module_spec.GetObjectModificationTime(); 23434f1159bSGreg Clayton 235b9a01b39SGreg Clayton } 236b9a01b39SGreg Clayton 237e72dfb32SGreg Clayton Module::Module(const FileSpec& file_spec, 238e72dfb32SGreg Clayton const ArchSpec& arch, 239e72dfb32SGreg Clayton const ConstString *object_name, 240a746e8e5SZachary Turner lldb::offset_t object_offset, 24157abc5d6SGreg Clayton const TimeValue *object_mod_time_ptr) : 24230fdc8d8SChris Lattner m_mutex (Mutex::eMutexTypeRecursive), 24330fdc8d8SChris Lattner m_mod_time (file_spec.GetModificationTime()), 24430fdc8d8SChris Lattner m_arch (arch), 24530fdc8d8SChris Lattner m_uuid (), 24630fdc8d8SChris Lattner m_file (file_spec), 24732e0a750SGreg Clayton m_platform_file(), 248fbb76349SGreg Clayton m_remote_install_file (), 249e72dfb32SGreg Clayton m_symfile_spec (), 25030fdc8d8SChris Lattner m_object_name (), 2518b82f087SGreg Clayton m_object_offset (object_offset), 25257abc5d6SGreg Clayton m_object_mod_time (), 253762f7135SGreg Clayton m_objfile_sp (), 254e83e731eSGreg Clayton m_symfile_ap (), 25556939cb3SGreg Clayton m_type_system_map(), 256d804d285SGreg Clayton m_source_mappings (), 25723f8c95aSGreg Clayton m_sections_ap(), 258e83e731eSGreg Clayton m_did_load_objfile (false), 259e83e731eSGreg Clayton m_did_load_symbol_vendor (false), 260e83e731eSGreg Clayton m_did_parse_uuid (false), 2611d60909eSGreg Clayton m_file_has_changed (false), 2621d60909eSGreg Clayton m_first_file_changed_log (false) 26330fdc8d8SChris Lattner { 26465a03991SGreg Clayton // Scope for locker below... 26565a03991SGreg Clayton { 26665a03991SGreg Clayton Mutex::Locker locker (GetAllocationModuleCollectionMutex()); 26765a03991SGreg Clayton GetModuleCollection().push_back(this); 26865a03991SGreg Clayton } 26965a03991SGreg Clayton 27030fdc8d8SChris Lattner if (object_name) 27130fdc8d8SChris Lattner m_object_name = *object_name; 27257abc5d6SGreg Clayton 27357abc5d6SGreg Clayton if (object_mod_time_ptr) 27457abc5d6SGreg Clayton m_object_mod_time = *object_mod_time_ptr; 27557abc5d6SGreg Clayton 2765160ce5cSGreg Clayton Log *log(lldb_private::GetLogIfAnyCategoriesSet (LIBLLDB_LOG_OBJECT|LIBLLDB_LOG_MODULES)); 27730fdc8d8SChris Lattner if (log) 278b5ad4ec7SGreg Clayton log->Printf ("%p Module::Module((%s) '%s%s%s%s')", 279324a1036SSaleem Abdulrasool static_cast<void*>(this), m_arch.GetArchitectureName(), 280b5ad4ec7SGreg Clayton m_file.GetPath().c_str(), 28130fdc8d8SChris Lattner m_object_name.IsEmpty() ? "" : "(", 28230fdc8d8SChris Lattner m_object_name.IsEmpty() ? "" : m_object_name.AsCString(""), 28330fdc8d8SChris Lattner m_object_name.IsEmpty() ? "" : ")"); 28430fdc8d8SChris Lattner } 28530fdc8d8SChris Lattner 28623f8c95aSGreg Clayton Module::Module () : 28723f8c95aSGreg Clayton m_mutex (Mutex::eMutexTypeRecursive), 28823f8c95aSGreg Clayton m_mod_time (), 28923f8c95aSGreg Clayton m_arch (), 29023f8c95aSGreg Clayton m_uuid (), 29123f8c95aSGreg Clayton m_file (), 29223f8c95aSGreg Clayton m_platform_file(), 29323f8c95aSGreg Clayton m_remote_install_file (), 29423f8c95aSGreg Clayton m_symfile_spec (), 29523f8c95aSGreg Clayton m_object_name (), 29623f8c95aSGreg Clayton m_object_offset (0), 29723f8c95aSGreg Clayton m_object_mod_time (), 29823f8c95aSGreg Clayton m_objfile_sp (), 29923f8c95aSGreg Clayton m_symfile_ap (), 30056939cb3SGreg Clayton m_type_system_map(), 30123f8c95aSGreg Clayton m_source_mappings (), 30223f8c95aSGreg Clayton m_sections_ap(), 30323f8c95aSGreg Clayton m_did_load_objfile (false), 30423f8c95aSGreg Clayton m_did_load_symbol_vendor (false), 30523f8c95aSGreg Clayton m_did_parse_uuid (false), 30623f8c95aSGreg Clayton m_file_has_changed (false), 30723f8c95aSGreg Clayton m_first_file_changed_log (false) 30823f8c95aSGreg Clayton { 30923f8c95aSGreg Clayton Mutex::Locker locker (GetAllocationModuleCollectionMutex()); 31023f8c95aSGreg Clayton GetModuleCollection().push_back(this); 31123f8c95aSGreg Clayton } 31223f8c95aSGreg Clayton 31330fdc8d8SChris Lattner Module::~Module() 31430fdc8d8SChris Lattner { 315217b28baSGreg Clayton // Lock our module down while we tear everything down to make sure 316217b28baSGreg Clayton // we don't get any access to the module while it is being destroyed 317217b28baSGreg Clayton Mutex::Locker locker (m_mutex); 31865a03991SGreg Clayton // Scope for locker below... 31965a03991SGreg Clayton { 32065a03991SGreg Clayton Mutex::Locker locker (GetAllocationModuleCollectionMutex()); 32165a03991SGreg Clayton ModuleCollection &modules = GetModuleCollection(); 32265a03991SGreg Clayton ModuleCollection::iterator end = modules.end(); 32365a03991SGreg Clayton ModuleCollection::iterator pos = std::find(modules.begin(), end, this); 3243a18e319SGreg Clayton assert (pos != end); 32565a03991SGreg Clayton modules.erase(pos); 32665a03991SGreg Clayton } 3275160ce5cSGreg Clayton Log *log(lldb_private::GetLogIfAnyCategoriesSet (LIBLLDB_LOG_OBJECT|LIBLLDB_LOG_MODULES)); 32830fdc8d8SChris Lattner if (log) 329b5ad4ec7SGreg Clayton log->Printf ("%p Module::~Module((%s) '%s%s%s%s')", 330324a1036SSaleem Abdulrasool static_cast<void*>(this), 33164195a2cSGreg Clayton m_arch.GetArchitectureName(), 332b5ad4ec7SGreg Clayton m_file.GetPath().c_str(), 33330fdc8d8SChris Lattner m_object_name.IsEmpty() ? "" : "(", 33430fdc8d8SChris Lattner m_object_name.IsEmpty() ? "" : m_object_name.AsCString(""), 33530fdc8d8SChris Lattner m_object_name.IsEmpty() ? "" : ")"); 3366beaaa68SGreg Clayton // Release any auto pointers before we start tearing down our member 3376beaaa68SGreg Clayton // variables since the object file and symbol files might need to make 3386beaaa68SGreg Clayton // function calls back into this module object. The ordering is important 3396beaaa68SGreg Clayton // here because symbol files can require the module object file. So we tear 3406beaaa68SGreg Clayton // down the symbol file first, then the object file. 3413046e668SGreg Clayton m_sections_ap.reset(); 3426beaaa68SGreg Clayton m_symfile_ap.reset(); 343762f7135SGreg Clayton m_objfile_sp.reset(); 34430fdc8d8SChris Lattner } 34530fdc8d8SChris Lattner 346c7f09ccaSGreg Clayton ObjectFile * 34717220c18SAndrew MacPherson Module::GetMemoryObjectFile (const lldb::ProcessSP &process_sp, lldb::addr_t header_addr, Error &error, size_t size_to_read) 348c7f09ccaSGreg Clayton { 349c7f09ccaSGreg Clayton if (m_objfile_sp) 350c7f09ccaSGreg Clayton { 351c7f09ccaSGreg Clayton error.SetErrorString ("object file already exists"); 352c7f09ccaSGreg Clayton } 353c7f09ccaSGreg Clayton else 354c7f09ccaSGreg Clayton { 355c7f09ccaSGreg Clayton Mutex::Locker locker (m_mutex); 356c7f09ccaSGreg Clayton if (process_sp) 357c7f09ccaSGreg Clayton { 358c7f09ccaSGreg Clayton m_did_load_objfile = true; 35917220c18SAndrew MacPherson std::unique_ptr<DataBufferHeap> data_ap (new DataBufferHeap (size_to_read, 0)); 360c7f09ccaSGreg Clayton Error readmem_error; 361c7f09ccaSGreg Clayton const size_t bytes_read = process_sp->ReadMemory (header_addr, 362c7f09ccaSGreg Clayton data_ap->GetBytes(), 363c7f09ccaSGreg Clayton data_ap->GetByteSize(), 364c7f09ccaSGreg Clayton readmem_error); 36517220c18SAndrew MacPherson if (bytes_read == size_to_read) 366c7f09ccaSGreg Clayton { 367c7f09ccaSGreg Clayton DataBufferSP data_sp(data_ap.release()); 368c7f09ccaSGreg Clayton m_objfile_sp = ObjectFile::FindPlugin(shared_from_this(), process_sp, header_addr, data_sp); 369c7f09ccaSGreg Clayton if (m_objfile_sp) 370c7f09ccaSGreg Clayton { 3713e10cf3bSGreg Clayton StreamString s; 372d01b2953SDaniel Malea s.Printf("0x%16.16" PRIx64, header_addr); 3733e10cf3bSGreg Clayton m_object_name.SetCString (s.GetData()); 3743e10cf3bSGreg Clayton 375c7f09ccaSGreg Clayton // Once we get the object file, update our module with the object file's 376c7f09ccaSGreg Clayton // architecture since it might differ in vendor/os if some parts were 377c7f09ccaSGreg Clayton // unknown. 378c7f09ccaSGreg Clayton m_objfile_sp->GetArchitecture (m_arch); 379c7f09ccaSGreg Clayton } 380c7f09ccaSGreg Clayton else 381c7f09ccaSGreg Clayton { 382c7f09ccaSGreg Clayton error.SetErrorString ("unable to find suitable object file plug-in"); 383c7f09ccaSGreg Clayton } 384c7f09ccaSGreg Clayton } 385c7f09ccaSGreg Clayton else 386c7f09ccaSGreg Clayton { 387c7f09ccaSGreg Clayton error.SetErrorStringWithFormat ("unable to read header from memory: %s", readmem_error.AsCString()); 388c7f09ccaSGreg Clayton } 389c7f09ccaSGreg Clayton } 390c7f09ccaSGreg Clayton else 391c7f09ccaSGreg Clayton { 392c7f09ccaSGreg Clayton error.SetErrorString ("invalid process"); 393c7f09ccaSGreg Clayton } 394c7f09ccaSGreg Clayton } 395c7f09ccaSGreg Clayton return m_objfile_sp.get(); 396c7f09ccaSGreg Clayton } 397c7f09ccaSGreg Clayton 39830fdc8d8SChris Lattner 39960830268SGreg Clayton const lldb_private::UUID& 40030fdc8d8SChris Lattner Module::GetUUID() 40130fdc8d8SChris Lattner { 40288c05f54SGreg Clayton if (m_did_parse_uuid.load() == false) 40388c05f54SGreg Clayton { 40430fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 40588c05f54SGreg Clayton if (m_did_parse_uuid.load() == false) 40630fdc8d8SChris Lattner { 40730fdc8d8SChris Lattner ObjectFile * obj_file = GetObjectFile (); 40830fdc8d8SChris Lattner 40930fdc8d8SChris Lattner if (obj_file != NULL) 41030fdc8d8SChris Lattner { 41130fdc8d8SChris Lattner obj_file->GetUUID(&m_uuid); 412e83e731eSGreg Clayton m_did_parse_uuid = true; 41330fdc8d8SChris Lattner } 41430fdc8d8SChris Lattner } 41588c05f54SGreg Clayton } 41630fdc8d8SChris Lattner return m_uuid; 41730fdc8d8SChris Lattner } 41830fdc8d8SChris Lattner 4198b4edba9SGreg Clayton TypeSystem * 4208b4edba9SGreg Clayton Module::GetTypeSystemForLanguage (LanguageType language) 4218b4edba9SGreg Clayton { 4225beec213SGreg Clayton return m_type_system_map.GetTypeSystemForLanguage(language, this, true); 4236beaaa68SGreg Clayton } 4246beaaa68SGreg Clayton 42530fdc8d8SChris Lattner void 42630fdc8d8SChris Lattner Module::ParseAllDebugSymbols() 42730fdc8d8SChris Lattner { 42830fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 429c7bece56SGreg Clayton size_t num_comp_units = GetNumCompileUnits(); 43030fdc8d8SChris Lattner if (num_comp_units == 0) 43130fdc8d8SChris Lattner return; 43230fdc8d8SChris Lattner 433a2eee184SGreg Clayton SymbolContext sc; 434e1cd1be6SGreg Clayton sc.module_sp = shared_from_this(); 43530fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 43630fdc8d8SChris Lattner 437c7bece56SGreg Clayton for (size_t cu_idx = 0; cu_idx < num_comp_units; cu_idx++) 43830fdc8d8SChris Lattner { 43930fdc8d8SChris Lattner sc.comp_unit = symbols->GetCompileUnitAtIndex(cu_idx).get(); 44030fdc8d8SChris Lattner if (sc.comp_unit) 44130fdc8d8SChris Lattner { 44230fdc8d8SChris Lattner sc.function = NULL; 44330fdc8d8SChris Lattner symbols->ParseVariablesForContext(sc); 44430fdc8d8SChris Lattner 44530fdc8d8SChris Lattner symbols->ParseCompileUnitFunctions(sc); 44630fdc8d8SChris Lattner 447c7bece56SGreg Clayton for (size_t func_idx = 0; (sc.function = sc.comp_unit->GetFunctionAtIndex(func_idx).get()) != NULL; ++func_idx) 44830fdc8d8SChris Lattner { 44930fdc8d8SChris Lattner symbols->ParseFunctionBlocks(sc); 45030fdc8d8SChris Lattner 45130fdc8d8SChris Lattner // Parse the variables for this function and all its blocks 45230fdc8d8SChris Lattner symbols->ParseVariablesForContext(sc); 45330fdc8d8SChris Lattner } 45430fdc8d8SChris Lattner 45530fdc8d8SChris Lattner 45630fdc8d8SChris Lattner // Parse all types for this compile unit 45730fdc8d8SChris Lattner sc.function = NULL; 45830fdc8d8SChris Lattner symbols->ParseTypes(sc); 45930fdc8d8SChris Lattner } 46030fdc8d8SChris Lattner } 46130fdc8d8SChris Lattner } 46230fdc8d8SChris Lattner 46330fdc8d8SChris Lattner void 46430fdc8d8SChris Lattner Module::CalculateSymbolContext(SymbolContext* sc) 46530fdc8d8SChris Lattner { 466e1cd1be6SGreg Clayton sc->module_sp = shared_from_this(); 46730fdc8d8SChris Lattner } 46830fdc8d8SChris Lattner 469e72dfb32SGreg Clayton ModuleSP 4707e9b1fd0SGreg Clayton Module::CalculateSymbolContextModule () 4717e9b1fd0SGreg Clayton { 472e72dfb32SGreg Clayton return shared_from_this(); 4737e9b1fd0SGreg Clayton } 4747e9b1fd0SGreg Clayton 47530fdc8d8SChris Lattner void 47630fdc8d8SChris Lattner Module::DumpSymbolContext(Stream *s) 47730fdc8d8SChris Lattner { 478324a1036SSaleem Abdulrasool s->Printf(", Module{%p}", static_cast<void*>(this)); 47930fdc8d8SChris Lattner } 48030fdc8d8SChris Lattner 481c7bece56SGreg Clayton size_t 48230fdc8d8SChris Lattner Module::GetNumCompileUnits() 48330fdc8d8SChris Lattner { 48430fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 485324a1036SSaleem Abdulrasool Timer scoped_timer(__PRETTY_FUNCTION__, 486324a1036SSaleem Abdulrasool "Module::GetNumCompileUnits (module = %p)", 487324a1036SSaleem Abdulrasool static_cast<void*>(this)); 48830fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 48930fdc8d8SChris Lattner if (symbols) 49030fdc8d8SChris Lattner return symbols->GetNumCompileUnits(); 49130fdc8d8SChris Lattner return 0; 49230fdc8d8SChris Lattner } 49330fdc8d8SChris Lattner 49430fdc8d8SChris Lattner CompUnitSP 495c7bece56SGreg Clayton Module::GetCompileUnitAtIndex (size_t index) 49630fdc8d8SChris Lattner { 49730fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 498c7bece56SGreg Clayton size_t num_comp_units = GetNumCompileUnits (); 49930fdc8d8SChris Lattner CompUnitSP cu_sp; 50030fdc8d8SChris Lattner 50130fdc8d8SChris Lattner if (index < num_comp_units) 50230fdc8d8SChris Lattner { 50330fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 50430fdc8d8SChris Lattner if (symbols) 50530fdc8d8SChris Lattner cu_sp = symbols->GetCompileUnitAtIndex(index); 50630fdc8d8SChris Lattner } 50730fdc8d8SChris Lattner return cu_sp; 50830fdc8d8SChris Lattner } 50930fdc8d8SChris Lattner 51030fdc8d8SChris Lattner bool 51130fdc8d8SChris Lattner Module::ResolveFileAddress (lldb::addr_t vm_addr, Address& so_addr) 51230fdc8d8SChris Lattner { 51330fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 514d01b2953SDaniel Malea Timer scoped_timer(__PRETTY_FUNCTION__, "Module::ResolveFileAddress (vm_addr = 0x%" PRIx64 ")", vm_addr); 5153046e668SGreg Clayton SectionList *section_list = GetSectionList(); 5163046e668SGreg Clayton if (section_list) 5173046e668SGreg Clayton return so_addr.ResolveAddressUsingFileSections(vm_addr, section_list); 51830fdc8d8SChris Lattner return false; 51930fdc8d8SChris Lattner } 52030fdc8d8SChris Lattner 52130fdc8d8SChris Lattner uint32_t 52235729bb1SAshok Thirumurthi Module::ResolveSymbolContextForAddress (const Address& so_addr, uint32_t resolve_scope, SymbolContext& sc, 52335729bb1SAshok Thirumurthi bool resolve_tail_call_address) 52430fdc8d8SChris Lattner { 52530fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 52630fdc8d8SChris Lattner uint32_t resolved_flags = 0; 52730fdc8d8SChris Lattner 52872310355SGreg Clayton // Clear the result symbol context in case we don't find anything, but don't clear the target 52972310355SGreg Clayton sc.Clear(false); 53030fdc8d8SChris Lattner 53130fdc8d8SChris Lattner // Get the section from the section/offset address. 532e72dfb32SGreg Clayton SectionSP section_sp (so_addr.GetSection()); 53330fdc8d8SChris Lattner 53430fdc8d8SChris Lattner // Make sure the section matches this module before we try and match anything 535e72dfb32SGreg Clayton if (section_sp && section_sp->GetModule().get() == this) 53630fdc8d8SChris Lattner { 53730fdc8d8SChris Lattner // If the section offset based address resolved itself, then this 53830fdc8d8SChris Lattner // is the right module. 539e1cd1be6SGreg Clayton sc.module_sp = shared_from_this(); 54030fdc8d8SChris Lattner resolved_flags |= eSymbolContextModule; 54130fdc8d8SChris Lattner 54238807141SAshok Thirumurthi SymbolVendor* sym_vendor = GetSymbolVendor(); 54338807141SAshok Thirumurthi if (!sym_vendor) 54438807141SAshok Thirumurthi return resolved_flags; 54538807141SAshok Thirumurthi 54630fdc8d8SChris Lattner // Resolve the compile unit, function, block, line table or line 54730fdc8d8SChris Lattner // entry if requested. 54830fdc8d8SChris Lattner if (resolve_scope & eSymbolContextCompUnit || 54930fdc8d8SChris Lattner resolve_scope & eSymbolContextFunction || 55030fdc8d8SChris Lattner resolve_scope & eSymbolContextBlock || 55130fdc8d8SChris Lattner resolve_scope & eSymbolContextLineEntry ) 55230fdc8d8SChris Lattner { 55338807141SAshok Thirumurthi resolved_flags |= sym_vendor->ResolveSymbolContext (so_addr, resolve_scope, sc); 55430fdc8d8SChris Lattner } 55530fdc8d8SChris Lattner 556680e1778SJim Ingham // Resolve the symbol if requested, but don't re-look it up if we've already found it. 557680e1778SJim Ingham if (resolve_scope & eSymbolContextSymbol && !(resolved_flags & eSymbolContextSymbol)) 55830fdc8d8SChris Lattner { 559a7499c98SMichael Sartain Symtab *symtab = sym_vendor->GetSymtab(); 56038807141SAshok Thirumurthi if (symtab && so_addr.IsSectionOffset()) 56130fdc8d8SChris Lattner { 562*0d9dd7dfSMohit K. Bhakkad Symbol *matching_symbol = nullptr; 563*0d9dd7dfSMohit K. Bhakkad symtab->ForEachSymbolContainingFileAddresss (so_addr.GetFileAddress(), [&matching_symbol](Symbol *symbol) -> bool { 564*0d9dd7dfSMohit K. Bhakkad if (symbol->GetType() != eSymbolTypeInvalid) 565*0d9dd7dfSMohit K. Bhakkad { 566*0d9dd7dfSMohit K. Bhakkad matching_symbol = symbol; 567*0d9dd7dfSMohit K. Bhakkad return false; // Stop iterating 568*0d9dd7dfSMohit K. Bhakkad } 569*0d9dd7dfSMohit K. Bhakkad return true; // Keep iterating 570*0d9dd7dfSMohit K. Bhakkad }); 571*0d9dd7dfSMohit K. Bhakkad sc.symbol = matching_symbol; 57235729bb1SAshok Thirumurthi if (!sc.symbol && 57335729bb1SAshok Thirumurthi resolve_scope & eSymbolContextFunction && !(resolved_flags & eSymbolContextFunction)) 57435729bb1SAshok Thirumurthi { 57535729bb1SAshok Thirumurthi bool verify_unique = false; // No need to check again since ResolveSymbolContext failed to find a symbol at this address. 57635729bb1SAshok Thirumurthi if (ObjectFile *obj_file = sc.module_sp->GetObjectFile()) 57735729bb1SAshok Thirumurthi sc.symbol = obj_file->ResolveSymbolForAddress(so_addr, verify_unique); 57835729bb1SAshok Thirumurthi } 57935729bb1SAshok Thirumurthi 58030fdc8d8SChris Lattner if (sc.symbol) 58193e2861bSGreg Clayton { 58293e2861bSGreg Clayton if (sc.symbol->IsSynthetic()) 58393e2861bSGreg Clayton { 58493e2861bSGreg Clayton // We have a synthetic symbol so lets check if the object file 58593e2861bSGreg Clayton // from the symbol file in the symbol vendor is different than 58693e2861bSGreg Clayton // the object file for the module, and if so search its symbol 58793e2861bSGreg Clayton // table to see if we can come up with a better symbol. For example 58893e2861bSGreg Clayton // dSYM files on MacOSX have an unstripped symbol table inside of 58993e2861bSGreg Clayton // them. 59093e2861bSGreg Clayton ObjectFile *symtab_objfile = symtab->GetObjectFile(); 59193e2861bSGreg Clayton if (symtab_objfile && symtab_objfile->IsStripped()) 59293e2861bSGreg Clayton { 59393e2861bSGreg Clayton SymbolFile *symfile = sym_vendor->GetSymbolFile(); 59493e2861bSGreg Clayton if (symfile) 59593e2861bSGreg Clayton { 59693e2861bSGreg Clayton ObjectFile *symfile_objfile = symfile->GetObjectFile(); 59793e2861bSGreg Clayton if (symfile_objfile != symtab_objfile) 59893e2861bSGreg Clayton { 59993e2861bSGreg Clayton Symtab *symfile_symtab = symfile_objfile->GetSymtab(); 60093e2861bSGreg Clayton if (symfile_symtab) 60193e2861bSGreg Clayton { 60293e2861bSGreg Clayton Symbol *symbol = symfile_symtab->FindSymbolContainingFileAddress(so_addr.GetFileAddress()); 60393e2861bSGreg Clayton if (symbol && !symbol->IsSynthetic()) 60493e2861bSGreg Clayton { 60593e2861bSGreg Clayton sc.symbol = symbol; 60693e2861bSGreg Clayton } 60793e2861bSGreg Clayton } 60893e2861bSGreg Clayton } 60993e2861bSGreg Clayton } 61093e2861bSGreg Clayton } 61193e2861bSGreg Clayton } 61230fdc8d8SChris Lattner resolved_flags |= eSymbolContextSymbol; 61330fdc8d8SChris Lattner } 61430fdc8d8SChris Lattner } 61593e2861bSGreg Clayton } 61638807141SAshok Thirumurthi 61738807141SAshok Thirumurthi // For function symbols, so_addr may be off by one. This is a convention consistent 61838807141SAshok Thirumurthi // with FDE row indices in eh_frame sections, but requires extra logic here to permit 61938807141SAshok Thirumurthi // symbol lookup for disassembly and unwind. 62038807141SAshok Thirumurthi if (resolve_scope & eSymbolContextSymbol && !(resolved_flags & eSymbolContextSymbol) && 62135729bb1SAshok Thirumurthi resolve_tail_call_address && so_addr.IsSectionOffset()) 62238807141SAshok Thirumurthi { 62338807141SAshok Thirumurthi Address previous_addr = so_addr; 624edfaae39SGreg Clayton previous_addr.Slide(-1); 62538807141SAshok Thirumurthi 62635729bb1SAshok Thirumurthi bool do_resolve_tail_call_address = false; // prevent recursion 62735729bb1SAshok Thirumurthi const uint32_t flags = ResolveSymbolContextForAddress(previous_addr, resolve_scope, sc, 62835729bb1SAshok Thirumurthi do_resolve_tail_call_address); 62938807141SAshok Thirumurthi if (flags & eSymbolContextSymbol) 63038807141SAshok Thirumurthi { 63138807141SAshok Thirumurthi AddressRange addr_range; 63238807141SAshok Thirumurthi if (sc.GetAddressRange (eSymbolContextFunction | eSymbolContextSymbol, 0, false, addr_range)) 63338807141SAshok Thirumurthi { 63438807141SAshok Thirumurthi if (addr_range.GetBaseAddress().GetSection() == so_addr.GetSection()) 63538807141SAshok Thirumurthi { 63638807141SAshok Thirumurthi // If the requested address is one past the address range of a function (i.e. a tail call), 63738807141SAshok Thirumurthi // or the decremented address is the start of a function (i.e. some forms of trampoline), 63838807141SAshok Thirumurthi // indicate that the symbol has been resolved. 63938807141SAshok Thirumurthi if (so_addr.GetOffset() == addr_range.GetBaseAddress().GetOffset() || 64038807141SAshok Thirumurthi so_addr.GetOffset() == addr_range.GetBaseAddress().GetOffset() + addr_range.GetByteSize()) 64138807141SAshok Thirumurthi { 64238807141SAshok Thirumurthi resolved_flags |= flags; 64338807141SAshok Thirumurthi } 64438807141SAshok Thirumurthi } 64538807141SAshok Thirumurthi else 64638807141SAshok Thirumurthi { 64738807141SAshok Thirumurthi sc.symbol = nullptr; // Don't trust the symbol if the sections didn't match. 64838807141SAshok Thirumurthi } 64938807141SAshok Thirumurthi } 65030fdc8d8SChris Lattner } 65130fdc8d8SChris Lattner } 65230fdc8d8SChris Lattner } 65330fdc8d8SChris Lattner return resolved_flags; 65430fdc8d8SChris Lattner } 65530fdc8d8SChris Lattner 65630fdc8d8SChris Lattner uint32_t 657274060b6SGreg Clayton Module::ResolveSymbolContextForFilePath 658274060b6SGreg Clayton ( 659274060b6SGreg Clayton const char *file_path, 660274060b6SGreg Clayton uint32_t line, 661274060b6SGreg Clayton bool check_inlines, 662274060b6SGreg Clayton uint32_t resolve_scope, 663274060b6SGreg Clayton SymbolContextList& sc_list 664274060b6SGreg Clayton ) 66530fdc8d8SChris Lattner { 666274060b6SGreg Clayton FileSpec file_spec(file_path, false); 66730fdc8d8SChris Lattner return ResolveSymbolContextsForFileSpec (file_spec, line, check_inlines, resolve_scope, sc_list); 66830fdc8d8SChris Lattner } 66930fdc8d8SChris Lattner 67030fdc8d8SChris Lattner uint32_t 67130fdc8d8SChris Lattner Module::ResolveSymbolContextsForFileSpec (const FileSpec &file_spec, uint32_t line, bool check_inlines, uint32_t resolve_scope, SymbolContextList& sc_list) 67230fdc8d8SChris Lattner { 67330fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 67430fdc8d8SChris Lattner Timer scoped_timer(__PRETTY_FUNCTION__, 675b5ad4ec7SGreg Clayton "Module::ResolveSymbolContextForFilePath (%s:%u, check_inlines = %s, resolve_scope = 0x%8.8x)", 676b5ad4ec7SGreg Clayton file_spec.GetPath().c_str(), 67730fdc8d8SChris Lattner line, 67830fdc8d8SChris Lattner check_inlines ? "yes" : "no", 67930fdc8d8SChris Lattner resolve_scope); 68030fdc8d8SChris Lattner 68130fdc8d8SChris Lattner const uint32_t initial_count = sc_list.GetSize(); 68230fdc8d8SChris Lattner 68330fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 68430fdc8d8SChris Lattner if (symbols) 68530fdc8d8SChris Lattner symbols->ResolveSymbolContext (file_spec, line, check_inlines, resolve_scope, sc_list); 68630fdc8d8SChris Lattner 68730fdc8d8SChris Lattner return sc_list.GetSize() - initial_count; 68830fdc8d8SChris Lattner } 68930fdc8d8SChris Lattner 69030fdc8d8SChris Lattner 691c7bece56SGreg Clayton size_t 692c7bece56SGreg Clayton Module::FindGlobalVariables (const ConstString &name, 69399558cc4SGreg Clayton const CompilerDeclContext *parent_decl_ctx, 694c7bece56SGreg Clayton bool append, 695c7bece56SGreg Clayton size_t max_matches, 696c7bece56SGreg Clayton VariableList& variables) 69730fdc8d8SChris Lattner { 69830fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 69930fdc8d8SChris Lattner if (symbols) 70099558cc4SGreg Clayton return symbols->FindGlobalVariables(name, parent_decl_ctx, append, max_matches, variables); 70130fdc8d8SChris Lattner return 0; 70230fdc8d8SChris Lattner } 703c7bece56SGreg Clayton 704c7bece56SGreg Clayton size_t 705c7bece56SGreg Clayton Module::FindGlobalVariables (const RegularExpression& regex, 706c7bece56SGreg Clayton bool append, 707c7bece56SGreg Clayton size_t max_matches, 708c7bece56SGreg Clayton VariableList& variables) 70930fdc8d8SChris Lattner { 71030fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 71130fdc8d8SChris Lattner if (symbols) 71230fdc8d8SChris Lattner return symbols->FindGlobalVariables(regex, append, max_matches, variables); 71330fdc8d8SChris Lattner return 0; 71430fdc8d8SChris Lattner } 71530fdc8d8SChris Lattner 716c7bece56SGreg Clayton size_t 717644247c1SGreg Clayton Module::FindCompileUnits (const FileSpec &path, 718644247c1SGreg Clayton bool append, 719644247c1SGreg Clayton SymbolContextList &sc_list) 720644247c1SGreg Clayton { 721644247c1SGreg Clayton if (!append) 722644247c1SGreg Clayton sc_list.Clear(); 723644247c1SGreg Clayton 724c7bece56SGreg Clayton const size_t start_size = sc_list.GetSize(); 725c7bece56SGreg Clayton const size_t num_compile_units = GetNumCompileUnits(); 726644247c1SGreg Clayton SymbolContext sc; 727e1cd1be6SGreg Clayton sc.module_sp = shared_from_this(); 728ddd7a2a6SSean Callanan const bool compare_directory = (bool)path.GetDirectory(); 729c7bece56SGreg Clayton for (size_t i=0; i<num_compile_units; ++i) 730644247c1SGreg Clayton { 731644247c1SGreg Clayton sc.comp_unit = GetCompileUnitAtIndex(i).get(); 7322dafd8edSGreg Clayton if (sc.comp_unit) 7332dafd8edSGreg Clayton { 734644247c1SGreg Clayton if (FileSpec::Equal (*sc.comp_unit, path, compare_directory)) 735644247c1SGreg Clayton sc_list.Append(sc); 736644247c1SGreg Clayton } 7372dafd8edSGreg Clayton } 738644247c1SGreg Clayton return sc_list.GetSize() - start_size; 739644247c1SGreg Clayton } 740644247c1SGreg Clayton 741c7bece56SGreg Clayton size_t 742931180e6SGreg Clayton Module::FindFunctions (const ConstString &name, 74399558cc4SGreg Clayton const CompilerDeclContext *parent_decl_ctx, 744931180e6SGreg Clayton uint32_t name_type_mask, 745931180e6SGreg Clayton bool include_symbols, 7469df05fbbSSean Callanan bool include_inlines, 747931180e6SGreg Clayton bool append, 748931180e6SGreg Clayton SymbolContextList& sc_list) 74930fdc8d8SChris Lattner { 750931180e6SGreg Clayton if (!append) 751931180e6SGreg Clayton sc_list.Clear(); 752931180e6SGreg Clayton 75343fe217bSGreg Clayton const size_t old_size = sc_list.GetSize(); 754931180e6SGreg Clayton 755931180e6SGreg Clayton // Find all the functions (not symbols, but debug information functions... 75630fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 75743fe217bSGreg Clayton 75843fe217bSGreg Clayton if (name_type_mask & eFunctionNameTypeAuto) 75943fe217bSGreg Clayton { 76043fe217bSGreg Clayton ConstString lookup_name; 76143fe217bSGreg Clayton uint32_t lookup_name_type_mask = 0; 76243fe217bSGreg Clayton bool match_name_after_lookup = false; 76343fe217bSGreg Clayton Module::PrepareForFunctionNameLookup (name, 76443fe217bSGreg Clayton name_type_mask, 76523b1decbSDawn Perchik eLanguageTypeUnknown, // TODO: add support 76643fe217bSGreg Clayton lookup_name, 76743fe217bSGreg Clayton lookup_name_type_mask, 76843fe217bSGreg Clayton match_name_after_lookup); 76943fe217bSGreg Clayton 77043fe217bSGreg Clayton if (symbols) 771a7499c98SMichael Sartain { 77243fe217bSGreg Clayton symbols->FindFunctions(lookup_name, 77399558cc4SGreg Clayton parent_decl_ctx, 77443fe217bSGreg Clayton lookup_name_type_mask, 77543fe217bSGreg Clayton include_inlines, 77643fe217bSGreg Clayton append, 77743fe217bSGreg Clayton sc_list); 77843fe217bSGreg Clayton 77943fe217bSGreg Clayton // Now check our symbol table for symbols that are code symbols if requested 78043fe217bSGreg Clayton if (include_symbols) 78143fe217bSGreg Clayton { 782a7499c98SMichael Sartain Symtab *symtab = symbols->GetSymtab(); 78343fe217bSGreg Clayton if (symtab) 78443fe217bSGreg Clayton symtab->FindFunctionSymbols(lookup_name, lookup_name_type_mask, sc_list); 78543fe217bSGreg Clayton } 78643fe217bSGreg Clayton } 78743fe217bSGreg Clayton 78843fe217bSGreg Clayton if (match_name_after_lookup) 78943fe217bSGreg Clayton { 79043fe217bSGreg Clayton SymbolContext sc; 79143fe217bSGreg Clayton size_t i = old_size; 79243fe217bSGreg Clayton while (i<sc_list.GetSize()) 79343fe217bSGreg Clayton { 79443fe217bSGreg Clayton if (sc_list.GetContextAtIndex(i, sc)) 79543fe217bSGreg Clayton { 79643fe217bSGreg Clayton const char *func_name = sc.GetFunctionName().GetCString(); 79743fe217bSGreg Clayton if (func_name && strstr (func_name, name.GetCString()) == NULL) 79843fe217bSGreg Clayton { 79943fe217bSGreg Clayton // Remove the current context 80043fe217bSGreg Clayton sc_list.RemoveContextAtIndex(i); 80143fe217bSGreg Clayton // Don't increment i and continue in the loop 80243fe217bSGreg Clayton continue; 80343fe217bSGreg Clayton } 80443fe217bSGreg Clayton } 80543fe217bSGreg Clayton ++i; 80643fe217bSGreg Clayton } 80743fe217bSGreg Clayton } 80843fe217bSGreg Clayton } 80943fe217bSGreg Clayton else 81043fe217bSGreg Clayton { 81130fdc8d8SChris Lattner if (symbols) 812a7499c98SMichael Sartain { 81399558cc4SGreg Clayton symbols->FindFunctions(name, parent_decl_ctx, name_type_mask, include_inlines, append, sc_list); 814931180e6SGreg Clayton 815931180e6SGreg Clayton // Now check our symbol table for symbols that are code symbols if requested 816931180e6SGreg Clayton if (include_symbols) 817931180e6SGreg Clayton { 818a7499c98SMichael Sartain Symtab *symtab = symbols->GetSymtab(); 819931180e6SGreg Clayton if (symtab) 82043fe217bSGreg Clayton symtab->FindFunctionSymbols(name, name_type_mask, sc_list); 821931180e6SGreg Clayton } 822931180e6SGreg Clayton } 823931180e6SGreg Clayton } 82443fe217bSGreg Clayton 82543fe217bSGreg Clayton return sc_list.GetSize() - old_size; 82630fdc8d8SChris Lattner } 82730fdc8d8SChris Lattner 828c7bece56SGreg Clayton size_t 829931180e6SGreg Clayton Module::FindFunctions (const RegularExpression& regex, 830931180e6SGreg Clayton bool include_symbols, 8319df05fbbSSean Callanan bool include_inlines, 832931180e6SGreg Clayton bool append, 833931180e6SGreg Clayton SymbolContextList& sc_list) 83430fdc8d8SChris Lattner { 835931180e6SGreg Clayton if (!append) 836931180e6SGreg Clayton sc_list.Clear(); 837931180e6SGreg Clayton 838c7bece56SGreg Clayton const size_t start_size = sc_list.GetSize(); 839931180e6SGreg Clayton 84030fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 84130fdc8d8SChris Lattner if (symbols) 842a7499c98SMichael Sartain { 8439df05fbbSSean Callanan symbols->FindFunctions(regex, include_inlines, append, sc_list); 844a7499c98SMichael Sartain 845931180e6SGreg Clayton // Now check our symbol table for symbols that are code symbols if requested 846931180e6SGreg Clayton if (include_symbols) 847931180e6SGreg Clayton { 848a7499c98SMichael Sartain Symtab *symtab = symbols->GetSymtab(); 849931180e6SGreg Clayton if (symtab) 850931180e6SGreg Clayton { 851931180e6SGreg Clayton std::vector<uint32_t> symbol_indexes; 85200049b8bSMatt Kopec symtab->AppendSymbolIndexesMatchingRegExAndType (regex, eSymbolTypeAny, Symtab::eDebugAny, Symtab::eVisibilityAny, symbol_indexes); 853c7bece56SGreg Clayton const size_t num_matches = symbol_indexes.size(); 854931180e6SGreg Clayton if (num_matches) 855931180e6SGreg Clayton { 856931180e6SGreg Clayton SymbolContext sc(this); 857d8cf1a11SGreg Clayton const size_t end_functions_added_index = sc_list.GetSize(); 858d8cf1a11SGreg Clayton size_t num_functions_added_to_sc_list = end_functions_added_index - start_size; 859d8cf1a11SGreg Clayton if (num_functions_added_to_sc_list == 0) 860d8cf1a11SGreg Clayton { 861d8cf1a11SGreg Clayton // No functions were added, just symbols, so we can just append them 862d8cf1a11SGreg Clayton for (size_t i=0; i<num_matches; ++i) 863931180e6SGreg Clayton { 864931180e6SGreg Clayton sc.symbol = symtab->SymbolAtIndex(symbol_indexes[i]); 86500049b8bSMatt Kopec SymbolType sym_type = sc.symbol->GetType(); 86600049b8bSMatt Kopec if (sc.symbol && (sym_type == eSymbolTypeCode || 86700049b8bSMatt Kopec sym_type == eSymbolTypeResolver)) 868d8cf1a11SGreg Clayton sc_list.Append(sc); 869d8cf1a11SGreg Clayton } 870d8cf1a11SGreg Clayton } 871d8cf1a11SGreg Clayton else 872d8cf1a11SGreg Clayton { 873d8cf1a11SGreg Clayton typedef std::map<lldb::addr_t, uint32_t> FileAddrToIndexMap; 874d8cf1a11SGreg Clayton FileAddrToIndexMap file_addr_to_index; 875d8cf1a11SGreg Clayton for (size_t i=start_size; i<end_functions_added_index; ++i) 876d8cf1a11SGreg Clayton { 877d8cf1a11SGreg Clayton const SymbolContext &sc = sc_list[i]; 878d8cf1a11SGreg Clayton if (sc.block) 879d8cf1a11SGreg Clayton continue; 880d8cf1a11SGreg Clayton file_addr_to_index[sc.function->GetAddressRange().GetBaseAddress().GetFileAddress()] = i; 881d8cf1a11SGreg Clayton } 882d8cf1a11SGreg Clayton 883d8cf1a11SGreg Clayton FileAddrToIndexMap::const_iterator end = file_addr_to_index.end(); 884d8cf1a11SGreg Clayton // Functions were added so we need to merge symbols into any 885d8cf1a11SGreg Clayton // existing function symbol contexts 886d8cf1a11SGreg Clayton for (size_t i=start_size; i<num_matches; ++i) 887d8cf1a11SGreg Clayton { 888d8cf1a11SGreg Clayton sc.symbol = symtab->SymbolAtIndex(symbol_indexes[i]); 889d8cf1a11SGreg Clayton SymbolType sym_type = sc.symbol->GetType(); 890358cf1eaSGreg Clayton if (sc.symbol && sc.symbol->ValueIsAddress() && (sym_type == eSymbolTypeCode || sym_type == eSymbolTypeResolver)) 891d8cf1a11SGreg Clayton { 892358cf1eaSGreg Clayton FileAddrToIndexMap::const_iterator pos = file_addr_to_index.find(sc.symbol->GetAddressRef().GetFileAddress()); 893d8cf1a11SGreg Clayton if (pos == end) 894d8cf1a11SGreg Clayton sc_list.Append(sc); 895d8cf1a11SGreg Clayton else 896d8cf1a11SGreg Clayton sc_list[pos->second].symbol = sc.symbol; 897d8cf1a11SGreg Clayton } 898d8cf1a11SGreg Clayton } 899931180e6SGreg Clayton } 900931180e6SGreg Clayton } 901931180e6SGreg Clayton } 902931180e6SGreg Clayton } 903931180e6SGreg Clayton } 904931180e6SGreg Clayton return sc_list.GetSize() - start_size; 90530fdc8d8SChris Lattner } 90630fdc8d8SChris Lattner 907f86248d9SRichard Mitton void 908f86248d9SRichard Mitton Module::FindAddressesForLine (const lldb::TargetSP target_sp, 909f86248d9SRichard Mitton const FileSpec &file, uint32_t line, 910f86248d9SRichard Mitton Function *function, 911f86248d9SRichard Mitton std::vector<Address> &output_local, std::vector<Address> &output_extern) 912f86248d9SRichard Mitton { 913f86248d9SRichard Mitton SearchFilterByModule filter(target_sp, m_file); 914f86248d9SRichard Mitton AddressResolverFileLine resolver(file, line, true); 915f86248d9SRichard Mitton resolver.ResolveAddress (filter); 916f86248d9SRichard Mitton 917f86248d9SRichard Mitton for (size_t n=0;n<resolver.GetNumberOfAddresses();n++) 918f86248d9SRichard Mitton { 919f86248d9SRichard Mitton Address addr = resolver.GetAddressRangeAtIndex(n).GetBaseAddress(); 920f86248d9SRichard Mitton Function *f = addr.CalculateSymbolContextFunction(); 921f86248d9SRichard Mitton if (f && f == function) 922f86248d9SRichard Mitton output_local.push_back (addr); 923f86248d9SRichard Mitton else 924f86248d9SRichard Mitton output_extern.push_back (addr); 925f86248d9SRichard Mitton } 926f86248d9SRichard Mitton } 927f86248d9SRichard Mitton 928c7bece56SGreg Clayton size_t 92984db9105SGreg Clayton Module::FindTypes_Impl (const SymbolContext& sc, 93084db9105SGreg Clayton const ConstString &name, 93199558cc4SGreg Clayton const CompilerDeclContext *parent_decl_ctx, 93284db9105SGreg Clayton bool append, 933c7bece56SGreg Clayton size_t max_matches, 9344069730cSRavitheja Addepally TypeMap& types) 9353504eee8SGreg Clayton { 9363504eee8SGreg Clayton Timer scoped_timer(__PRETTY_FUNCTION__, __PRETTY_FUNCTION__); 9373504eee8SGreg Clayton if (sc.module_sp.get() == NULL || sc.module_sp.get() == this) 9383504eee8SGreg Clayton { 9393504eee8SGreg Clayton SymbolVendor *symbols = GetSymbolVendor (); 9403504eee8SGreg Clayton if (symbols) 94199558cc4SGreg Clayton return symbols->FindTypes(sc, name, parent_decl_ctx, append, max_matches, types); 9423504eee8SGreg Clayton } 9433504eee8SGreg Clayton return 0; 9443504eee8SGreg Clayton } 9453504eee8SGreg Clayton 946c7bece56SGreg Clayton size_t 94784db9105SGreg Clayton Module::FindTypesInNamespace (const SymbolContext& sc, 94884db9105SGreg Clayton const ConstString &type_name, 94999558cc4SGreg Clayton const CompilerDeclContext *parent_decl_ctx, 950c7bece56SGreg Clayton size_t max_matches, 95184db9105SGreg Clayton TypeList& type_list) 9526f3533fbSEnrico Granata { 95384db9105SGreg Clayton const bool append = true; 9544069730cSRavitheja Addepally TypeMap types_map; 9554069730cSRavitheja Addepally size_t num_types = FindTypes_Impl(sc, type_name, parent_decl_ctx, append, max_matches, types_map); 9564069730cSRavitheja Addepally if (num_types > 0) 9574069730cSRavitheja Addepally sc.SortTypeList(types_map, type_list); 9584069730cSRavitheja Addepally return num_types; 9596f3533fbSEnrico Granata } 9606f3533fbSEnrico Granata 961b43165b7SGreg Clayton lldb::TypeSP 962b43165b7SGreg Clayton Module::FindFirstType (const SymbolContext& sc, 963b43165b7SGreg Clayton const ConstString &name, 964b43165b7SGreg Clayton bool exact_match) 965b43165b7SGreg Clayton { 966b43165b7SGreg Clayton TypeList type_list; 967c7bece56SGreg Clayton const size_t num_matches = FindTypes (sc, name, exact_match, 1, type_list); 968b43165b7SGreg Clayton if (num_matches) 969b43165b7SGreg Clayton return type_list.GetTypeAtIndex(0); 970b43165b7SGreg Clayton return TypeSP(); 971b43165b7SGreg Clayton } 972b43165b7SGreg Clayton 973b43165b7SGreg Clayton 974c7bece56SGreg Clayton size_t 97584db9105SGreg Clayton Module::FindTypes (const SymbolContext& sc, 97684db9105SGreg Clayton const ConstString &name, 97784db9105SGreg Clayton bool exact_match, 978c7bece56SGreg Clayton size_t max_matches, 97984db9105SGreg Clayton TypeList& types) 9806f3533fbSEnrico Granata { 981c7bece56SGreg Clayton size_t num_matches = 0; 98284db9105SGreg Clayton const char *type_name_cstr = name.GetCString(); 98384db9105SGreg Clayton std::string type_scope; 98484db9105SGreg Clayton std::string type_basename; 98584db9105SGreg Clayton const bool append = true; 9867bc31332SGreg Clayton TypeClass type_class = eTypeClassAny; 9874069730cSRavitheja Addepally TypeMap typesmap; 9887bc31332SGreg Clayton if (Type::GetTypeScopeAndBasename (type_name_cstr, type_scope, type_basename, type_class)) 98984db9105SGreg Clayton { 99084db9105SGreg Clayton // Check if "name" starts with "::" which means the qualified type starts 99184db9105SGreg Clayton // from the root namespace and implies and exact match. The typenames we 99284db9105SGreg Clayton // get back from clang do not start with "::" so we need to strip this off 993d93c4a33SBruce Mitchener // in order to get the qualified names to match 9946f3533fbSEnrico Granata 99584db9105SGreg Clayton if (type_scope.size() >= 2 && type_scope[0] == ':' && type_scope[1] == ':') 9966f3533fbSEnrico Granata { 99784db9105SGreg Clayton type_scope.erase(0,2); 99884db9105SGreg Clayton exact_match = true; 99984db9105SGreg Clayton } 100084db9105SGreg Clayton ConstString type_basename_const_str (type_basename.c_str()); 10014069730cSRavitheja Addepally if (FindTypes_Impl(sc, type_basename_const_str, NULL, append, max_matches, typesmap)) 100284db9105SGreg Clayton { 10034069730cSRavitheja Addepally typesmap.RemoveMismatchedTypes (type_scope, type_basename, type_class, exact_match); 10044069730cSRavitheja Addepally num_matches = typesmap.GetSize(); 10056f3533fbSEnrico Granata } 100684db9105SGreg Clayton } 100784db9105SGreg Clayton else 100884db9105SGreg Clayton { 100984db9105SGreg Clayton // The type is not in a namespace/class scope, just search for it by basename 10107bc31332SGreg Clayton if (type_class != eTypeClassAny) 10117bc31332SGreg Clayton { 10127bc31332SGreg Clayton // The "type_name_cstr" will have been modified if we have a valid type class 10137bc31332SGreg Clayton // prefix (like "struct", "class", "union", "typedef" etc). 10144069730cSRavitheja Addepally FindTypes_Impl(sc, ConstString(type_name_cstr), NULL, append, max_matches, typesmap); 10154069730cSRavitheja Addepally typesmap.RemoveMismatchedTypes (type_class); 10164069730cSRavitheja Addepally num_matches = typesmap.GetSize(); 10177bc31332SGreg Clayton } 10187bc31332SGreg Clayton else 10197bc31332SGreg Clayton { 10204069730cSRavitheja Addepally num_matches = FindTypes_Impl(sc, name, NULL, append, max_matches, typesmap); 102184db9105SGreg Clayton } 10227bc31332SGreg Clayton } 10234069730cSRavitheja Addepally if (num_matches > 0) 10244069730cSRavitheja Addepally sc.SortTypeList(typesmap, types); 102584db9105SGreg Clayton return num_matches; 10266f3533fbSEnrico Granata } 10276f3533fbSEnrico Granata 102830fdc8d8SChris Lattner SymbolVendor* 1029136dff87SGreg Clayton Module::GetSymbolVendor (bool can_create, lldb_private::Stream *feedback_strm) 103030fdc8d8SChris Lattner { 103188c05f54SGreg Clayton if (m_did_load_symbol_vendor.load() == false) 103288c05f54SGreg Clayton { 103330fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 103488c05f54SGreg Clayton if (m_did_load_symbol_vendor.load() == false && can_create) 103530fdc8d8SChris Lattner { 103630fdc8d8SChris Lattner ObjectFile *obj_file = GetObjectFile (); 103730fdc8d8SChris Lattner if (obj_file != NULL) 103830fdc8d8SChris Lattner { 103930fdc8d8SChris Lattner Timer scoped_timer(__PRETTY_FUNCTION__, __PRETTY_FUNCTION__); 1040136dff87SGreg Clayton m_symfile_ap.reset(SymbolVendor::FindPlugin(shared_from_this(), feedback_strm)); 1041e83e731eSGreg Clayton m_did_load_symbol_vendor = true; 104230fdc8d8SChris Lattner } 104330fdc8d8SChris Lattner } 104488c05f54SGreg Clayton } 104530fdc8d8SChris Lattner return m_symfile_ap.get(); 104630fdc8d8SChris Lattner } 104730fdc8d8SChris Lattner 104830fdc8d8SChris Lattner void 104930fdc8d8SChris Lattner Module::SetFileSpecAndObjectName (const FileSpec &file, const ConstString &object_name) 105030fdc8d8SChris Lattner { 105130fdc8d8SChris Lattner // Container objects whose paths do not specify a file directly can call 105230fdc8d8SChris Lattner // this function to correct the file and object names. 105330fdc8d8SChris Lattner m_file = file; 105430fdc8d8SChris Lattner m_mod_time = file.GetModificationTime(); 105530fdc8d8SChris Lattner m_object_name = object_name; 105630fdc8d8SChris Lattner } 105730fdc8d8SChris Lattner 105830fdc8d8SChris Lattner const ArchSpec& 105930fdc8d8SChris Lattner Module::GetArchitecture () const 106030fdc8d8SChris Lattner { 106130fdc8d8SChris Lattner return m_arch; 106230fdc8d8SChris Lattner } 106330fdc8d8SChris Lattner 1064b5ad4ec7SGreg Clayton std::string 1065b5ad4ec7SGreg Clayton Module::GetSpecificationDescription () const 1066b5ad4ec7SGreg Clayton { 1067b5ad4ec7SGreg Clayton std::string spec(GetFileSpec().GetPath()); 1068b5ad4ec7SGreg Clayton if (m_object_name) 1069b5ad4ec7SGreg Clayton { 1070b5ad4ec7SGreg Clayton spec += '('; 1071b5ad4ec7SGreg Clayton spec += m_object_name.GetCString(); 1072b5ad4ec7SGreg Clayton spec += ')'; 1073b5ad4ec7SGreg Clayton } 1074b5ad4ec7SGreg Clayton return spec; 1075b5ad4ec7SGreg Clayton } 1076b5ad4ec7SGreg Clayton 107730fdc8d8SChris Lattner void 1078c982b3d6SGreg Clayton Module::GetDescription (Stream *s, lldb::DescriptionLevel level) 1079ceb6b139SCaroline Tice { 1080ceb6b139SCaroline Tice Mutex::Locker locker (m_mutex); 1081ceb6b139SCaroline Tice 1082c982b3d6SGreg Clayton if (level >= eDescriptionLevelFull) 1083c982b3d6SGreg Clayton { 1084cfd1acedSGreg Clayton if (m_arch.IsValid()) 108564195a2cSGreg Clayton s->Printf("(%s) ", m_arch.GetArchitectureName()); 1086c982b3d6SGreg Clayton } 1087ceb6b139SCaroline Tice 1088c982b3d6SGreg Clayton if (level == eDescriptionLevelBrief) 1089c982b3d6SGreg Clayton { 1090c982b3d6SGreg Clayton const char *filename = m_file.GetFilename().GetCString(); 1091c982b3d6SGreg Clayton if (filename) 1092c982b3d6SGreg Clayton s->PutCString (filename); 1093c982b3d6SGreg Clayton } 1094c982b3d6SGreg Clayton else 1095c982b3d6SGreg Clayton { 1096cfd1acedSGreg Clayton char path[PATH_MAX]; 1097cfd1acedSGreg Clayton if (m_file.GetPath(path, sizeof(path))) 1098cfd1acedSGreg Clayton s->PutCString(path); 1099c982b3d6SGreg Clayton } 1100cfd1acedSGreg Clayton 1101cfd1acedSGreg Clayton const char *object_name = m_object_name.GetCString(); 1102cfd1acedSGreg Clayton if (object_name) 1103cfd1acedSGreg Clayton s->Printf("(%s)", object_name); 1104ceb6b139SCaroline Tice } 1105ceb6b139SCaroline Tice 1106ceb6b139SCaroline Tice void 1107c982b3d6SGreg Clayton Module::ReportError (const char *format, ...) 1108c982b3d6SGreg Clayton { 1109e38a5eddSGreg Clayton if (format && format[0]) 1110e38a5eddSGreg Clayton { 1111e38a5eddSGreg Clayton StreamString strm; 1112e38a5eddSGreg Clayton strm.PutCString("error: "); 1113e38a5eddSGreg Clayton GetDescription(&strm, lldb::eDescriptionLevelBrief); 11148b35334eSGreg Clayton strm.PutChar (' '); 1115c982b3d6SGreg Clayton va_list args; 1116c982b3d6SGreg Clayton va_start (args, format); 1117e38a5eddSGreg Clayton strm.PrintfVarArg(format, args); 1118c982b3d6SGreg Clayton va_end (args); 1119e38a5eddSGreg Clayton 1120e38a5eddSGreg Clayton const int format_len = strlen(format); 1121e38a5eddSGreg Clayton if (format_len > 0) 1122e38a5eddSGreg Clayton { 1123e38a5eddSGreg Clayton const char last_char = format[format_len-1]; 1124e38a5eddSGreg Clayton if (last_char != '\n' || last_char != '\r') 1125e38a5eddSGreg Clayton strm.EOL(); 1126e38a5eddSGreg Clayton } 1127e38a5eddSGreg Clayton Host::SystemLog (Host::eSystemLogError, "%s", strm.GetString().c_str()); 1128e38a5eddSGreg Clayton 1129e38a5eddSGreg Clayton } 1130e38a5eddSGreg Clayton } 1131e38a5eddSGreg Clayton 11321d60909eSGreg Clayton bool 11331d60909eSGreg Clayton Module::FileHasChanged () const 11341d60909eSGreg Clayton { 11351d60909eSGreg Clayton if (m_file_has_changed == false) 11361d60909eSGreg Clayton m_file_has_changed = (m_file.GetModificationTime() != m_mod_time); 11371d60909eSGreg Clayton return m_file_has_changed; 11381d60909eSGreg Clayton } 11391d60909eSGreg Clayton 1140e38a5eddSGreg Clayton void 1141e38a5eddSGreg Clayton Module::ReportErrorIfModifyDetected (const char *format, ...) 1142e38a5eddSGreg Clayton { 11431d60909eSGreg Clayton if (m_first_file_changed_log == false) 1144e38a5eddSGreg Clayton { 11451d60909eSGreg Clayton if (FileHasChanged ()) 11461d60909eSGreg Clayton { 11471d60909eSGreg Clayton m_first_file_changed_log = true; 1148e38a5eddSGreg Clayton if (format) 1149e38a5eddSGreg Clayton { 1150e38a5eddSGreg Clayton StreamString strm; 1151e38a5eddSGreg Clayton strm.PutCString("error: the object file "); 1152e38a5eddSGreg Clayton GetDescription(&strm, lldb::eDescriptionLevelFull); 1153e38a5eddSGreg Clayton strm.PutCString (" has been modified\n"); 1154e38a5eddSGreg Clayton 1155e38a5eddSGreg Clayton va_list args; 1156e38a5eddSGreg Clayton va_start (args, format); 1157e38a5eddSGreg Clayton strm.PrintfVarArg(format, args); 1158e38a5eddSGreg Clayton va_end (args); 1159e38a5eddSGreg Clayton 1160e38a5eddSGreg Clayton const int format_len = strlen(format); 1161e38a5eddSGreg Clayton if (format_len > 0) 1162e38a5eddSGreg Clayton { 1163e38a5eddSGreg Clayton const char last_char = format[format_len-1]; 1164e38a5eddSGreg Clayton if (last_char != '\n' || last_char != '\r') 1165e38a5eddSGreg Clayton strm.EOL(); 1166e38a5eddSGreg Clayton } 1167e38a5eddSGreg Clayton strm.PutCString("The debug session should be aborted as the original debug information has been overwritten.\n"); 1168e38a5eddSGreg Clayton Host::SystemLog (Host::eSystemLogError, "%s", strm.GetString().c_str()); 1169e38a5eddSGreg Clayton } 1170e38a5eddSGreg Clayton } 1171c982b3d6SGreg Clayton } 11721d60909eSGreg Clayton } 1173c982b3d6SGreg Clayton 1174c982b3d6SGreg Clayton void 1175c982b3d6SGreg Clayton Module::ReportWarning (const char *format, ...) 1176c982b3d6SGreg Clayton { 1177e38a5eddSGreg Clayton if (format && format[0]) 1178e38a5eddSGreg Clayton { 1179e38a5eddSGreg Clayton StreamString strm; 1180e38a5eddSGreg Clayton strm.PutCString("warning: "); 11818b35334eSGreg Clayton GetDescription(&strm, lldb::eDescriptionLevelFull); 11828b35334eSGreg Clayton strm.PutChar (' '); 1183c982b3d6SGreg Clayton 1184c982b3d6SGreg Clayton va_list args; 1185c982b3d6SGreg Clayton va_start (args, format); 1186e38a5eddSGreg Clayton strm.PrintfVarArg(format, args); 1187c982b3d6SGreg Clayton va_end (args); 1188e38a5eddSGreg Clayton 1189e38a5eddSGreg Clayton const int format_len = strlen(format); 1190e38a5eddSGreg Clayton if (format_len > 0) 1191e38a5eddSGreg Clayton { 1192e38a5eddSGreg Clayton const char last_char = format[format_len-1]; 1193e38a5eddSGreg Clayton if (last_char != '\n' || last_char != '\r') 1194e38a5eddSGreg Clayton strm.EOL(); 1195e38a5eddSGreg Clayton } 1196e38a5eddSGreg Clayton Host::SystemLog (Host::eSystemLogWarning, "%s", strm.GetString().c_str()); 1197e38a5eddSGreg Clayton } 1198c982b3d6SGreg Clayton } 1199c982b3d6SGreg Clayton 1200c982b3d6SGreg Clayton void 1201c982b3d6SGreg Clayton Module::LogMessage (Log *log, const char *format, ...) 1202c982b3d6SGreg Clayton { 1203c982b3d6SGreg Clayton if (log) 1204c982b3d6SGreg Clayton { 1205c982b3d6SGreg Clayton StreamString log_message; 12068b35334eSGreg Clayton GetDescription(&log_message, lldb::eDescriptionLevelFull); 1207c982b3d6SGreg Clayton log_message.PutCString (": "); 1208c982b3d6SGreg Clayton va_list args; 1209c982b3d6SGreg Clayton va_start (args, format); 1210c982b3d6SGreg Clayton log_message.PrintfVarArg (format, args); 1211c982b3d6SGreg Clayton va_end (args); 1212c982b3d6SGreg Clayton log->PutCString(log_message.GetString().c_str()); 1213c982b3d6SGreg Clayton } 1214c982b3d6SGreg Clayton } 1215c982b3d6SGreg Clayton 1216d61c0fc0SGreg Clayton void 1217d61c0fc0SGreg Clayton Module::LogMessageVerboseBacktrace (Log *log, const char *format, ...) 1218d61c0fc0SGreg Clayton { 1219d61c0fc0SGreg Clayton if (log) 1220d61c0fc0SGreg Clayton { 1221d61c0fc0SGreg Clayton StreamString log_message; 1222d61c0fc0SGreg Clayton GetDescription(&log_message, lldb::eDescriptionLevelFull); 1223d61c0fc0SGreg Clayton log_message.PutCString (": "); 1224d61c0fc0SGreg Clayton va_list args; 1225d61c0fc0SGreg Clayton va_start (args, format); 1226d61c0fc0SGreg Clayton log_message.PrintfVarArg (format, args); 1227d61c0fc0SGreg Clayton va_end (args); 1228d61c0fc0SGreg Clayton if (log->GetVerbose()) 1229a893d301SZachary Turner { 1230a893d301SZachary Turner std::string back_trace; 1231a893d301SZachary Turner llvm::raw_string_ostream stream(back_trace); 1232a893d301SZachary Turner llvm::sys::PrintStackTrace(stream); 1233a893d301SZachary Turner log_message.PutCString(back_trace.c_str()); 1234a893d301SZachary Turner } 1235d61c0fc0SGreg Clayton log->PutCString(log_message.GetString().c_str()); 1236d61c0fc0SGreg Clayton } 1237d61c0fc0SGreg Clayton } 1238d61c0fc0SGreg Clayton 1239c982b3d6SGreg Clayton void 124030fdc8d8SChris Lattner Module::Dump(Stream *s) 124130fdc8d8SChris Lattner { 124230fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 12438941142aSGreg Clayton //s->Printf("%.*p: ", (int)sizeof(void*) * 2, this); 124430fdc8d8SChris Lattner s->Indent(); 1245b5ad4ec7SGreg Clayton s->Printf("Module %s%s%s%s\n", 1246b5ad4ec7SGreg Clayton m_file.GetPath().c_str(), 124730fdc8d8SChris Lattner m_object_name ? "(" : "", 124830fdc8d8SChris Lattner m_object_name ? m_object_name.GetCString() : "", 124930fdc8d8SChris Lattner m_object_name ? ")" : ""); 125030fdc8d8SChris Lattner 125130fdc8d8SChris Lattner s->IndentMore(); 125230fdc8d8SChris Lattner 1253a7499c98SMichael Sartain ObjectFile *objfile = GetObjectFile (); 125430fdc8d8SChris Lattner if (objfile) 125530fdc8d8SChris Lattner objfile->Dump(s); 125630fdc8d8SChris Lattner 125730fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 125830fdc8d8SChris Lattner if (symbols) 125930fdc8d8SChris Lattner symbols->Dump(s); 126030fdc8d8SChris Lattner 126130fdc8d8SChris Lattner s->IndentLess(); 126230fdc8d8SChris Lattner } 126330fdc8d8SChris Lattner 126430fdc8d8SChris Lattner 126530fdc8d8SChris Lattner TypeList* 126630fdc8d8SChris Lattner Module::GetTypeList () 126730fdc8d8SChris Lattner { 126830fdc8d8SChris Lattner SymbolVendor *symbols = GetSymbolVendor (); 126930fdc8d8SChris Lattner if (symbols) 127030fdc8d8SChris Lattner return &symbols->GetTypeList(); 127130fdc8d8SChris Lattner return NULL; 127230fdc8d8SChris Lattner } 127330fdc8d8SChris Lattner 127430fdc8d8SChris Lattner const ConstString & 127530fdc8d8SChris Lattner Module::GetObjectName() const 127630fdc8d8SChris Lattner { 127730fdc8d8SChris Lattner return m_object_name; 127830fdc8d8SChris Lattner } 127930fdc8d8SChris Lattner 128030fdc8d8SChris Lattner ObjectFile * 128130fdc8d8SChris Lattner Module::GetObjectFile() 128230fdc8d8SChris Lattner { 128388c05f54SGreg Clayton if (m_did_load_objfile.load() == false) 128488c05f54SGreg Clayton { 128530fdc8d8SChris Lattner Mutex::Locker locker (m_mutex); 128688c05f54SGreg Clayton if (m_did_load_objfile.load() == false) 128730fdc8d8SChris Lattner { 128830fdc8d8SChris Lattner Timer scoped_timer(__PRETTY_FUNCTION__, 128930fdc8d8SChris Lattner "Module::GetObjectFile () module = %s", GetFileSpec().GetFilename().AsCString("")); 12905ce9c565SGreg Clayton DataBufferSP data_sp; 12915ce9c565SGreg Clayton lldb::offset_t data_offset = 0; 12922540a8a7SGreg Clayton const lldb::offset_t file_size = m_file.GetByteSize(); 12932540a8a7SGreg Clayton if (file_size > m_object_offset) 12942540a8a7SGreg Clayton { 12952540a8a7SGreg Clayton m_did_load_objfile = true; 1296e72dfb32SGreg Clayton m_objfile_sp = ObjectFile::FindPlugin (shared_from_this(), 1297e72dfb32SGreg Clayton &m_file, 1298e72dfb32SGreg Clayton m_object_offset, 12992540a8a7SGreg Clayton file_size - m_object_offset, 13005ce9c565SGreg Clayton data_sp, 13015ce9c565SGreg Clayton data_offset); 1302593577a1SGreg Clayton if (m_objfile_sp) 1303593577a1SGreg Clayton { 1304593577a1SGreg Clayton // Once we get the object file, update our module with the object file's 1305593577a1SGreg Clayton // architecture since it might differ in vendor/os if some parts were 13065e6f4520SZachary Turner // unknown. But since the matching arch might already be more specific 13075e6f4520SZachary Turner // than the generic COFF architecture, only merge in those values that 13085e6f4520SZachary Turner // overwrite unspecified unknown values. 13095e6f4520SZachary Turner ArchSpec new_arch; 13105e6f4520SZachary Turner m_objfile_sp->GetArchitecture(new_arch); 13115e6f4520SZachary Turner m_arch.MergeFrom(new_arch); 1312593577a1SGreg Clayton } 13130ee56ce6STodd Fiala else 13140ee56ce6STodd Fiala { 13150ee56ce6STodd Fiala ReportError ("failed to load objfile for %s", GetFileSpec().GetPath().c_str()); 13160ee56ce6STodd Fiala } 131730fdc8d8SChris Lattner } 13182540a8a7SGreg Clayton } 131988c05f54SGreg Clayton } 1320762f7135SGreg Clayton return m_objfile_sp.get(); 132130fdc8d8SChris Lattner } 132230fdc8d8SChris Lattner 1323a7499c98SMichael Sartain SectionList * 13243046e668SGreg Clayton Module::GetSectionList() 13253046e668SGreg Clayton { 13263046e668SGreg Clayton // Populate m_unified_sections_ap with sections from objfile. 13273046e668SGreg Clayton if (m_sections_ap.get() == NULL) 13283046e668SGreg Clayton { 13293046e668SGreg Clayton ObjectFile *obj_file = GetObjectFile(); 13303046e668SGreg Clayton if (obj_file) 13313046e668SGreg Clayton obj_file->CreateSections(*GetUnifiedSectionList()); 13323046e668SGreg Clayton } 13333046e668SGreg Clayton return m_sections_ap.get(); 13343046e668SGreg Clayton } 13353046e668SGreg Clayton 133605a09c67SJason Molenda void 133705a09c67SJason Molenda Module::SectionFileAddressesChanged () 133805a09c67SJason Molenda { 133905a09c67SJason Molenda ObjectFile *obj_file = GetObjectFile (); 134005a09c67SJason Molenda if (obj_file) 134105a09c67SJason Molenda obj_file->SectionFileAddressesChanged (); 134205a09c67SJason Molenda SymbolVendor* sym_vendor = GetSymbolVendor(); 134305a09c67SJason Molenda if (sym_vendor) 134405a09c67SJason Molenda sym_vendor->SectionFileAddressesChanged (); 134505a09c67SJason Molenda } 134605a09c67SJason Molenda 13473046e668SGreg Clayton SectionList * 1348a7499c98SMichael Sartain Module::GetUnifiedSectionList() 1349a7499c98SMichael Sartain { 13503046e668SGreg Clayton // Populate m_unified_sections_ap with sections from objfile. 13513046e668SGreg Clayton if (m_sections_ap.get() == NULL) 13523046e668SGreg Clayton m_sections_ap.reset(new SectionList()); 13533046e668SGreg Clayton return m_sections_ap.get(); 1354a7499c98SMichael Sartain } 135530fdc8d8SChris Lattner 135630fdc8d8SChris Lattner const Symbol * 135730fdc8d8SChris Lattner Module::FindFirstSymbolWithNameAndType (const ConstString &name, SymbolType symbol_type) 135830fdc8d8SChris Lattner { 135930fdc8d8SChris Lattner Timer scoped_timer(__PRETTY_FUNCTION__, 136030fdc8d8SChris Lattner "Module::FindFirstSymbolWithNameAndType (name = %s, type = %i)", 136130fdc8d8SChris Lattner name.AsCString(), 136230fdc8d8SChris Lattner symbol_type); 1363a7499c98SMichael Sartain SymbolVendor* sym_vendor = GetSymbolVendor(); 1364a7499c98SMichael Sartain if (sym_vendor) 136530fdc8d8SChris Lattner { 1366a7499c98SMichael Sartain Symtab *symtab = sym_vendor->GetSymtab(); 136730fdc8d8SChris Lattner if (symtab) 1368bcf2cfbdSGreg Clayton return symtab->FindFirstSymbolWithNameAndType (name, symbol_type, Symtab::eDebugAny, Symtab::eVisibilityAny); 136930fdc8d8SChris Lattner } 137030fdc8d8SChris Lattner return NULL; 137130fdc8d8SChris Lattner } 137230fdc8d8SChris Lattner void 137330fdc8d8SChris Lattner Module::SymbolIndicesToSymbolContextList (Symtab *symtab, std::vector<uint32_t> &symbol_indexes, SymbolContextList &sc_list) 137430fdc8d8SChris Lattner { 137530fdc8d8SChris Lattner // No need to protect this call using m_mutex all other method calls are 137630fdc8d8SChris Lattner // already thread safe. 137730fdc8d8SChris Lattner 137830fdc8d8SChris Lattner size_t num_indices = symbol_indexes.size(); 137930fdc8d8SChris Lattner if (num_indices > 0) 138030fdc8d8SChris Lattner { 138130fdc8d8SChris Lattner SymbolContext sc; 138230fdc8d8SChris Lattner CalculateSymbolContext (&sc); 138330fdc8d8SChris Lattner for (size_t i = 0; i < num_indices; i++) 138430fdc8d8SChris Lattner { 138530fdc8d8SChris Lattner sc.symbol = symtab->SymbolAtIndex (symbol_indexes[i]); 138630fdc8d8SChris Lattner if (sc.symbol) 138730fdc8d8SChris Lattner sc_list.Append (sc); 138830fdc8d8SChris Lattner } 138930fdc8d8SChris Lattner } 139030fdc8d8SChris Lattner } 139130fdc8d8SChris Lattner 139230fdc8d8SChris Lattner size_t 1393c1b2ccfdSGreg Clayton Module::FindFunctionSymbols (const ConstString &name, 1394c1b2ccfdSGreg Clayton uint32_t name_type_mask, 1395c1b2ccfdSGreg Clayton SymbolContextList& sc_list) 1396c1b2ccfdSGreg Clayton { 1397c1b2ccfdSGreg Clayton Timer scoped_timer(__PRETTY_FUNCTION__, 1398c1b2ccfdSGreg Clayton "Module::FindSymbolsFunctions (name = %s, mask = 0x%8.8x)", 1399c1b2ccfdSGreg Clayton name.AsCString(), 1400c1b2ccfdSGreg Clayton name_type_mask); 1401a7499c98SMichael Sartain SymbolVendor* sym_vendor = GetSymbolVendor(); 1402a7499c98SMichael Sartain if (sym_vendor) 1403c1b2ccfdSGreg Clayton { 1404a7499c98SMichael Sartain Symtab *symtab = sym_vendor->GetSymtab(); 1405c1b2ccfdSGreg Clayton if (symtab) 1406c1b2ccfdSGreg Clayton return symtab->FindFunctionSymbols (name, name_type_mask, sc_list); 1407c1b2ccfdSGreg Clayton } 1408c1b2ccfdSGreg Clayton return 0; 1409c1b2ccfdSGreg Clayton } 1410c1b2ccfdSGreg Clayton 1411c1b2ccfdSGreg Clayton size_t 1412b96ff33bSSean Callanan Module::FindSymbolsWithNameAndType (const ConstString &name, SymbolType symbol_type, SymbolContextList &sc_list) 141330fdc8d8SChris Lattner { 141430fdc8d8SChris Lattner // No need to protect this call using m_mutex all other method calls are 141530fdc8d8SChris Lattner // already thread safe. 141630fdc8d8SChris Lattner 141730fdc8d8SChris Lattner 141830fdc8d8SChris Lattner Timer scoped_timer(__PRETTY_FUNCTION__, 141930fdc8d8SChris Lattner "Module::FindSymbolsWithNameAndType (name = %s, type = %i)", 142030fdc8d8SChris Lattner name.AsCString(), 142130fdc8d8SChris Lattner symbol_type); 142230fdc8d8SChris Lattner const size_t initial_size = sc_list.GetSize(); 1423a7499c98SMichael Sartain SymbolVendor* sym_vendor = GetSymbolVendor(); 1424a7499c98SMichael Sartain if (sym_vendor) 142530fdc8d8SChris Lattner { 1426a7499c98SMichael Sartain Symtab *symtab = sym_vendor->GetSymtab(); 142730fdc8d8SChris Lattner if (symtab) 142830fdc8d8SChris Lattner { 142930fdc8d8SChris Lattner std::vector<uint32_t> symbol_indexes; 143030fdc8d8SChris Lattner symtab->FindAllSymbolsWithNameAndType (name, symbol_type, symbol_indexes); 143130fdc8d8SChris Lattner SymbolIndicesToSymbolContextList (symtab, symbol_indexes, sc_list); 143230fdc8d8SChris Lattner } 143330fdc8d8SChris Lattner } 143430fdc8d8SChris Lattner return sc_list.GetSize() - initial_size; 143530fdc8d8SChris Lattner } 143630fdc8d8SChris Lattner 143730fdc8d8SChris Lattner size_t 143830fdc8d8SChris Lattner Module::FindSymbolsMatchingRegExAndType (const RegularExpression ®ex, SymbolType symbol_type, SymbolContextList &sc_list) 143930fdc8d8SChris Lattner { 144030fdc8d8SChris Lattner // No need to protect this call using m_mutex all other method calls are 144130fdc8d8SChris Lattner // already thread safe. 144230fdc8d8SChris Lattner 144330fdc8d8SChris Lattner Timer scoped_timer(__PRETTY_FUNCTION__, 144430fdc8d8SChris Lattner "Module::FindSymbolsMatchingRegExAndType (regex = %s, type = %i)", 144530fdc8d8SChris Lattner regex.GetText(), 144630fdc8d8SChris Lattner symbol_type); 144730fdc8d8SChris Lattner const size_t initial_size = sc_list.GetSize(); 1448a7499c98SMichael Sartain SymbolVendor* sym_vendor = GetSymbolVendor(); 1449a7499c98SMichael Sartain if (sym_vendor) 145030fdc8d8SChris Lattner { 1451a7499c98SMichael Sartain Symtab *symtab = sym_vendor->GetSymtab(); 145230fdc8d8SChris Lattner if (symtab) 145330fdc8d8SChris Lattner { 145430fdc8d8SChris Lattner std::vector<uint32_t> symbol_indexes; 1455bcf2cfbdSGreg Clayton symtab->FindAllSymbolsMatchingRexExAndType (regex, symbol_type, Symtab::eDebugAny, Symtab::eVisibilityAny, symbol_indexes); 145630fdc8d8SChris Lattner SymbolIndicesToSymbolContextList (symtab, symbol_indexes, sc_list); 145730fdc8d8SChris Lattner } 145830fdc8d8SChris Lattner } 145930fdc8d8SChris Lattner return sc_list.GetSize() - initial_size; 146030fdc8d8SChris Lattner } 146130fdc8d8SChris Lattner 1462e01e07b6SGreg Clayton void 1463e01e07b6SGreg Clayton Module::SetSymbolFileFileSpec (const FileSpec &file) 1464e01e07b6SGreg Clayton { 146590271672SGreg Clayton if (!file.Exists()) 146690271672SGreg Clayton return; 1467a7499c98SMichael Sartain if (m_symfile_ap) 1468a7499c98SMichael Sartain { 146990271672SGreg Clayton // Remove any sections in the unified section list that come from the current symbol vendor. 14703046e668SGreg Clayton SectionList *section_list = GetSectionList(); 1471a7499c98SMichael Sartain SymbolFile *symbol_file = m_symfile_ap->GetSymbolFile(); 1472a7499c98SMichael Sartain if (section_list && symbol_file) 1473a7499c98SMichael Sartain { 1474a7499c98SMichael Sartain ObjectFile *obj_file = symbol_file->GetObjectFile(); 1475540fbbfaSGreg Clayton // Make sure we have an object file and that the symbol vendor's objfile isn't 1476540fbbfaSGreg Clayton // the same as the module's objfile before we remove any sections for it... 147790271672SGreg Clayton if (obj_file) 147890271672SGreg Clayton { 147990271672SGreg Clayton // Check to make sure we aren't trying to specify the file we already have 148090271672SGreg Clayton if (obj_file->GetFileSpec() == file) 148190271672SGreg Clayton { 148290271672SGreg Clayton // We are being told to add the exact same file that we already have 148390271672SGreg Clayton // we don't have to do anything. 148490271672SGreg Clayton return; 148590271672SGreg Clayton } 1486d00438e8STamas Berghammer 1487d00438e8STamas Berghammer // Cleare the current symtab as we are going to replace it with a new one 1488d00438e8STamas Berghammer obj_file->ClearSymtab(); 148990271672SGreg Clayton 149090271672SGreg Clayton // The symbol file might be a directory bundle ("/tmp/a.out.dSYM") instead 149190271672SGreg Clayton // of a full path to the symbol file within the bundle 149290271672SGreg Clayton // ("/tmp/a.out.dSYM/Contents/Resources/DWARF/a.out"). So we need to check this 149390271672SGreg Clayton 149490271672SGreg Clayton if (file.IsDirectory()) 149590271672SGreg Clayton { 149690271672SGreg Clayton std::string new_path(file.GetPath()); 149790271672SGreg Clayton std::string old_path(obj_file->GetFileSpec().GetPath()); 149890271672SGreg Clayton if (old_path.find(new_path) == 0) 149990271672SGreg Clayton { 150090271672SGreg Clayton // We specified the same bundle as the symbol file that we already have 150190271672SGreg Clayton return; 150290271672SGreg Clayton } 150390271672SGreg Clayton } 150490271672SGreg Clayton 150590271672SGreg Clayton if (obj_file != m_objfile_sp.get()) 1506a7499c98SMichael Sartain { 1507a7499c98SMichael Sartain size_t num_sections = section_list->GetNumSections (0); 1508a7499c98SMichael Sartain for (size_t idx = num_sections; idx > 0; --idx) 1509a7499c98SMichael Sartain { 1510a7499c98SMichael Sartain lldb::SectionSP section_sp (section_list->GetSectionAtIndex (idx - 1)); 1511a7499c98SMichael Sartain if (section_sp->GetObjectFile() == obj_file) 1512a7499c98SMichael Sartain { 15133046e668SGreg Clayton section_list->DeleteSection (idx - 1); 1514a7499c98SMichael Sartain } 1515a7499c98SMichael Sartain } 1516a7499c98SMichael Sartain } 1517a7499c98SMichael Sartain } 1518a7499c98SMichael Sartain } 151990271672SGreg Clayton // Keep all old symbol files around in case there are any lingering type references in 152090271672SGreg Clayton // any SBValue objects that might have been handed out. 152190271672SGreg Clayton m_old_symfiles.push_back(std::move(m_symfile_ap)); 152290271672SGreg Clayton } 1523e01e07b6SGreg Clayton m_symfile_spec = file; 1524e01e07b6SGreg Clayton m_symfile_ap.reset(); 1525e01e07b6SGreg Clayton m_did_load_symbol_vendor = false; 1526e01e07b6SGreg Clayton } 1527e01e07b6SGreg Clayton 15285aee162fSJim Ingham bool 15295aee162fSJim Ingham Module::IsExecutable () 15305aee162fSJim Ingham { 15315aee162fSJim Ingham if (GetObjectFile() == NULL) 15325aee162fSJim Ingham return false; 15335aee162fSJim Ingham else 15345aee162fSJim Ingham return GetObjectFile()->IsExecutable(); 15355aee162fSJim Ingham } 15365aee162fSJim Ingham 15375aee162fSJim Ingham bool 1538b53cb271SJim Ingham Module::IsLoadedInTarget (Target *target) 1539b53cb271SJim Ingham { 1540b53cb271SJim Ingham ObjectFile *obj_file = GetObjectFile(); 1541b53cb271SJim Ingham if (obj_file) 1542b53cb271SJim Ingham { 15433046e668SGreg Clayton SectionList *sections = GetSectionList(); 1544b53cb271SJim Ingham if (sections != NULL) 1545b53cb271SJim Ingham { 1546b53cb271SJim Ingham size_t num_sections = sections->GetSize(); 1547b53cb271SJim Ingham for (size_t sect_idx = 0; sect_idx < num_sections; sect_idx++) 1548b53cb271SJim Ingham { 1549b53cb271SJim Ingham SectionSP section_sp = sections->GetSectionAtIndex(sect_idx); 1550b53cb271SJim Ingham if (section_sp->GetLoadBaseAddress(target) != LLDB_INVALID_ADDRESS) 1551b53cb271SJim Ingham { 1552b53cb271SJim Ingham return true; 1553b53cb271SJim Ingham } 1554b53cb271SJim Ingham } 1555b53cb271SJim Ingham } 1556b53cb271SJim Ingham } 1557b53cb271SJim Ingham return false; 1558b53cb271SJim Ingham } 15591759848bSEnrico Granata 15601759848bSEnrico Granata bool 15619730339bSEnrico Granata Module::LoadScriptingResourceInTarget (Target *target, Error& error, Stream* feedback_stream) 15621759848bSEnrico Granata { 15631759848bSEnrico Granata if (!target) 15641759848bSEnrico Granata { 15651759848bSEnrico Granata error.SetErrorString("invalid destination Target"); 15661759848bSEnrico Granata return false; 15671759848bSEnrico Granata } 15681759848bSEnrico Granata 1569d93c4a33SBruce Mitchener LoadScriptFromSymFile should_load = target->TargetProperties::GetLoadScriptFromSymbolFile(); 15702ea43cdcSEnrico Granata 1571994740fbSGreg Clayton if (should_load == eLoadScriptFromSymFileFalse) 1572994740fbSGreg Clayton return false; 1573994740fbSGreg Clayton 157491c0e749SGreg Clayton Debugger &debugger = target->GetDebugger(); 157591c0e749SGreg Clayton const ScriptLanguage script_language = debugger.GetScriptLanguage(); 157691c0e749SGreg Clayton if (script_language != eScriptLanguageNone) 157791c0e749SGreg Clayton { 157891c0e749SGreg Clayton 15791759848bSEnrico Granata PlatformSP platform_sp(target->GetPlatform()); 15801759848bSEnrico Granata 15811759848bSEnrico Granata if (!platform_sp) 15821759848bSEnrico Granata { 15831759848bSEnrico Granata error.SetErrorString("invalid Platform"); 15841759848bSEnrico Granata return false; 15851759848bSEnrico Granata } 15861759848bSEnrico Granata 158791c0e749SGreg Clayton FileSpecList file_specs = platform_sp->LocateExecutableScriptingResources (target, 1588fe7295dcSEnrico Granata *this, 1589fe7295dcSEnrico Granata feedback_stream); 159091c0e749SGreg Clayton 159191c0e749SGreg Clayton 159291c0e749SGreg Clayton const uint32_t num_specs = file_specs.GetSize(); 159391c0e749SGreg Clayton if (num_specs) 159491c0e749SGreg Clayton { 1595b9d8890bSGreg Clayton ScriptInterpreter *script_interpreter = debugger.GetCommandInterpreter().GetScriptInterpreter(); 1596b9d8890bSGreg Clayton if (script_interpreter) 1597b9d8890bSGreg Clayton { 159891c0e749SGreg Clayton for (uint32_t i=0; i<num_specs; ++i) 159991c0e749SGreg Clayton { 160091c0e749SGreg Clayton FileSpec scripting_fspec (file_specs.GetFileSpecAtIndex(i)); 160191c0e749SGreg Clayton if (scripting_fspec && scripting_fspec.Exists()) 160291c0e749SGreg Clayton { 1603d93c4a33SBruce Mitchener if (should_load == eLoadScriptFromSymFileWarn) 16042ea43cdcSEnrico Granata { 1605397ddd5fSEnrico Granata if (feedback_stream) 1606d516deb4SJim Ingham feedback_stream->Printf("warning: '%s' contains a debug script. To run this script in " 1607d516deb4SJim Ingham "this debug session:\n\n command script import \"%s\"\n\n" 1608d516deb4SJim Ingham "To run all discovered debug scripts in this session:\n\n" 1609d516deb4SJim Ingham " settings set target.load-script-from-symbol-file true\n", 1610d516deb4SJim Ingham GetFileSpec().GetFileNameStrippingExtension().GetCString(), 1611d516deb4SJim Ingham scripting_fspec.GetPath().c_str()); 16122ea43cdcSEnrico Granata return false; 16132ea43cdcSEnrico Granata } 16141759848bSEnrico Granata StreamString scripting_stream; 16151759848bSEnrico Granata scripting_fspec.Dump(&scripting_stream); 1616e0c70f1bSEnrico Granata const bool can_reload = true; 16176a51085eSJim Ingham const bool init_lldb_globals = false; 1618d516deb4SJim Ingham bool did_load = script_interpreter->LoadScriptingModule(scripting_stream.GetData(), 1619d516deb4SJim Ingham can_reload, 1620d516deb4SJim Ingham init_lldb_globals, 1621d516deb4SJim Ingham error); 16221759848bSEnrico Granata if (!did_load) 16231759848bSEnrico Granata return false; 16241759848bSEnrico Granata } 162591c0e749SGreg Clayton } 162691c0e749SGreg Clayton } 16271759848bSEnrico Granata else 16281759848bSEnrico Granata { 16291759848bSEnrico Granata error.SetErrorString("invalid ScriptInterpreter"); 16301759848bSEnrico Granata return false; 16311759848bSEnrico Granata } 16321759848bSEnrico Granata } 1633b9d8890bSGreg Clayton } 16341759848bSEnrico Granata return true; 16351759848bSEnrico Granata } 16361759848bSEnrico Granata 1637b53cb271SJim Ingham bool 16385aee162fSJim Ingham Module::SetArchitecture (const ArchSpec &new_arch) 16395aee162fSJim Ingham { 164064195a2cSGreg Clayton if (!m_arch.IsValid()) 16415aee162fSJim Ingham { 16425aee162fSJim Ingham m_arch = new_arch; 16435aee162fSJim Ingham return true; 16445aee162fSJim Ingham } 1645b6cd5fe9SChaoren Lin return m_arch.IsCompatibleMatch(new_arch); 16465aee162fSJim Ingham } 16475aee162fSJim Ingham 1648c9660546SGreg Clayton bool 1649751caf65SGreg Clayton Module::SetLoadAddress (Target &target, lldb::addr_t value, bool value_is_offset, bool &changed) 1650c9660546SGreg Clayton { 16519e02dacdSSteve Pucci ObjectFile *object_file = GetObjectFile(); 16529e02dacdSSteve Pucci if (object_file) 1653c9660546SGreg Clayton { 1654751caf65SGreg Clayton changed = object_file->SetLoadAddress(target, value, value_is_offset); 16557524e090SGreg Clayton return true; 16567524e090SGreg Clayton } 16577524e090SGreg Clayton else 16587524e090SGreg Clayton { 16597524e090SGreg Clayton changed = false; 1660c9660546SGreg Clayton } 16619e02dacdSSteve Pucci return false; 1662c9660546SGreg Clayton } 1663c9660546SGreg Clayton 1664b9a01b39SGreg Clayton 1665b9a01b39SGreg Clayton bool 1666b9a01b39SGreg Clayton Module::MatchesModuleSpec (const ModuleSpec &module_ref) 1667b9a01b39SGreg Clayton { 1668b9a01b39SGreg Clayton const UUID &uuid = module_ref.GetUUID(); 1669b9a01b39SGreg Clayton 1670b9a01b39SGreg Clayton if (uuid.IsValid()) 1671b9a01b39SGreg Clayton { 1672b9a01b39SGreg Clayton // If the UUID matches, then nothing more needs to match... 1673b9a01b39SGreg Clayton if (uuid == GetUUID()) 1674b9a01b39SGreg Clayton return true; 1675b9a01b39SGreg Clayton else 1676b9a01b39SGreg Clayton return false; 1677b9a01b39SGreg Clayton } 1678b9a01b39SGreg Clayton 1679b9a01b39SGreg Clayton const FileSpec &file_spec = module_ref.GetFileSpec(); 1680b9a01b39SGreg Clayton if (file_spec) 1681b9a01b39SGreg Clayton { 1682980662eeSTamas Berghammer if (!FileSpec::Equal (file_spec, m_file, (bool)file_spec.GetDirectory()) && 1683980662eeSTamas Berghammer !FileSpec::Equal (file_spec, m_platform_file, (bool)file_spec.GetDirectory())) 1684b9a01b39SGreg Clayton return false; 1685b9a01b39SGreg Clayton } 1686b9a01b39SGreg Clayton 1687b9a01b39SGreg Clayton const FileSpec &platform_file_spec = module_ref.GetPlatformFileSpec(); 1688b9a01b39SGreg Clayton if (platform_file_spec) 1689b9a01b39SGreg Clayton { 1690ddd7a2a6SSean Callanan if (!FileSpec::Equal (platform_file_spec, GetPlatformFileSpec (), (bool)platform_file_spec.GetDirectory())) 1691b9a01b39SGreg Clayton return false; 1692b9a01b39SGreg Clayton } 1693b9a01b39SGreg Clayton 1694b9a01b39SGreg Clayton const ArchSpec &arch = module_ref.GetArchitecture(); 1695b9a01b39SGreg Clayton if (arch.IsValid()) 1696b9a01b39SGreg Clayton { 1697bf4b7be6SSean Callanan if (!m_arch.IsCompatibleMatch(arch)) 1698b9a01b39SGreg Clayton return false; 1699b9a01b39SGreg Clayton } 1700b9a01b39SGreg Clayton 1701b9a01b39SGreg Clayton const ConstString &object_name = module_ref.GetObjectName(); 1702b9a01b39SGreg Clayton if (object_name) 1703b9a01b39SGreg Clayton { 1704b9a01b39SGreg Clayton if (object_name != GetObjectName()) 1705b9a01b39SGreg Clayton return false; 1706b9a01b39SGreg Clayton } 1707b9a01b39SGreg Clayton return true; 1708b9a01b39SGreg Clayton } 1709b9a01b39SGreg Clayton 1710d804d285SGreg Clayton bool 1711d804d285SGreg Clayton Module::FindSourceFile (const FileSpec &orig_spec, FileSpec &new_spec) const 1712d804d285SGreg Clayton { 1713d804d285SGreg Clayton Mutex::Locker locker (m_mutex); 1714d804d285SGreg Clayton return m_source_mappings.FindFile (orig_spec, new_spec); 1715d804d285SGreg Clayton } 1716d804d285SGreg Clayton 1717f9be6933SGreg Clayton bool 1718f9be6933SGreg Clayton Module::RemapSourceFile (const char *path, std::string &new_path) const 1719f9be6933SGreg Clayton { 1720f9be6933SGreg Clayton Mutex::Locker locker (m_mutex); 1721f9be6933SGreg Clayton return m_source_mappings.RemapPath(path, new_path); 1722f9be6933SGreg Clayton } 1723f9be6933SGreg Clayton 17243467d80bSEnrico Granata uint32_t 17253467d80bSEnrico Granata Module::GetVersion (uint32_t *versions, uint32_t num_versions) 17263467d80bSEnrico Granata { 17273467d80bSEnrico Granata ObjectFile *obj_file = GetObjectFile(); 17283467d80bSEnrico Granata if (obj_file) 17293467d80bSEnrico Granata return obj_file->GetVersion (versions, num_versions); 17303467d80bSEnrico Granata 17313467d80bSEnrico Granata if (versions && num_versions) 17323467d80bSEnrico Granata { 17333467d80bSEnrico Granata for (uint32_t i=0; i<num_versions; ++i) 1734afcbdb15SEnrico Granata versions[i] = LLDB_INVALID_MODULE_VERSION; 17353467d80bSEnrico Granata } 17363467d80bSEnrico Granata return 0; 17373467d80bSEnrico Granata } 173843fe217bSGreg Clayton 173943fe217bSGreg Clayton void 174043fe217bSGreg Clayton Module::PrepareForFunctionNameLookup (const ConstString &name, 174143fe217bSGreg Clayton uint32_t name_type_mask, 174223b1decbSDawn Perchik LanguageType language, 174343fe217bSGreg Clayton ConstString &lookup_name, 174443fe217bSGreg Clayton uint32_t &lookup_name_type_mask, 174543fe217bSGreg Clayton bool &match_name_after_lookup) 174643fe217bSGreg Clayton { 174743fe217bSGreg Clayton const char *name_cstr = name.GetCString(); 174843fe217bSGreg Clayton lookup_name_type_mask = eFunctionNameTypeNone; 174943fe217bSGreg Clayton match_name_after_lookup = false; 1750fa39bb4aSJim Ingham 1751fa39bb4aSJim Ingham llvm::StringRef basename; 1752fa39bb4aSJim Ingham llvm::StringRef context; 175343fe217bSGreg Clayton 175443fe217bSGreg Clayton if (name_type_mask & eFunctionNameTypeAuto) 175543fe217bSGreg Clayton { 1756aa816b8fSJim Ingham if (CPlusPlusLanguage::IsCPPMangledName (name_cstr)) 175743fe217bSGreg Clayton lookup_name_type_mask = eFunctionNameTypeFull; 175823b1decbSDawn Perchik else if ((language == eLanguageTypeUnknown || 17590e0984eeSJim Ingham Language::LanguageIsObjC(language)) && 1760aa816b8fSJim Ingham ObjCLanguage::IsPossibleObjCMethodName (name_cstr)) 176143fe217bSGreg Clayton lookup_name_type_mask = eFunctionNameTypeFull; 17620e0984eeSJim Ingham else if (Language::LanguageIsC(language)) 176323b1decbSDawn Perchik { 176423b1decbSDawn Perchik lookup_name_type_mask = eFunctionNameTypeFull; 176523b1decbSDawn Perchik } 176643fe217bSGreg Clayton else 176743fe217bSGreg Clayton { 176823b1decbSDawn Perchik if ((language == eLanguageTypeUnknown || 17690e0984eeSJim Ingham Language::LanguageIsObjC(language)) && 1770aa816b8fSJim Ingham ObjCLanguage::IsPossibleObjCSelector(name_cstr)) 177143fe217bSGreg Clayton lookup_name_type_mask |= eFunctionNameTypeSelector; 177243fe217bSGreg Clayton 1773aa816b8fSJim Ingham CPlusPlusLanguage::MethodName cpp_method (name); 1774fa39bb4aSJim Ingham basename = cpp_method.GetBasename(); 17756ecb232bSGreg Clayton if (basename.empty()) 17766ecb232bSGreg Clayton { 1777aa816b8fSJim Ingham if (CPlusPlusLanguage::ExtractContextAndIdentifier (name_cstr, context, basename)) 177843fe217bSGreg Clayton lookup_name_type_mask |= (eFunctionNameTypeMethod | eFunctionNameTypeBase); 1779c3795409SGreg Clayton else 178065b0e763SGreg Clayton lookup_name_type_mask |= eFunctionNameTypeFull; 178143fe217bSGreg Clayton } 17826ecb232bSGreg Clayton else 17836ecb232bSGreg Clayton { 17846ecb232bSGreg Clayton lookup_name_type_mask |= (eFunctionNameTypeMethod | eFunctionNameTypeBase); 17856ecb232bSGreg Clayton } 17866ecb232bSGreg Clayton } 178743fe217bSGreg Clayton } 178843fe217bSGreg Clayton else 178943fe217bSGreg Clayton { 179043fe217bSGreg Clayton lookup_name_type_mask = name_type_mask; 179143fe217bSGreg Clayton if (lookup_name_type_mask & eFunctionNameTypeMethod || name_type_mask & eFunctionNameTypeBase) 179243fe217bSGreg Clayton { 179343fe217bSGreg Clayton // If they've asked for a CPP method or function name and it can't be that, we don't 179443fe217bSGreg Clayton // even need to search for CPP methods or names. 1795aa816b8fSJim Ingham CPlusPlusLanguage::MethodName cpp_method (name); 17966ecb232bSGreg Clayton if (cpp_method.IsValid()) 17976ecb232bSGreg Clayton { 1798fa39bb4aSJim Ingham basename = cpp_method.GetBasename(); 17996ecb232bSGreg Clayton 18006ecb232bSGreg Clayton if (!cpp_method.GetQualifiers().empty()) 18016ecb232bSGreg Clayton { 1802d93c4a33SBruce Mitchener // There is a "const" or other qualifier following the end of the function parens, 18036ecb232bSGreg Clayton // this can't be a eFunctionNameTypeBase 18046ecb232bSGreg Clayton lookup_name_type_mask &= ~(eFunctionNameTypeBase); 18056ecb232bSGreg Clayton if (lookup_name_type_mask == eFunctionNameTypeNone) 18066ecb232bSGreg Clayton return; 18076ecb232bSGreg Clayton } 18086ecb232bSGreg Clayton } 18096ecb232bSGreg Clayton else 18106ecb232bSGreg Clayton { 1811fa39bb4aSJim Ingham // If the CPP method parser didn't manage to chop this up, try to fill in the base name if we can. 1812fa39bb4aSJim Ingham // If a::b::c is passed in, we need to just look up "c", and then we'll filter the result later. 1813aa816b8fSJim Ingham CPlusPlusLanguage::ExtractContextAndIdentifier (name_cstr, context, basename); 181443fe217bSGreg Clayton } 18156ecb232bSGreg Clayton } 181643fe217bSGreg Clayton 181743fe217bSGreg Clayton if (lookup_name_type_mask & eFunctionNameTypeSelector) 181843fe217bSGreg Clayton { 1819aa816b8fSJim Ingham if (!ObjCLanguage::IsPossibleObjCSelector(name_cstr)) 182043fe217bSGreg Clayton { 182143fe217bSGreg Clayton lookup_name_type_mask &= ~(eFunctionNameTypeSelector); 182243fe217bSGreg Clayton if (lookup_name_type_mask == eFunctionNameTypeNone) 182343fe217bSGreg Clayton return; 182443fe217bSGreg Clayton } 182543fe217bSGreg Clayton } 182643fe217bSGreg Clayton } 182743fe217bSGreg Clayton 1828fa39bb4aSJim Ingham if (!basename.empty()) 182943fe217bSGreg Clayton { 183043fe217bSGreg Clayton // The name supplied was a partial C++ path like "a::count". In this case we want to do a 183143fe217bSGreg Clayton // lookup on the basename "count" and then make sure any matching results contain "a::count" 183243fe217bSGreg Clayton // so that it would match "b::a::count" and "a::count". This is why we set "match_name_after_lookup" 183343fe217bSGreg Clayton // to true 1834fa39bb4aSJim Ingham lookup_name.SetString(basename); 183543fe217bSGreg Clayton match_name_after_lookup = true; 183643fe217bSGreg Clayton } 183743fe217bSGreg Clayton else 183843fe217bSGreg Clayton { 183943fe217bSGreg Clayton // The name is already correct, just use the exact name as supplied, and we won't need 184043fe217bSGreg Clayton // to check if any matches contain "name" 184143fe217bSGreg Clayton lookup_name = name; 184243fe217bSGreg Clayton match_name_after_lookup = false; 184343fe217bSGreg Clayton } 184443fe217bSGreg Clayton } 184523f8c95aSGreg Clayton 184623f8c95aSGreg Clayton ModuleSP 184723f8c95aSGreg Clayton Module::CreateJITModule (const lldb::ObjectFileJITDelegateSP &delegate_sp) 184823f8c95aSGreg Clayton { 184923f8c95aSGreg Clayton if (delegate_sp) 185023f8c95aSGreg Clayton { 185123f8c95aSGreg Clayton // Must create a module and place it into a shared pointer before 185223f8c95aSGreg Clayton // we can create an object file since it has a std::weak_ptr back 185323f8c95aSGreg Clayton // to the module, so we need to control the creation carefully in 185423f8c95aSGreg Clayton // this static function 185523f8c95aSGreg Clayton ModuleSP module_sp(new Module()); 185623f8c95aSGreg Clayton module_sp->m_objfile_sp.reset (new ObjectFileJIT (module_sp, delegate_sp)); 185723f8c95aSGreg Clayton if (module_sp->m_objfile_sp) 185823f8c95aSGreg Clayton { 185923f8c95aSGreg Clayton // Once we get the object file, update our module with the object file's 186023f8c95aSGreg Clayton // architecture since it might differ in vendor/os if some parts were 186123f8c95aSGreg Clayton // unknown. 186223f8c95aSGreg Clayton module_sp->m_objfile_sp->GetArchitecture (module_sp->m_arch); 186323f8c95aSGreg Clayton } 186423f8c95aSGreg Clayton return module_sp; 186523f8c95aSGreg Clayton } 186623f8c95aSGreg Clayton return ModuleSP(); 186723f8c95aSGreg Clayton } 186823f8c95aSGreg Clayton 186908928f30SGreg Clayton bool 187008928f30SGreg Clayton Module::GetIsDynamicLinkEditor() 187108928f30SGreg Clayton { 187208928f30SGreg Clayton ObjectFile * obj_file = GetObjectFile (); 187308928f30SGreg Clayton 187408928f30SGreg Clayton if (obj_file) 187508928f30SGreg Clayton return obj_file->GetIsDynamicLinkEditor(); 187608928f30SGreg Clayton 187708928f30SGreg Clayton return false; 187808928f30SGreg Clayton } 1879