56#include "llvm/ADT/STLExtras.h"
57#include "llvm/Support/Compiler.h"
58#include "llvm/Support/DJB.h"
59#include "llvm/Support/FileSystem.h"
60#include "llvm/Support/FormatVariadic.h"
61#include "llvm/Support/JSON.h"
62#include "llvm/Support/MemoryBuffer.h"
63#include "llvm/Support/Signals.h"
64#include "llvm/Support/VirtualFileSystem.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(
146 LLDB_LOGF(log,
"%p Module::Module((%s) '%s%s%s%s')",
147 static_cast<void *
>(
this),
157 file_size = extractor_sp->GetByteSize();
162 module_spec.
GetFileSpec(), 0, file_size, extractor_sp);
163 if (modules_specs.
GetSize() == 0)
175 matching_module_spec)) {
176 LLDB_LOGF(log,
"Found local object file but the specs didn't match");
183 if (
auto module_spec_extractor_sp = module_spec.
GetExtractor()) {
237 const llvm::sys::TimePoint<> &object_mod_time)
246 std::lock_guard<std::recursive_mutex> guard(
252 LLDB_LOGF(log,
"%p Module::Module((%s) '%s')",
static_cast<void *
>(
this),
253 m_arch.GetArchitectureName(),
260 std::lock_guard<std::recursive_mutex> guard(
268 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
271 std::lock_guard<std::recursive_mutex> guard(
274 ModuleCollection::iterator end = modules.end();
275 ModuleCollection::iterator pos = std::find(modules.begin(), end,
this);
280 LLDB_LOGF(log,
"%p Module::~Module((%s) '%s')",
static_cast<void *
>(
this),
281 m_arch.GetArchitectureName(),
295 size_t size_to_read) {
299 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
302 std::shared_ptr<DataBufferHeap> data_sp =
303 std::make_shared<DataBufferHeap>(size_to_read, 0);
305 const size_t bytes_read =
306 process_sp->ReadMemory(header_addr, data_sp->GetBytes(),
307 data_sp->GetByteSize(), readmem_error);
308 if (bytes_read < size_to_read)
309 data_sp->SetByteSize(bytes_read);
310 if (data_sp->GetByteSize() > 0) {
312 header_addr, data_sp);
323 m_arch.MergeFrom(process_sp->GetTarget().GetArchitecture());
328 "unable to find suitable object file plug-in");
332 "unable to read header from memory: %s", readmem_error.
AsCString());
343 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
347 if (obj_file !=
nullptr) {
356llvm::Expected<TypeSystemSP>
368 size_t num_comp_units = symbols ? symbols->GetNumCompileUnits() : 0;
369 if (num_comp_units == 0)
372 for (
size_t cu_idx = 0; cu_idx < num_comp_units; cu_idx++) {
375 sc.
comp_unit = symbols->GetCompileUnitAtIndex(cu_idx).
get();
379 symbols->ParseVariablesForContext(sc);
384 symbols->ParseBlocksRecursive(*f);
388 symbols->ParseVariablesForContext(sc);
404 s->
Printf(
", Module{%p}",
static_cast<void *
>(
this));
409 return symbols->GetNumCompileUnits();
414 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
418 if (index < num_comp_units) {
420 cu_sp = symbols->GetCompileUnitAtIndex(index);
433 const Address &so_addr, lldb::SymbolContextItem resolve_scope,
435 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
436 uint32_t resolved_flags = 0;
446 if (section_sp && section_sp->GetModule().get() ==
this) {
450 resolved_flags |= eSymbolContextModule;
454 return resolved_flags;
458 if (resolve_scope & eSymbolContextCompUnit ||
459 resolve_scope & eSymbolContextFunction ||
460 resolve_scope & eSymbolContextBlock ||
461 resolve_scope & eSymbolContextLineEntry ||
462 resolve_scope & eSymbolContextVariable) {
473 if (resolve_scope & eSymbolContextSymbol &&
474 !(resolved_flags & eSymbolContextSymbol)) {
477 Symbol *matching_symbol =
nullptr;
480 Symbol *symbol_at_address =
482 if (symbol_at_address &&
484 matching_symbol = symbol_at_address;
487 file_address, [&matching_symbol](
Symbol *symbol) ->
bool {
489 matching_symbol = symbol;
496 sc.
symbol = matching_symbol;
506 if (symtab_objfile && symtab_objfile->
IsStripped()) {
508 if (symfile_objfile != symtab_objfile) {
510 if (symfile_symtab) {
521 resolved_flags |= eSymbolContextSymbol;
529 if (resolve_scope & eSymbolContextSymbol &&
530 !(resolved_flags & eSymbolContextSymbol) && resolve_tail_call_address &&
532 Address previous_addr = so_addr;
533 previous_addr.
Slide(-1);
535 bool do_resolve_tail_call_address =
false;
537 previous_addr, resolve_scope, sc, do_resolve_tail_call_address);
538 if (flags & eSymbolContextSymbol) {
540 if (sc.
GetAddressRange(eSymbolContextFunction | eSymbolContextSymbol, 0,
541 false, addr_range)) {
552 resolved_flags |= flags;
562 return resolved_flags;
566 const char *file_path, uint32_t line,
bool check_inlines,
570 resolve_scope, sc_list);
574 const FileSpec &file_spec, uint32_t line,
bool check_inlines,
576 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
578 "check_inlines = %s, resolve_scope = 0x%8.8x)",
579 file_spec.
GetPath().c_str(), line,
580 check_inlines ?
"yes" :
"no", resolve_scope);
582 const uint32_t initial_count = sc_list.
GetSize();
587 check_inlines,
false);
589 symbols->ResolveSymbolContext(location_spec, resolve_scope, sc_list);
592 return sc_list.
GetSize() - initial_count;
599 symbols->FindGlobalVariables(name, parent_decl_ctx, max_matches, variables);
614 for (
size_t i = 0; i < num_compile_units; ++i) {
630 FunctionNameType name_type_mask,
632 : m_name(name), m_lookup_name(lookup_name), m_language(lang_type) {
633 std::optional<ConstString> basename;
636 if (name_type_mask & eFunctionNameTypeAuto) {
639 if (info.first != eFunctionNameTypeNone) {
641 if (!basename && info.second)
642 basename = info.second;
662 basename = info.second;
663 }
else if (name_type_mask & eFunctionNameTypeFull &&
664 info.first != eFunctionNameTypeNone && !basename &&
668 basename = info.second;
685 ConstString name, lldb::FunctionNameType name_type_mask,
687 std::vector<LanguageType> lang_types;
689 lang_types.push_back(lang_type);
695 if (!llvm::is_contained(lang_types, lang_type))
696 lang_types.push_back(lang_type);
700 if (lang_types.empty())
704 ConstString lookup_name = lookup_name_override ? lookup_name_override : name;
706 std::vector<Module::LookupInfo> infos;
707 infos.reserve(lang_types.size());
710 infos.push_back(info);
722 if (
m_name == function_name)
730 const bool function_name_may_be_mangled =
732 ConstString demangled_function_name = function_name;
733 if (function_name_may_be_mangled) {
734 Mangled mangled_function_name(function_name);
742 return language->DemangledNameContainsPath(
m_name, demangled_function_name);
744 llvm::StringRef function_name_ref = demangled_function_name;
745 return function_name_ref.contains(
m_name);
749 size_t start_idx)
const {
752 size_t i = start_idx;
753 while (i < sc_list.
GetSize()) {
773 size_t i = start_idx;
774 while (i < sc_list.
GetSize()) {
782 std::unique_ptr<Language::MethodName> cpp_method =
784 if (cpp_method->IsValid()) {
785 if (cpp_method->GetContext().empty()) {
786 if (cpp_method->GetBasename().compare(
m_name) != 0) {
791 std::string qualified_name;
792 llvm::StringRef anon_prefix(
"(anonymous namespace)");
793 if (cpp_method->GetContext() == anon_prefix)
794 qualified_name = cpp_method->GetBasename().str();
796 qualified_name = cpp_method->GetScopeQualifiedName();
797 if (qualified_name !=
m_name.GetCString()) {
813 for (
auto &lookup_info : lookup_infos) {
822 symtab->FindFunctionSymbols(lookup_info.GetLookupName(),
823 lookup_info.GetNameTypeMask(), sc_list);
829 FunctionNameType name_type_mask,
832 std::vector<LookupInfo> lookup_infos =
834 for (
auto &lookup_info : lookup_infos) {
835 const size_t old_size = sc_list.
GetSize();
836 FindFunctions(lookup_info, parent_decl_ctx, options, sc_list);
837 if (name_type_mask & eFunctionNameTypeAuto) {
838 const size_t new_size = sc_list.
GetSize();
839 if (old_size < new_size)
840 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();
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(
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);
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) {
1040 s << llvm::formatv(
"({0}) ",
m_arch.GetArchitectureName());
1044 const char *filename =
m_file.GetFilename().GetCString();
1049 if (
m_file.GetPath(path,
sizeof(path)))
1055 s << llvm::formatv(
"({0})", object_name);
1072 std::optional<lldb::user_id_t> debugger_id) {
1079 <<
" was compiled with optimization - stepping may behave "
1080 "oddly; variables may not be available";
1086 LanguageType language, std::optional<lldb::user_id_t> debugger_id) {
1088 ss <<
"this version of LLDB has no plugin for the language \""
1091 "Inspection of frame variables will be limited";
1097 const llvm::formatv_object_base &payload) {
1106 strm.
PutCString(
"The debug session should be aborted as the original "
1107 "debug information has been overwritten.");
1117 once_ptr = std::make_unique<std::once_flag>();
1118 return once_ptr.get();
1124 std::string msg = payload.str();
1132 std::string msg = payload.str();
1147 Log *log,
const llvm::formatv_object_base &payload) {
1153 std::string back_trace;
1154 llvm::raw_string_ostream stream(back_trace);
1155 llvm::sys::PrintStackTrace(stream);
1162 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
1183 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
1213 ReportError(
"failed to load objfile for {0}\nDebugging will be "
1214 "degraded for this module.",
1227 if (obj_file !=
nullptr)
1274 "Module::FindFirstSymbolWithNameAndType (name = %s, type = %i)",
1277 return symtab->FindFirstSymbolWithNameAndType(
1282 Symtab *symtab, std::vector<uint32_t> &symbol_indexes,
1287 size_t num_indices = symbol_indexes.size();
1288 if (num_indices > 0) {
1291 for (
size_t i = 0; i < num_indices; i++) {
1304 symtab->FindFunctionSymbols(name, name_type_mask, sc_list);
1313 std::vector<uint32_t> symbol_indexes;
1314 symtab->FindAllSymbolsWithNameAndType(name, symbol_type, symbol_indexes);
1325 "Module::FindSymbolsMatchingRegExAndType (regex = %s, type = %i)",
1326 regex.
GetText().str().c_str(), symbol_type);
1328 std::vector<uint32_t> symbol_indexes;
1329 symtab->FindAllSymbolsMatchingRexExAndType(
1331 symbol_indexes, mangling_preference);
1343 if (
Symtab *symtab = sym_file->GetSymtab())
1344 symtab->PreloadSymbols();
1348 sym_file->PreloadSymbols();
1359 if (section_list && symbol_file) {
1382 std::string new_path(file.
GetPath());
1384 if (llvm::StringRef(old_path).starts_with(new_path)) {
1393 for (
size_t idx = num_sections; idx > 0; --idx) {
1396 if (section_sp->GetObjectFile() == obj_file) {
1423 if (sections !=
nullptr) {
1424 size_t num_sections = sections->
GetSize();
1425 for (
size_t sect_idx = 0; sect_idx < num_sections; sect_idx++) {
1441 return m_arch.IsCompatibleMatch(new_arch);
1445 bool value_is_offset,
bool &changed) {
1447 if (object_file !=
nullptr) {
1448 changed = object_file->
SetLoadAddress(target, value, value_is_offset);
1475 if (!
m_arch.IsCompatibleMatch(arch))
1488 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
1491 new_spec = *remapped;
1498 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
1508 llvm::vfs::FileSystem &vfs = *llvm::vfs::getRealFileSystem();
1511 llvm::DenseSet<ConstString> searched;
1513 for (
FileSpec current(start_cs.GetStringRef());;) {
1515 if (!searched.insert(directory_cs).second)
1519 llvm::ErrorOr<std::unique_ptr<llvm::vfs::File>> file =
1520 vfs.openFileForRead(map_file.
GetPath());
1521 if (file && *file) {
1522 LLDB_LOG(log,
"found compilation-prefix-map.json at {0}",
1524 llvm::ErrorOr<std::unique_ptr<llvm::MemoryBuffer>> buf =
1525 (*file)->getBuffer(map_file.
GetPath());
1527 llvm::Expected<llvm::json::Value> val =
1528 llvm::json::parse((*buf)->getBuffer());
1534 if (llvm::json::Object *obj = val->getAsObject()) {
1535 for (
const llvm::json::Object::value_type &kv : *obj)
1536 if (std::optional<llvm::StringRef> to = kv.second.getAsString()) {
1537 LLDB_LOG(log,
"applying prefix map: '{0}' -> '{1}'", kv.first,
1548 if (parent == current)
1557 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
1560 return remapped->GetPath();
1565 llvm::StringRef sysroot) {
1566 Progress progress(
"Looking for Xcode SDK", sdk_name.str());
1567 auto sdk_path_or_err =
1568 HostInfo::GetSDKRoot(HostInfo::SDKOptions{sdk_name.str()});
1570 if (!sdk_path_or_err) {
1572 toString(sdk_path_or_err.takeError()),
1578 auto sdk_path = *sdk_path_or_err;
1579 if (sdk_path.empty())
1592 "module has arch %s, merging/replacing with arch %s",
1593 m_arch.GetTriple().getTriple().c_str(),
1594 arch_spec.
GetTriple().getTriple().c_str());
1595 if (!
m_arch.IsCompatibleMatch(arch_spec)) {
1618 return obj_file->GetVersion();
1619 return llvm::VersionTuple();
1632 std::string identifier;
1633 llvm::raw_string_ostream id_strm(identifier);
1634 id_strm <<
m_arch.GetTriple().str() <<
'-' <<
m_file.GetPath();
1642 return llvm::djbHash(identifier);
1647 llvm::raw_string_ostream strm(key);
1648 strm <<
m_arch.GetTriple().str() <<
'-' <<
m_file.GetFilename();
1651 strm <<
'-' << llvm::format_hex(
Hash(), 10);
1662 .GetLLDBIndexCachePath()
1664 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_LOG(log,...)
The LLDB_LOG* macros defined below are the way to emit log messages.
#define LLDB_LOGF(log,...)
#define LLDB_LOG_ERROR(log, error,...)
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.
bool IsEmpty() const
Test for empty string.
const char * AsCString(const char *value_if_empty) const
Get the string value as a C string.
This class enables data to be cached into a directory using the llvm caching code.
static void ReportWarning(std::string message, std::optional< lldb::user_id_t > debugger_id=std::nullopt, std::once_flag *once=nullptr)
Report warning events.
static void ReportError(std::string message, std::optional< lldb::user_id_t > debugger_id=std::nullopt, std::once_flag *once=nullptr)
Report error events.
std::vector< lldb::DebuggerSP > DebuggerList
static DebuggerList DebuggersRequestingInterruption()
void AppendPathComponent(llvm::StringRef component)
static bool Match(const FileSpec &pattern, const FileSpec &file)
Match FileSpec pattern against FileSpec file.
const ConstString & GetFilename() const
Filename string const get accessor.
bool RemoveLastPathComponent()
Removes the last path component by replacing the current path with its parent.
size_t GetPath(char *path, size_t max_path_length, bool denormalize=true) const
Extract the full path to the file.
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 void ForEach(llvm::function_ref< IterationAction(Language *)> callback)
static Language * FindPlugin(lldb::LanguageType language)
static const char * GetNameForLanguageType(lldb::LanguageType language)
Returns the internal LLDB name for the specified language.
virtual std::unique_ptr< Language::MethodName > GetMethodName(ConstString name) const
virtual lldb::LanguageType GetLanguageType() const =0
virtual std::pair< lldb::FunctionNameType, std::optional< ConstString > > GetFunctionNameInfo(ConstString name) const
void PutCString(const char *cstr)
A class that handles mangled names.
ConstString GetDemangledName() const
Demangled name get accessor.
static Mangled::ManglingScheme GetManglingScheme(llvm::StringRef name)
Try to identify the mangling scheme used.
static ModuleListProperties & GetGlobalModuleListProperties()
bool FindMatchingModuleSpec(const ModuleSpec &module_spec, ModuleSpec &match_module_spec) const
uint64_t GetObjectOffset() const
ConstString & GetObjectName()
FileSpec & GetPlatformFileSpec()
ArchSpec & GetArchitecture()
FileSpec & GetSymbolFileSpec()
llvm::sys::TimePoint & GetObjectModificationTime()
lldb::DataExtractorSP GetExtractor() const
A class that encapsulates name lookup information.
lldb::FunctionNameType GetNameTypeMask() const
lldb::LanguageType GetLanguageType() const
ConstString m_lookup_name
The actual name will lookup when calling in the object or symbol file.
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
lldb::LanguageType m_language
Limit matches to only be for this language.
ConstString m_name
What the user originally typed.
ConstString GetName() const
static std::vector< LookupInfo > MakeLookupInfos(ConstString name, lldb::FunctionNameType name_type_mask, lldb::LanguageType lang_type, ConstString lookup_name_override={})
Creates a vector of lookup infos for function name resolution.
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::optional< std::string > RemapSourceFile(llvm::StringRef path)
Remaps a source file given path into new_path.
std::recursive_mutex m_diagnostic_mutex
bool FindSourceFile(const FileSpec &orig_spec, FileSpec &new_spec)
Finds a source file given a file spec using the module source path remappings (if any).
void FindFunctions(llvm::ArrayRef< LookupInfo > lookup_infos, const CompilerDeclContext &parent_decl_ctx, const ModuleFunctionSearchOptions &options, SymbolContextList &sc_list)
Find functions by a vector of lookup infos.
UUID m_uuid
Each module is assumed to have a unique identifier to help match it up to debug symbols.
llvm::sys::TimePoint m_mod_time
The modification time for this module when it was created.
lldb::CompUnitSP GetCompileUnitAtIndex(size_t idx)
LockedPtr< SectionList > GetSectionListLocked()
Like GetSectionList, but the returned handle holds the Module mutex for its lifetime.
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()
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 AddPrefixMapSearchDir(FileSpec dir)
Register a directory to be searched for compilation-prefix-map.json on the first call to RemapSourceF...
void FindSymbolsWithNameAndType(ConstString name, lldb::SymbolType symbol_type, SymbolContextList &sc_list)
void CalculateSymbolContext(SymbolContext *sc) override
Reconstruct the object's symbol context into sc.
LockedPtr< Symtab > GetSymtabLocked(bool can_create=true)
Like GetSymtab, but the returned handle holds the Module mutex for its lifetime.
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.
std::optional< lldb::addr_t > m_memory_module_addr
For a Module read from memory, the address it was read from.
lldb::DataExtractorSP m_extractor_sp
DataExtractor containing the module image, if it was provided at construction time.
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 LoadPrefixMapsIfNeeded()
Search each registered directory upward for compilation-prefix-map.json and apply any found mappings ...
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.
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.
LockedPtr< SymbolFile > GetSymbolFileLocked(bool can_create=true, Stream *feedback_strm=nullptr)
Like GetSymbolFile, but the returned handle holds the Module mutex for its lifetime.
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)
bool m_first_file_changed_log
void SymbolIndicesToSymbolContextList(Symtab *symtab, std::vector< uint32_t > &symbol_indexes, SymbolContextList &sc_list)
llvm::DenseSet< ConstString > m_prefix_map_search_dirs
Directories registered via AddPrefixMapSearchDir, searched lazily on the first call to RemapSourceFil...
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
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.
LockedPtr< ObjectFile > GetObjectFileLocked()
Like GetObjectFile, but the returned handle holds the Module mutex for its lifetime,...
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.
static lldb::ObjectFileSP FindPlugin(const lldb::ModuleSP &module_sp, const FileSpec *file_spec, lldb::offset_t file_offset, lldb::offset_t file_size, lldb::DataExtractorSP extractor_sp, lldb::offset_t &data_offset)
Find a ObjectFile plug-in that can parse file_spec.
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.
static ModuleSpecList GetModuleSpecifications(const FileSpec &file, lldb::offset_t file_offset, lldb::offset_t file_size, lldb::DataExtractorSP=lldb::DataExtractorSP())
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)
A Progress indicator helper class.
llvm::StringRef GetText() const
Access the regular expression text.
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.
void SetSymbolAtIndex(size_t idx, Symbol *symbol)
Replace the symbol in the symbol context at index idx.
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 void SectionFileAddressesChanged()=0
Notify the SymbolFile that the file addresses in the Sections for this module have been changed.
virtual void SetLoadDebugInfoEnabled()
Specify debug info should be loaded.
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 void FindTypes(const TypeQuery &query, TypeResults &results)
Find types using a type-matching object that contains all search parameters.
virtual void FindFunctions(const Module::LookupInfo &lookup_info, const CompilerDeclContext &parent_decl_ctx, bool include_inlines, SymbolContextList &sc_list)
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
virtual void Dump(Stream &s)=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 * FindSymbolAtFileAddress(lldb::addr_t file_addr)
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)
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.
Locked< T *, Mutex > LockedPtr
Exclusive (write) access aliases.
std::string toString(FormatterBytecode::OpCodes op)
std::shared_ptr< lldb_private::Function > FunctionSP
std::shared_ptr< lldb_private::TypeSystem > TypeSystemSP
DescriptionLevel
Description levels for "void GetDescription(Stream *, DescriptionLevel)" calls.
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::DataExtractor > DataExtractorSP
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.