71#include "llvm/ADT/ScopeExit.h"
72#include "llvm/ADT/SetVector.h"
73#include "llvm/Support/ErrorExtras.h"
74#include "llvm/Support/ThreadPool.h"
86struct ExecutableInstaller {
89 : m_platform{platform}, m_module{module},
90 m_local_file{m_module->GetFileSpec()},
91 m_remote_file{m_module->GetRemoteInstallFileSpec()} {}
93 void setupRemoteFile()
const { m_module->SetPlatformFileSpec(m_remote_file); }
97 const FileSpec m_local_file;
98 const FileSpec m_remote_file;
101struct MainExecutableInstaller {
104 ProcessLaunchInfo &launch_info)
105 : m_platform{platform}, m_module{module},
106 m_local_file{m_module->GetFileSpec()},
108 getRemoteFileSpec(m_platform, target, m_module, m_local_file)},
109 m_launch_info{launch_info} {}
111 void setupRemoteFile()
const {
112 m_module->SetPlatformFileSpec(m_remote_file);
115 m_platform->SetFilePermissions(m_remote_file, 0700 );
120 const FileSpec m_local_file;
121 const FileSpec m_remote_file;
126 const FileSpec &local_file) {
127 FileSpec remote_file =
module->GetRemoteInstallFileSpec();
128 if (remote_file || !target->GetAutoInstallMainExecutable())
134 remote_file = platform->GetRemoteWorkingDirectory();
140 ProcessLaunchInfo &m_launch_info;
146template <
typename Installer>
148 if (!installer.m_local_file || !installer.m_remote_file)
151 Status error = installer.m_platform->Install(installer.m_local_file,
152 installer.m_remote_file);
156 installer.setupRemoteFile();
171 static constexpr llvm::StringLiteral class_name(
"lldb.target");
203 static_cast<void *
>(
this));
206 "Target::Target created with architecture {0} ({1})",
208 target_arch.
GetTriple().getTriple().c_str());
216 LLDB_LOG(log,
"{0} Target::~Target()",
static_cast<void *
>(
this));
226 if (breakpoint_sp->IsInternal())
271 std::unique_lock<std::recursive_mutex> lock;
302 llvm::StringRef plugin_name,
309 listener_sp, crash_file, can_connect);
316 const char *repl_options,
bool can_create) {
324 language = *single_lang;
325 }
else if (repl_languages.
Empty()) {
327 "LLDB isn't configured with REPL support for any languages.");
331 "Multiple possible REPL languages. Please specify a language.");
336 REPLMap::iterator pos =
m_repl_map.find(language);
344 "Couldn't find an existing REPL for %s, and can't create a new one",
359 "Couldn't create a REPL for %s",
373 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
380 const bool notify =
false;
404 return abi_sp->GetPluginName();
437 shared_lib_filter.
Append(main_module_sp->GetFileSpec());
438 llvm::SetVector<std::string, std::vector<std::string>,
439 std::unordered_set<std::string>>
448 if (!entryPointName.empty())
449 entryPointNamesSet.insert(entryPointName);
451 if (entryPointNamesSet.empty()) {
457 nullptr, entryPointNamesSet.takeVector(),
458 eFunctionNameTypeFull,
468 bp_sp->SetOneShot(
true);
475 const std::unordered_set<std::string> &function_names,
479 containingModules, source_file_spec_list));
483 nullptr, std::move(source_regex), function_names,
484 !
static_cast<bool>(move_to_nearest_code)));
490 const FileSpec &file, uint32_t line_no,
493 LazyBool skip_prologue,
bool internal,
497 std::optional<llvm::StringRef> removed_prefix_opt =
499 if (!removed_prefix_opt)
500 remapped_file = file;
504 switch (inline_strategy) {
525 compile_unit_list.
Append(remapped_file);
538 !
static_cast<bool>(move_to_nearest_code));
543 nullptr, offset, skip_prologue, location_spec, removed_prefix_opt));
570 std::make_shared<SearchFilterForUnconstrainedSearches>(
573 std::make_shared<BreakpointResolverAddress>(
nullptr, addr);
580 bool request_hardware) {
582 std::make_shared<SearchFilterForUnconstrainedSearches>(
585 std::make_shared<BreakpointResolverAddress>(
nullptr, file_addr,
593 const FileSpecList *containingSourceFiles,
const char *func_name,
594 FunctionNameType func_name_type_mask,
LanguageType language,
596 bool internal,
bool hardware) {
600 containingModules, containingSourceFiles));
609 offset, offset_is_insn_count, skip_prologue));
618 const std::vector<std::string> &func_names,
619 FunctionNameType func_name_type_mask,
621 LazyBool skip_prologue,
bool internal,
bool hardware) {
623 size_t num_names = func_names.size();
626 containingModules, containingSourceFiles));
634 new BreakpointResolverName(
nullptr, func_names, func_name_type_mask,
635 language, offset, skip_prologue));
644 const char *func_names[],
size_t num_names,
645 FunctionNameType func_name_type_mask,
647 LazyBool skip_prologue,
bool internal,
bool hardware) {
651 containingModules, containingSourceFiles));
663 nullptr, func_names, num_names, func_name_type_mask, language, offset,
665 resolver_sp->SetOffset(offset);
674 if (containingModule !=
nullptr) {
677 filter_sp = std::make_shared<SearchFilterByModule>(shared_from_this(),
682 std::make_shared<SearchFilterForUnconstrainedSearches>(
692 if (containingModules && containingModules->
GetSize() != 0) {
695 filter_sp = std::make_shared<SearchFilterByModuleList>(shared_from_this(),
700 std::make_shared<SearchFilterForUnconstrainedSearches>(
710 if (containingSourceFiles ==
nullptr || containingSourceFiles->
GetSize() == 0)
714 if (containingModules ==
nullptr) {
718 filter_sp = std::make_shared<SearchFilterByModuleListAndCU>(
719 shared_from_this(),
FileSpecList(), *containingSourceFiles);
721 filter_sp = std::make_shared<SearchFilterByModuleListAndCU>(
722 shared_from_this(), *containingModules, *containingSourceFiles);
731 bool internal,
bool hardware) {
733 containingModules, containingSourceFiles));
736 :
static_cast<bool>(skip_prologue);
738 nullptr, std::move(func_regex), requested_language, 0,
skip));
745 bool catch_bp,
bool throw_bp,
bool internal,
748 *
this, language, catch_bp, throw_bp, internal);
749 if (exc_bkpt_sp && additional_args) {
751 if (precondition_sp && additional_args) {
753 *
error = precondition_sp->ConfigurePrecondition(*additional_args);
755 precondition_sp->ConfigurePrecondition(*additional_args);
762 const llvm::StringRef class_name,
const FileSpecList *containingModules,
763 const FileSpecList *containingSourceFiles,
bool internal,
770 containingSourceFiles && containingSourceFiles->
GetSize() > 0;
771 bool has_modules = containingModules && containingModules->
GetSize() > 0;
773 if (has_files && has_modules) {
775 containingSourceFiles);
776 }
else if (has_files) {
779 }
else if (has_modules) {
782 filter_sp = std::make_shared<SearchFilterForUnconstrainedSearches>(
793 bool internal,
bool request_hardware,
794 bool resolve_indirect_symbols) {
796 if (filter_sp && resolver_sp) {
798 bp_sp.reset(
new Breakpoint(*
this, filter_sp, resolver_sp, hardware,
799 resolve_indirect_symbols));
800 resolver_sp->SetBreakpoint(bp_sp);
818 LLDB_LOGF(log,
"Target::%s (internal = %s) => break_id = %s\n",
819 __FUNCTION__, bp_sp->IsInternal() ?
"yes" :
"no", s.
GetData());
822 bp_sp->ResolveBreakpoint();
853 bp_sp->AddName(name);
858 std::make_pair(bp_name->GetName(), std::move(bp_name)));
864 if (!
error.Success())
869 return iter->second.get();
874 "Breakpoint name \"%s\" doesn't exist and "
875 "can_create is false.",
881 .insert(std::make_pair(name, std::make_unique<BreakpointName>(name)))
882 .first->second.get();
889 const char *name_cstr = name.
AsCString();
892 bp_sp->RemoveName(name_cstr);
910 llvm::Expected<std::vector<BreakpointSP>> expected_vector =
913 if (!expected_vector) {
915 llvm::toString(expected_vector.takeError()));
919 for (
auto bp_sp : *expected_vector)
926 names.push_back(bp_name_entry.first.AsCString());
936 std::optional<uint32_t> num_supported_hardware_watchpoints =
941 if (!num_supported_hardware_watchpoints)
944 if (*num_supported_hardware_watchpoints == 0) {
946 "Target supports (%u) hardware watchpoint slots.\n",
947 *num_supported_hardware_watchpoints);
960 "Target::%s (addr = 0x%8.8" PRIx64
" size = %" PRIu64
962 __FUNCTION__, addr, (uint64_t)size, kind);
973 "cannot set a watchpoint with watch_size of 0");
976 "invalid watch address: %" PRIu64, addr);
992 const bool notify =
false;
997 addr = abi->FixDataAddress(addr);
1011 std::unique_lock<std::recursive_mutex> lock;
1015 size_t old_size = matched_sp->GetByteSize();
1021 if (size == old_size && kind == old_type) {
1023 wp_sp->SetEnabled(
false, notify);
1032 wp_sp = std::make_shared<Watchpoint>(*
this, addr, size, type);
1033 wp_sp->SetWatchpointType(kind, notify);
1038 LLDB_LOGF(log,
"Target::%s (creation of watchpoint %s with id = %u)\n",
1039 __FUNCTION__,
error.Success() ?
"succeeded" :
"failed",
1054 LLDB_LOGF(log,
"Target::%s \n", __FUNCTION__);
1063 LLDB_LOGF(log,
"Target::%s (internal_also = %s)\n", __FUNCTION__,
1064 internal_also ?
"yes" :
"no");
1075 LLDB_LOGF(log,
"Target::%s (internal_also = %s)\n", __FUNCTION__,
1076 internal_also ?
"yes" :
"no");
1085 LLDB_LOGF(log,
"Target::%s", __FUNCTION__);
1092 LLDB_LOGF(log,
"Target::%s (internal_also = %s)\n", __FUNCTION__,
1093 internal_also ?
"yes" :
"no");
1102 LLDB_LOGF(log,
"Target::%s", __FUNCTION__);
1109 LLDB_LOGF(log,
"Target::%s (break_id = %i, internal = %s)\n", __FUNCTION__,
1129 LLDB_LOGF(log,
"Target::%s (break_id = %i, internal = %s)\n", __FUNCTION__,
1139 bp_sp->SetEnabled(
false);
1147 LLDB_LOGF(log,
"Target::%s (break_id = %i, internal = %s)\n", __FUNCTION__,
1158 bp_sp->SetEnabled(
true);
1178 std::string path(file.
GetPath());
1186 if (
error.Success()) {
1187 break_store_ptr = input_data_sp->GetAsArray();
1188 if (!break_store_ptr) {
1190 "Tried to append to invalid input file %s", path.c_str());
1196 if (!break_store_ptr) {
1197 break_store_sp = std::make_shared<StructuredData::Array>();
1198 break_store_ptr = break_store_sp.get();
1205 lldb::eFilePermissionsFileDefault);
1212 std::unique_lock<std::recursive_mutex> lock;
1218 size_t num_breakpoints = breakpoints.
GetSize();
1219 for (
size_t i = 0; i < num_breakpoints; i++) {
1224 break_store_ptr->
AddItem(bkpt_save_sp);
1228 std::unordered_set<lldb::break_id_t> processed_bkpts;
1229 const size_t count = bp_ids.
GetSize();
1230 for (
size_t i = 0; i < count; ++i) {
1236 std::pair<std::unordered_set<lldb::break_id_t>::iterator,
bool>
1237 insert_result = processed_bkpts.insert(bp_id);
1238 if (!insert_result.second)
1245 if (!bkpt_save_sp) {
1247 "Unable to serialize breakpoint %d", bp_id);
1250 break_store_ptr->
AddItem(bkpt_save_sp);
1255 break_store_ptr->
Dump(out_file,
false);
1262 std::vector<std::string> no_names;
1267 std::vector<std::string> &names,
1269 std::unique_lock<std::recursive_mutex> lock;
1275 if (!
error.Success()) {
1277 }
else if (!input_data_sp || !input_data_sp->IsValid()) {
1279 "Invalid JSON from input file: %s.", file.
GetPath().c_str());
1286 "Invalid breakpoint data from input file: %s.", file.
GetPath().c_str());
1290 size_t num_bkpts = bkpt_array->
GetSize();
1291 size_t num_names = names.size();
1293 for (
size_t i = 0; i < num_bkpts; i++) {
1299 "Invalid breakpoint data for element %zu from input file: %s.", i,
1310 shared_from_this(), bkpt_data_sp,
error);
1311 if (!
error.Success()) {
1313 "Error restoring breakpoint %zu from %s: %s.", i,
1329 LLDB_LOGF(log,
"Target::%s\n", __FUNCTION__);
1358 LLDB_LOGF(log,
"Target::%s\n", __FUNCTION__);
1385 LLDB_LOGF(log,
"Target::%s\n", __FUNCTION__);
1411 LLDB_LOGF(log,
"Target::%s\n", __FUNCTION__);
1417 wp_sp->ResetHitCount();
1425 LLDB_LOGF(log,
"Target::%s\n", __FUNCTION__);
1431 wp_sp->ResetHistoricValues();
1440 LLDB_LOGF(log,
"Target::%s\n", __FUNCTION__);
1449 wp_sp->SetIgnoreCount(ignore_count);
1457 LLDB_LOGF(log,
"Target::%s (watch_id = %i)\n", __FUNCTION__, watch_id);
1476 LLDB_LOGF(log,
"Target::%s (watch_id = %i)\n", __FUNCTION__, watch_id);
1495 LLDB_LOGF(log,
"Target::%s (watch_id = %i)\n", __FUNCTION__, watch_id);
1510 uint32_t ignore_count) {
1512 LLDB_LOGF(log,
"Target::%s (watch_id = %i)\n", __FUNCTION__, watch_id);
1519 wp_sp->SetIgnoreCount(ignore_count);
1526 std::lock_guard<std::recursive_mutex> lock(
m_images.GetMutex());
1538 return m_images.GetModuleAtIndex(0);
1549 if (module_sp && !module_sp->LoadScriptingResourceInTarget(target,
error,
1551 if (
error.AsCString())
1553 "unable to load scripting data for module %s - error reported was "
1555 module_sp->GetFileSpec().GetFileNameStrippingExtension().GetCString(),
1558 if (feedback_stream.
GetSize())
1560 "%s\n", feedback_stream.
GetData());
1583 if (executable_sp) {
1586 pid = proc->GetID();
1590 info->
uuid = executable_sp->GetUUID();
1592 info->
triple = executable_sp->GetArchitecture().GetTriple().getTriple();
1598 info->
uuid = executable_sp->GetUUID();
1604 executable_sp->GetFileSpec().GetPath().c_str());
1606 const bool notify =
true;
1612 if (!
m_arch.GetSpec().IsValid()) {
1613 m_arch = executable_sp->GetArchitecture();
1615 "Target::SetExecutableModule setting architecture to {0} ({1}) "
1616 "based on executable file",
1617 m_arch.GetSpec().GetArchitectureName(),
1618 m_arch.GetSpec().GetTriple().getTriple());
1621 ObjectFile *executable_objfile = executable_sp->GetObjectFile();
1622 bool load_dependents =
true;
1623 switch (load_dependent_files) {
1625 load_dependents = executable_sp->IsExecutable();
1628 load_dependents =
true;
1631 load_dependents =
false;
1635 if (executable_objfile && load_dependents) {
1638 std::mutex dependent_files_mutex;
1643 auto GetDependentModules = [&](
FileSpec dependent_file_spec) {
1644 FileSpec platform_dependent_file_spec;
1646 m_platform_sp->GetFileWithUUID(dependent_file_spec,
nullptr,
1647 platform_dependent_file_spec);
1649 platform_dependent_file_spec = dependent_file_spec;
1654 if (image_module_sp) {
1656 ObjectFile *objfile = image_module_sp->GetObjectFile();
1662 std::lock_guard<std::mutex> guard(dependent_files_mutex);
1663 dependent_files_copy = dependent_files;
1668 const size_t previous_dependent_files =
1669 dependent_files_copy.
GetSize();
1674 std::lock_guard<std::mutex> guard(dependent_files_mutex);
1675 for (
size_t i = previous_dependent_files;
1676 i < dependent_files_copy.
GetSize(); ++i)
1687 for (uint32_t i = 0; i < dependent_files.
GetSize(); i++) {
1693 std::lock_guard<std::mutex> guard(dependent_files_mutex);
1694 for (; i < dependent_files.
GetSize(); i++)
1695 task_group.async(GetDependentModules,
1708 bool missing_local_arch = !
m_arch.GetSpec().IsValid();
1709 bool replace_local_arch =
true;
1710 bool compatible_local_arch =
false;
1719 if (!platform_sp || !platform_sp->IsCompatibleArchitecture(
1723 GetDebugger().GetPlatformList().GetOrCreate(other, {},
1725 arch_platform_sp->SetLocateModuleCallback(
1726 platform_sp->GetLocateModuleCallback());
1729 other = platform_arch;
1735 if (!missing_local_arch) {
1736 if (merge &&
m_arch.GetSpec().IsCompatibleMatch(arch_spec)) {
1739 if (
m_arch.GetSpec().IsCompatibleMatch(other)) {
1740 compatible_local_arch =
true;
1743 replace_local_arch =
false;
1748 if (compatible_local_arch || missing_local_arch) {
1752 if (replace_local_arch)
1755 "Target::SetArchitecture merging compatible arch; arch "
1757 m_arch.GetSpec().GetArchitectureName(),
1758 m_arch.GetSpec().GetTriple().getTriple());
1766 "Target::SetArchitecture changing architecture to %s (%s) from %s (%s)",
1768 arch_spec.
GetTriple().getTriple().c_str(),
1769 m_arch.GetSpec().GetArchitectureName(),
1770 m_arch.GetSpec().GetTriple().getTriple().c_str());
1777 if (executable_sp) {
1779 "Target::SetArchitecture Trying to select executable file "
1780 "architecture %s (%s)",
1782 arch_spec.
GetTriple().getTriple().c_str());
1783 ModuleSpec module_spec(executable_sp->GetFileSpec(), other);
1784 module_spec.
SetTarget(shared_from_this());
1788 if (!
error.Fail() && executable_sp) {
1799 if (
m_arch.GetSpec().IsCompatibleMatch(arch_spec)) {
1804 "Target::MergeArchitecture target has arch %s, merging with "
1806 m_arch.GetSpec().GetTriple().getTriple().c_str(),
1807 arch_spec.
GetTriple().getTriple().c_str());
1828 my_module_list.
Append(module_sp);
1838 my_module_list.
Append(module_sp);
1851 old_module_sp, new_module_sp);
1863 const size_t num_images = module_list.
GetSize();
1865 for (
size_t idx = 0; idx < num_images; ++idx) {
1877 std::make_shared<TargetEventData>(shared_from_this(), module_list);
1886 runtime->SymbolsDidLoad(module_list);
1893 std::make_shared<TargetEventData>(shared_from_this(), module_list);
1902 std::make_shared<TargetEventData>(shared_from_this(), module_list);
1916 const bool should_flush_type_systems =
1918 auto *object_file =
module.GetObjectFile();
1923 auto type = object_file->GetType();
1927 return module.FileHasChanged() &&
1928 (type == ObjectFile::eTypeObjectFile ||
1929 type == ObjectFile::eTypeExecutable ||
1930 type == ObjectFile::eTypeSharedLibrary);
1933 if (should_flush_type_systems)
1939 const FileSpec &module_file_spec) {
1944 size_t num_modules = matchingModules.
GetSize();
1948 if (num_modules > 0) {
1949 for (
size_t i = 0; i < num_modules; i++) {
1964 return m_platform_sp->ModuleIsExcludedForUnconstrainedSearches(*
this,
1976 if (section_sp->IsEncrypted()) {
1980 ModuleSP module_sp(section_sp->GetModule());
1982 ObjectFile *objfile = section_sp->GetModule()->GetObjectFile();
1985 section_sp.get(), addr.
GetOffset(), dst, dst_len);
1990 "error reading data from section %s",
1991 section_sp->GetName().GetCString());
1998 "address doesn't contain a section that points to a "
1999 "section in a object file");
2007 bool *did_read_live_memory) {
2009 if (did_read_live_memory)
2010 *did_read_live_memory =
false;
2023 size_t bytes_read = 0;
2030 if (section_load_list.
IsEmpty()) {
2036 m_images.ResolveFileAddress(file_addr, resolved_addr);
2049 resolved_addr = fixed_addr;
2054 std::unique_ptr<uint8_t[]> file_cache_read_buffer;
2055 size_t file_cache_bytes_read = 0;
2061 auto permissions =
Flags(section_sp->GetPermissions());
2062 bool is_readonly = !permissions.Test(ePermissionsWritable) &&
2063 permissions.Test(ePermissionsReadable);
2065 file_cache_bytes_read =
2067 if (file_cache_bytes_read == dst_len)
2068 return file_cache_bytes_read;
2069 else if (file_cache_bytes_read > 0) {
2070 file_cache_read_buffer =
2071 std::make_unique<uint8_t[]>(file_cache_bytes_read);
2072 std::memcpy(file_cache_read_buffer.get(), dst, file_cache_bytes_read);
2084 if (addr_module_sp && addr_module_sp->GetFileSpec())
2086 "{0:F}[{1:x+}] can't be resolved, {0:F} is not currently loaded",
2090 "0x%" PRIx64
" can't be resolved", resolved_addr.
GetFileAddress());
2093 if (bytes_read != dst_len) {
2094 if (
error.Success()) {
2095 if (bytes_read == 0)
2097 "read memory from 0x%" PRIx64
" failed", load_addr);
2100 "only %" PRIu64
" of %" PRIu64
2101 " bytes were read from memory at 0x%" PRIx64,
2102 (uint64_t)bytes_read, (uint64_t)dst_len, load_addr);
2107 *load_addr_ptr = load_addr;
2108 if (did_read_live_memory)
2109 *did_read_live_memory =
true;
2115 if (file_cache_read_buffer && file_cache_bytes_read > 0) {
2118 std::memcpy(dst, file_cache_read_buffer.get(), file_cache_bytes_read);
2119 return file_cache_bytes_read;
2141 out_str.append(buf, length);
2144 if (length ==
sizeof(buf) - 1)
2145 curr_addr += length;
2150 return out_str.size();
2154 size_t dst_max_len,
Status &result_error,
2155 bool force_live_memory) {
2156 size_t total_cstr_len = 0;
2157 if (dst && dst_max_len) {
2158 result_error.
Clear();
2160 memset(dst, 0, dst_max_len);
2167 const size_t cache_line_size = 512;
2169 size_t bytes_left = dst_max_len - 1;
2170 char *curr_dst = dst;
2172 while (bytes_left > 0) {
2173 addr_t cache_line_bytes_left =
2174 cache_line_size - (curr_addr % cache_line_size);
2176 std::min<addr_t>(bytes_left, cache_line_bytes_left);
2178 size_t bytes_read =
ReadMemory(address, curr_dst, bytes_to_read,
error,
2181 if (bytes_read == 0) {
2182 result_error = std::move(
error);
2183 dst[total_cstr_len] =
'\0';
2186 const size_t len = strlen(curr_dst);
2188 total_cstr_len += len;
2190 if (len < bytes_to_read)
2193 curr_dst += bytes_read;
2194 curr_addr += bytes_read;
2195 bytes_left -= bytes_read;
2202 result_error.
Clear();
2204 return total_cstr_len;
2212 return cache_line_size - (load_addr % cache_line_size);
2222 size_t type_width,
bool force_live_memory) {
2223 if (!dst || !max_bytes || !type_width || max_bytes < type_width)
2226 size_t total_bytes_read = 0;
2230 memset(dst, 0, max_bytes);
2231 size_t bytes_left = max_bytes - type_width;
2233 const char terminator[4] = {
'\0',
'\0',
'\0',
'\0'};
2234 assert(
sizeof(terminator) >= type_width &&
"Attempting to validate a "
2235 "string with more than 4 bytes "
2239 char *curr_dst = dst;
2242 while (bytes_left > 0 &&
error.Success()) {
2246 ReadMemory(address, curr_dst, bytes_to_read,
error, force_live_memory);
2248 if (bytes_read == 0)
2253 size_t aligned_start = total_bytes_read - total_bytes_read % type_width;
2254 for (
size_t i = aligned_start;
2255 i + type_width <= total_bytes_read + bytes_read; i += type_width)
2256 if (::memcmp(&dst[i], terminator, type_width) == 0) {
2261 total_bytes_read += bytes_read;
2262 curr_dst += bytes_read;
2263 address.
Slide(bytes_read);
2264 bytes_left -= bytes_read;
2266 return total_bytes_read;
2270 bool is_signed,
Scalar &scalar,
2272 bool force_live_memory) {
2275 if (byte_size <=
sizeof(uval)) {
2278 if (bytes_read == byte_size) {
2280 m_arch.GetSpec().GetAddressByteSize());
2283 scalar = data.
GetMaxU32(&offset, byte_size);
2285 scalar = data.
GetMaxU64(&offset, byte_size);
2295 "byte size of %u is too large for integer scalar type", byte_size);
2301 size_t integer_byte_size,
2303 bool force_live_memory) {
2312 size_t integer_byte_size,
2314 bool force_live_memory) {
2324 bool force_live_memory) {
2327 false, scalar,
error, force_live_memory)) {
2331 if (section_load_list.
IsEmpty()) {
2334 m_images.ResolveFileAddress(pointer_vm_addr, pointer_addr);
2345 pointer_addr.
SetOffset(pointer_vm_addr);
2353 bool notify,
Status *error_ptr) {
2360 module_spec.
SetTarget(shared_from_this());
2362 if (std::optional<FileSpec> remapped_obj_file =
2373 module_sp =
m_images.FindFirstModule(module_spec);
2376 llvm::SmallVector<ModuleSP, 1>
2379 bool did_create_module =
false;
2389 module_spec, module_sp, symbol_file_spec, &did_create_module);
2419 transformed_spec.
SetTarget(shared_from_this());
2421 &old_modules, &did_create_module);
2438 &old_modules, &did_create_module);
2446 module_spec,
m_process_sp.get(), module_sp, &old_modules,
2447 &did_create_module);
2458 ObjectFile *objfile = module_sp->GetObjectFile();
2474 "debug info files aren't valid target "
2475 "modules, please specify an executable");
2482 "stub libraries aren't valid target "
2483 "modules, please specify an executable");
2488 "unsupported file type, please specify an executable");
2507 m_images.FindModules(module_spec_copy, found_modules);
2509 old_modules.push_back(found_module);
2516 if (symbol_file_spec)
2517 module_sp->SetSymbolFileFileSpec(symbol_file_spec);
2519 llvm::SmallVector<ModuleSP, 1> replaced_modules;
2520 for (
ModuleSP &old_module_sp : old_modules) {
2521 if (
m_images.GetIndexForModule(old_module_sp.get()) !=
2523 if (replaced_modules.empty())
2524 m_images.ReplaceModule(old_module_sp, module_sp);
2528 replaced_modules.push_back(std::move(old_module_sp));
2532 if (replaced_modules.size() > 1) {
2545 auto dump = [&message](
Module &dump_module) ->
void {
2546 UUID dump_uuid = dump_module.GetUUID();
2550 message <<
" (uuid ";
2553 dump_uuid.
Dump(message);
2555 message <<
"not specified";
2560 message <<
"New module ";
2563 << llvm::formatv(
" simultaneously replaced {0} old modules: ",
2564 replaced_modules.size());
2565 for (
ModuleSP &replaced_module_sp : replaced_modules)
2566 dump(*replaced_module_sp);
2572 if (replaced_modules.empty())
2573 m_images.Append(module_sp, notify);
2575 for (
ModuleSP &old_module_sp : replaced_modules) {
2576 auto old_module_wp = old_module_sp->weak_from_this();
2577 old_module_sp.reset();
2585 *error_ptr = std::move(
error);
2614llvm::Expected<lldb::TypeSystemSP>
2616 bool create_on_demand) {
2618 return llvm::createStringError(
"Invalid Target");
2631 if (languages_for_expressions.
Empty())
2632 return llvm::createStringError(
2633 "No expression support for any languages");
2644 uint32_t byte_size) {
2647 return provider->GetRegisterType(name, flags, byte_size);
2650std::vector<lldb::TypeSystemSP>
2658 std::vector<lldb::TypeSystemSP> scratch_type_systems;
2663 for (
auto bit : languages_for_expressions.
bitvector.set_bits()) {
2665 auto type_system_or_err =
2667 if (!type_system_or_err)
2670 "Language '{1}' has expression support but no scratch type "
2671 "system available: {0}",
2674 if (
auto ts = *type_system_or_err)
2675 scratch_type_systems.push_back(ts);
2678 std::sort(scratch_type_systems.begin(), scratch_type_systems.end());
2679 scratch_type_systems.erase(llvm::unique(scratch_type_systems),
2680 scratch_type_systems.end());
2681 return scratch_type_systems;
2688 if (
auto err = type_system_or_err.takeError()) {
2691 "Unable to get persistent expression state for language {1}: {0}",
2696 if (
auto ts = *type_system_or_err)
2697 return ts->GetPersistentExpressionState();
2700 "Unable to get persistent expression state for language {1}: {0}",
2706 llvm::StringRef expr, llvm::StringRef prefix,
SourceLanguage language,
2710 auto type_system_or_err =
2712 if (
auto err = type_system_or_err.takeError()) {
2714 "Could not find type system for language %s: %s",
2716 llvm::toString(std::move(err)).c_str());
2720 auto ts = *type_system_or_err;
2723 "Type system for language %s is no longer live",
2728 auto *user_expr = ts->GetUserExpression(expr, prefix, language, desired_type,
2732 "Could not create an expression for language %s",
2743 if (
auto err = type_system_or_err.takeError()) {
2745 "Could not find type system for language %s: %s",
2747 llvm::toString(std::move(err)).c_str());
2750 auto ts = *type_system_or_err;
2753 "Type system for language %s is no longer live",
2757 auto *persistent_fn = ts->GetFunctionCaller(return_type, function_address,
2758 arg_value_list, name);
2761 "Could not create an expression for language %s",
2764 return persistent_fn;
2767llvm::Expected<std::unique_ptr<UtilityFunction>>
2772 if (!type_system_or_err)
2773 return type_system_or_err.takeError();
2774 auto ts = *type_system_or_err;
2776 return llvm::createStringError(
2777 llvm::StringRef(
"Type system for language ") +
2779 llvm::StringRef(
" is no longer live"));
2780 std::unique_ptr<UtilityFunction> utility_fn =
2781 ts->CreateUtilityFunction(std::move(expression), std::move(name));
2783 return llvm::createStringError(
2784 llvm::StringRef(
"Could not create an expression for language") +
2788 if (!utility_fn->Install(diagnostics, exe_ctx))
2790 "Could not install utility function:");
2792 return std::move(utility_fn);
2813 "setting target's default architecture to {0} ({1})",
2820 if (llvm::to_integer(label, n))
2821 return llvm::createStringError(
"Cannot use integer as target label.");
2825 if (target_sp && target_sp->GetLabel() == label) {
2826 return llvm::createStringErrorV(
2827 "Cannot use label '{0}' since it's set in target #{1}.", label, i);
2832 return llvm::Error::success();
2841 Target *target =
nullptr;
2842 if (sc_ptr !=
nullptr)
2844 if (target ==
nullptr && exe_ctx_ptr)
2854 result_valobj_sp.reset();
2859 m_stats.GetExpressionStats().NotifyFailure();
2860 return execution_results;
2866 llvm::scope_exit on_exit([
this, old_suppress_value]() {
2884 if (expr[0] ==
'$') {
2885 auto type_system_or_err =
2887 if (
auto err = type_system_or_err.takeError()) {
2889 "Unable to get scratch type system");
2891 auto ts = *type_system_or_err;
2894 "Scratch type system is no longer live: {0}");
2897 ts->GetPersistentExpressionState()->GetVariable(expr);
2900 if (persistent_var_sp) {
2901 result_valobj_sp = persistent_var_sp->GetValueObject();
2907 result_valobj_sp, fixed_expression, ctx_obj);
2911 m_stats.GetExpressionStats().NotifySuccess();
2913 m_stats.GetExpressionStats().NotifyFailure();
2914 return execution_results;
2920 [name, &variable_sp](
TypeSystemSP type_system) ->
bool {
2921 auto ts = type_system.get();
2925 ts->GetPersistentExpressionState()) {
2926 variable_sp = persistent_state->GetVariable(name);
2941 auto ts = type_system.get();
2946 ts->GetPersistentExpressionState()) {
2947 address = persistent_state->LookupSymbol(name);
2960 const bool has_primary_executable = exe_module && exe_module->
GetObjectFile();
2961 if (has_primary_executable) {
2968 const size_t num_images = modules.
GetSize();
2969 for (
size_t idx = 0; idx < num_images; ++idx) {
2971 if (!module_sp || !module_sp->GetObjectFile())
2974 Address entry_addr = module_sp->GetObjectFile()->GetEntryPointAddress();
2980 if (!has_primary_executable)
2981 return llvm::createStringError(
2982 "No primary executable found and could not find entry point address in "
2983 "any executable module");
2985 return llvm::createStringError(
2986 "Could not find entry point address for primary executable module \"" +
2994 ? arch_plugin->GetCallableLoadAddress(load_addr, addr_class)
3001 return arch_plugin ? arch_plugin->GetOpcodeLoadAddress(load_addr, addr_class)
3007 return arch_plugin ? arch_plugin->GetBreakableLoadAddress(addr, *
this) : addr;
3010llvm::Expected<lldb::DisassemblerSP>
3012 const char *flavor_string) {
3014 bool force_live_memory =
true;
3017 const size_t bytes_read =
3019 force_live_memory, &load_addr);
3022 return llvm::createStringError(
3023 error.AsCString(
"Target::ReadInstructions failed to read memory at %s"),
3027 if (!flavor_string || flavor_string[0] ==
'\0') {
3032 if (arch == llvm::Triple::x86 || arch == llvm::Triple::x86_64)
3060 stop_hook_sp.reset(
new StopHookCoded(shared_from_this(), new_uid));
3067 return stop_hook_sp;
3079 return (num_removed != 0);
3087 StopHookCollection::iterator specified_hook_iter;
3090 found_hook = (*specified_hook_iter).second;
3095 bool active_state) {
3096 StopHookCollection::iterator specified_hook_iter;
3101 (*specified_hook_iter).second->SetIsActive(active_state);
3106 StopHookCollection::iterator pos, end =
m_stop_hooks.end();
3108 (*pos).second->SetIsActive(active_state);
3117const std::vector<Target::StopHookSP>
3122 std::vector<StopHookSP> stop_hooks;
3124 stop_hooks.push_back(hook);
3142 auto is_active = [at_initial_stop](
StopHookSP hook) {
3143 bool should_run_now = (!at_initial_stop || hook->GetRunAtInitialStop());
3144 return hook->IsActive() && should_run_now;
3148 std::vector<StopHookSP> active_hooks;
3152 if (is_active(hook))
3153 active_hooks.push_back(hook);
3155 if (active_hooks.empty())
3164 uint32_t last_natural_stop =
m_process_sp->GetModIDRef().GetLastNaturalStopID();
3170 std::vector<ExecutionContext> exc_ctx_with_reasons;
3173 size_t num_threads = cur_threadlist.
GetSize();
3174 for (
size_t i = 0; i < num_threads; i++) {
3176 if (cur_thread_sp->ThreadStoppedForAReason()) {
3178 exc_ctx_with_reasons.emplace_back(
m_process_sp.get(), cur_thread_sp.get(),
3179 cur_frame_sp.get());
3188 size_t num_exe_ctx = exc_ctx_with_reasons.size();
3189 if (num_exe_ctx == 0) {
3190 if (at_initial_stop && num_threads > 0) {
3192 exc_ctx_with_reasons.emplace_back(
3194 thread_to_use_sp->GetStackFrameAtIndex(0).get());
3202 llvm::scope_exit on_exit([output_sp] { output_sp->Flush(); });
3204 size_t num_hooks_with_output = llvm::count_if(
3205 active_hooks, [](
auto h) {
return !h->GetSuppressOutput(); });
3206 bool print_hook_header = (num_hooks_with_output > 1);
3207 bool print_thread_header = (num_exe_ctx > 1);
3208 bool should_stop =
false;
3209 bool requested_continue =
false;
3216 for (
auto cur_hook_sp : active_hooks) {
3217 bool any_thread_matched =
false;
3218 for (
auto exc_ctx : exc_ctx_with_reasons) {
3219 if (!cur_hook_sp->ExecutionContextPasses(exc_ctx))
3222 bool suppress_output = cur_hook_sp->GetSuppressOutput();
3223 if (print_hook_header && !any_thread_matched && !suppress_output) {
3227 output_sp->Printf(
"\n- Hook %" PRIu64
" (%s)\n", cur_hook_sp->GetID(),
3230 output_sp->Printf(
"\n- Hook %" PRIu64
"\n", cur_hook_sp->GetID());
3231 any_thread_matched =
true;
3234 if (print_thread_header && !suppress_output)
3235 output_sp->Printf(
"-- Thread %d\n",
3236 exc_ctx.GetThreadPtr()->GetIndexID());
3238 auto result = cur_hook_sp->HandleStop(exc_ctx, output_sp);
3241 if (cur_hook_sp->GetAutoContinue())
3242 requested_continue =
true;
3247 requested_continue =
true;
3256 output_sp->Printf(
"\nAborting stop hooks, hook %" PRIu64
3257 " set the program running.\n"
3258 " Consider using '-G true' to make "
3259 "stop hooks auto-continue.\n",
3260 cur_hook_sp->GetID());
3271 if (requested_continue && !should_stop) {
3274 if (
error.Success()) {
3275 LLDB_LOG(log,
"Resuming from RunStopHooks");
3278 LLDB_LOG(log,
"Resuming from RunStopHooks failed: {0}",
error);
3291 return *g_settings_ptr;
3297 if (!platform_sp || !platform_sp->IsRemote() || !platform_sp->IsConnected())
3307 MainExecutableInstaller installer{platform_sp, module_sp,
3308 shared_from_this(), *launch_info};
3311 ExecutableInstaller installer{platform_sp, module_sp};
3323 uint32_t stop_id,
bool allow_section_end) {
3330 return m_images.ResolveFileAddress(file_addr, resolved_addr);
3334 addr_t new_section_load_addr,
3335 bool warn_multiple) {
3336 const addr_t old_section_load_addr =
3339 if (old_section_load_addr != new_section_load_addr) {
3340 uint32_t stop_id = 0;
3343 stop_id = process_sp->GetStopID();
3347 stop_id, section_sp, new_section_load_addr, warn_multiple))
3354 size_t section_unload_count = 0;
3355 size_t num_modules = module_list.
GetSize();
3356 for (
size_t i = 0; i < num_modules; ++i) {
3357 section_unload_count +=
3360 return section_unload_count;
3364 uint32_t stop_id = 0;
3367 stop_id = process_sp->GetStopID();
3370 SectionList *sections = module_sp->GetSectionList();
3371 size_t section_unload_count = 0;
3374 for (uint32_t i = 0; i < num_sections; ++i) {
3379 return section_unload_count;
3383 uint32_t stop_id = 0;
3386 stop_id = process_sp->GetStopID();
3394 uint32_t stop_id = 0;
3397 stop_id = process_sp->GetStopID();
3428 m_stats.SetLaunchOrAttachTime();
3432 LLDB_LOGF(log,
"Target::%s() called for %s", __FUNCTION__,
3444 state = process_sp->GetState();
3446 "Target::%s the process exists, and its current state is %s",
3449 LLDB_LOGF(log,
"Target::%s the process instance doesn't currently exist.",
3462 const bool synchronous_execution =
3470 if (launch_info.
GetFlags().
Test(eLaunchFlagLaunchInTTY))
3472 "can't launch in tty when launching through a remote connection");
3490 LLDB_LOGF(log,
"Target::%s asking the platform to debug the process",
3504 "Target::%s the platform doesn't know how to debug a "
3505 "process, getting a process plugin to do this for us.",
3524 if (!
error.Success())
3530 bool rebroadcast_first_stop =
3531 !synchronous_execution &&
3537 state =
m_process_sp->WaitForProcessToStop(std::nullopt, &first_stop_event_sp,
3538 rebroadcast_first_stop,
3542 if (rebroadcast_first_stop) {
3545 assert(first_stop_event_sp);
3554 if (launch_info.
GetFlags().
Test(eLaunchFlagStopAtEntry))
3556 if (synchronous_execution)
3563 if (!
error.Success()) {
3565 "process resume at entry point failed: %s",
error.AsCString());
3569 bool with_shell = !!launch_info.
GetShell();
3571 const char *exit_desc =
m_process_sp->GetExitDescription();
3573 if (exit_desc && exit_desc[0])
3574 desc =
" (" + std::string(exit_desc) +
')';
3577 "process exited with status %i%s\n"
3578 "'r' and 'run' are aliases that default to launching through a "
3580 "Try launching without going through a shell by using "
3581 "'process launch'.",
3582 exit_status, desc.c_str());
3585 "process exited with status %i%s", exit_status, desc.c_str());
3589 "initial process state wasn't stopped: %s",
StateAsCString(state));
3601 return llvm::createStringError(llvm::inconvertibleErrorCode(),
3602 "A process is required for tracing");
3604 return llvm::createStringError(llvm::inconvertibleErrorCode(),
3605 "A trace already exists for the target");
3607 llvm::Expected<TraceSupportedResponse> trace_type =
3610 return llvm::createStringError(
3611 llvm::inconvertibleErrorCode(),
"Tracing is not supported. %s",
3612 llvm::toString(trace_type.takeError()).c_str());
3613 if (llvm::Expected<TraceSP> trace_sp =
3617 return llvm::createStringError(
3618 llvm::inconvertibleErrorCode(),
3619 "Couldn't create a Trace object for the process. %s",
3620 llvm::toString(trace_sp.takeError()).c_str());
3631 Progress attach_progress(
"Waiting to attach to process");
3632 m_stats.SetLaunchOrAttachTime();
3636 state = process_sp->GetState();
3649 if (old_exec_module_sp)
3651 old_exec_module_sp->GetPlatformFileSpec().GetFilename());
3655 "no process specified, create a target with a file, or "
3656 "specify the --pid or --name");
3660 const auto platform_sp =
3663 const bool async = attach_info.
GetAsync();
3681 plugin_name,
nullptr,
false);
3684 "failed to create process using plugin '{0}'",
3685 plugin_name.empty() ?
"<empty>" : plugin_name);
3689 if (hijack_listener_sp)
3690 process_sp->HijackProcessEvents(hijack_listener_sp);
3691 error = process_sp->Attach(attach_info);
3694 if (
error.Success() && process_sp) {
3696 process_sp->RestoreProcessEvents();
3699 state = process_sp->WaitForProcessToStop(
3702 process_sp->RestoreProcessEvents();
3709 const char *exit_desc = process_sp->GetExitDescription();
3714 "process did not stop (no such process or permission problem?)");
3715 process_sp->Destroy(
false);
3725 return llvm::createStringError(
"invalid frame provider descriptor");
3727 uint32_t descriptor_id = descriptor.
GetID();
3729 llvm::StringRef name = descriptor.
GetName();
3731 return llvm::createStringError(
3732 "frame provider descriptor has no class name");
3735 std::unique_lock<std::recursive_mutex> guard(
3742 return descriptor_id;
3746 bool removed =
false;
3748 std::lock_guard<std::recursive_mutex> guard(
3760 std::lock_guard<std::recursive_mutex> guard(
3768const llvm::DenseMap<uint32_t, ScriptedFrameProviderDescriptor> &
3770 std::lock_guard<std::recursive_mutex> guard(
3779 for (
ThreadSP thread_sp : process_sp->Threads()) {
3781 thread_sp->ClearScriptedFrameProvider();
3784 auto data_sp = std::make_shared<Thread::ThreadEventData>(thread_sp);
3796 const bool default_to_use_pty =
3800 "have platform={0}, platform_sp->IsHost()={1}, default_to_use_pty={2}",
3802 platform_sp ? (platform_sp->IsHost() ?
"true" :
"false") :
"n/a",
3803 default_to_use_pty);
3810 LLDB_LOG(log,
"at least one of stdin/stdout/stderr was not set, evaluating "
3811 "default handling");
3820 LLDB_LOG(log,
"eLaunchFlagDisableSTDIO set, adding suppression action "
3821 "for stdin, stdout and stderr");
3841 LLDB_LOG(log,
"target stdin='{0}', target stdout='{1}', stderr='{2}'",
3842 in_file_spec, out_file_spec, err_file_spec);
3846 LLDB_LOG(log,
"appended stdin open file action for {0}", in_file_spec);
3849 if (out_file_spec) {
3851 LLDB_LOG(log,
"appended stdout open file action for {0}",
3855 if (err_file_spec) {
3857 LLDB_LOG(log,
"appended stderr open file action for {0}",
3861 if (default_to_use_pty) {
3863 LLDB_LOG_ERROR(log, std::move(Err),
"SetUpPtyRedirection failed: {0}");
3880 elem.notify = notify;
3890 = signals_sp->GetSignalNumberFromName(elem.first().str().c_str());
3895 signals_sp->SetShouldSuppress(signo,
false);
3897 signals_sp->SetShouldSuppress(signo,
true);
3900 signals_sp->SetShouldNotify(signo,
true);
3902 signals_sp->SetShouldNotify(signo,
false);
3905 signals_sp->SetShouldStop(signo,
true);
3907 signals_sp->SetShouldStop(signo,
false);
3916 = signals_sp->GetSignalNumberFromName(elem.first().str().c_str());
3922 signals_sp->ResetSignal(signo, do_stop, do_notify, do_pass);
3933 warning_stream_sp->Printf(
"Target signal '%s' not found in process\n",
3934 elem.first().str().c_str());
3947 signals_sp = process_sp->GetUnixSignals();
3950 const char *signal_name = entry.c_str();
3964 strm.
Printf(
"NAME PASS STOP NOTIFY\n");
3965 strm.
Printf(
"=========== ======= ======= =======\n");
3967 auto str_for_lazy = [] (
LazyBool lazy) ->
const char * {
3973 llvm_unreachable(
"Fully covered switch above!");
3977 bool print_it =
false;
3978 for (
size_t idx = 0; idx < num_args; idx++) {
3985 strm.
Printf(
"%-11s ", elem.first().str().c_str());
3986 strm.
Printf(
"%s %s %s\n", str_for_lazy(elem.second.pass),
3987 str_for_lazy(elem.second.stop),
3988 str_for_lazy(elem.second.notify));
4019 bool will_run =
true;
4043 s.
Indent(
"State: enabled\n");
4045 s.
Indent(
"State: disabled\n");
4048 s.
Indent(
"AutoContinue on\n");
4078 uint32_t num_commands =
m_commands.GetSize();
4079 for (uint32_t i = 0; i < num_commands; i++) {
4091 const std::vector<std::string> &strings) {
4092 for (
auto string : strings)
4099 assert(exc_ctx.
GetTargetPtr() &&
"Can't call PerformAction on a context "
4136 GetTarget()->GetDebugger().GetScriptInterpreter();
4137 if (!script_interp) {
4145 "ScriptedStopHook::%s () - ERROR: %s", __FUNCTION__,
4146 "Script interpreter couldn't create Scripted Stop Hook Interface");
4160 if (!object_sp || !object_sp->IsValid()) {
4162 "ScriptedStopHook::%s () - ERROR: %s", __FUNCTION__,
4163 "Failed to create valid script object");
4173 assert(exc_ctx.
GetTargetPtr() &&
"Can't call HandleStop on a context "
4179 lldb::StreamSP stream = std::make_shared<lldb_private::StreamString>();
4180 auto should_stop_or_err =
m_interface_sp->HandleStop(exc_ctx, stream);
4181 output_sp->PutCString(
4183 if (!should_stop_or_err)
4205 if (!object_sp || !object_sp->IsValid())
4209 if (!as_dict || !as_dict->
IsValid())
4212 uint32_t num_keys = as_dict->
GetSize();
4219 auto print_one_element = [&s](llvm::StringRef key,
4222 s.
Format(
"{0} : {1}\n", key, object->GetStringValue());
4226 as_dict->
ForEach(print_one_element);
4232 "no-dynamic-values",
4233 "Don't calculate the dynamic type of values",
4238 "Calculate the dynamic type of values "
4239 "even if you have to run the target.",
4244 "Calculate the dynamic type of values, but don't run the target.",
4256 "Never look for inline breakpoint locations (fastest). This setting "
4257 "should only be used if you know that no inlining occurs in your"
4263 "Only check for inline breakpoint locations when setting breakpoints "
4264 "in header files, but not when setting breakpoint in implementation "
4265 "source files (default).",
4270 "Always look for inline breakpoint locations when setting file and "
4271 "line breakpoints (slower but most accurate).",
4285 "Disassembler default (currently att).",
4290 "Intel disassembler flavor.",
4295 "AT&T disassembler flavor.",
4303 "Never import the 'std' C++ module in the expression parser.",
4308 "Retry evaluating expressions with an imported 'std' C++ module if they"
4309 " failed to parse without the module. This allows evaluating more "
4310 "complex expressions involving C++ standard library types."
4315 "Always import the 'std' C++ module. This allows evaluating more "
4316 "complex expressions involving C++ standard library types. This feature"
4321static constexpr OptionEnumValueElement
4326 "Automatically determine the most appropriate method for the "
4330 "Prefer using the realized classes struct."},
4332 "Prefer using the CopyRealizedClassList API."},
4334 "Prefer using the GetRealizedClassList API."},
4341 "C-style (0xffff).",
4346 "Asm-style (0ffffh).",
4354 "Load debug scripts inside symbol files",
4359 "Do not load debug scripts inside symbol files.",
4364 "Warn about debug scripts inside symbol files but do not load them.",
4372 "Load .lldbinit files from current directory",
4377 "Do not load .lldbinit files from current directory",
4382 "Warn about loading .lldbinit files from current directory",
4390 "Load minimal information when loading modules from memory. Currently "
4391 "this setting loads sections only.",
4396 "Load partial information when loading modules from memory. Currently "
4397 "this setting loads sections and function bounds.",
4402 "Load complete information when loading modules from memory. Currently "
4403 "this setting loads sections and all symbols.",
4407#define LLDB_PROPERTIES_target
4408#include "TargetProperties.inc"
4411#define LLDB_PROPERTIES_target
4412#include "TargetPropertiesEnum.inc"
4417 :
public Cloneable<TargetOptionValueProperties, OptionValueProperties> {
4428 Target *target = exe_ctx->GetTargetPtr();
4433 if (
this != target_properties)
4442#define LLDB_PROPERTIES_target_experimental
4443#include "TargetProperties.inc"
4446#define LLDB_PROPERTIES_target_experimental
4447#include "TargetPropertiesEnum.inc"
4451 :
public Cloneable<TargetExperimentalOptionValueProperties,
4452 OptionValueProperties> {
4489 m_collection_sp->SetValueChangedCallback(ePropertyDetachOnError, [
this] {
4502 std::make_unique<TargetExperimentalProperties>();
4505 "Experimental settings - setting these won't produce "
4506 "errors if the setting is not present.",
4509 m_collection_sp = std::make_shared<TargetOptionValueProperties>(
"target");
4512 std::make_unique<TargetExperimentalProperties>();
4515 "Experimental settings - setting these won't produce "
4516 "errors if the setting is not present.",
4519 "process",
"Settings specific to processes.",
true,
4546 exp_property->
GetValue()->GetAsProperties();
4549 return std::nullopt;
4562 exp_property->
GetValue()->GetAsProperties();
4574 exp_property->
GetValue()->GetAsProperties();
4580 const uint32_t idx = ePropertyDefaultArch;
4585 const uint32_t idx = ePropertyDefaultArch;
4590 const uint32_t idx = ePropertyMoveToNearestCode;
4592 idx, g_target_properties[idx].default_uint_value != 0);
4596 const uint32_t idx = ePropertyPreferDynamic;
4599 g_target_properties[idx].default_uint_value));
4603 const uint32_t idx = ePropertyPreferDynamic;
4609 "Interrupted checking preload symbols")) {
4612 const uint32_t idx = ePropertyPreloadSymbols;
4614 idx, g_target_properties[idx].default_uint_value != 0);
4618 const uint32_t idx = ePropertyPreloadSymbols;
4623 const uint32_t idx = ePropertyDisableASLR;
4625 idx, g_target_properties[idx].default_uint_value != 0);
4629 const uint32_t idx = ePropertyDisableASLR;
4634 const uint32_t idx = ePropertyInheritTCC;
4636 idx, g_target_properties[idx].default_uint_value != 0);
4640 const uint32_t idx = ePropertyInheritTCC;
4645 const uint32_t idx = ePropertyDetachOnError;
4647 idx, g_target_properties[idx].default_uint_value != 0);
4651 const uint32_t idx = ePropertyDetachOnError;
4656 const uint32_t idx = ePropertyDisableSTDIO;
4658 idx, g_target_properties[idx].default_uint_value != 0);
4662 const uint32_t idx = ePropertyDisableSTDIO;
4666 const uint32_t idx = ePropertyLaunchWorkingDir;
4668 idx, g_target_properties[idx].default_cstr_value);
4672 const uint32_t idx = ePropertyParallelModuleLoad;
4674 idx, g_target_properties[idx].default_uint_value != 0);
4678 const uint32_t idx = ePropertyDisassemblyFlavor;
4679 const char *return_value;
4684 g_target_properties[idx].default_uint_value));
4687 return return_value;
4691 const uint32_t idx = ePropertyDisassemblyCPU;
4693 idx, g_target_properties[idx].default_cstr_value);
4694 return str.empty() ? nullptr : str.data();
4698 const uint32_t idx = ePropertyDisassemblyFeatures;
4700 idx, g_target_properties[idx].default_cstr_value);
4701 return str.empty() ? nullptr : str.data();
4705 const uint32_t idx = ePropertyInlineStrategy;
4708 static_cast<InlineStrategy>(g_target_properties[idx].default_uint_value));
4714 const uint32_t idx = ePropertySourceRealpathPrefixes;
4719 const uint32_t idx = ePropertyArg0;
4721 idx, g_target_properties[idx].default_cstr_value);
4725 const uint32_t idx = ePropertyArg0;
4731 const uint32_t idx = ePropertyRunArgs;
4736 const uint32_t idx = ePropertyRunArgs;
4746 ePropertyInheritEnv,
4747 g_target_properties[ePropertyInheritEnv].default_uint_value != 0)) {
4748 if (
auto platform_sp =
m_target->GetPlatform()) {
4749 Environment platform_env = platform_sp->GetEnvironment();
4750 for (
const auto &KV : platform_env)
4751 env[KV.first()] = KV.second;
4755 Args property_unset_env;
4757 property_unset_env);
4758 for (
const auto &var : property_unset_env)
4759 env.erase(var.ref());
4762 m_collection_sp->GetPropertyAtIndexAsArgs(ePropertyEnvVars, property_env);
4764 env[KV.first()] = KV.second;
4780 ePropertyInheritEnv,
4781 g_target_properties[ePropertyInheritEnv].default_uint_value != 0))
4785 if (platform_sp ==
nullptr)
4788 Environment platform_environment = platform_sp->GetEnvironment();
4789 for (
const auto &KV : platform_environment)
4790 environment[KV.first()] = KV.second;
4792 Args property_unset_environment;
4794 property_unset_environment);
4795 for (
const auto &var : property_unset_environment)
4796 environment.erase(var.ref());
4802 Args property_environment;
4804 property_environment);
4806 for (
const auto &KV :
Environment(property_environment))
4807 environment[KV.first()] = KV.second;
4814 const uint32_t idx = ePropertyEnvVars;
4819 const uint32_t idx = ePropertySkipPrologue;
4821 idx, g_target_properties[idx].default_uint_value != 0);
4825 const uint32_t idx = ePropertySourceMap;
4828 assert(option_value);
4833 const uint32_t idx = ePropertyObjectMap;
4836 assert(option_value);
4841 const uint32_t idx = ePropertyAutoSourceMapRelative;
4843 idx, g_target_properties[idx].default_uint_value != 0);
4847 const uint32_t idx = ePropertyExecutableSearchPaths;
4850 assert(option_value);
4855 const uint32_t idx = ePropertyExecutableSearchPaths;
4860 const uint32_t idx = ePropertyDebugFileSearchPaths;
4865 const uint32_t idx = ePropertyClangModuleSearchPaths;
4870 const uint32_t idx = ePropertyAutoImportClangModules;
4872 idx, g_target_properties[idx].default_uint_value != 0);
4876 const uint32_t idx = ePropertyImportStdModule;
4879 g_target_properties[idx].default_uint_value));
4883 const uint32_t idx = ePropertyDynamicClassInfoHelper;
4886 g_target_properties[idx].default_uint_value));
4890 const uint32_t idx = ePropertyAutoApplyFixIts;
4892 idx, g_target_properties[idx].default_uint_value != 0);
4896 const uint32_t idx = ePropertyRetriesWithFixIts;
4898 idx, g_target_properties[idx].default_uint_value);
4902 const uint32_t idx = ePropertyNotifyAboutFixIts;
4904 idx, g_target_properties[idx].default_uint_value != 0);
4908 const uint32_t idx = ePropertySaveObjectsDir;
4918 bool exists = instance.
Exists(new_dir);
4919 bool is_directory = instance.
IsDirectory(new_dir);
4920 std::string path = new_dir.
GetPath(
true);
4921 bool writable = llvm::sys::fs::can_write(path);
4922 if (exists && is_directory && writable)
4930 llvm::raw_string_ostream os(buffer);
4931 os <<
"JIT object dir '" << path <<
"' ";
4933 os <<
"does not exist";
4934 else if (!is_directory)
4935 os <<
"is not a directory";
4937 os <<
"is not writable";
4939 std::optional<lldb::user_id_t> debugger_id;
4941 debugger_id =
m_target->GetDebugger().GetID();
4946 const uint32_t idx = ePropertyEnableSynthetic;
4948 idx, g_target_properties[idx].default_uint_value != 0);
4952 const uint32_t idx = ePropertyShowHexVariableValuesWithLeadingZeroes;
4954 idx, g_target_properties[idx].default_uint_value != 0);
4958 const uint32_t idx = ePropertyMaxZeroPaddingInFloatFormat;
4960 idx, g_target_properties[idx].default_uint_value);
4964 const uint32_t idx = ePropertyMaxChildrenCount;
4966 idx, g_target_properties[idx].default_uint_value);
4969std::pair<uint32_t, bool>
4971 const uint32_t idx = ePropertyMaxChildrenDepth;
4972 auto *option_value =
4974 bool is_default = !option_value->OptionWasSet();
4975 return {option_value->GetCurrentValue(), is_default};
4979 const uint32_t idx = ePropertyMaxSummaryLength;
4981 idx, g_target_properties[idx].default_uint_value);
4985 const uint32_t idx = ePropertyMaxMemReadSize;
4987 idx, g_target_properties[idx].default_uint_value);
4991 const uint32_t idx = ePropertyInputPath;
4996 const uint32_t idx = ePropertyInputPath;
5001 const uint32_t idx = ePropertyOutputPath;
5006 const uint32_t idx = ePropertyOutputPath;
5011 const uint32_t idx = ePropertyErrorPath;
5016 const uint32_t idx = ePropertyErrorPath;
5021 const uint32_t idx = ePropertyLanguage;
5026 const uint32_t idx = ePropertyExprPrefix;
5032 return llvm::StringRef(
5033 reinterpret_cast<const char *
>(data_sp->GetBytes()),
5034 data_sp->GetByteSize());
5040 const uint32_t idx = ePropertyExprErrorLimit;
5042 idx, g_target_properties[idx].default_uint_value);
5046 const uint32_t idx = ePropertyExprAllocAddress;
5048 idx, g_target_properties[idx].default_uint_value);
5052 const uint32_t idx = ePropertyExprAllocSize;
5054 idx, g_target_properties[idx].default_uint_value);
5058 const uint32_t idx = ePropertyExprAllocAlign;
5060 idx, g_target_properties[idx].default_uint_value);
5064 const uint32_t idx = ePropertyBreakpointUseAvoidList;
5066 idx, g_target_properties[idx].default_uint_value != 0);
5070 const uint32_t idx = ePropertyUseHexImmediates;
5072 idx, g_target_properties[idx].default_uint_value != 0);
5076 const uint32_t idx = ePropertyUseFastStepping;
5078 idx, g_target_properties[idx].default_uint_value != 0);
5082 const uint32_t idx = ePropertyDisplayExpressionsInCrashlogs;
5084 idx, g_target_properties[idx].default_uint_value != 0);
5088 const uint32_t idx = ePropertyLoadScriptFromSymbolFile;
5091 g_target_properties[idx].default_uint_value));
5095 const uint32_t idx = ePropertyLoadCWDlldbinitFile;
5098 g_target_properties[idx].default_uint_value));
5102 const uint32_t idx = ePropertyHexImmediateStyle;
5105 g_target_properties[idx].default_uint_value));
5109 const uint32_t idx = ePropertyMemoryModuleLoadLevel;
5112 g_target_properties[idx].default_uint_value));
5116 const uint32_t idx = ePropertyTrapHandlerNames;
5121 const uint32_t idx = ePropertyTrapHandlerNames;
5126 const uint32_t idx = ePropertyDisplayRuntimeSupportValues;
5128 idx, g_target_properties[idx].default_uint_value != 0);
5132 const uint32_t idx = ePropertyDisplayRuntimeSupportValues;
5137 const uint32_t idx = ePropertyDisplayRecognizedArguments;
5139 idx, g_target_properties[idx].default_uint_value != 0);
5143 const uint32_t idx = ePropertyDisplayRecognizedArguments;
5159 if (input_file_action) {
5164 if (output_file_action) {
5169 if (error_file_action) {
5175 launch_info.
GetFlags().
Test(lldb::eLaunchFlagInheritTCCFromParent));
5180 const uint32_t idx = ePropertyRequireHardwareBreakpoints;
5182 idx, g_target_properties[idx].default_uint_value != 0);
5186 const uint32_t idx = ePropertyRequireHardwareBreakpoints;
5191 const uint32_t idx = ePropertyAutoInstallMainExecutable;
5193 idx, g_target_properties[idx].default_uint_value != 0);
5227 m_launch_info.GetFlags().Set(lldb::eLaunchFlagDetachOnError);
5229 m_launch_info.GetFlags().Clear(lldb::eLaunchFlagDetachOnError);
5236 m_launch_info.GetFlags().Clear(lldb::eLaunchFlagDisableASLR);
5241 m_launch_info.GetFlags().Set(lldb::eLaunchFlagInheritTCCFromParent);
5243 m_launch_info.GetFlags().Clear(lldb::eLaunchFlagInheritTCCFromParent);
5248 m_launch_info.GetFlags().Set(lldb::eLaunchFlagDisableSTDIO);
5250 m_launch_info.GetFlags().Clear(lldb::eLaunchFlagDisableSTDIO);
5254 const uint32_t idx = ePropertyDebugUtilityExpression;
5256 idx, g_target_properties[idx].default_uint_value != 0);
5260 const uint32_t idx = ePropertyDebugUtilityExpression;
5281 return "Target::TargetEventData";
5318 return created_target_sp;
5340 return m_stats.ToJSON(*
this, options);
5358 lldb::BreakpointEventType eventKind) {
5360 std::shared_ptr<Breakpoint::BreakpointEventData> data_sp =
5361 std::make_shared<Breakpoint::BreakpointEventData>(
5362 eventKind, bp.shared_from_this());
5380 if (option_name.empty())
5381 return llvm::createStringError(
"can't set an option with an empty name");
5386 return llvm::createStringErrorV(
"trying to override existing option '{0}' "
5387 "of type '{1}' with a boolean value",
5388 option_name, existing_sp->GetType());
5392 return llvm::Error::success();
5396 llvm::StringRef option_name)
const {
5399 if (!opts.
HasKey(option_name))
5400 return llvm::createStringErrorV(
"option '{0}' does not exist", option_name);
5404 return llvm::createStringErrorV(
"failed to get option '{0}' as boolean",
5426 "c++-ignore-context-qualifiers";
5439 return llvm::cantFail(
static void dump(const StructuredData::Array &array, Stream &s)
static llvm::raw_ostream & error(Stream &strm)
#define INTERRUPT_REQUESTED(debugger,...)
This handy define will keep you from having to generate a report for the interruption by hand.
#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,...)
static void skip(TSLexer *lexer)
static double elapsed(const StatsTimepoint &start, const StatsTimepoint &end)
static Status installExecutable(const Installer &installer)
constexpr llvm::StringLiteral s_cpp_ignore_context_qualifiers_option
static constexpr OptionEnumValueElement g_dynamic_class_info_helper_value_types[]
static bool CheckIfWatchpointsSupported(Target *target, Status &error)
static constexpr OptionEnumValueElement g_load_cwd_lldbinit_values[]
static void LoadScriptingResourceForModule(const ModuleSP &module_sp, Target *target)
static constexpr OptionEnumValueElement g_dynamic_value_types[]
static constexpr OptionEnumValueElement g_memory_module_load_level_values[]
static constexpr OptionEnumValueElement g_load_script_from_sym_file_values[]
static std::atomic< lldb::user_id_t > g_target_unique_id
static constexpr OptionEnumValueElement g_x86_dis_flavor_value_types[]
static constexpr OptionEnumValueElement g_hex_immediate_style_values[]
static constexpr OptionEnumValueElement g_inline_breakpoint_enums[]
static constexpr OptionEnumValueElement g_import_std_module_value_types[]
#define LLDB_SCOPED_TIMERF(...)
TargetExperimentalOptionValueProperties()
const Property * GetPropertyAtIndex(size_t idx, const ExecutionContext *exe_ctx=nullptr) const override
TargetOptionValueProperties(llvm::StringRef name)
static lldb::ABISP FindPlugin(lldb::ProcessSP process_sp, const ArchSpec &arch)
A section + offset based address class.
lldb::addr_t GetLoadAddress(Target *target) const
Get the load address.
bool SetLoadAddress(lldb::addr_t load_addr, Target *target, bool allow_section_end=false)
Set the address to represent load_addr.
lldb::SectionSP GetSection() const
Get const accessor for the section.
bool Slide(int64_t offset)
lldb::ModuleSP GetModule() const
Get accessor for the module for this address.
lldb::addr_t GetFileAddress() const
Get the file address.
lldb::addr_t GetOffset() const
Get the section relative offset value.
bool IsValid() const
Check if the object state is valid.
bool IsSectionOffset() const
Check if an address is section offset.
bool SetOffset(lldb::addr_t offset)
Set accessor for the 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.
A command line argument class.
size_t GetArgumentCount() const
Gets the number of arguments left in this command object.
const char * GetArgumentAtIndex(size_t idx) const
Gets the NULL terminated C string argument pointer for the argument at index idx.
bool AddBreakpointID(BreakpointID bp_id)
BreakpointID GetBreakpointIDAtIndex(size_t index) const
lldb::break_id_t GetBreakpointID() const
static bool StringIsBreakpointName(llvm::StringRef str, Status &error)
Takes an input string and checks to see whether it is a breakpoint name.
General Outline: Allows adding and removing breakpoints and find by ID and index.
BreakpointIterable Breakpoints()
void GetListMutex(std::unique_lock< std::recursive_mutex > &lock)
Sets the passed in Locker to hold the Breakpoint List mutex.
void ResetHitCounts()
Resets the hit count of all breakpoints.
size_t GetSize() const
Returns the number of elements in this breakpoint list.
lldb::BreakpointSP GetBreakpointAtIndex(size_t i) const
Returns a shared pointer to the breakpoint with index i.
void MergeInto(const Permissions &incoming)
ConstString GetName() const
Permissions & GetPermissions()
BreakpointOptions & GetOptions()
void ConfigureBreakpoint(lldb::BreakpointSP bp_sp)
"lldb/Breakpoint/BreakpointOptions.h" Class that manages the options on a breakpoint or breakpoint lo...
void CopyOverSetOptions(const BreakpointOptions &rhs)
Copy over only the options set in the incoming BreakpointOptions.
"lldb/Breakpoint/BreakpointResolverFileLine.h" This class sets breakpoints by file and line.
"lldb/Breakpoint/BreakpointResolverFileRegex.h" This class sets breakpoints by file and line.
"lldb/Breakpoint/BreakpointResolverName.h" This class sets breakpoints on a given function name,...
"lldb/Breakpoint/BreakpointResolverScripted.h" This class sets breakpoints on a given Address.
General Outline: A breakpoint has four main parts, a filter, a resolver, the list of breakpoint locat...
virtual StructuredData::ObjectSP SerializeToStructuredData()
static lldb::BreakpointSP CreateFromStructuredData(lldb::TargetSP target_sp, StructuredData::ObjectSP &data_object_sp, Status &error)
static lldb::BreakpointSP CopyFromBreakpoint(lldb::TargetSP new_target, const Breakpoint &bp_to_copy_from)
static const char * GetSerializationKey()
static bool SerializedBreakpointMatchesNames(StructuredData::ObjectSP &bkpt_object_sp, std::vector< std::string > &names)
bool EventTypeHasListeners(uint32_t event_type)
Broadcaster(lldb::BroadcasterManagerSP manager_sp, std::string name)
Construct with a broadcaster with a name.
void SetEventName(uint32_t event_mask, const char *name)
Set the name for an event bit.
void BroadcastEvent(lldb::EventSP &event_sp)
Broadcast an event which has no associated data.
void CheckInWithManager()
A class that implements CRTP-based "virtual constructor" idiom.
void SetStopOnContinue(bool stop_on_continue)
void SetPrintErrors(bool print_errors)
void SetEchoCommands(bool echo_commands)
void SetAddToHistory(bool add_to_history)
void SetStopOnError(bool stop_on_error)
void SetPrintResults(bool print_results)
void HandleCommands(const StringList &commands, const ExecutionContext &context, const CommandInterpreterRunOptions &options, CommandReturnObject &result)
Execute a list of commands in sequence.
void SetInteractive(bool b)
void SetImmediateOutputStream(const lldb::StreamSP &stream_sp)
lldb::ReturnStatus GetStatus() const
Generic representation of a type in a programming language.
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.
llvm::StringRef GetStringRef() const
Get the string value as a llvm::StringRef.
const char * GetCString() const
Get the string value as a C string.
A subclass of DataBuffer that stores a data buffer on the heap.
lldb::offset_t GetByteSize() const override
Get the number of bytes in the data buffer.
void SetAsyncExecution(bool async)
CommandInterpreter & GetCommandInterpreter()
lldb::StreamUP GetAsyncErrorStream()
TargetList & GetTargetList()
Get accessor for the target list.
static llvm::ThreadPoolInterface & GetThreadPool()
Shared thread pool. Use only with ThreadPoolTaskGroup.
static void ReportError(std::string message, std::optional< lldb::user_id_t > debugger_id=std::nullopt, std::once_flag *once=nullptr)
Report error events.
PlatformList & GetPlatformList()
lldb::ListenerSP GetListener()
llvm::Error GetAsError(lldb::ExpressionResults result, llvm::Twine message={}) const
Returns an ExpressionError with arg as error code.
static lldb::DisassemblerSP DisassembleBytes(const ArchSpec &arch, const char *plugin_name, const char *flavor, const char *cpu, const char *features, const Address &start, const void *bytes, size_t length, uint32_t max_num_instructions, bool data_from_file)
A class that measures elapsed time in an exception safe way.
EvaluateExpressionOptions()
bool GetCppIgnoreContextQualifiers() const
void SetCppIgnoreContextQualifiers(bool value)
const StructuredData::Dictionary & GetLanguageOptions() const
llvm::Expected< bool > GetBooleanLanguageOption(llvm::StringRef option_name) const
Get the language-plugin specific boolean option called option_name.
llvm::Error SetBooleanLanguageOption(llvm::StringRef option_name, bool value)
Set language-plugin specific option called option_name to the specified boolean value.
StructuredData::DictionarySP m_language_options_sp
Dictionary mapping names of language-plugin specific options to values.
virtual llvm::StringRef GetFlavor() const =0
"lldb/Target/ExecutionContextScope.h" Inherit from this if your object can reconstruct its execution ...
virtual void CalculateExecutionContext(ExecutionContext &exe_ctx)=0
Reconstruct the object's execution context into sc.
"lldb/Target/ExecutionContext.h" A class that contains an execution context.
void Clear()
Clear the object's state.
void SetTargetPtr(Target *target)
Set accessor to set only the target shared pointer from a target pointer.
StackFrame * GetFramePtr() const
Returns a pointer to the frame object.
Target * GetTargetPtr() const
Returns a pointer to the target object.
Thread & GetThreadRef() const
Returns a reference to the thread object.
const FileSpec & GetFileSpec() const
const FileSpec & GetFileSpecAtIndex(size_t idx) const
Get file at index.
void Append(const FileSpec &file)
Append a FileSpec object to the list.
size_t GetSize() const
Get the number of files in the file list.
bool AppendIfUnique(const FileSpec &file)
Append a FileSpec object if unique.
void AppendPathComponent(llvm::StringRef component)
void SetDirectory(ConstString directory)
Directory string set accessor.
const ConstString & GetFilename() const
Filename string const get accessor.
const ConstString & GetDirectory() const
Directory string const get accessor.
void SetPath(llvm::StringRef p)
Temporary helper for FileSystem change.
size_t GetPath(char *path, size_t max_path_length, bool denormalize=true) const
Extract the full path to the file.
bool IsSourceImplementationFile() const
Returns true if the filespec represents an implementation source file (files with a "....
void SetFilename(ConstString filename)
Filename string set accessor.
bool Exists(const FileSpec &file_spec) const
Returns whether the given file exists.
bool IsDirectory(const FileSpec &file_spec) const
Returns whether the given path is a directory.
static FileSystem & Instance()
bool IsValid() const override
IsValid.
bool Test(ValueType bit) const
Test a single flag bit.
ValueType Set(ValueType mask)
Set one or more flags by logical OR'ing mask with the current flags.
Encapsulates a function that can be called.
static lldb::BreakpointSP CreateExceptionBreakpoint(Target &target, lldb::LanguageType language, bool catch_bp, bool throw_bp, bool is_internal=false)
static LanguageSet GetLanguagesSupportingREPLs()
static Language * FindPlugin(lldb::LanguageType language)
static const char * GetNameForLanguageType(lldb::LanguageType language)
Returns the internal LLDB name for the specified language.
static LanguageSet GetLanguagesSupportingTypeSystemsForExpressions()
virtual llvm::StringRef GetUserEntryPointName() const
static std::set< lldb::LanguageType > GetSupportedLanguages()
static lldb::ListenerSP MakeListener(const char *name)
A collection class for Module objects.
bool AnyOf(std::function< bool(lldb_private::Module &module)> const &callback) const
Returns true if 'callback' returns true for one of the modules in this ModuleList.
static Status GetSharedModule(const ModuleSpec &module_spec, lldb::ModuleSP &module_sp, llvm::SmallVectorImpl< lldb::ModuleSP > *old_modules, bool *did_create_ptr, bool invoke_locate_callback=true)
static bool RemoveSharedModuleIfOrphaned(const lldb::ModuleWP module_ptr)
void PreloadSymbols(bool parallelize) const
For each module in this ModuleList, preload its symbols.
bool AppendIfNeeded(const lldb::ModuleSP &new_module, bool notify=true)
Append a module to the module list, if it is not already there.
void FindModules(const ModuleSpec &module_spec, ModuleList &matching_module_list) const
Finds modules whose file specification matches module_spec.
lldb::ModuleSP GetModuleAtIndex(size_t idx) const
Get the module shared pointer for the module at index idx.
void Append(const lldb::ModuleSP &module_sp, bool notify=true)
Append a module to the module list.
size_t GetSize() const
Gets the size of the module list.
void ForEach(std::function< IterationAction(const lldb::ModuleSP &module_sp)> const &callback) const
Applies 'callback' to each module in this ModuleList.
void SetTarget(lldb::TargetSP target)
Set the target to be used when resolving a module.
A class that describes an executable image and its associated object and symbol files.
virtual ObjectFile * GetObjectFile()
Get the object file representation for the current architecture.
const FileSpec & GetFileSpec() const
Get const accessor for the module file specification.
A plug-in interface definition class for object file parsers.
virtual uint32_t GetDependentModules(FileSpecList &file_list)=0
Extract the dependent modules from an object file.
virtual lldb_private::Address GetEntryPointAddress()
Returns the address of the Entry Point in this object file - if the object file doesn't have an entry...
@ eTypeExecutable
A normal executable.
@ eTypeDebugInfo
An object file that contains only debug information.
@ eTypeStubLibrary
A library that can be linked against but not used for execution.
@ eTypeObjectFile
An intermediate object file.
@ eTypeDynamicLinker
The platform's dynamic linker executable.
@ eTypeCoreFile
A core file that has a checkpoint of a program's execution state.
@ eTypeSharedLibrary
A shared library that can be used during execution.
virtual size_t ReadSectionData(Section *section, lldb::offset_t section_offset, void *dst, size_t dst_len)
void AppendCurrentValue(const FileSpec &value)
const lldb::DataBufferSP & GetFileContents()
PathMappingList & GetCurrentValue()
auto GetPropertyAtIndexAs(size_t idx, const ExecutionContext *exe_ctx=nullptr) const
Property * ProtectedGetPropertyAtIndex(size_t idx)
bool SetPropertyAtIndex(size_t idx, T t, const ExecutionContext *exe_ctx=nullptr) const
static lldb::OptionValuePropertiesSP CreateLocalCopy(const Properties &global_properties)
bool RemapPath(ConstString path, ConstString &new_path) const
std::optional< llvm::StringRef > ReverseRemapPath(const FileSpec &file, FileSpec &fixed) const
Perform reverse source path remap for input file.
static std::unique_ptr< Architecture > CreateArchitectureInstance(const ArchSpec &arch)
static lldb::RegisterTypeBuilderSP GetRegisterTypeBuilder(Target &target)
bool ProcessInfoSpecified() const
lldb::ListenerSP GetListenerForProcess(Debugger &debugger)
llvm::StringRef GetProcessPluginName() const
void SetHijackListener(const lldb::ListenerSP &listener_sp)
void SetExecutableFile(const FileSpec &exe_file, bool add_exe_file_as_first_arg)
lldb::ScriptedMetadataSP GetScriptedMetadata() const
lldb::ListenerSP GetHijackListener() const
llvm::StringRef GetArg0() const
void SetScriptedMetadata(lldb::ScriptedMetadataSP metadata_sp)
FileSpec & GetExecutableFile()
lldb::ListenerSP GetListener() const
lldb::ListenerSP GetShadowListener() const
Environment & GetEnvironment()
bool IsScriptedProcess() const
ArchSpec & GetArchitecture()
llvm::StringRef GetProcessPluginName() const
const FileSpec & GetShell() const
llvm::Error SetUpPtyRedirection()
bool AppendOpenFileAction(int fd, const FileSpec &file_spec, bool read, bool write)
bool AppendSuppressFileAction(int fd, bool read, bool write)
const FileAction * GetFileActionForFD(int fd) const
void SetProcessPluginName(llvm::StringRef plugin)
static void SettingsInitialize()
static constexpr llvm::StringRef AttachSynchronousHijackListenerName
static lldb::ProcessSP FindPlugin(lldb::TargetSP target_sp, llvm::StringRef plugin_name, lldb::ListenerSP listener_sp, const FileSpec *crash_file_path, bool can_connect)
Find a Process plug-in that can debug module using the currently selected architecture.
static constexpr llvm::StringRef LaunchSynchronousHijackListenerName
static ProcessProperties & GetGlobalProperties()
static void SettingsTerminate()
A Progress indicator helper class.
lldb::OptionValuePropertiesSP m_collection_sp
T GetPropertyAtIndexAs(uint32_t idx, T default_value, const ExecutionContext *exe_ctx=nullptr) const
static llvm::StringRef GetExperimentalSettingsName()
bool SetPropertyAtIndex(uint32_t idx, T t, const ExecutionContext *exe_ctx=nullptr) const
lldb::OptionValuePropertiesSP GetValueProperties() const
const lldb::OptionValueSP & GetValue() const
static lldb::REPLSP Create(Status &Status, lldb::LanguageType language, Debugger *debugger, Target *target, const char *repl_options)
Get a REPL with an existing target (or, failing that, a debugger to use), and (optional) extra argume...
bool SignExtend(uint32_t bit_pos)
unsigned long long ULongLong(unsigned long long fail_value=0) const
long long SLongLong(long long fail_value=0) const
virtual lldb::ScriptedStopHookInterfaceSP CreateScriptedStopHookInterface()
size_t GetNumSections(uint32_t depth) const
lldb::SectionSP GetSectionAtIndex(size_t idx) const
void Dump(Stream &s, Target *target)
bool ResolveLoadAddress(lldb::addr_t load_addr, Address &so_addr, bool allow_section_end=false) const
lldb::addr_t GetSectionLoadAddress(const lldb::SectionSP §ion_sp) const
"lldb/Core/SourceLocationSpec.h" A source location specifier class.
Class that provides a registry of known stack frame recognizers.
virtual const SymbolContext & GetSymbolContext(lldb::SymbolContextItem resolve_scope)
Provide a SymbolContext for this StackFrame's current pc value.
void Clear()
Clear the object state.
static Status FromErrorStringWithFormat(const char *format,...) __attribute__((format(printf
static Status FromErrorString(const char *str)
bool Fail() const
Test for error condition.
static Status static Status FromErrorStringWithFormatv(const char *format, Args &&...args)
static Status FromError(llvm::Error error)
Avoid using this in new code. Migrate APIs to llvm::Expected instead.
bool Success() const
Test for success condition.
const char * GetData() const
llvm::StringRef GetString() const
A stream class that can stream formatted output to a file.
void Format(const char *format, Args &&... args)
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.
IndentScope MakeIndentScope(unsigned indent_amount=2)
Create an indentation scope that restores the original indent level when the object goes out of scope...
void IndentLess(unsigned amount=2)
Decrement the current indentation level.
void IndentMore(unsigned amount=2)
Increment the current indentation level.
void AddItem(const ObjectSP &item)
ObjectSP GetItemAtIndex(size_t idx) const
bool GetValueForKeyAsBoolean(llvm::StringRef key, bool &result) const
ObjectSP GetValueForKey(llvm::StringRef key) const
bool HasKey(llvm::StringRef key) const
void ForEach(std::function< bool(llvm::StringRef key, Object *object)> const &callback) const
virtual bool IsValid() const
void Dump(lldb_private::Stream &s, bool pretty_print=true) const
A class which can hold structured data.
std::shared_ptr< Object > ObjectSP
std::shared_ptr< Array > ArraySP
static ObjectSP ParseJSONFromFile(const FileSpec &file, Status &error)
A class that wraps a std::map of SummaryStatistics objects behind a mutex.
Defines a symbol context baton that can be handed other debug core functions.
lldb::TargetSP target_sp
The Target for a given query.
TargetExperimentalProperties()
lldb::TargetSP GetTargetAtIndex(uint32_t index) const
size_t GetNumTargets() const
uint32_t GetMaximumSizeOfStringSummary() const
FileSpecList GetDebugFileSearchPaths()
llvm::StringRef GetLaunchWorkingDirectory() const
bool GetDisplayRecognizedArguments() const
ImportStdModule GetImportStdModule() const
bool GetDisableSTDIO() const
bool GetMoveToNearestCode() const
~TargetProperties() override
void AppendExecutableSearchPaths(const FileSpec &)
void SetInheritTCC(bool b)
bool GetEnableSyntheticValue() const
void UpdateLaunchInfoFromProperties()
ProcessLaunchInfo m_launch_info
uint64_t GetExprAllocAlign() const
MemoryModuleLoadLevel GetMemoryModuleLoadLevel() const
llvm::StringRef GetArg0() const
uint32_t GetMaximumMemReadSize() const
void SetRunArguments(const Args &args)
FileSpec GetStandardErrorPath() const
bool GetEnableNotifyAboutFixIts() const
bool SetPreferDynamicValue(lldb::DynamicValueType d)
void SetDisplayRecognizedArguments(bool b)
std::optional< bool > GetExperimentalPropertyValue(size_t prop_idx, ExecutionContext *exe_ctx=nullptr) const
bool GetDisableASLR() const
bool GetUseFastStepping() const
const ProcessLaunchInfo & GetProcessLaunchInfo() const
Environment ComputeEnvironment() const
void Arg0ValueChangedCallback()
bool GetUserSpecifiedTrapHandlerNames(Args &args) const
uint64_t GetExprErrorLimit() const
bool GetEnableAutoImportClangModules() const
bool GetDebugUtilityExpression() const
void CheckJITObjectsDir()
bool GetSkipPrologue() const
DynamicClassInfoHelper GetDynamicClassInfoHelper() const
FileSpec GetStandardOutputPath() const
void InputPathValueChangedCallback()
void SetDisplayRuntimeSupportValues(bool b)
uint32_t GetMaximumNumberOfChildrenToDisplay() const
void SetRequireHardwareBreakpoints(bool b)
void SetDisableSTDIO(bool b)
bool GetAutoInstallMainExecutable() const
const char * GetDisassemblyFeatures() const
RealpathPrefixes GetSourceRealpathPrefixes() const
uint64_t GetNumberOfRetriesWithFixits() const
uint64_t GetExprAllocSize() const
llvm::StringRef GetExpressionPrefixContents()
PathMappingList & GetObjectPathMap() const
const char * GetDisassemblyFlavor() const
void SetPreloadSymbols(bool b)
FileSpec GetStandardInputPath() const
bool GetInheritTCC() const
void InheritTCCValueChangedCallback()
lldb::DynamicValueType GetPreferDynamicValue() const
void DisableSTDIOValueChangedCallback()
InlineStrategy GetInlineStrategy() const
Environment GetTargetEnvironment() const
bool GetDisplayRuntimeSupportValues() const
void SetDetachOnError(bool b)
void SetUserSpecifiedTrapHandlerNames(const Args &args)
bool GetUseHexImmediates() const
bool GetPreloadSymbols() const
uint32_t GetMaxZeroPaddingInFloatFormat() const
uint64_t GetExprAllocAddress() const
void DetachOnErrorValueChangedCallback()
LoadCWDlldbinitFile GetLoadCWDlldbinitFile() const
Environment GetInheritedEnvironment() const
void SetArg0(llvm::StringRef arg)
void EnvVarsValueChangedCallback()
bool GetInjectLocalVariables(ExecutionContext *exe_ctx) const
bool ShowHexVariableValuesWithLeadingZeroes() const
SourceLanguage GetLanguage() const
void OutputPathValueChangedCallback()
Environment GetEnvironment() const
void SetProcessLaunchInfo(const ProcessLaunchInfo &launch_info)
void RunArgsValueChangedCallback()
FileSpec GetSaveJITObjectsDir() const
void SetEnvironment(Environment env)
LoadScriptFromSymFile GetLoadScriptFromSymbolFile() const
const char * GetDisassemblyCPU() const
void SetStandardErrorPath(llvm::StringRef path)
bool GetRunArguments(Args &args) const
bool GetBreakpointsConsultPlatformAvoidList()
FileSpecList GetExecutableSearchPaths()
void SetDisableASLR(bool b)
ArchSpec GetDefaultArchitecture() const
Disassembler::HexImmediateStyle GetHexImmediateStyle() const
bool GetParallelModuleLoad() const
void SetUseDIL(ExecutionContext *exe_ctx, bool b)
std::unique_ptr< TargetExperimentalProperties > m_experimental_properties_up
FileSpecList GetClangModuleSearchPaths()
void SetStandardOutputPath(llvm::StringRef path)
void ErrorPathValueChangedCallback()
bool GetRequireHardwareBreakpoints() const
PathMappingList & GetSourcePathMap() const
bool GetAutoSourceMapRelative() const
bool GetUseDIL(ExecutionContext *exe_ctx) const
void SetDefaultArchitecture(const ArchSpec &arch)
void SetStandardInputPath(llvm::StringRef path)
TargetProperties(Target *target)
bool GetDisplayExpressionsInCrashlogs() const
void DisableASLRValueChangedCallback()
bool GetEnableAutoApplyFixIts() const
void SetDebugUtilityExpression(bool debug)
std::pair< uint32_t, bool > GetMaximumDepthOfChildrenToDisplay() const
Get the max depth value, augmented with a bool to indicate whether the depth is the default.
bool GetDetachOnError() const
std::unique_ptr< Architecture > m_plugin_up
const Arch & operator=(const ArchSpec &spec)
Arch(const ArchSpec &spec)
StringList & GetCommands()
void SetActionFromString(const std::string &strings)
void SetActionFromStrings(const std::vector< std::string > &strings)
StopHookResult HandleStop(ExecutionContext &exc_ctx, lldb::StreamSP output_sp) override
void GetSubclassDescription(Stream &s, lldb::DescriptionLevel level) const override
Status SetScriptCallback(std::string class_name, StructuredData::ObjectSP extra_args_sp)
StopHookResult HandleStop(ExecutionContext &exc_ctx, lldb::StreamSP output) override
void GetSubclassDescription(Stream &s, lldb::DescriptionLevel level) const override
StructuredDataImpl m_extra_args
This holds the dictionary of keys & values that can be used to parametrize any given callback's behav...
lldb::ScriptedStopHookInterfaceSP m_interface_sp
SymbolContextSpecifier * GetSpecifier()
void SetSpecifier(SymbolContextSpecifier *specifier)
std::unique_ptr< ThreadSpec > m_thread_spec_up
void SetThreadSpecifier(ThreadSpec *specifier)
ThreadSpec * GetThreadSpecifier()
lldb::TargetSP m_target_sp
StopHook(const StopHook &rhs)
bool ExecutionContextPasses(const ExecutionContext &exe_ctx)
lldb::TargetSP & GetTarget()
lldb::SymbolContextSpecifierSP m_specifier_sp
virtual void GetSubclassDescription(Stream &s, lldb::DescriptionLevel level) const =0
void GetDescription(Stream &s, lldb::DescriptionLevel level) const
void Dump(Stream *s) const override
static llvm::StringRef GetFlavorString()
static lldb::TargetSP GetCreatedTargetFromEvent(const Event *event_ptr)
static ModuleList GetModuleListFromEvent(const Event *event_ptr)
~TargetEventData() override
static const TargetEventData * GetEventDataFromEvent(const Event *event_ptr)
lldb::TargetSP m_created_target_sp
TargetEventData(const lldb::TargetSP &target_sp)
lldb::TargetSP m_target_sp
static lldb::TargetSP GetTargetFromEvent(const Event *event_ptr)
void ModulesDidLoad(ModuleList &module_list)
This call may preload module symbols, and may do so in parallel depending on the following target set...
lldb::ThreadSP CalculateThread() override
llvm::Expected< uint32_t > AddScriptedFrameProviderDescriptor(const ScriptedFrameProviderDescriptor &descriptor)
Add or update a scripted frame provider descriptor for this target.
StopHookCollection m_stop_hooks
Module * GetExecutableModulePointer()
void Dump(Stream *s, lldb::DescriptionLevel description_level)
Dump a description of this object to a Stream.
bool m_suppress_stop_hooks
void DisableAllBreakpoints(bool internal_also=false)
lldb::WatchpointSP CreateWatchpoint(lldb::addr_t addr, size_t size, const CompilerType *type, uint32_t kind, Status &error)
void ApplyNameToBreakpoints(BreakpointName &bp_name)
lldb::TraceSP GetTrace()
Get the Trace object containing processor trace information of this target.
PathMappingList & GetImageSearchPathList()
void FinalizeFileActions(ProcessLaunchInfo &info)
lldb::addr_t GetCallableLoadAddress(lldb::addr_t load_addr, AddressClass addr_class=AddressClass::eInvalid) const
Get load_addr as a callable code load address for this target.
lldb::addr_t GetOpcodeLoadAddress(lldb::addr_t load_addr, AddressClass addr_class=AddressClass::eInvalid) const
Get load_addr as an opcode for this target.
lldb::BreakpointSP CreateScriptedBreakpoint(const llvm::StringRef class_name, const FileSpecList *containingModules, const FileSpecList *containingSourceFiles, bool internal, bool request_hardware, StructuredData::ObjectSP extra_args_sp, Status *creation_error=nullptr)
static Target * GetTargetFromContexts(const ExecutionContext *exe_ctx_ptr, const SymbolContext *sc_ptr)
lldb::addr_t GetBreakableLoadAddress(lldb::addr_t addr)
void ClearDummySignals(Args &signal_names)
Clear the dummy signals in signal_names from the target, or all signals if signal_names is empty.
static void ImageSearchPathsChanged(const PathMappingList &path_list, void *baton)
llvm::Expected< lldb_private::Address > GetEntryPointAddress()
This method will return the address of the starting function for this binary, e.g.
bool IgnoreWatchpointByID(lldb::watch_id_t watch_id, uint32_t ignore_count)
lldb::BreakpointSP CreateFuncRegexBreakpoint(const FileSpecList *containingModules, const FileSpecList *containingSourceFiles, RegularExpression func_regexp, lldb::LanguageType requested_language, LazyBool skip_prologue, bool internal, bool request_hardware)
lldb::BreakpointSP GetBreakpointByID(lldb::break_id_t break_id)
std::shared_ptr< StopHook > StopHookSP
void SymbolsDidLoad(ModuleList &module_list)
bool ClearAllWatchpointHistoricValues()
const std::vector< StopHookSP > GetStopHooks(bool internal=false) const
void SetTrace(const lldb::TraceSP &trace_sp)
Set the Trace object containing processor trace information of this target.
BreakpointList & GetBreakpointList(bool internal=false)
CompilerType GetRegisterType(const std::string &name, const lldb_private::RegisterFlags &flags, uint32_t byte_size)
BreakpointNameList m_breakpoint_names
lldb_private::SummaryStatisticsCache & GetSummaryStatisticsCache()
lldb::addr_t GetSectionLoadAddress(const lldb::SectionSP §ion_sp)
llvm::StringRef GetABIName() const
Returns the name of the target's ABI plugin.
SourceManager & GetSourceManager()
lldb::SearchFilterSP GetSearchFilterForModuleList(const FileSpecList *containingModuleList)
StopHookSP GetStopHookByID(lldb::user_id_t uid)
llvm::StringMap< DummySignalValues > m_dummy_signals
These are used to set the signal state when you don't have a process and more usefully in the Dummy t...
lldb::ProcessSP m_process_sp
Debugger & GetDebugger() const
lldb::SearchFilterSP m_search_filter_sp
PersistentExpressionState * GetPersistentExpressionStateForLanguage(lldb::LanguageType language)
void UpdateSignalsFromDummy(lldb::UnixSignalsSP signals_sp, lldb::StreamSP warning_stream_sp)
Updates the signals in signals_sp using the stored dummy signals.
bool m_is_dummy_target
Used to not run stop hooks for expressions.
static bool UpdateSignalFromDummy(lldb::UnixSignalsSP signals_sp, const DummySignalElement &element)
PathMappingList m_image_search_paths
bool ModuleIsExcludedForUnconstrainedSearches(const FileSpec &module_spec)
Return whether this FileSpec corresponds to a module that should be considered for general searches.
lldb::StackFrameSP CalculateStackFrame() override
SectionLoadList & GetSectionLoadList()
lldb::addr_t GetPersistentSymbol(ConstString name)
void PrimeFromDummyTarget(Target &target)
bool RemoveScriptedFrameProviderDescriptor(uint32_t id)
Remove a scripted frame provider descriptor by id.
static void SettingsTerminate()
bool EnableWatchpointByID(lldb::watch_id_t watch_id)
bool ResolveFileAddress(lldb::addr_t load_addr, Address &so_addr)
bool ClearAllWatchpointHitCounts()
size_t ReadMemoryFromFileCache(const Address &addr, void *dst, size_t dst_len, Status &error)
void ClearAllLoadedSections()
std::vector< lldb::TypeSystemSP > GetScratchTypeSystems(bool create_on_demand=true)
size_t ReadScalarIntegerFromMemory(const Address &addr, uint32_t byte_size, bool is_signed, Scalar &scalar, Status &error, bool force_live_memory=false)
void AddNameToBreakpoint(BreakpointID &id, llvm::StringRef name, Status &error)
void DumpSectionLoadList(Stream &s)
void DeleteCurrentProcess()
BreakpointList m_internal_breakpoint_list
int64_t ReadSignedIntegerFromMemory(const Address &addr, size_t integer_byte_size, int64_t fail_value, Status &error, bool force_live_memory=false)
void DisableAllowedBreakpoints()
bool SetSectionUnloaded(const lldb::SectionSP §ion_sp)
lldb::TargetSP CalculateTarget() override
const lldb::ProcessSP & GetProcessSP() const
void ClearModules(bool delete_locations)
bool RemoveBreakpointByID(lldb::break_id_t break_id)
lldb::ModuleSP GetOrCreateModule(const ModuleSpec &module_spec, bool notify, Status *error_ptr=nullptr)
Find a binary on the system and return its Module, or return an existing Module that is already in th...
static bool ResetSignalFromDummy(lldb::UnixSignalsSP signals_sp, const DummySignalElement &element)
Architecture * GetArchitecturePlugin() const
llvm::json::Value ReportStatistics(const lldb_private::StatisticsOptions &options)
Get metrics associated with this target in JSON format.
FunctionCaller * GetFunctionCallerForLanguage(lldb::LanguageType language, const CompilerType &return_type, const Address &function_address, const ValueList &arg_value_list, const char *name, Status &error)
void EnableAllBreakpoints(bool internal_also=false)
Status Launch(ProcessLaunchInfo &launch_info, Stream *stream)
bool DisableBreakpointByID(lldb::break_id_t break_id)
lldb::BreakpointSP CreateBreakpointAtUserEntry(Status &error)
BreakpointName * FindBreakpointName(ConstString name, bool can_create, Status &error)
llvm::Expected< lldb::TraceSP > CreateTrace()
Create a Trace object for the current target using the using the default supported tracing technology...
lldb::TraceSP m_trace_sp
An optional lldb_private::Trace object containing processor trace information of this target.
bool RemoveAllWatchpoints(bool end_to_end=true)
bool ReadPointerFromMemory(const Address &addr, Status &error, Address &pointer_addr, bool force_live_memory=false)
void UndoCreateStopHook(lldb::user_id_t uid)
If you tried to create a stop hook, and that failed, call this to remove the stop hook,...
WatchpointList m_watchpoint_list
BreakpointList m_breakpoint_list
lldb::SourceManagerUP m_source_manager_up
bool RemoveWatchpointByID(lldb::watch_id_t watch_id)
bool ResolveLoadAddress(lldb::addr_t load_addr, Address &so_addr, uint32_t stop_id=SectionLoadHistory::eStopIDNow, bool allow_section_end=false)
size_t ReadStringFromMemory(const Address &addr, char *dst, size_t max_bytes, Status &error, size_t type_width, bool force_live_memory=true)
Read a NULL terminated string from memory.
const llvm::DenseMap< uint32_t, ScriptedFrameProviderDescriptor > & GetScriptedFrameProviderDescriptors() const
Get all scripted frame provider descriptors for this target.
void DeleteBreakpointName(ConstString name)
void NotifyWillClearList(const ModuleList &module_list) override
bool SetArchitecture(const ArchSpec &arch_spec, bool set_platform=false, bool merge=true)
Set the architecture for this target.
void NotifyModuleAdded(const ModuleList &module_list, const lldb::ModuleSP &module_sp) override
Implementing of ModuleList::Notifier.
llvm::Expected< lldb::TypeSystemSP > GetScratchTypeSystemForLanguage(lldb::LanguageType language, bool create_on_demand=true)
void ConfigureBreakpointName(BreakpointName &bp_name, const BreakpointOptions &options, const BreakpointName::Permissions &permissions)
lldb_private::SummaryStatisticsSP GetSummaryStatisticsSPForProviderName(lldb_private::TypeSummaryImpl &summary_provider)
lldb::SearchFilterSP GetSearchFilterForModuleAndCUList(const FileSpecList *containingModules, const FileSpecList *containingSourceFiles)
lldb::ModuleSP GetExecutableModule()
Gets the module for the main executable.
bool SetStopHookActiveStateByID(lldb::user_id_t uid, bool active_state)
const lldb::ProcessSP & CreateProcess(lldb::ListenerSP listener_sp, llvm::StringRef plugin_name, const FileSpec *crash_file, bool can_connect)
void SetAllStopHooksActiveState(bool active_state)
std::vector< StopHookSP > m_internal_stop_hooks
lldb::ExpressionVariableSP GetPersistentVariable(ConstString name)
void NotifyModulesRemoved(lldb_private::ModuleList &module_list) override
StopHookSP CreateStopHook(StopHook::StopHookKind kind, bool internal=false)
Add an empty stop hook to the Target's stop hook list, and returns a shared pointer to the new hook.
size_t ReadCStringFromMemory(const Address &addr, std::string &out_str, Status &error, bool force_live_memory=false)
std::recursive_mutex m_mutex
An API mutex that is used by the lldb::SB* classes make the SB interface thread safe.
std::recursive_mutex m_frame_provider_descriptors_mutex
lldb::user_id_t m_target_unique_id
The globally unique ID assigned to this target.
void ModulesDidUnload(ModuleList &module_list, bool delete_locations)
void CalculateExecutionContext(ExecutionContext &exe_ctx) override
Reconstruct the object's execution context into sc.
llvm::Expected< lldb::DisassemblerSP > ReadInstructions(const Address &start_addr, uint32_t count, const char *flavor_string=nullptr)
llvm::Expected< lldb::TraceSP > GetTraceOrCreate()
If a Trace object is present, this returns it, otherwise a new Trace is created with Trace::CreateTra...
void NotifyModuleUpdated(const ModuleList &module_list, const lldb::ModuleSP &old_module_sp, const lldb::ModuleSP &new_module_sp) override
SummaryStatisticsCache m_summary_statistics_cache
Status SerializeBreakpointsToFile(const FileSpec &file, const BreakpointIDList &bp_ids, bool append)
void DidExec()
Called as the last function in Process::DidExec().
void SaveScriptedLaunchInfo(lldb_private::ProcessInfo &process_info)
lldb::user_id_t m_stop_hook_next_id
void RemoveAllStopHooks()
static FileSpecList GetDefaultExecutableSearchPaths()
lldb::BreakpointSP CreateExceptionBreakpoint(enum lldb::LanguageType language, bool catch_bp, bool throw_bp, bool internal, Args *additional_args=nullptr, Status *additional_args_error=nullptr)
void NotifyBreakpointChanged(Breakpoint &bp, lldb::BreakpointEventType event_kind)
Sends a breakpoint notification event.
lldb::SearchFilterSP GetSearchFilterForModule(const FileSpec *containingModule)
llvm::StringMapEntry< DummySignalValues > DummySignalElement
std::recursive_mutex & GetAPIMutex()
static llvm::StringRef GetStaticBroadcasterClass()
static FileSpecList GetDefaultDebugFileSearchPaths()
void EnableAllowedBreakpoints()
virtual size_t ReadMemory(const Address &addr, void *dst, size_t dst_len, Status &error, bool force_live_memory=false, lldb::addr_t *load_addr_ptr=nullptr, bool *did_read_live_memory=nullptr)
llvm::Error SetLabel(llvm::StringRef label)
Set a label for a target.
uint32_t m_latest_stop_hook_id
void RemoveAllowedBreakpoints()
bool DisableAllWatchpoints(bool end_to_end=true)
bool RunStopHooks(bool at_initial_stop=false)
void ClearSectionLoadList()
lldb::addr_t GetReasonableReadSize(const Address &addr)
Return a recommended size for memory reads at addr, optimizing for cache usage.
lldb::PlatformSP m_platform_sp
The platform for this target.
llvm::Expected< std::unique_ptr< UtilityFunction > > CreateUtilityFunction(std::string expression, std::string name, lldb::LanguageType language, ExecutionContext &exe_ctx)
Creates and installs a UtilityFunction for the given language.
static TargetProperties & GetGlobalProperties()
Status Install(ProcessLaunchInfo *launch_info)
lldb::PlatformSP GetPlatform()
void NotifyModuleRemoved(const ModuleList &module_list, const lldb::ModuleSP &module_sp) override
lldb::BreakpointSP CreateAddressInModuleBreakpoint(lldb::addr_t file_addr, bool internal, const FileSpec &file_spec, bool request_hardware)
lldb::BreakpointSP CreateBreakpoint(const FileSpecList *containingModules, const FileSpec &file, uint32_t line_no, uint32_t column, lldb::addr_t offset, LazyBool check_inlines, LazyBool skip_prologue, bool internal, bool request_hardware, LazyBool move_to_nearest_code)
void RemoveAllBreakpoints(bool internal_also=false)
lldb::BreakpointSP CreateSourceRegexBreakpoint(const FileSpecList *containingModules, const FileSpecList *source_file_list, const std::unordered_set< std::string > &function_names, RegularExpression source_regex, bool internal, bool request_hardware, LazyBool move_to_nearest_code)
static ArchSpec GetDefaultArchitecture()
void ResetBreakpointHitCounts()
Resets the hit count of all breakpoints.
const ModuleList & GetImages() const
Get accessor for the images for this process.
const ArchSpec & GetArchitecture() const
WatchpointList & GetWatchpointList()
@ eBroadcastBitModulesLoaded
@ eBroadcastBitSymbolsLoaded
@ eBroadcastBitModulesUnloaded
@ eBroadcastBitWatchpointChanged
@ eBroadcastBitBreakpointChanged
@ eBroadcastBitNewTargetCreated
bool EnableBreakpointByID(lldb::break_id_t break_id)
uint64_t ReadUnsignedIntegerFromMemory(const Address &addr, size_t integer_byte_size, uint64_t fail_value, Status &error, bool force_live_memory=false)
void InvalidateThreadFrameProviders()
Invalidate all potentially cached frame providers for all threads and trigger a stack changed event f...
bool IgnoreAllWatchpoints(uint32_t ignore_count)
void AddBreakpoint(lldb::BreakpointSP breakpoint_sp, bool internal)
std::string m_target_session_name
The target session name for this target, used to name debugging sessions in DAP.
TypeSystemMap m_scratch_type_system_map
void AddBreakpointName(std::unique_ptr< BreakpointName > bp_name)
SectionLoadHistory m_section_load_history
void GetBreakpointNames(std::vector< std::string > &names)
Target(Debugger &debugger, const ArchSpec &target_arch, const lldb::PlatformSP &platform_sp, bool is_dummy_target)
Construct with optional file and arch.
size_t UnloadModuleSections(const lldb::ModuleSP &module_sp)
llvm::DenseMap< uint32_t, ScriptedFrameProviderDescriptor > m_frame_provider_descriptors
Map of scripted frame provider descriptors for this target.
bool m_valid
This records the last natural stop at which we ran a stop-hook.
bool DisableWatchpointByID(lldb::watch_id_t watch_id)
void AddDummySignal(llvm::StringRef name, LazyBool pass, LazyBool print, LazyBool stop)
Add a signal to the Target's list of stored signals/actions.
void ClearScriptedFrameProviderDescriptors()
Clear all scripted frame provider descriptors for this target.
lldb::WatchpointSP m_last_created_watchpoint
Status CreateBreakpointsFromFile(const FileSpec &file, BreakpointIDList &new_bps)
void SetREPL(lldb::LanguageType language, lldb::REPLSP repl_sp)
void SetExecutableModule(lldb::ModuleSP &module_sp, LoadDependentFiles load_dependent_files=eLoadDependentsDefault)
Set the main executable module.
lldb::StackFrameRecognizerManagerUP m_frame_recognizer_manager_up
Stores the frame recognizers of this target.
lldb::REPLSP GetREPL(Status &err, lldb::LanguageType language, const char *repl_options, bool can_create)
UserExpression * GetUserExpressionForLanguage(llvm::StringRef expr, llvm::StringRef prefix, SourceLanguage language, Expression::ResultType desired_type, const EvaluateExpressionOptions &options, ValueObject *ctx_obj, Status &error)
ModuleList m_images
The list of images for this process (shared libraries and anything dynamically loaded).
lldb::ProcessSP CalculateProcess() override
void PrintDummySignals(Stream &strm, Args &signals)
Print all the signals set in this target.
void SetPlatform(const lldb::PlatformSP &platform_sp)
bool SetSectionLoadAddress(const lldb::SectionSP §ion, lldb::addr_t load_addr, bool warn_multiple=false)
Status Attach(ProcessAttachInfo &attach_info, Stream *stream)
static void SetDefaultArchitecture(const ArchSpec &arch)
lldb::BreakpointSP m_last_created_breakpoint
void RemoveNameFromBreakpoint(lldb::BreakpointSP &bp_sp, ConstString name)
bool RemoveStopHookByID(lldb::user_id_t uid)
static void SettingsInitialize()
bool EnableAllWatchpoints(bool end_to_end=true)
std::recursive_mutex m_private_mutex
When the private state thread calls SB API's - usually because it is running OS plugin or Python Thre...
lldb::ExpressionResults EvaluateExpression(llvm::StringRef expression, ExecutionContextScope *exe_scope, lldb::ValueObjectSP &result_valobj_sp, const EvaluateExpressionOptions &options=EvaluateExpressionOptions(), std::string *fixed_expression=nullptr, ValueObject *ctx_obj=nullptr)
bool MergeArchitecture(const ArchSpec &arch_spec)
uint32_t GetSize(bool can_update=true)
lldb::ThreadSP GetThreadAtIndex(uint32_t idx, bool can_update=true)
@ eBroadcastBitStackChanged
static llvm::Expected< lldb::TraceSP > FindPluginForLiveProcess(llvm::StringRef plugin_name, Process &process)
Find a trace plug-in to trace a live process.
Represents UUID's of various sizes.
void Dump(Stream &s) const
Encapsulates a one-time expression for use in lldb.
static lldb::ExpressionResults Evaluate(ExecutionContext &exe_ctx, const EvaluateExpressionOptions &options, llvm::StringRef expr_cstr, llvm::StringRef expr_prefix, lldb::ValueObjectSP &result_valobj_sp, std::string *fixed_expression=nullptr, ValueObject *ctx_obj=nullptr)
Evaluate one expression in the scratch context of the target passed in the exe_ctx and return its res...
void GetListMutex(std::unique_lock< std::recursive_mutex > &lock)
Sets the passed in Locker to hold the Watchpoint List mutex.
uint8_t * GetBytes()
Get a pointer to the data.
#define LLDB_WATCH_TYPE_WRITE
#define LLDB_INVALID_BREAK_ID
#define LLDB_INVALID_SIGNAL_NUMBER
#define LLDB_INVALID_INDEX32
#define LLDB_WATCH_TYPE_IS_VALID(type)
#define LLDB_BREAK_ID_IS_INTERNAL(bid)
#define LLDB_WATCH_TYPE_MODIFY
#define LLDB_WATCH_TYPE_READ
#define LLDB_INVALID_ADDRESS
#define LLDB_INVALID_PROCESS_ID
@ SelectMostRelevantFrame
A class that represents a running process on the host machine.
@ eMemoryModuleLoadLevelPartial
@ eMemoryModuleLoadLevelComplete
@ eMemoryModuleLoadLevelMinimal
Log * GetLog(Cat mask)
Retrieve the Log object for the channel associated with the given log enum.
std::shared_ptr< SummaryStatistics > SummaryStatisticsSP
@ eLoadScriptFromSymFileTrue
@ eLoadScriptFromSymFileFalse
@ eLoadScriptFromSymFileWarn
static uint32_t bit(const uint32_t val, const uint32_t msbit)
@ eDynamicClassInfoHelperCopyRealizedClassList
@ eDynamicClassInfoHelperGetRealizedClassList
@ eDynamicClassInfoHelperAuto
@ eDynamicClassInfoHelperRealizedClassesStruct
OptionEnumValues GetDynamicValueTypes()
@ eImportStdModuleFallback
void LoadTypeSummariesForModule(lldb::ModuleSP module_sp)
Load type summaries embedded in the binary.
const char * StateAsCString(lldb::StateType state)
Converts a StateType to a C string.
llvm::ArrayRef< OptionEnumValueElement > OptionEnumValues
void LoadFormattersForModule(lldb::ModuleSP module_sp)
Load data formatters embedded in the binary.
@ eInlineBreakpointsNever
@ eInlineBreakpointsAlways
@ eInlineBreakpointsHeaders
std::shared_ptr< lldb_private::OptionValueProperties > OptionValuePropertiesSP
std::shared_ptr< lldb_private::Trace > TraceSP
std::shared_ptr< lldb_private::TypeSystem > TypeSystemSP
std::shared_ptr< lldb_private::ABI > ABISP
std::shared_ptr< lldb_private::StackFrame > StackFrameSP
std::shared_ptr< lldb_private::SearchFilter > SearchFilterSP
std::shared_ptr< lldb_private::BreakpointResolver > BreakpointResolverSP
DescriptionLevel
Description levels for "void GetDescription(Stream *, DescriptionLevel)" calls.
@ eDescriptionLevelVerbose
std::shared_ptr< lldb_private::Thread > ThreadSP
std::shared_ptr< lldb_private::ValueObject > ValueObjectSP
std::shared_ptr< lldb_private::ExpressionVariable > ExpressionVariableSP
std::shared_ptr< lldb_private::UnixSignals > UnixSignalsSP
std::shared_ptr< lldb_private::Platform > PlatformSP
StateType
Process and Thread States.
@ eStateConnected
Process is connected to remote debug services, but not launched or attached to anything yet.
@ eStateStopped
Process or thread is stopped and can be examined.
@ eStateAttaching
Process is currently trying to attach.
@ eStateExited
Process has exited and can't be examined.
std::shared_ptr< lldb_private::RegisterTypeBuilder > RegisterTypeBuilderSP
LanguageType
Programming language type.
@ eLanguageTypeMipsAssembler
Mips_Assembler.
@ eLanguageTypeUnknown
Unknown or invalid language value.
@ eLanguageTypeC
Non-standardized C, such as K&R.
std::shared_ptr< lldb_private::Stream > StreamSP
std::shared_ptr< lldb_private::Breakpoint > BreakpointSP
ExpressionResults
The results of expression evaluation.
std::shared_ptr< lldb_private::Process > ProcessSP
std::shared_ptr< lldb_private::BreakpointPrecondition > BreakpointPreconditionSP
std::shared_ptr< lldb_private::Event > EventSP
ReturnStatus
Command Return Status Types.
@ eReturnStatusSuccessContinuingResult
@ eReturnStatusSuccessContinuingNoResult
std::shared_ptr< lldb_private::Watchpoint > WatchpointSP
std::shared_ptr< lldb_private::Listener > ListenerSP
std::shared_ptr< lldb_private::DataBuffer > DataBufferSP
std::shared_ptr< lldb_private::Section > SectionSP
std::shared_ptr< lldb_private::Target > TargetSP
@ eStructuredDataTypeBoolean
std::shared_ptr< lldb_private::Module > ModuleSP
std::shared_ptr< lldb_private::EventData > EventDataSP
std::shared_ptr< lldb_private::REPL > REPLSP
A SmallBitVector that represents a set of source languages (lldb::LanguageType).
llvm::SmallBitVector bitvector
std::optional< lldb::LanguageType > GetSingularLanguage()
If the set contains a single language only, return it.
This struct contains the metadata needed to instantiate a frame provider and optional filters to cont...
uint32_t GetID() const
Get a unique identifier for this descriptor based on its contents.
llvm::StringRef GetName() const
Get the name of this descriptor (the scripted class name).
bool IsValid() const
Check if this descriptor has valid metadata for script-based providers.
A type-erased pair of llvm::dwarf::SourceLanguageName and version.
lldb::LanguageType AsLanguageType() const
llvm::StringRef GetDescription() const
UserID(lldb::user_id_t uid=LLDB_INVALID_UID)
Construct with optional user ID.
lldb::user_id_t GetID() const
Get accessor for the user ID.
std::string triple
The triple of this executable module.
bool is_start_entry
If true, this entry was emitted at the beginning of an event (eg., before the executable is set).
UUID uuid
The same as the executable-module's UUID.
lldb::pid_t pid
PID of the process owned by this target.
Helper RAII class for collecting telemetry.
void DispatchOnExit(llvm::unique_function< void(Info *info)> final_callback)
void DispatchNow(llvm::unique_function< void(Info *info)> populate_fields_cb)