58#include "llvm/ADT/STLExtras.h"
59#include "llvm/Support/Compiler.h"
60#include "llvm/Support/DJB.h"
61#include "llvm/Support/FileSystem.h"
62#include "llvm/Support/FormatVariadic.h"
63#include "llvm/Support/JSON.h"
64#include "llvm/Support/Signals.h"
65#include "llvm/Support/raw_ostream.h"
100 if (g_module_collection ==
nullptr)
103 return *g_module_collection;
112 static std::recursive_mutex *g_module_collection_mutex =
nullptr;
113 if (g_module_collection_mutex ==
nullptr)
114 g_module_collection_mutex =
new std::recursive_mutex;
115 return *g_module_collection_mutex;
119 std::lock_guard<std::recursive_mutex> guard(
125 std::lock_guard<std::recursive_mutex> guard(
128 if (idx < modules.size())
140 std::lock_guard<std::recursive_mutex> guard(
147 LLDB_LOGF(log,
"%p Module::Module((%s) '%s%s%s%s')",
148 static_cast<void *
>(
this),
155 auto data_sp = module_spec.
GetData();
158 file_size = data_sp->GetByteSize();
164 module_spec.
GetFileSpec(), 0, file_size, modules_specs, data_sp) == 0)
176 matching_module_spec)) {
178 LLDB_LOGF(log,
"Found local object file but the specs didn't match");
186 if (
auto module_spec_data_sp = module_spec.
GetData()) {
240 const llvm::sys::TimePoint<> &object_mod_time)
249 std::lock_guard<std::recursive_mutex> guard(
256 LLDB_LOGF(log,
"%p Module::Module((%s) '%s%s%s%s')",
257 static_cast<void *
>(
this),
m_arch.GetArchitectureName(),
265 std::lock_guard<std::recursive_mutex> guard(
273 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
276 std::lock_guard<std::recursive_mutex> guard(
279 ModuleCollection::iterator end = modules.end();
280 ModuleCollection::iterator pos = std::find(modules.begin(), end,
this);
286 LLDB_LOGF(log,
"%p Module::~Module((%s) '%s%s%s%s')",
287 static_cast<void *
>(
this),
m_arch.GetArchitectureName(),
302 size_t size_to_read) {
306 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
309 std::shared_ptr<DataBufferHeap> data_sp =
310 std::make_shared<DataBufferHeap>(size_to_read, 0);
312 const size_t bytes_read =
313 process_sp->ReadMemory(header_addr, data_sp->GetBytes(),
314 data_sp->GetByteSize(), readmem_error);
315 if (bytes_read < size_to_read)
316 data_sp->SetByteSize(bytes_read);
317 if (data_sp->GetByteSize() > 0) {
319 header_addr, data_sp);
322 s.
Printf(
"0x%16.16" PRIx64, header_addr);
332 m_arch.MergeFrom(process_sp->GetTarget().GetArchitecture());
337 "unable to find suitable object file plug-in");
341 "unable to read header from memory: %s", readmem_error.
AsCString());
352 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
356 if (obj_file !=
nullptr) {
366 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
371 lldbassert(0 &&
"Attempting to overwrite the existing module UUID");
375llvm::Expected<TypeSystemSP>
386 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
388 if (num_comp_units == 0)
393 for (
size_t cu_idx = 0; cu_idx < num_comp_units; cu_idx++) {
425 s->
Printf(
", Module{%p}",
static_cast<void *
>(
this));
429 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
431 return symbols->GetNumCompileUnits();
436 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
440 if (index < num_comp_units) {
442 cu_sp = symbols->GetCompileUnitAtIndex(index);
448 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
456 const Address &so_addr, lldb::SymbolContextItem resolve_scope,
458 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
459 uint32_t resolved_flags = 0;
469 if (section_sp && section_sp->GetModule().get() ==
this) {
473 resolved_flags |= eSymbolContextModule;
477 return resolved_flags;
481 if (resolve_scope & eSymbolContextCompUnit ||
482 resolve_scope & eSymbolContextFunction ||
483 resolve_scope & eSymbolContextBlock ||
484 resolve_scope & eSymbolContextLineEntry ||
485 resolve_scope & eSymbolContextVariable) {
496 if (resolve_scope & eSymbolContextSymbol &&
497 !(resolved_flags & eSymbolContextSymbol)) {
500 Symbol *matching_symbol =
nullptr;
504 [&matching_symbol](
Symbol *symbol) ->
bool {
505 if (symbol->GetType() != eSymbolTypeInvalid) {
506 matching_symbol = symbol;
511 sc.
symbol = matching_symbol;
512 if (!sc.
symbol && resolve_scope & eSymbolContextFunction &&
513 !(resolved_flags & eSymbolContextFunction)) {
514 bool verify_unique =
false;
519 obj_file->ResolveSymbolForAddress(so_addr, verify_unique);
530 if (symtab_objfile && symtab_objfile->
IsStripped()) {
532 if (symfile_objfile != symtab_objfile) {
534 if (symfile_symtab) {
545 resolved_flags |= eSymbolContextSymbol;
553 if (resolve_scope & eSymbolContextSymbol &&
554 !(resolved_flags & eSymbolContextSymbol) && resolve_tail_call_address &&
556 Address previous_addr = so_addr;
557 previous_addr.
Slide(-1);
559 bool do_resolve_tail_call_address =
false;
561 previous_addr, resolve_scope, sc, do_resolve_tail_call_address);
562 if (flags & eSymbolContextSymbol) {
564 if (sc.
GetAddressRange(eSymbolContextFunction | eSymbolContextSymbol, 0,
565 false, addr_range)) {
576 resolved_flags |= flags;
586 return resolved_flags;
590 const char *file_path, uint32_t line,
bool check_inlines,
594 resolve_scope, sc_list);
598 const FileSpec &file_spec, uint32_t line,
bool check_inlines,
600 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
602 "check_inlines = %s, resolve_scope = 0x%8.8x)",
603 file_spec.
GetPath().c_str(), line,
604 check_inlines ?
"yes" :
"no", resolve_scope);
606 const uint32_t initial_count = sc_list.
GetSize();
611 check_inlines,
false);
613 symbols->ResolveSymbolContext(location_spec, resolve_scope, sc_list);
616 return sc_list.
GetSize() - initial_count;
623 symbols->FindGlobalVariables(name, parent_decl_ctx, max_matches, variables);
638 for (
size_t i = 0; i < num_compile_units; ++i) {
648 FunctionNameType name_type_mask,
650 : m_name(name), m_lookup_name(name), m_language(language) {
651 std::optional<ConstString> basename;
653 std::vector<Language *> languages;
655 std::vector<LanguageType> lang_types;
657 lang_types.push_back(language);
663 languages.push_back(lang);
667 if (name_type_mask & eFunctionNameTypeAuto) {
669 auto info = lang->GetFunctionNameInfo(name);
670 if (info.first != eFunctionNameTypeNone) {
671 m_name_type_mask |= info.first;
672 if (!basename && info.second)
673 basename = info.second;
680 if (m_name_type_mask == eFunctionNameTypeNone)
681 m_name_type_mask = eFunctionNameTypeFull;
684 m_name_type_mask = name_type_mask;
686 auto info = lang->GetFunctionNameInfo(name);
687 if (info.first & m_name_type_mask) {
692 m_name_type_mask &= info.first;
693 basename = info.second;
698 if (name_type_mask & eFunctionNameTypeFull &&
699 info.first != eFunctionNameTypeNone && !basename && info.second) {
700 basename = info.second;
712 m_lookup_name.SetString(*basename);
713 m_match_name_after_lookup =
true;
724 if (
m_name == function_name)
732 const bool function_name_may_be_mangled =
734 ConstString demangled_function_name = function_name;
735 if (function_name_may_be_mangled) {
736 Mangled mangled_function_name(function_name);
744 return language->DemangledNameContainsPath(
m_name, demangled_function_name);
746 llvm::StringRef function_name_ref = demangled_function_name;
747 return function_name_ref.contains(
m_name);
751 size_t start_idx)
const {
754 size_t i = start_idx;
755 while (i < sc_list.
GetSize()) {
775 size_t i = start_idx;
776 while (i < sc_list.
GetSize()) {
784 std::unique_ptr<Language::MethodName> cpp_method =
785 lang->GetMethodName(full_name);
786 if (cpp_method->IsValid()) {
787 if (cpp_method->GetContext().empty()) {
788 if (cpp_method->GetBasename().compare(
m_name) != 0) {
793 std::string qualified_name;
794 llvm::StringRef anon_prefix(
"(anonymous namespace)");
795 if (cpp_method->GetContext() == anon_prefix)
796 qualified_name = cpp_method->GetBasename().str();
798 qualified_name = cpp_method->GetScopeQualifiedName();
799 if (qualified_name !=
m_name.GetCString()) {
817 symbols->FindFunctions(lookup_info, parent_decl_ctx,
822 if (
Symtab *symtab = symbols->GetSymtab()) {
832 FunctionNameType name_type_mask,
835 const size_t old_size = sc_list.
GetSize();
837 FindFunctions(lookup_info, parent_decl_ctx, options, sc_list);
838 if (name_type_mask & eFunctionNameTypeAuto) {
839 const size_t new_size = sc_list.
GetSize();
840 if (old_size < new_size)
841 lookup_info.Prune(sc_list, old_size);
846 FunctionNameType name_type_mask,
847 const ModuleFunctionSearchOptions &options,
848 SymbolContextList &sc_list) {
849 if (compiler_ctx.empty() ||
852 ConstString name = compiler_ctx.back().name;
853 SymbolContextList unfiltered;
854 FindFunctions(name, CompilerDeclContext(), name_type_mask, options,
857 for (
auto &sc : unfiltered)
858 if (sc.function && compiler_ctx.equals(sc.function->GetCompilerContext()))
865 const size_t start_size = sc_list.
GetSize();
873 Symtab *symtab = symbols->GetSymtab();
875 std::vector<uint32_t> symbol_indexes;
879 const size_t num_matches = symbol_indexes.size();
882 const size_t end_functions_added_index = sc_list.
GetSize();
883 size_t num_functions_added_to_sc_list =
884 end_functions_added_index - start_size;
885 if (num_functions_added_to_sc_list == 0) {
888 for (
size_t i = 0; i < num_matches; ++i) {
896 typedef std::map<lldb::addr_t, uint32_t> FileAddrToIndexMap;
897 FileAddrToIndexMap file_addr_to_index;
898 for (
size_t i = start_size; i < end_functions_added_index; ++i) {
906 FileAddrToIndexMap::const_iterator end = file_addr_to_index.end();
909 for (
size_t i = start_size; i < num_matches; ++i) {
915 FileAddrToIndexMap::const_iterator pos =
916 file_addr_to_index.find(
921 sc_list[pos->second].symbol = sc.
symbol;
932 const FileSpec &file, uint32_t line,
934 std::vector<Address> &output_local,
935 std::vector<Address> &output_extern) {
948 if (f && f == function)
949 output_local.push_back(addr);
951 output_extern.push_back(addr);
957 symbols->FindTypes(query, results);
965 if (requestors.empty())
968 for (
auto debugger_sp : requestors) {
969 if (!debugger_sp->InterruptRequested())
971 if (debugger_sp->GetTargetList().AnyTargetContainsModule(module))
972 interruptors.push_back(debugger_sp);
979 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
983 if (!interruptors.empty()) {
984 for (
auto debugger_sp : interruptors) {
986 "Interrupted fetching symbols for module {0}",
987 this->GetFileSpec());
992 if (obj_file !=
nullptr) {
1006 return symbols->GetSymtab(can_create);
1035 s << llvm::formatv(
"({0}) ",
m_arch.GetArchitectureName());
1039 const char *filename =
m_file.GetFilename().GetCString();
1044 if (
m_file.GetPath(path,
sizeof(path)))
1050 s << llvm::formatv(
"({0})", object_name);
1065 std::optional<lldb::user_id_t> debugger_id) {
1072 <<
" was compiled with optimization - stepping may behave "
1073 "oddly; variables may not be available.";
1079 LanguageType language, std::optional<lldb::user_id_t> debugger_id) {
1081 ss <<
"This version of LLDB has no plugin for the language \""
1084 "Inspection of frame variables will be limited.";
1090 const llvm::formatv_object_base &payload) {
1099 strm.
PutCString(
"The debug session should be aborted as the original "
1100 "debug information has been overwritten.");
1110 once_ptr = std::make_unique<std::once_flag>();
1111 return once_ptr.get();
1117 std::string msg = payload.str();
1125 std::string msg = payload.str();
1140 Log *log,
const llvm::formatv_object_base &payload) {
1146 std::string back_trace;
1147 llvm::raw_string_ostream stream(back_trace);
1148 llvm::sys::PrintStackTrace(stream);
1155 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
1158 s->
Printf(
"Module %s%s%s%s\n",
m_file.GetPath().c_str(),
1179 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
1209 ReportError(
"failed to load objfile for {0}\nDebugging will be "
1210 "degraded for this module.",
1223 if (obj_file !=
nullptr)
1234 symbols->SectionFileAddressesChanged();
1252 "Module::FindFirstSymbolWithNameAndType (name = %s, type = %i)",
1255 return symtab->FindFirstSymbolWithNameAndType(
1260 Symtab *symtab, std::vector<uint32_t> &symbol_indexes,
1265 size_t num_indices = symbol_indexes.size();
1266 if (num_indices > 0) {
1269 for (
size_t i = 0; i < num_indices; i++) {
1282 symtab->FindFunctionSymbols(name, name_type_mask, sc_list);
1291 std::vector<uint32_t> symbol_indexes;
1292 symtab->FindAllSymbolsWithNameAndType(name, symbol_type, symbol_indexes);
1303 "Module::FindSymbolsMatchingRegExAndType (regex = %s, type = %i)",
1304 regex.
GetText().str().c_str(), symbol_type);
1306 std::vector<uint32_t> symbol_indexes;
1307 symtab->FindAllSymbolsMatchingRexExAndType(
1309 symbol_indexes, mangling_preference);
1315 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
1323 symtab->PreloadSymbols();
1338 if (section_list && symbol_file) {
1361 std::string new_path(file.
GetPath());
1363 if (llvm::StringRef(old_path).starts_with(new_path)) {
1372 for (
size_t idx = num_sections; idx > 0; --idx) {
1375 if (section_sp->GetObjectFile() == obj_file) {
1402 if (sections !=
nullptr) {
1403 size_t num_sections = sections->
GetSize();
1404 for (
size_t sect_idx = 0; sect_idx < num_sections; sect_idx++) {
1416 Stream &feedback_stream) {
1423 target->TargetProperties::GetLoadScriptFromSymbolFile();
1439 FileSpecList file_specs = platform_sp->LocateExecutableScriptingResources(
1440 target, *
this, feedback_stream);
1442 const uint32_t num_specs = file_specs.
GetSize();
1445 if (script_interpreter) {
1446 for (uint32_t i = 0; i < num_specs; ++i) {
1448 if (scripting_fspec &&
1452 "warning: '%s' contains a debug script. To run this script "
1454 "this debug session:\n\n command script import "
1456 "To run all discovered debug scripts in this session:\n\n"
1457 " settings set target.load-script-from-symbol-file "
1459 GetFileSpec().GetFileNameStrippingExtension().GetCString(),
1460 scripting_fspec.
GetPath().c_str());
1469 target->shared_from_this());
1488 return m_arch.IsCompatibleMatch(new_arch);
1492 bool value_is_offset,
bool &changed) {
1494 if (object_file !=
nullptr) {
1495 changed = object_file->
SetLoadAddress(target, value, value_is_offset);
1522 if (!
m_arch.IsCompatibleMatch(arch))
1536 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
1538 new_spec = *remapped;
1545 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
1547 return remapped->GetPath();
1552 llvm::StringRef sysroot) {
1553 auto sdk_path_or_err =
1554 HostInfo::GetSDKRoot(HostInfo::SDKOptions{sdk_name.str()});
1556 if (!sdk_path_or_err) {
1558 toString(sdk_path_or_err.takeError()));
1562 auto sdk_path = *sdk_path_or_err;
1563 if (sdk_path.empty())
1576 "module has arch %s, merging/replacing with arch %s",
1577 m_arch.GetTriple().getTriple().c_str(),
1578 arch_spec.
GetTriple().getTriple().c_str());
1579 if (!
m_arch.IsCompatibleMatch(arch_spec)) {
1602 return obj_file->GetVersion();
1603 return llvm::VersionTuple();
1616 std::string identifier;
1617 llvm::raw_string_ostream id_strm(identifier);
1618 id_strm <<
m_arch.GetTriple().str() <<
'-' <<
m_file.GetPath();
1626 return llvm::djbHash(identifier);
1631 llvm::raw_string_ostream strm(key);
1632 strm <<
m_arch.GetTriple().str() <<
'-' <<
m_file.GetFilename();
1635 strm <<
'-' << llvm::format_hex(
Hash(), 10);
1646 .GetLLDBIndexCachePath()
1648 return g_data_file_cache;
static llvm::raw_ostream & error(Stream &strm)
static lldb::user_id_t g_unique_id
#define REPORT_INTERRUPTION(debugger,...)
#define LLDB_LOGF(log,...)
std::vector< Module * > ModuleCollection
static ModuleCollection & GetModuleCollection()
static Debugger::DebuggerList DebuggersOwningModuleRequestingInterruption(Module &module)
#define LLDB_SCOPED_TIMER()
#define LLDB_SCOPED_TIMERF(...)
A section + offset based address range class.
Address & GetBaseAddress()
Get accessor for the base address of the range.
lldb::addr_t GetByteSize() const
Get accessor for the byte size of this range.
"lldb/Core/AddressResolverFileLine.h" This class finds address for source file and line.
size_t GetNumberOfAddresses()
virtual void ResolveAddress(SearchFilter &filter)
AddressRange & GetAddressRangeAtIndex(size_t idx)
A section + offset based address class.
bool ResolveAddressUsingFileSections(lldb::addr_t addr, const SectionList *sections)
Resolve a file virtual address using a section list.
lldb::SectionSP GetSection() const
Get const accessor for the section.
Function * CalculateSymbolContextFunction() const
bool Slide(int64_t offset)
lldb::addr_t GetFileAddress() const
Get the file address.
lldb::addr_t GetOffset() const
Get the section relative offset value.
bool IsSectionOffset() const
Check if an address is section offset.
An architecture specification class.
bool IsValid() const
Tests if this ArchSpec is valid.
llvm::Triple & GetTriple()
Architecture triple accessor.
void MergeFrom(const ArchSpec &other)
Merges fields from another ArchSpec into this ArchSpec.
const char * GetArchitectureName() const
Returns a static string representing the current architecture.
const FileSpec & GetPrimaryFile() const
Return the primary source spec associated with this compile unit.
void ForeachFunction(llvm::function_ref< bool(const lldb::FunctionSP &)> lambda) const
Apply a lambda to each function in this compile unit.
Represents a generic declaration context in a program.
A uniqued constant string class.
const char * AsCString(const char *value_if_empty=nullptr) const
Get the string value as a C string.
bool IsEmpty() const
Test for empty string.
This class enables data to be cached into a directory using the llvm caching code.
A class to manage flag bits.
static void ReportWarning(std::string message, std::optional< lldb::user_id_t > debugger_id=std::nullopt, std::once_flag *once=nullptr)
Report warning events.
lldb::ScriptLanguage GetScriptLanguage() const
static void ReportError(std::string message, std::optional< lldb::user_id_t > debugger_id=std::nullopt, std::once_flag *once=nullptr)
Report error events.
ScriptInterpreter * GetScriptInterpreter(bool can_create=true, std::optional< lldb::ScriptLanguage > language={})
std::vector< lldb::DebuggerSP > DebuggerList
static DebuggerList DebuggersRequestingInterruption()
const FileSpec & GetFileSpecAtIndex(size_t idx) const
Get file at index.
size_t GetSize() const
Get the number of files in the file list.
static bool Match(const FileSpec &pattern, const FileSpec &file)
Match FileSpec pattern against FileSpec file.
const ConstString & GetFilename() const
Filename string const get accessor.
size_t GetPath(char *path, size_t max_path_length, bool denormalize=true) const
Extract the full path to the file.
void Dump(llvm::raw_ostream &s) const
Dump this object to a Stream.
uint64_t GetByteSize(const FileSpec &file_spec) const
Returns the on-disk size of the given file in bytes.
llvm::sys::TimePoint GetModificationTime(const FileSpec &file_spec) const
Returns the modification time of the given file.
static FileSystem & Instance()
A class that describes a function.
const Address & GetAddress() const
Return the address of the function (its entry point).
static Language * FindPlugin(lldb::LanguageType language)
static const char * GetNameForLanguageType(lldb::LanguageType language)
void PutCString(const char *cstr)
A class that handles mangled names.
static Mangled::ManglingScheme GetManglingScheme(llvm::StringRef const name)
Try to identify the mangling scheme used.
ConstString GetDemangledName() const
Demangled name get accessor.
static ModuleListProperties & GetGlobalModuleListProperties()
bool FindMatchingModuleSpec(const ModuleSpec &module_spec, ModuleSpec &match_module_spec) const
uint64_t GetObjectOffset() const
ConstString & GetObjectName()
FileSpec & GetPlatformFileSpec()
lldb::DataBufferSP GetData() const
ArchSpec & GetArchitecture()
FileSpec & GetSymbolFileSpec()
llvm::sys::TimePoint & GetObjectModificationTime()
A class that encapsulates name lookup information.
lldb::FunctionNameType GetNameTypeMask() const
ConstString GetLookupName() const
lldb::FunctionNameType m_name_type_mask
One or more bits from lldb::FunctionNameType that indicate what kind of names we are looking for.
bool NameMatchesLookupInfo(ConstString function_name, lldb::LanguageType language_type=lldb::eLanguageTypeUnknown) const
ConstString m_name
What the user originally typed.
void Prune(SymbolContextList &sc_list, size_t start_idx) const
bool m_match_name_after_lookup
If true, then demangled names that match will need to contain "m_name" in order to be considered a ma...
A class that describes an executable image and its associated object and symbol files.
const lldb_private::UUID & GetUUID()
Get a reference to the UUID value contained in this object.
uint32_t ResolveSymbolContextForFilePath(const char *file_path, uint32_t line, bool check_inlines, lldb::SymbolContextItem resolve_scope, SymbolContextList &sc_list)
Resolve items in the symbol context for a given file and line.
std::atomic< bool > m_did_set_uuid
void ReportWarningOptimization(std::optional< lldb::user_id_t > debugger_id)
PathMappingList m_source_mappings
Module specific source remappings for when you have debug info for a module that doesn't match where ...
llvm::sys::TimePoint m_object_mod_time
virtual ObjectFile * GetObjectFile()
Get the object file representation for the current architecture.
void FindGlobalVariables(ConstString name, const CompilerDeclContext &parent_decl_ctx, size_t max_matches, VariableList &variable_list)
Find global and static variables by name.
void ReportWarning(const char *format, Args &&...args)
FileSpec m_file
The file representation on disk for this module (if there is one).
virtual SymbolFile * GetSymbolFile(bool can_create=true, Stream *feedback_strm=nullptr)
Get the module's symbol file.
static DataFileCache * GetIndexCache()
Get the global index file cache.
std::vector< lldb::SymbolVendorUP > m_old_symfiles
If anyone calls Module::SetSymbolFileFileSpec() and changes the symbol file,.
void ReportWarningUnsupportedLanguage(lldb::LanguageType language, std::optional< lldb::user_id_t > debugger_id)
std::once_flag * GetDiagnosticOnceFlag(llvm::StringRef msg)
void FindCompileUnits(const FileSpec &path, SymbolContextList &sc_list)
Find compile units by partial or full path.
ConstString GetObjectName() const
uint32_t Hash()
Get a unique hash for this module.
lldb::ModuleSP CalculateSymbolContextModule() override
static Module * GetAllocatedModuleAtIndex(size_t idx)
std::recursive_mutex m_diagnostic_mutex
UUID m_uuid
Each module is assumed to have a unique identifier to help match it up to debug symbols.
std::optional< std::string > RemapSourceFile(llvm::StringRef path) const
Remaps a source file given path into new_path.
llvm::sys::TimePoint m_mod_time
The modification time for this module when it was created.
lldb::CompUnitSP GetCompileUnitAtIndex(size_t idx)
uint32_t ResolveSymbolContextForAddress(const Address &so_addr, lldb::SymbolContextItem resolve_scope, SymbolContext &sc, bool resolve_tail_call_address=false)
Resolve the symbol context for the given address.
void SetFileSpecAndObjectName(const FileSpec &file, ConstString object_name)
std::recursive_mutex m_mutex
A mutex to keep this object happy in multi-threaded environments.
static std::recursive_mutex & GetAllocationModuleCollectionMutex()
lldb::DataBufferSP m_data_sp
DataBuffer containing the module image, if it was provided at construction time.
bool SetLoadAddress(Target &target, lldb::addr_t value, bool value_is_offset, bool &changed)
Set the load address for all sections in a module to be the file address plus slide.
void SetSymbolFileFileSpec(const FileSpec &file)
void RegisterXcodeSDK(llvm::StringRef sdk, llvm::StringRef sysroot)
This callback will be called by SymbolFile implementations when parsing a compile unit that contains ...
void FindSymbolsWithNameAndType(ConstString name, lldb::SymbolType symbol_type, SymbolContextList &sc_list)
void CalculateSymbolContext(SymbolContext *sc) override
Reconstruct the object's symbol context into sc.
FileSpec m_symfile_spec
If this path is valid, then this is the file that will be used as the symbol file for this module.
StatsDuration m_symtab_index_time
We store a symbol named index time duration here because we might have an object file and a symbol fi...
bool ResolveFileAddress(lldb::addr_t vm_addr, Address &so_addr)
ArchSpec m_arch
The architecture for this module.
void ReportError(const char *format, Args &&...args)
const FileSpec & GetPlatformFileSpec() const
Get accessor for the module platform file specification.
lldb::SymbolVendorUP m_symfile_up
A pointer to the symbol vendor for this module.
const Symbol * FindFirstSymbolWithNameAndType(ConstString name, lldb::SymbolType symbol_type=lldb::eSymbolTypeAny)
Find a symbol in the object file's symbol table.
llvm::DenseMap< llvm::stable_hash, std::unique_ptr< std::once_flag > > m_shown_diagnostics
A set of hashes of all warnings and errors, to avoid reporting them multiple times to the same Debugg...
Module(const FileSpec &file_spec, const ArchSpec &arch, ConstString object_name=ConstString(), lldb::offset_t object_offset=0, const llvm::sys::TimePoint<> &object_mod_time=llvm::sys::TimePoint<>())
Construct with file specification and architecture.
llvm::VersionTuple GetVersion()
void FindAddressesForLine(const lldb::TargetSP target_sp, const FileSpec &file, uint32_t line, Function *function, std::vector< Address > &output_local, std::vector< Address > &output_extern)
Find addresses by file/line.
void FindFunctions(const LookupInfo &lookup_info, const CompilerDeclContext &parent_decl_ctx, const ModuleFunctionSearchOptions &options, SymbolContextList &sc_list)
Find functions by lookup info.
void DumpSymbolContext(Stream *s) override
Dump the object's symbol context to the stream s.
void FindFunctionSymbols(ConstString name, uint32_t name_type_mask, SymbolContextList &sc_list)
Find a function symbols in the object file's symbol table.
Symtab * GetSymtab(bool can_create=true)
Get the module's symbol table.
size_t GetNumCompileUnits()
Get the number of compile units for this module.
ConstString m_object_name
The name an object within this module that is selected, or empty of the module is represented by m_fi...
void LogMessage(Log *log, const char *format, Args &&...args)
bool MatchesModuleSpec(const ModuleSpec &module_ref)
~Module() override
Destructor.
static size_t GetNumberAllocatedModules()
ObjectFile * GetMemoryObjectFile(const lldb::ProcessSP &process_sp, lldb::addr_t header_addr, Status &error, size_t size_to_read=512)
Load an object file from memory.
bool LoadScriptingResourceInTarget(Target *target, Status &error, Stream &feedback_stream)
TypeSystemMap m_type_system_map
A map of any type systems associated with this module.
void ForEachTypeSystem(llvm::function_ref< bool(lldb::TypeSystemSP)> callback)
Call callback for each TypeSystem in this Module.
lldb::SectionListUP m_sections_up
Unified section list for module that is used by the ObjectFile and ObjectFile instances for the debug...
bool IsExecutable()
Tells whether this module is capable of being the main executable for a process.
FileSpec m_platform_file
The path to the module on the platform on which it is being debugged.
bool MergeArchitecture(const ArchSpec &arch_spec)
Update the ArchSpec to a more specific variant.
bool FileHasChanged() const
const ArchSpec & GetArchitecture() const
Get const accessor for the module architecture.
void LogMessageVerboseBacktrace(Log *log, const char *format, Args &&...args)
bool GetIsDynamicLinkEditor()
std::string GetCacheKey()
Get a unique cache key for the current module.
virtual SectionList * GetSectionList()
Get the unified section list for the module.
llvm::Expected< lldb::TypeSystemSP > GetTypeSystemForLanguage(lldb::LanguageType language)
void Dump(Stream *s)
Dump a description of this object to a Stream.
uint32_t ResolveSymbolContextsForFileSpec(const FileSpec &file_spec, uint32_t line, bool check_inlines, lldb::SymbolContextItem resolve_scope, SymbolContextList &sc_list)
Resolve items in the symbol context for a given file and line.
lldb::ObjectFileSP m_objfile_sp
A shared pointer to the object file parser for this module as it may or may not be shared with the Sy...
void ReportErrorIfModifyDetected(const char *format, Args &&...args)
void FindSymbolsMatchingRegExAndType(const RegularExpression ®ex, lldb::SymbolType symbol_type, SymbolContextList &sc_list, Mangled::NamePreference mangling_preference=Mangled::ePreferDemangled)
std::atomic< bool > m_did_load_symfile
UnwindTable & GetUnwindTable()
Returns a reference to the UnwindTable for this Module.
std::string GetSpecificationDescription() const
Get the module path and object name.
UnwindTable m_unwind_table
Table of FuncUnwinders objects created for this Module's functions.
const FileSpec & GetFileSpec() const
Get const accessor for the module file specification.
bool IsLoadedInTarget(Target *target)
Tells whether this module has been loaded in the target passed in.
void GetDescription(llvm::raw_ostream &s, lldb::DescriptionLevel level=lldb::eDescriptionLevelFull)
void SetUUID(const lldb_private::UUID &uuid)
bool m_first_file_changed_log
void SymbolIndicesToSymbolContextList(Symtab *symtab, std::vector< uint32_t > &symbol_indexes, SymbolContextList &sc_list)
const llvm::sys::TimePoint & GetModificationTime() const
virtual void SectionFileAddressesChanged()
Notify the module that the file addresses for the Sections have been updated.
std::atomic< bool > m_did_load_objfile
bool FindSourceFile(const FileSpec &orig_spec, FileSpec &new_spec) const
Finds a source file given a file spec using the module source path remappings (if any).
void FindTypes(const TypeQuery &query, TypeResults &results)
Find types using a type-matching object that contains all search parameters.
bool SetArchitecture(const ArchSpec &new_arch)
SectionList * GetUnifiedSectionList()
StatsDuration m_symtab_parse_time
See if the module was modified after it was initially opened.
void ParseAllDebugSymbols()
A debugging function that will cause everything in a module to be parsed.
static lldb::ObjectFileSP FindPlugin(const lldb::ModuleSP &module_sp, const FileSpec *file_spec, lldb::offset_t file_offset, lldb::offset_t file_size, lldb::DataBufferSP &data_sp, lldb::offset_t &data_offset)
Find a ObjectFile plug-in that can parse file_spec.
virtual bool SetLoadAddress(Target &target, lldb::addr_t value, bool value_is_offset)
Sets the load address for an entire module, assuming a rigid slide of sections, if possible in the im...
virtual void Dump(Stream *s)=0
Dump a description of this object to a Stream.
virtual bool IsStripped()=0
Detect if this object file has been stripped of local symbols.
Symtab * GetSymtab(bool can_create=true)
Gets the symbol table for the currently selected architecture (and object for archives).
virtual bool IsExecutable() const =0
Tells whether this object file is capable of being the main executable for a process.
virtual void ClearSymtab()
Frees the symbol table.
virtual FileSpec & GetFileSpec()
Get accessor to the object file specification.
virtual void CreateSections(SectionList &unified_section_list)=0
virtual void SectionFileAddressesChanged()
Notify the ObjectFile that the file addresses in the Sections for this module have been changed.
virtual UUID GetUUID()=0
Gets the UUID for this object file.
virtual bool GetIsDynamicLinkEditor()
Return true if this file is a dynamic link editor (dyld)
static size_t GetModuleSpecifications(const FileSpec &file, lldb::offset_t file_offset, lldb::offset_t file_size, ModuleSpecList &specs, lldb::DataBufferSP data_sp=lldb::DataBufferSP())
llvm::StringRef GetText() const
Access the regular expression text.
virtual bool LoadScriptingModule(const char *filename, const LoadScriptOptions &options, lldb_private::Status &error, StructuredData::ObjectSP *module_sp=nullptr, FileSpec extra_search_dir={}, lldb::TargetSP loaded_into_target_sp={})
This is a SearchFilter that restricts the search to a given module.
size_t GetNumSections(uint32_t depth) const
bool DeleteSection(size_t idx)
lldb::SectionSP GetSectionAtIndex(size_t idx) const
"lldb/Core/SourceLocationSpec.h" A source location specifier class.
static Status FromErrorStringWithFormat(const char *format,...) __attribute__((format(printf
static Status FromErrorString(const char *str)
const char * AsCString(const char *default_error_str="unknown error") const
Get the error string associated with the current error.
const char * GetData() const
llvm::StringRef GetString() const
A stream class that can stream formatted output to a file.
llvm::raw_ostream & AsRawOstream()
Returns a raw_ostream that forwards the data to this Stream object.
size_t Indent(llvm::StringRef s="")
Indent the current line in the stream.
size_t Printf(const char *format,...) __attribute__((format(printf
Output printf formatted output to the stream.
size_t PutCString(llvm::StringRef cstr)
Output a C string to the stream.
void IndentLess(unsigned amount=2)
Decrement the current indentation level.
void IndentMore(unsigned amount=2)
Increment the current indentation level.
Defines a list of symbol context objects.
bool GetContextAtIndex(size_t idx, SymbolContext &sc) const
Get accessor for a symbol context at index idx.
uint32_t GetSize() const
Get accessor for a symbol context list size.
bool RemoveContextAtIndex(size_t idx)
void Append(const SymbolContext &sc)
Append a new symbol context to the list.
Defines a symbol context baton that can be handed other debug core functions.
lldb::LanguageType GetLanguage() const
Function * function
The Function for a given query.
ConstString GetFunctionName(Mangled::NamePreference preference=Mangled::ePreferDemangled) const
Find a name of the innermost function for the symbol context.
Block * block
The Block for a given query.
lldb::ModuleSP module_sp
The Module for a given query.
CompileUnit * comp_unit
The CompileUnit for a given query.
void Clear(bool clear_target)
Clear the object's state.
bool GetAddressRange(uint32_t scope, uint32_t range_idx, bool use_inline_block_range, AddressRange &range) const
Get the address range contained within a symbol context.
Symbol * symbol
The Symbol for a given query.
lldb::TargetSP target_sp
The Target for a given query.
LineEntry line_entry
The LineEntry for a given query.
virtual size_t ParseTypes(CompileUnit &comp_unit)=0
virtual void SetLoadDebugInfoEnabled()
Specify debug info should be loaded.
virtual void PreloadSymbols()
virtual void FindGlobalVariables(ConstString name, const CompilerDeclContext &parent_decl_ctx, uint32_t max_matches, VariableList &variables)
virtual Symtab * GetSymtab(bool can_create=true)=0
virtual size_t ParseFunctions(CompileUnit &comp_unit)=0
virtual size_t ParseBlocksRecursive(Function &func)=0
virtual lldb::CompUnitSP GetCompileUnitAtIndex(uint32_t idx)=0
virtual size_t ParseVariablesForContext(const SymbolContext &sc)=0
virtual ObjectFile * GetObjectFile()=0
virtual void ResetStatistics()
Reset the statistics for the symbol file.
virtual uint32_t ResolveSymbolContext(const Address &so_addr, lldb::SymbolContextItem resolve_scope, SymbolContext &sc)=0
static void DownloadSymbolFileAsync(const UUID &uuid)
Locate the symbol file for the given UUID on a background thread.
static SymbolVendor * FindPlugin(const lldb::ModuleSP &module_sp, Stream *feedback_strm)
bool ValueIsAddress() const
Address & GetAddressRef()
lldb::SymbolType GetType() const
Symbol * SymbolAtIndex(size_t idx)
void ForEachSymbolContainingFileAddress(lldb::addr_t file_addr, std::function< bool(Symbol *)> const &callback)
Symbol * FindSymbolContainingFileAddress(lldb::addr_t file_addr)
ObjectFile * GetObjectFile() const
uint32_t AppendSymbolIndexesMatchingRegExAndType(const RegularExpression ®ex, lldb::SymbolType symbol_type, std::vector< uint32_t > &indexes, Mangled::NamePreference name_preference=Mangled::ePreferDemangled)
Debugger & GetDebugger() const
lldb::PlatformSP GetPlatform()
A class that contains all state required for type lookups.
This class tracks the state and results of a TypeQuery.
Represents UUID's of various sizes.
#define LLDB_INVALID_ADDRESS
A class that represents a running process on the host machine.
Log * GetLog(Cat mask)
Retrieve the Log object for the channel associated with the given log enum.
@ eLoadScriptFromSymFileFalse
@ eLoadScriptFromSymFileWarn
const char * toString(AppleArm64ExceptionClass EC)
std::shared_ptr< lldb_private::Function > FunctionSP
ScriptLanguage
Script interpreter types.
std::shared_ptr< lldb_private::TypeSystem > TypeSystemSP
DescriptionLevel
Description levels for "void GetDescription(Stream *, DescriptionLevel)" calls.
std::shared_ptr< lldb_private::Platform > PlatformSP
LanguageType
Programming language type.
@ eLanguageTypeUnknown
Unknown or invalid language value.
@ eLanguageTypeObjC
Objective-C.
@ eLanguageTypeC_plus_plus
ISO C++:1998.
std::shared_ptr< lldb_private::Process > ProcessSP
std::shared_ptr< lldb_private::Section > SectionSP
std::shared_ptr< lldb_private::Target > TargetSP
std::shared_ptr< lldb_private::Module > ModuleSP
std::shared_ptr< lldb_private::CompileUnit > CompUnitSP
bool IsValid() const
Check if a line entry object is valid.
void ApplyFileMappings(lldb::TargetSP target_sp)
Apply file mappings from target.source-map to the LineEntry's file.
Options used by Module::FindFunctions.
bool include_inlines
Include inlined functions.
bool include_symbols
Include the symbol table.
UserID(lldb::user_id_t uid=LLDB_INVALID_UID)
Construct with optional user ID.