71#include "llvm/ADT/ScopeExit.h"
72#include "llvm/ADT/SetVector.h"
73#include "llvm/Support/ThreadPool.h"
85struct ExecutableInstaller {
88 : m_platform{platform}, m_module{module},
89 m_local_file{m_module->GetFileSpec()},
90 m_remote_file{m_module->GetRemoteInstallFileSpec()} {}
92 void setupRemoteFile()
const { m_module->SetPlatformFileSpec(m_remote_file); }
96 const FileSpec m_local_file;
97 const FileSpec m_remote_file;
100struct MainExecutableInstaller {
103 ProcessLaunchInfo &launch_info)
104 : m_platform{platform}, m_module{module},
105 m_local_file{m_module->GetFileSpec()},
107 getRemoteFileSpec(m_platform, target, m_module, m_local_file)},
108 m_launch_info{launch_info} {}
110 void setupRemoteFile()
const {
111 m_module->SetPlatformFileSpec(m_remote_file);
114 m_platform->SetFilePermissions(m_remote_file, 0700 );
119 const FileSpec m_local_file;
120 const FileSpec m_remote_file;
125 const FileSpec &local_file) {
126 FileSpec remote_file =
module->GetRemoteInstallFileSpec();
127 if (remote_file || !target->GetAutoInstallMainExecutable())
133 remote_file = platform->GetRemoteWorkingDirectory();
139 ProcessLaunchInfo &m_launch_info;
145template <
typename Installer>
147 if (!installer.m_local_file || !installer.m_remote_file)
150 Status error = installer.m_platform->Install(installer.m_local_file,
151 installer.m_remote_file);
155 installer.setupRemoteFile();
172 static constexpr llvm::StringLiteral class_name(
"lldb.target");
201 static_cast<void *
>(
this));
204 "Target::Target created with architecture {0} ({1})",
206 target_arch.
GetTriple().getTriple().c_str());
214 LLDB_LOG(log,
"{0} Target::~Target()",
static_cast<void *
>(
this));
224 if (breakpoint_sp->IsInternal())
269 std::unique_lock<std::recursive_mutex> lock;
300 llvm::StringRef plugin_name,
307 listener_sp, crash_file, can_connect);
314 const char *repl_options,
bool can_create) {
322 language = *single_lang;
323 }
else if (repl_languages.
Empty()) {
325 "LLDB isn't configured with REPL support for any languages.");
329 "Multiple possible REPL languages. Please specify a language.");
334 REPLMap::iterator pos =
m_repl_map.find(language);
342 "Couldn't find an existing REPL for %s, and can't create a new one",
357 "Couldn't create a REPL for %s",
371 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
378 const bool notify =
false;
402 return abi_sp->GetPluginName();
435 shared_lib_filter.
Append(main_module_sp->GetFileSpec());
436 llvm::SetVector<std::string, std::vector<std::string>,
437 std::unordered_set<std::string>>
446 if (!entryPointName.empty())
447 entryPointNamesSet.insert(entryPointName);
449 if (entryPointNamesSet.empty()) {
455 nullptr, entryPointNamesSet.takeVector(),
456 eFunctionNameTypeFull,
466 bp_sp->SetOneShot(
true);
473 const std::unordered_set<std::string> &function_names,
477 containingModules, source_file_spec_list));
481 nullptr, std::move(source_regex), function_names,
482 !
static_cast<bool>(move_to_nearest_code)));
488 const FileSpec &file, uint32_t line_no,
491 LazyBool skip_prologue,
bool internal,
495 std::optional<llvm::StringRef> removed_prefix_opt =
497 if (!removed_prefix_opt)
498 remapped_file = file;
502 switch (inline_strategy) {
523 compile_unit_list.
Append(remapped_file);
536 !
static_cast<bool>(move_to_nearest_code));
541 nullptr, offset, skip_prologue, location_spec, removed_prefix_opt));
568 std::make_shared<SearchFilterForUnconstrainedSearches>(
571 std::make_shared<BreakpointResolverAddress>(
nullptr, addr);
578 bool request_hardware) {
580 std::make_shared<SearchFilterForUnconstrainedSearches>(
583 std::make_shared<BreakpointResolverAddress>(
nullptr, file_addr,
591 const FileSpecList *containingSourceFiles,
const char *func_name,
592 FunctionNameType func_name_type_mask,
LanguageType language,
594 bool internal,
bool hardware) {
598 containingModules, containingSourceFiles));
607 offset, offset_is_insn_count, skip_prologue));
616 const std::vector<std::string> &func_names,
617 FunctionNameType func_name_type_mask,
619 LazyBool skip_prologue,
bool internal,
bool hardware) {
621 size_t num_names = func_names.size();
624 containingModules, containingSourceFiles));
632 new BreakpointResolverName(
nullptr, func_names, func_name_type_mask,
633 language, offset, skip_prologue));
642 const char *func_names[],
size_t num_names,
643 FunctionNameType func_name_type_mask,
645 LazyBool skip_prologue,
bool internal,
bool hardware) {
649 containingModules, containingSourceFiles));
661 nullptr, func_names, num_names, func_name_type_mask, language, offset,
663 resolver_sp->SetOffset(offset);
672 if (containingModule !=
nullptr) {
675 filter_sp = std::make_shared<SearchFilterByModule>(shared_from_this(),
680 std::make_shared<SearchFilterForUnconstrainedSearches>(
690 if (containingModules && containingModules->
GetSize() != 0) {
693 filter_sp = std::make_shared<SearchFilterByModuleList>(shared_from_this(),
698 std::make_shared<SearchFilterForUnconstrainedSearches>(
708 if (containingSourceFiles ==
nullptr || containingSourceFiles->
GetSize() == 0)
712 if (containingModules ==
nullptr) {
716 filter_sp = std::make_shared<SearchFilterByModuleListAndCU>(
717 shared_from_this(),
FileSpecList(), *containingSourceFiles);
719 filter_sp = std::make_shared<SearchFilterByModuleListAndCU>(
720 shared_from_this(), *containingModules, *containingSourceFiles);
729 bool internal,
bool hardware) {
731 containingModules, containingSourceFiles));
734 :
static_cast<bool>(skip_prologue);
736 nullptr, std::move(func_regex), requested_language, 0, skip));
743 bool catch_bp,
bool throw_bp,
bool internal,
746 *
this, language, catch_bp, throw_bp, internal);
747 if (exc_bkpt_sp && additional_args) {
749 if (precondition_sp && additional_args) {
751 *
error = precondition_sp->ConfigurePrecondition(*additional_args);
753 precondition_sp->ConfigurePrecondition(*additional_args);
760 const llvm::StringRef class_name,
const FileSpecList *containingModules,
761 const FileSpecList *containingSourceFiles,
bool internal,
768 containingSourceFiles && containingSourceFiles->
GetSize() > 0;
769 bool has_modules = containingModules && containingModules->
GetSize() > 0;
771 if (has_files && has_modules) {
773 containingSourceFiles);
774 }
else if (has_files) {
777 }
else if (has_modules) {
780 filter_sp = std::make_shared<SearchFilterForUnconstrainedSearches>(
791 bool internal,
bool request_hardware,
792 bool resolve_indirect_symbols) {
794 if (filter_sp && resolver_sp) {
796 bp_sp.reset(
new Breakpoint(*
this, filter_sp, resolver_sp, hardware,
797 resolve_indirect_symbols));
798 resolver_sp->SetBreakpoint(bp_sp);
816 LLDB_LOGF(log,
"Target::%s (internal = %s) => break_id = %s\n",
817 __FUNCTION__, bp_sp->IsInternal() ?
"yes" :
"no", s.
GetData());
820 bp_sp->ResolveBreakpoint();
851 bp_sp->AddName(name);
856 std::make_pair(bp_name->GetName(), std::move(bp_name)));
862 if (!
error.Success())
867 return iter->second.get();
872 "Breakpoint name \"%s\" doesn't exist and "
873 "can_create is false.",
879 .insert(std::make_pair(name, std::make_unique<BreakpointName>(name)))
880 .first->second.get();
887 const char *name_cstr = name.
AsCString();
890 bp_sp->RemoveName(name_cstr);
908 llvm::Expected<std::vector<BreakpointSP>> expected_vector =
911 if (!expected_vector) {
913 llvm::toString(expected_vector.takeError()));
917 for (
auto bp_sp : *expected_vector)
924 names.push_back(bp_name_entry.first.AsCString());
934 std::optional<uint32_t> num_supported_hardware_watchpoints =
939 if (!num_supported_hardware_watchpoints)
942 if (*num_supported_hardware_watchpoints == 0) {
944 "Target supports (%u) hardware watchpoint slots.\n",
945 *num_supported_hardware_watchpoints);
958 "Target::%s (addr = 0x%8.8" PRIx64
" size = %" PRIu64
960 __FUNCTION__, addr, (uint64_t)size, kind);
971 "cannot set a watchpoint with watch_size of 0");
974 "invalid watch address: %" PRIu64, addr);
990 const bool notify =
false;
995 addr = abi->FixDataAddress(addr);
1009 std::unique_lock<std::recursive_mutex> lock;
1013 size_t old_size = matched_sp->GetByteSize();
1019 if (size == old_size && kind == old_type) {
1021 wp_sp->SetEnabled(
false, notify);
1030 wp_sp = std::make_shared<Watchpoint>(*
this, addr, size, type);
1031 wp_sp->SetWatchpointType(kind, notify);
1036 LLDB_LOGF(log,
"Target::%s (creation of watchpoint %s with id = %u)\n",
1037 __FUNCTION__,
error.Success() ?
"succeeded" :
"failed",
1052 LLDB_LOGF(log,
"Target::%s \n", __FUNCTION__);
1061 LLDB_LOGF(log,
"Target::%s (internal_also = %s)\n", __FUNCTION__,
1062 internal_also ?
"yes" :
"no");
1073 LLDB_LOGF(log,
"Target::%s (internal_also = %s)\n", __FUNCTION__,
1074 internal_also ?
"yes" :
"no");
1083 LLDB_LOGF(log,
"Target::%s", __FUNCTION__);
1090 LLDB_LOGF(log,
"Target::%s (internal_also = %s)\n", __FUNCTION__,
1091 internal_also ?
"yes" :
"no");
1100 LLDB_LOGF(log,
"Target::%s", __FUNCTION__);
1107 LLDB_LOGF(log,
"Target::%s (break_id = %i, internal = %s)\n", __FUNCTION__,
1127 LLDB_LOGF(log,
"Target::%s (break_id = %i, internal = %s)\n", __FUNCTION__,
1137 bp_sp->SetEnabled(
false);
1145 LLDB_LOGF(log,
"Target::%s (break_id = %i, internal = %s)\n", __FUNCTION__,
1156 bp_sp->SetEnabled(
true);
1176 std::string path(file.
GetPath());
1184 if (
error.Success()) {
1185 break_store_ptr = input_data_sp->
GetAsArray();
1186 if (!break_store_ptr) {
1188 "Tried to append to invalid input file %s", path.c_str());
1194 if (!break_store_ptr) {
1195 break_store_sp = std::make_shared<StructuredData::Array>();
1196 break_store_ptr = break_store_sp.get();
1203 lldb::eFilePermissionsFileDefault);
1210 std::unique_lock<std::recursive_mutex> lock;
1216 size_t num_breakpoints = breakpoints.
GetSize();
1217 for (
size_t i = 0; i < num_breakpoints; i++) {
1222 break_store_ptr->
AddItem(bkpt_save_sp);
1226 std::unordered_set<lldb::break_id_t> processed_bkpts;
1227 const size_t count = bp_ids.
GetSize();
1228 for (
size_t i = 0; i < count; ++i) {
1234 std::pair<std::unordered_set<lldb::break_id_t>::iterator,
bool>
1235 insert_result = processed_bkpts.insert(bp_id);
1236 if (!insert_result.second)
1243 if (!bkpt_save_sp) {
1245 "Unable to serialize breakpoint %d", bp_id);
1248 break_store_ptr->
AddItem(bkpt_save_sp);
1253 break_store_ptr->
Dump(out_file,
false);
1260 std::vector<std::string> no_names;
1265 std::vector<std::string> &names,
1267 std::unique_lock<std::recursive_mutex> lock;
1273 if (!
error.Success()) {
1275 }
else if (!input_data_sp || !input_data_sp->IsValid()) {
1277 "Invalid JSON from input file: %s.", file.
GetPath().c_str());
1284 "Invalid breakpoint data from input file: %s.", file.
GetPath().c_str());
1288 size_t num_bkpts = bkpt_array->
GetSize();
1289 size_t num_names = names.size();
1291 for (
size_t i = 0; i < num_bkpts; i++) {
1297 "Invalid breakpoint data for element %zu from input file: %s.", i,
1308 shared_from_this(), bkpt_data_sp,
error);
1309 if (!
error.Success()) {
1311 "Error restoring breakpoint %zu from %s: %s.", i,
1327 LLDB_LOGF(log,
"Target::%s\n", __FUNCTION__);
1356 LLDB_LOGF(log,
"Target::%s\n", __FUNCTION__);
1383 LLDB_LOGF(log,
"Target::%s\n", __FUNCTION__);
1409 LLDB_LOGF(log,
"Target::%s\n", __FUNCTION__);
1415 wp_sp->ResetHitCount();
1423 LLDB_LOGF(log,
"Target::%s\n", __FUNCTION__);
1429 wp_sp->ResetHistoricValues();
1438 LLDB_LOGF(log,
"Target::%s\n", __FUNCTION__);
1447 wp_sp->SetIgnoreCount(ignore_count);
1455 LLDB_LOGF(log,
"Target::%s (watch_id = %i)\n", __FUNCTION__, watch_id);
1474 LLDB_LOGF(log,
"Target::%s (watch_id = %i)\n", __FUNCTION__, watch_id);
1493 LLDB_LOGF(log,
"Target::%s (watch_id = %i)\n", __FUNCTION__, watch_id);
1508 uint32_t ignore_count) {
1510 LLDB_LOGF(log,
"Target::%s (watch_id = %i)\n", __FUNCTION__, watch_id);
1517 wp_sp->SetIgnoreCount(ignore_count);
1524 std::lock_guard<std::recursive_mutex> lock(
m_images.GetMutex());
1536 return m_images.GetModuleAtIndex(0);
1547 if (module_sp && !module_sp->LoadScriptingResourceInTarget(target,
error,
1549 if (
error.AsCString())
1551 "unable to load scripting data for module %s - error reported was "
1553 module_sp->GetFileSpec().GetFileNameStrippingExtension().GetCString(),
1556 if (feedback_stream.
GetSize())
1558 "%s\n", feedback_stream.
GetData());
1581 if (executable_sp) {
1584 pid = proc->GetID();
1588 info->
uuid = executable_sp->GetUUID();
1590 info->
triple = executable_sp->GetArchitecture().GetTriple().getTriple();
1596 info->
uuid = executable_sp->GetUUID();
1602 executable_sp->GetFileSpec().GetPath().c_str());
1604 const bool notify =
true;
1610 if (!
m_arch.GetSpec().IsValid()) {
1611 m_arch = executable_sp->GetArchitecture();
1613 "Target::SetExecutableModule setting architecture to {0} ({1}) "
1614 "based on executable file",
1615 m_arch.GetSpec().GetArchitectureName(),
1616 m_arch.GetSpec().GetTriple().getTriple());
1619 ObjectFile *executable_objfile = executable_sp->GetObjectFile();
1620 bool load_dependents =
true;
1621 switch (load_dependent_files) {
1623 load_dependents = executable_sp->IsExecutable();
1626 load_dependents =
true;
1629 load_dependents =
false;
1633 if (executable_objfile && load_dependents) {
1636 std::mutex dependent_files_mutex;
1641 auto GetDependentModules = [&](
FileSpec dependent_file_spec) {
1642 FileSpec platform_dependent_file_spec;
1644 m_platform_sp->GetFileWithUUID(dependent_file_spec,
nullptr,
1645 platform_dependent_file_spec);
1647 platform_dependent_file_spec = dependent_file_spec;
1652 if (image_module_sp) {
1654 ObjectFile *objfile = image_module_sp->GetObjectFile();
1660 std::lock_guard<std::mutex> guard(dependent_files_mutex);
1661 dependent_files_copy = dependent_files;
1666 const size_t previous_dependent_files =
1667 dependent_files_copy.
GetSize();
1672 std::lock_guard<std::mutex> guard(dependent_files_mutex);
1673 for (
size_t i = previous_dependent_files;
1674 i < dependent_files_copy.
GetSize(); ++i)
1685 for (uint32_t i = 0; i < dependent_files.
GetSize(); i++) {
1691 std::lock_guard<std::mutex> guard(dependent_files_mutex);
1692 for (; i < dependent_files.
GetSize(); i++)
1693 task_group.async(GetDependentModules,
1706 bool missing_local_arch = !
m_arch.GetSpec().IsValid();
1707 bool replace_local_arch =
true;
1708 bool compatible_local_arch =
false;
1717 if (!platform_sp || !platform_sp->IsCompatibleArchitecture(
1721 GetDebugger().GetPlatformList().GetOrCreate(other, {},
1723 arch_platform_sp->SetLocateModuleCallback(
1724 platform_sp->GetLocateModuleCallback());
1727 other = platform_arch;
1733 if (!missing_local_arch) {
1734 if (merge &&
m_arch.GetSpec().IsCompatibleMatch(arch_spec)) {
1737 if (
m_arch.GetSpec().IsCompatibleMatch(other)) {
1738 compatible_local_arch =
true;
1741 replace_local_arch =
false;
1746 if (compatible_local_arch || missing_local_arch) {
1750 if (replace_local_arch)
1753 "Target::SetArchitecture merging compatible arch; arch "
1755 m_arch.GetSpec().GetArchitectureName(),
1756 m_arch.GetSpec().GetTriple().getTriple());
1764 "Target::SetArchitecture changing architecture to %s (%s) from %s (%s)",
1766 arch_spec.
GetTriple().getTriple().c_str(),
1767 m_arch.GetSpec().GetArchitectureName(),
1768 m_arch.GetSpec().GetTriple().getTriple().c_str());
1775 if (executable_sp) {
1777 "Target::SetArchitecture Trying to select executable file "
1778 "architecture %s (%s)",
1780 arch_spec.
GetTriple().getTriple().c_str());
1781 ModuleSpec module_spec(executable_sp->GetFileSpec(), other);
1782 module_spec.
SetTarget(shared_from_this());
1786 if (!
error.Fail() && executable_sp) {
1797 if (
m_arch.GetSpec().IsCompatibleMatch(arch_spec)) {
1802 "Target::MergeArchitecture target has arch %s, merging with "
1804 m_arch.GetSpec().GetTriple().getTriple().c_str(),
1805 arch_spec.
GetTriple().getTriple().c_str());
1826 my_module_list.
Append(module_sp);
1836 my_module_list.
Append(module_sp);
1849 old_module_sp, new_module_sp);
1858 const size_t num_images = module_list.
GetSize();
1860 for (
size_t idx = 0; idx < num_images; ++idx) {
1872 std::make_shared<TargetEventData>(shared_from_this(), module_list);
1881 runtime->SymbolsDidLoad(module_list);
1888 std::make_shared<TargetEventData>(shared_from_this(), module_list);
1897 std::make_shared<TargetEventData>(shared_from_this(), module_list);
1911 const bool should_flush_type_systems =
1913 auto *object_file =
module.GetObjectFile();
1918 auto type = object_file->GetType();
1922 return module.FileHasChanged() &&
1923 (type == ObjectFile::eTypeObjectFile ||
1924 type == ObjectFile::eTypeExecutable ||
1925 type == ObjectFile::eTypeSharedLibrary);
1928 if (should_flush_type_systems)
1934 const FileSpec &module_file_spec) {
1939 size_t num_modules = matchingModules.
GetSize();
1943 if (num_modules > 0) {
1944 for (
size_t i = 0; i < num_modules; i++) {
1959 return m_platform_sp->ModuleIsExcludedForUnconstrainedSearches(*
this,
1971 if (section_sp->IsEncrypted()) {
1975 ModuleSP module_sp(section_sp->GetModule());
1980 section_sp.get(), addr.
GetOffset(), dst, dst_len);
1985 "error reading data from section %s",
1986 section_sp->GetName().GetCString());
1993 "address doesn't contain a section that points to a "
1994 "section in a object file");
2002 bool *did_read_live_memory) {
2004 if (did_read_live_memory)
2005 *did_read_live_memory =
false;
2018 size_t bytes_read = 0;
2025 if (section_load_list.
IsEmpty()) {
2031 m_images.ResolveFileAddress(file_addr, resolved_addr);
2044 resolved_addr = fixed_addr;
2049 std::unique_ptr<uint8_t[]> file_cache_read_buffer;
2050 size_t file_cache_bytes_read = 0;
2056 auto permissions =
Flags(section_sp->GetPermissions());
2057 bool is_readonly = !permissions.Test(ePermissionsWritable) &&
2058 permissions.Test(ePermissionsReadable);
2060 file_cache_bytes_read =
2062 if (file_cache_bytes_read == dst_len)
2063 return file_cache_bytes_read;
2064 else if (file_cache_bytes_read > 0) {
2065 file_cache_read_buffer =
2066 std::make_unique<uint8_t[]>(file_cache_bytes_read);
2067 std::memcpy(file_cache_read_buffer.get(), dst, file_cache_bytes_read);
2079 if (addr_module_sp && addr_module_sp->GetFileSpec())
2081 "{0:F}[{1:x+}] can't be resolved, {0:F} is not currently loaded",
2085 "0x%" PRIx64
" can't be resolved", resolved_addr.
GetFileAddress());
2088 if (bytes_read != dst_len) {
2089 if (
error.Success()) {
2090 if (bytes_read == 0)
2092 "read memory from 0x%" PRIx64
" failed", load_addr);
2095 "only %" PRIu64
" of %" PRIu64
2096 " bytes were read from memory at 0x%" PRIx64,
2097 (uint64_t)bytes_read, (uint64_t)dst_len, load_addr);
2102 *load_addr_ptr = load_addr;
2103 if (did_read_live_memory)
2104 *did_read_live_memory =
true;
2110 if (file_cache_read_buffer && file_cache_bytes_read > 0) {
2113 std::memcpy(dst, file_cache_read_buffer.get(), file_cache_bytes_read);
2114 return file_cache_bytes_read;
2136 out_str.append(buf, length);
2139 if (length ==
sizeof(buf) - 1)
2140 curr_addr += length;
2145 return out_str.size();
2149 size_t dst_max_len,
Status &result_error,
2150 bool force_live_memory) {
2151 size_t total_cstr_len = 0;
2152 if (dst && dst_max_len) {
2153 result_error.
Clear();
2155 memset(dst, 0, dst_max_len);
2162 const size_t cache_line_size = 512;
2164 size_t bytes_left = dst_max_len - 1;
2165 char *curr_dst = dst;
2167 while (bytes_left > 0) {
2168 addr_t cache_line_bytes_left =
2169 cache_line_size - (curr_addr % cache_line_size);
2171 std::min<addr_t>(bytes_left, cache_line_bytes_left);
2173 size_t bytes_read =
ReadMemory(address, curr_dst, bytes_to_read,
error,
2176 if (bytes_read == 0) {
2177 result_error = std::move(
error);
2178 dst[total_cstr_len] =
'\0';
2181 const size_t len = strlen(curr_dst);
2183 total_cstr_len += len;
2185 if (len < bytes_to_read)
2188 curr_dst += bytes_read;
2189 curr_addr += bytes_read;
2190 bytes_left -= bytes_read;
2197 result_error.
Clear();
2199 return total_cstr_len;
2207 return cache_line_size - (load_addr % cache_line_size);
2217 size_t type_width,
bool force_live_memory) {
2218 if (!dst || !max_bytes || !type_width || max_bytes < type_width)
2221 size_t total_bytes_read = 0;
2225 memset(dst, 0, max_bytes);
2226 size_t bytes_left = max_bytes - type_width;
2228 const char terminator[4] = {
'\0',
'\0',
'\0',
'\0'};
2229 assert(
sizeof(terminator) >= type_width &&
"Attempting to validate a "
2230 "string with more than 4 bytes "
2234 char *curr_dst = dst;
2237 while (bytes_left > 0 &&
error.Success()) {
2241 ReadMemory(address, curr_dst, bytes_to_read,
error, force_live_memory);
2243 if (bytes_read == 0)
2248 size_t aligned_start = total_bytes_read - total_bytes_read % type_width;
2249 for (
size_t i = aligned_start;
2250 i + type_width <= total_bytes_read + bytes_read; i += type_width)
2251 if (::memcmp(&dst[i], terminator, type_width) == 0) {
2256 total_bytes_read += bytes_read;
2257 curr_dst += bytes_read;
2258 address.
Slide(bytes_read);
2259 bytes_left -= bytes_read;
2261 return total_bytes_read;
2265 bool is_signed,
Scalar &scalar,
2267 bool force_live_memory) {
2270 if (byte_size <=
sizeof(uval)) {
2273 if (bytes_read == byte_size) {
2275 m_arch.GetSpec().GetAddressByteSize());
2278 scalar = data.
GetMaxU32(&offset, byte_size);
2280 scalar = data.
GetMaxU64(&offset, byte_size);
2288 "byte size of %u is too large for integer scalar type", byte_size);
2294 size_t integer_byte_size,
2296 bool force_live_memory) {
2305 size_t integer_byte_size,
2307 bool force_live_memory) {
2317 bool force_live_memory) {
2320 false, scalar,
error, force_live_memory)) {
2324 if (section_load_list.
IsEmpty()) {
2327 m_images.ResolveFileAddress(pointer_vm_addr, pointer_addr);
2338 pointer_addr.
SetOffset(pointer_vm_addr);
2346 bool notify,
Status *error_ptr) {
2353 module_spec.
SetTarget(shared_from_this());
2355 if (std::optional<FileSpec> remapped_obj_file =
2366 module_sp =
m_images.FindFirstModule(module_spec);
2369 llvm::SmallVector<ModuleSP, 1>
2372 bool did_create_module =
false;
2382 module_spec, module_sp, symbol_file_spec, &did_create_module);
2412 transformed_spec.
SetTarget(shared_from_this());
2414 &old_modules, &did_create_module);
2431 &old_modules, &did_create_module);
2439 module_spec,
m_process_sp.get(), module_sp, &old_modules,
2440 &did_create_module);
2451 ObjectFile *objfile = module_sp->GetObjectFile();
2467 "debug info files aren't valid target "
2468 "modules, please specify an executable");
2475 "stub libraries aren't valid target "
2476 "modules, please specify an executable");
2481 "unsupported file type, please specify an executable");
2500 m_images.FindModules(module_spec_copy, found_modules);
2502 old_modules.push_back(found_module);
2509 if (symbol_file_spec)
2510 module_sp->SetSymbolFileFileSpec(symbol_file_spec);
2515 module_sp->PreloadSymbols();
2516 llvm::SmallVector<ModuleSP, 1> replaced_modules;
2517 for (
ModuleSP &old_module_sp : old_modules) {
2518 if (
m_images.GetIndexForModule(old_module_sp.get()) !=
2520 if (replaced_modules.empty())
2521 m_images.ReplaceModule(old_module_sp, module_sp);
2525 replaced_modules.push_back(std::move(old_module_sp));
2529 if (replaced_modules.size() > 1) {
2542 auto dump = [&message](
Module &dump_module) ->
void {
2543 UUID dump_uuid = dump_module.GetUUID();
2547 message <<
" (uuid ";
2550 dump_uuid.
Dump(message);
2552 message <<
"not specified";
2557 message <<
"New module ";
2560 << llvm::formatv(
" simultaneously replaced {0} old modules: ",
2561 replaced_modules.size());
2562 for (
ModuleSP &replaced_module_sp : replaced_modules)
2563 dump(*replaced_module_sp);
2569 if (replaced_modules.empty())
2570 m_images.Append(module_sp, notify);
2572 for (
ModuleSP &old_module_sp : replaced_modules) {
2573 auto old_module_wp = old_module_sp->weak_from_this();
2574 old_module_sp.reset();
2582 *error_ptr = std::move(
error);
2611llvm::Expected<lldb::TypeSystemSP>
2613 bool create_on_demand) {
2615 return llvm::createStringError(
"Invalid Target");
2627 if (languages_for_expressions.
Empty())
2628 return llvm::createStringError(
2629 "No expression support for any languages");
2640 uint32_t byte_size) {
2643 return provider->GetRegisterType(name, flags, byte_size);
2646std::vector<lldb::TypeSystemSP>
2654 std::vector<lldb::TypeSystemSP> scratch_type_systems;
2659 for (
auto bit : languages_for_expressions.
bitvector.set_bits()) {
2661 auto type_system_or_err =
2663 if (!type_system_or_err)
2666 "Language '{1}' has expression support but no scratch type "
2667 "system available: {0}",
2670 if (
auto ts = *type_system_or_err)
2671 scratch_type_systems.push_back(ts);
2674 std::sort(scratch_type_systems.begin(), scratch_type_systems.end());
2675 scratch_type_systems.erase(llvm::unique(scratch_type_systems),
2676 scratch_type_systems.end());
2677 return scratch_type_systems;
2684 if (
auto err = type_system_or_err.takeError()) {
2687 "Unable to get persistent expression state for language {1}: {0}",
2692 if (
auto ts = *type_system_or_err)
2693 return ts->GetPersistentExpressionState();
2696 "Unable to get persistent expression state for language {1}: {0}",
2702 llvm::StringRef expr, llvm::StringRef prefix,
SourceLanguage language,
2706 auto type_system_or_err =
2708 if (
auto err = type_system_or_err.takeError()) {
2710 "Could not find type system for language %s: %s",
2712 llvm::toString(std::move(err)).c_str());
2716 auto ts = *type_system_or_err;
2719 "Type system for language %s is no longer live",
2724 auto *user_expr = ts->GetUserExpression(expr, prefix, language, desired_type,
2728 "Could not create an expression for language %s",
2739 if (
auto err = type_system_or_err.takeError()) {
2741 "Could not find type system for language %s: %s",
2743 llvm::toString(std::move(err)).c_str());
2746 auto ts = *type_system_or_err;
2749 "Type system for language %s is no longer live",
2753 auto *persistent_fn = ts->GetFunctionCaller(return_type, function_address,
2754 arg_value_list, name);
2757 "Could not create an expression for language %s",
2760 return persistent_fn;
2763llvm::Expected<std::unique_ptr<UtilityFunction>>
2768 if (!type_system_or_err)
2769 return type_system_or_err.takeError();
2770 auto ts = *type_system_or_err;
2772 return llvm::createStringError(
2773 llvm::StringRef(
"Type system for language ") +
2775 llvm::StringRef(
" is no longer live"));
2776 std::unique_ptr<UtilityFunction> utility_fn =
2777 ts->CreateUtilityFunction(std::move(expression), std::move(name));
2779 return llvm::createStringError(
2780 llvm::StringRef(
"Could not create an expression for language") +
2784 if (!utility_fn->Install(diagnostics, exe_ctx))
2786 "Could not install utility function:");
2788 return std::move(utility_fn);
2809 "setting target's default architecture to {0} ({1})",
2816 if (llvm::to_integer(label, n))
2817 return llvm::createStringError(
"Cannot use integer as target label.");
2821 if (target_sp && target_sp->GetLabel() == label) {
2822 return llvm::make_error<llvm::StringError>(
2824 "Cannot use label '{0}' since it's set in target #{1}.", label,
2826 llvm::inconvertibleErrorCode());
2831 return llvm::Error::success();
2840 Target *target =
nullptr;
2841 if (sc_ptr !=
nullptr)
2843 if (target ==
nullptr && exe_ctx_ptr)
2853 result_valobj_sp.reset();
2858 m_stats.GetExpressionStats().NotifyFailure();
2859 return execution_results;
2865 auto on_exit = llvm::make_scope_exit([
this, old_suppress_value]() {
2883 if (expr[0] ==
'$') {
2884 auto type_system_or_err =
2886 if (
auto err = type_system_or_err.takeError()) {
2888 "Unable to get scratch type system");
2890 auto ts = *type_system_or_err;
2893 "Scratch type system is no longer live: {0}");
2896 ts->GetPersistentExpressionState()->GetVariable(expr);
2899 if (persistent_var_sp) {
2900 result_valobj_sp = persistent_var_sp->GetValueObject();
2906 result_valobj_sp, fixed_expression, ctx_obj);
2910 m_stats.GetExpressionStats().NotifySuccess();
2912 m_stats.GetExpressionStats().NotifyFailure();
2913 return execution_results;
2919 [name, &variable_sp](
TypeSystemSP type_system) ->
bool {
2920 auto ts = type_system.get();
2924 ts->GetPersistentExpressionState()) {
2925 variable_sp = persistent_state->GetVariable(name);
2940 auto ts = type_system.get();
2945 ts->GetPersistentExpressionState()) {
2946 address = persistent_state->LookupSymbol(name);
2959 const bool has_primary_executable = exe_module && exe_module->
GetObjectFile();
2960 if (has_primary_executable) {
2967 const size_t num_images = modules.
GetSize();
2968 for (
size_t idx = 0; idx < num_images; ++idx) {
2970 if (!module_sp || !module_sp->GetObjectFile())
2973 Address entry_addr = module_sp->GetObjectFile()->GetEntryPointAddress();
2979 if (!has_primary_executable)
2980 return llvm::createStringError(
2981 "No primary executable found and could not find entry point address in "
2982 "any executable module");
2984 return llvm::createStringError(
2985 "Could not find entry point address for primary executable module \"" +
2993 ? arch_plugin->GetCallableLoadAddress(load_addr, addr_class)
3000 return arch_plugin ? arch_plugin->GetOpcodeLoadAddress(load_addr, addr_class)
3006 return arch_plugin ? arch_plugin->GetBreakableLoadAddress(addr, *
this) : addr;
3009llvm::Expected<lldb::DisassemblerSP>
3011 const char *flavor_string) {
3013 bool force_live_memory =
true;
3016 const size_t bytes_read =
3018 force_live_memory, &load_addr);
3021 return llvm::createStringError(
3022 error.AsCString(
"Target::ReadInstructions failed to read memory at %s"),
3026 if (!flavor_string || flavor_string[0] ==
'\0') {
3031 if (arch == llvm::Triple::x86 || arch == llvm::Triple::x86_64)
3059 stop_hook_sp.reset(
new StopHookCoded(shared_from_this(), new_uid));
3066 return stop_hook_sp;
3078 return (num_removed != 0);
3086 StopHookCollection::iterator specified_hook_iter;
3089 found_hook = (*specified_hook_iter).second;
3094 bool active_state) {
3095 StopHookCollection::iterator specified_hook_iter;
3100 (*specified_hook_iter).second->SetIsActive(active_state);
3105 StopHookCollection::iterator pos, end =
m_stop_hooks.end();
3107 (*pos).second->SetIsActive(active_state);
3116const std::vector<Target::StopHookSP>
3121 std::vector<StopHookSP> stop_hooks;
3123 stop_hooks.push_back(hook);
3141 auto is_active = [at_initial_stop](
StopHookSP hook) {
3142 bool should_run_now = (!at_initial_stop || hook->GetRunAtInitialStop());
3143 return hook->IsActive() && should_run_now;
3147 std::vector<StopHookSP> active_hooks;
3151 if (is_active(hook))
3152 active_hooks.push_back(hook);
3154 if (active_hooks.empty())
3163 uint32_t last_natural_stop =
m_process_sp->GetModIDRef().GetLastNaturalStopID();
3169 std::vector<ExecutionContext> exc_ctx_with_reasons;
3172 size_t num_threads = cur_threadlist.
GetSize();
3173 for (
size_t i = 0; i < num_threads; i++) {
3175 if (cur_thread_sp->ThreadStoppedForAReason()) {
3177 exc_ctx_with_reasons.emplace_back(
m_process_sp.get(), cur_thread_sp.get(),
3178 cur_frame_sp.get());
3187 size_t num_exe_ctx = exc_ctx_with_reasons.size();
3188 if (num_exe_ctx == 0) {
3189 if (at_initial_stop && num_threads > 0) {
3191 exc_ctx_with_reasons.emplace_back(
3193 thread_to_use_sp->GetStackFrameAtIndex(0).get());
3201 auto on_exit = llvm::make_scope_exit([output_sp] { output_sp->Flush(); });
3203 size_t num_hooks_with_output = llvm::count_if(
3204 active_hooks, [](
auto h) {
return !h->GetSuppressOutput(); });
3205 bool print_hook_header = (num_hooks_with_output > 1);
3206 bool print_thread_header = (num_exe_ctx > 1);
3207 bool should_stop =
false;
3208 bool requested_continue =
false;
3215 for (
auto cur_hook_sp : active_hooks) {
3216 bool any_thread_matched =
false;
3217 for (
auto exc_ctx : exc_ctx_with_reasons) {
3218 if (!cur_hook_sp->ExecutionContextPasses(exc_ctx))
3221 bool suppress_output = cur_hook_sp->GetSuppressOutput();
3222 if (print_hook_header && !any_thread_matched && !suppress_output) {
3226 output_sp->
Printf(
"\n- Hook %" PRIu64
" (%s)\n", cur_hook_sp->GetID(),
3229 output_sp->Printf(
"\n- Hook %" PRIu64
"\n", cur_hook_sp->GetID());
3230 any_thread_matched =
true;
3233 if (print_thread_header && !suppress_output)
3234 output_sp->Printf(
"-- Thread %d\n",
3235 exc_ctx.GetThreadPtr()->GetIndexID());
3237 auto result = cur_hook_sp->HandleStop(exc_ctx, output_sp);
3240 if (cur_hook_sp->GetAutoContinue())
3241 requested_continue =
true;
3246 requested_continue =
true;
3255 output_sp->Printf(
"\nAborting stop hooks, hook %" PRIu64
3256 " set the program running.\n"
3257 " Consider using '-G true' to make "
3258 "stop hooks auto-continue.\n",
3259 cur_hook_sp->GetID());
3270 if (requested_continue && !should_stop) {
3273 if (
error.Success()) {
3274 LLDB_LOG(log,
"Resuming from RunStopHooks");
3277 LLDB_LOG(log,
"Resuming from RunStopHooks failed: {0}",
error);
3290 return *g_settings_ptr;
3296 if (!platform_sp || !platform_sp->IsRemote() || !platform_sp->IsConnected())
3306 MainExecutableInstaller installer{platform_sp, module_sp,
3307 shared_from_this(), *launch_info};
3310 ExecutableInstaller installer{platform_sp, module_sp};
3322 uint32_t stop_id,
bool allow_section_end) {
3329 return m_images.ResolveFileAddress(file_addr, resolved_addr);
3333 addr_t new_section_load_addr,
3334 bool warn_multiple) {
3335 const addr_t old_section_load_addr =
3338 if (old_section_load_addr != new_section_load_addr) {
3339 uint32_t stop_id = 0;
3342 stop_id = process_sp->GetStopID();
3346 stop_id, section_sp, new_section_load_addr, warn_multiple))
3353 size_t section_unload_count = 0;
3354 size_t num_modules = module_list.
GetSize();
3355 for (
size_t i = 0; i < num_modules; ++i) {
3356 section_unload_count +=
3359 return section_unload_count;
3363 uint32_t stop_id = 0;
3366 stop_id = process_sp->GetStopID();
3369 SectionList *sections = module_sp->GetSectionList();
3370 size_t section_unload_count = 0;
3373 for (uint32_t i = 0; i < num_sections; ++i) {
3378 return section_unload_count;
3382 uint32_t stop_id = 0;
3385 stop_id = process_sp->GetStopID();
3393 uint32_t stop_id = 0;
3396 stop_id = process_sp->GetStopID();
3427 m_stats.SetLaunchOrAttachTime();
3431 LLDB_LOGF(log,
"Target::%s() called for %s", __FUNCTION__,
3443 state = process_sp->GetState();
3445 "Target::%s the process exists, and its current state is %s",
3448 LLDB_LOGF(log,
"Target::%s the process instance doesn't currently exist.",
3461 const bool synchronous_execution =
3469 if (launch_info.
GetFlags().
Test(eLaunchFlagLaunchInTTY))
3471 "can't launch in tty when launching through a remote connection");
3489 LLDB_LOGF(log,
"Target::%s asking the platform to debug the process",
3503 "Target::%s the platform doesn't know how to debug a "
3504 "process, getting a process plugin to do this for us.",
3523 if (!
error.Success())
3529 bool rebroadcast_first_stop =
3530 !synchronous_execution &&
3536 state =
m_process_sp->WaitForProcessToStop(std::nullopt, &first_stop_event_sp,
3537 rebroadcast_first_stop,
3541 if (rebroadcast_first_stop) {
3544 assert(first_stop_event_sp);
3553 if (launch_info.
GetFlags().
Test(eLaunchFlagStopAtEntry))
3555 if (synchronous_execution)
3562 if (!
error.Success()) {
3564 "process resume at entry point failed: %s",
error.AsCString());
3568 bool with_shell = !!launch_info.
GetShell();
3570 const char *exit_desc =
m_process_sp->GetExitDescription();
3572 if (exit_desc && exit_desc[0])
3573 desc =
" (" + std::string(exit_desc) +
')';
3576 "process exited with status %i%s\n"
3577 "'r' and 'run' are aliases that default to launching through a "
3579 "Try launching without going through a shell by using "
3580 "'process launch'.",
3581 exit_status, desc.c_str());
3584 "process exited with status %i%s", exit_status, desc.c_str());
3588 "initial process state wasn't stopped: %s",
StateAsCString(state));
3600 return llvm::createStringError(llvm::inconvertibleErrorCode(),
3601 "A process is required for tracing");
3603 return llvm::createStringError(llvm::inconvertibleErrorCode(),
3604 "A trace already exists for the target");
3606 llvm::Expected<TraceSupportedResponse> trace_type =
3609 return llvm::createStringError(
3610 llvm::inconvertibleErrorCode(),
"Tracing is not supported. %s",
3611 llvm::toString(trace_type.takeError()).c_str());
3612 if (llvm::Expected<TraceSP> trace_sp =
3616 return llvm::createStringError(
3617 llvm::inconvertibleErrorCode(),
3618 "Couldn't create a Trace object for the process. %s",
3619 llvm::toString(trace_sp.takeError()).c_str());
3630 Progress attach_progress(
"Waiting to attach to process");
3631 m_stats.SetLaunchOrAttachTime();
3635 state = process_sp->GetState();
3648 if (old_exec_module_sp)
3650 old_exec_module_sp->GetPlatformFileSpec().GetFilename());
3654 "no process specified, create a target with a file, or "
3655 "specify the --pid or --name");
3659 const auto platform_sp =
3662 const bool async = attach_info.
GetAsync();
3680 plugin_name,
nullptr,
false);
3683 "failed to create process using plugin '{0}'",
3684 plugin_name.empty() ?
"<empty>" : plugin_name);
3688 if (hijack_listener_sp)
3689 process_sp->HijackProcessEvents(hijack_listener_sp);
3690 error = process_sp->Attach(attach_info);
3693 if (
error.Success() && process_sp) {
3695 process_sp->RestoreProcessEvents();
3698 state = process_sp->WaitForProcessToStop(
3701 process_sp->RestoreProcessEvents();
3708 const char *exit_desc = process_sp->GetExitDescription();
3713 "process did not stop (no such process or permission problem?)");
3714 process_sp->Destroy(
false);
3727 const bool default_to_use_pty =
3731 "have platform={0}, platform_sp->IsHost()={1}, default_to_use_pty={2}",
3733 platform_sp ? (platform_sp->IsHost() ?
"true" :
"false") :
"n/a",
3734 default_to_use_pty);
3741 LLDB_LOG(log,
"at least one of stdin/stdout/stderr was not set, evaluating "
3742 "default handling");
3751 LLDB_LOG(log,
"eLaunchFlagDisableSTDIO set, adding suppression action "
3752 "for stdin, stdout and stderr");
3772 LLDB_LOG(log,
"target stdin='{0}', target stdout='{1}', stderr='{2}'",
3773 in_file_spec, out_file_spec, err_file_spec);
3777 LLDB_LOG(log,
"appended stdin open file action for {0}", in_file_spec);
3780 if (out_file_spec) {
3782 LLDB_LOG(log,
"appended stdout open file action for {0}",
3786 if (err_file_spec) {
3788 LLDB_LOG(log,
"appended stderr open file action for {0}",
3792 if (default_to_use_pty) {
3794 LLDB_LOG_ERROR(log, std::move(Err),
"SetUpPtyRedirection failed: {0}");
3811 elem.notify = notify;
3821 = signals_sp->GetSignalNumberFromName(elem.first().str().c_str());
3826 signals_sp->SetShouldSuppress(signo,
false);
3828 signals_sp->SetShouldSuppress(signo,
true);
3831 signals_sp->SetShouldNotify(signo,
true);
3833 signals_sp->SetShouldNotify(signo,
false);
3836 signals_sp->SetShouldStop(signo,
true);
3838 signals_sp->SetShouldStop(signo,
false);
3847 = signals_sp->GetSignalNumberFromName(elem.first().str().c_str());
3853 signals_sp->ResetSignal(signo, do_stop, do_notify, do_pass);
3864 warning_stream_sp->Printf(
"Target signal '%s' not found in process\n",
3865 elem.first().str().c_str());
3878 signals_sp = process_sp->GetUnixSignals();
3881 const char *signal_name = entry.c_str();
3895 strm.
Printf(
"NAME PASS STOP NOTIFY\n");
3896 strm.
Printf(
"=========== ======= ======= =======\n");
3898 auto str_for_lazy = [] (
LazyBool lazy) ->
const char * {
3904 llvm_unreachable(
"Fully covered switch above!");
3908 bool print_it =
false;
3909 for (
size_t idx = 0; idx < num_args; idx++) {
3916 strm.
Printf(
"%-11s ", elem.first().str().c_str());
3917 strm.
Printf(
"%s %s %s\n", str_for_lazy(elem.second.pass),
3918 str_for_lazy(elem.second.stop),
3919 str_for_lazy(elem.second.notify));
3950 bool will_run =
true;
3974 s.
Indent(
"State: enabled\n");
3976 s.
Indent(
"State: disabled\n");
3979 s.
Indent(
"AutoContinue on\n");
4009 uint32_t num_commands =
m_commands.GetSize();
4010 for (uint32_t i = 0; i < num_commands; i++) {
4022 const std::vector<std::string> &strings) {
4023 for (
auto string : strings)
4030 assert(exc_ctx.
GetTargetPtr() &&
"Can't call PerformAction on a context "
4067 GetTarget()->GetDebugger().GetScriptInterpreter();
4068 if (!script_interp) {
4076 "ScriptedStopHook::%s () - ERROR: %s", __FUNCTION__,
4077 "Script interpreter couldn't create Scripted Stop Hook Interface");
4091 if (!object_sp || !object_sp->IsValid()) {
4093 "ScriptedStopHook::%s () - ERROR: %s", __FUNCTION__,
4094 "Failed to create valid script object");
4104 assert(exc_ctx.
GetTargetPtr() &&
"Can't call HandleStop on a context "
4110 lldb::StreamSP stream = std::make_shared<lldb_private::StreamString>();
4111 auto should_stop_or_err =
m_interface_sp->HandleStop(exc_ctx, stream);
4112 output_sp->PutCString(
4114 if (!should_stop_or_err)
4136 if (!object_sp || !object_sp->IsValid())
4140 if (!as_dict || !as_dict->
IsValid())
4143 uint32_t num_keys = as_dict->
GetSize();
4150 auto print_one_element = [&s](llvm::StringRef key,
4153 s.
Format(
"{0} : {1}\n", key, object->GetStringValue());
4157 as_dict->
ForEach(print_one_element);
4163 "no-dynamic-values",
4164 "Don't calculate the dynamic type of values",
4169 "Calculate the dynamic type of values "
4170 "even if you have to run the target.",
4175 "Calculate the dynamic type of values, but don't run the target.",
4187 "Never look for inline breakpoint locations (fastest). This setting "
4188 "should only be used if you know that no inlining occurs in your"
4194 "Only check for inline breakpoint locations when setting breakpoints "
4195 "in header files, but not when setting breakpoint in implementation "
4196 "source files (default).",
4201 "Always look for inline breakpoint locations when setting file and "
4202 "line breakpoints (slower but most accurate).",
4216 "Disassembler default (currently att).",
4221 "Intel disassembler flavor.",
4226 "AT&T disassembler flavor.",
4234 "Never import the 'std' C++ module in the expression parser.",
4239 "Retry evaluating expressions with an imported 'std' C++ module if they"
4240 " failed to parse without the module. This allows evaluating more "
4241 "complex expressions involving C++ standard library types."
4246 "Always import the 'std' C++ module. This allows evaluating more "
4247 "complex expressions involving C++ standard library types. This feature"
4252static constexpr OptionEnumValueElement
4257 "Automatically determine the most appropriate method for the "
4261 "Prefer using the realized classes struct."},
4263 "Prefer using the CopyRealizedClassList API."},
4265 "Prefer using the GetRealizedClassList API."},
4272 "C-style (0xffff).",
4277 "Asm-style (0ffffh).",
4285 "Load debug scripts inside symbol files",
4290 "Do not load debug scripts inside symbol files.",
4295 "Warn about debug scripts inside symbol files but do not load them.",
4303 "Load .lldbinit files from current directory",
4308 "Do not load .lldbinit files from current directory",
4313 "Warn about loading .lldbinit files from current directory",
4321 "Load minimal information when loading modules from memory. Currently "
4322 "this setting loads sections only.",
4327 "Load partial information when loading modules from memory. Currently "
4328 "this setting loads sections and function bounds.",
4333 "Load complete information when loading modules from memory. Currently "
4334 "this setting loads sections and all symbols.",
4338#define LLDB_PROPERTIES_target
4339#include "TargetProperties.inc"
4342#define LLDB_PROPERTIES_target
4343#include "TargetPropertiesEnum.inc"
4348 :
public Cloneable<TargetOptionValueProperties, OptionValueProperties> {
4359 Target *target = exe_ctx->GetTargetPtr();
4364 if (
this != target_properties)
4373#define LLDB_PROPERTIES_target_experimental
4374#include "TargetProperties.inc"
4377#define LLDB_PROPERTIES_target_experimental
4378#include "TargetPropertiesEnum.inc"
4382 :
public Cloneable<TargetExperimentalOptionValueProperties,
4383 OptionValueProperties> {
4420 m_collection_sp->SetValueChangedCallback(ePropertyDetachOnError, [
this] {
4433 std::make_unique<TargetExperimentalProperties>();
4436 "Experimental settings - setting these won't produce "
4437 "errors if the setting is not present.",
4440 m_collection_sp = std::make_shared<TargetOptionValueProperties>(
"target");
4443 std::make_unique<TargetExperimentalProperties>();
4446 "Experimental settings - setting these won't produce "
4447 "errors if the setting is not present.",
4450 "process",
"Settings specific to processes.",
true,
4477 exp_property->
GetValue()->GetAsProperties();
4480 return std::nullopt;
4493 exp_property->
GetValue()->GetAsProperties();
4505 exp_property->
GetValue()->GetAsProperties();
4511 const uint32_t idx = ePropertyDefaultArch;
4516 const uint32_t idx = ePropertyDefaultArch;
4521 const uint32_t idx = ePropertyMoveToNearestCode;
4523 idx, g_target_properties[idx].default_uint_value != 0);
4527 const uint32_t idx = ePropertyPreferDynamic;
4530 g_target_properties[idx].default_uint_value));
4534 const uint32_t idx = ePropertyPreferDynamic;
4540 "Interrupted checking preload symbols")) {
4543 const uint32_t idx = ePropertyPreloadSymbols;
4545 idx, g_target_properties[idx].default_uint_value != 0);
4549 const uint32_t idx = ePropertyPreloadSymbols;
4554 const uint32_t idx = ePropertyDisableASLR;
4556 idx, g_target_properties[idx].default_uint_value != 0);
4560 const uint32_t idx = ePropertyDisableASLR;
4565 const uint32_t idx = ePropertyInheritTCC;
4567 idx, g_target_properties[idx].default_uint_value != 0);
4571 const uint32_t idx = ePropertyInheritTCC;
4576 const uint32_t idx = ePropertyDetachOnError;
4578 idx, g_target_properties[idx].default_uint_value != 0);
4582 const uint32_t idx = ePropertyDetachOnError;
4587 const uint32_t idx = ePropertyDisableSTDIO;
4589 idx, g_target_properties[idx].default_uint_value != 0);
4593 const uint32_t idx = ePropertyDisableSTDIO;
4597 const uint32_t idx = ePropertyLaunchWorkingDir;
4599 idx, g_target_properties[idx].default_cstr_value);
4603 const uint32_t idx = ePropertyParallelModuleLoad;
4605 idx, g_target_properties[idx].default_uint_value != 0);
4609 const uint32_t idx = ePropertyDisassemblyFlavor;
4610 const char *return_value;
4615 g_target_properties[idx].default_uint_value));
4618 return return_value;
4622 const uint32_t idx = ePropertyDisassemblyCPU;
4624 idx, g_target_properties[idx].default_cstr_value);
4625 return str.empty() ? nullptr : str.data();
4629 const uint32_t idx = ePropertyDisassemblyFeatures;
4631 idx, g_target_properties[idx].default_cstr_value);
4632 return str.empty() ? nullptr : str.data();
4636 const uint32_t idx = ePropertyInlineStrategy;
4639 static_cast<InlineStrategy>(g_target_properties[idx].default_uint_value));
4645 const uint32_t idx = ePropertySourceRealpathPrefixes;
4650 const uint32_t idx = ePropertyArg0;
4652 idx, g_target_properties[idx].default_cstr_value);
4656 const uint32_t idx = ePropertyArg0;
4662 const uint32_t idx = ePropertyRunArgs;
4667 const uint32_t idx = ePropertyRunArgs;
4677 ePropertyInheritEnv,
4678 g_target_properties[ePropertyInheritEnv].default_uint_value != 0)) {
4679 if (
auto platform_sp =
m_target->GetPlatform()) {
4680 Environment platform_env = platform_sp->GetEnvironment();
4681 for (
const auto &KV : platform_env)
4682 env[KV.first()] = KV.second;
4686 Args property_unset_env;
4688 property_unset_env);
4689 for (
const auto &var : property_unset_env)
4690 env.erase(var.ref());
4693 m_collection_sp->GetPropertyAtIndexAsArgs(ePropertyEnvVars, property_env);
4695 env[KV.first()] = KV.second;
4711 ePropertyInheritEnv,
4712 g_target_properties[ePropertyInheritEnv].default_uint_value != 0))
4716 if (platform_sp ==
nullptr)
4719 Environment platform_environment = platform_sp->GetEnvironment();
4720 for (
const auto &KV : platform_environment)
4721 environment[KV.first()] = KV.second;
4723 Args property_unset_environment;
4725 property_unset_environment);
4726 for (
const auto &var : property_unset_environment)
4727 environment.erase(var.ref());
4733 Args property_environment;
4735 property_environment);
4737 for (
const auto &KV :
Environment(property_environment))
4738 environment[KV.first()] = KV.second;
4745 const uint32_t idx = ePropertyEnvVars;
4750 const uint32_t idx = ePropertySkipPrologue;
4752 idx, g_target_properties[idx].default_uint_value != 0);
4756 const uint32_t idx = ePropertySourceMap;
4759 assert(option_value);
4764 const uint32_t idx = ePropertyObjectMap;
4767 assert(option_value);
4772 const uint32_t idx = ePropertyAutoSourceMapRelative;
4774 idx, g_target_properties[idx].default_uint_value != 0);
4778 const uint32_t idx = ePropertyExecutableSearchPaths;
4781 assert(option_value);
4786 const uint32_t idx = ePropertyExecutableSearchPaths;
4791 const uint32_t idx = ePropertyDebugFileSearchPaths;
4796 const uint32_t idx = ePropertyClangModuleSearchPaths;
4801 const uint32_t idx = ePropertyAutoImportClangModules;
4803 idx, g_target_properties[idx].default_uint_value != 0);
4807 const uint32_t idx = ePropertyImportStdModule;
4810 g_target_properties[idx].default_uint_value));
4814 const uint32_t idx = ePropertyDynamicClassInfoHelper;
4817 g_target_properties[idx].default_uint_value));
4821 const uint32_t idx = ePropertyAutoApplyFixIts;
4823 idx, g_target_properties[idx].default_uint_value != 0);
4827 const uint32_t idx = ePropertyRetriesWithFixIts;
4829 idx, g_target_properties[idx].default_uint_value);
4833 const uint32_t idx = ePropertyNotifyAboutFixIts;
4835 idx, g_target_properties[idx].default_uint_value != 0);
4839 const uint32_t idx = ePropertySaveObjectsDir;
4849 bool exists = instance.
Exists(new_dir);
4850 bool is_directory = instance.
IsDirectory(new_dir);
4851 std::string path = new_dir.
GetPath(
true);
4852 bool writable = llvm::sys::fs::can_write(path);
4853 if (exists && is_directory && writable)
4861 llvm::raw_string_ostream os(buffer);
4862 os <<
"JIT object dir '" << path <<
"' ";
4864 os <<
"does not exist";
4865 else if (!is_directory)
4866 os <<
"is not a directory";
4868 os <<
"is not writable";
4870 std::optional<lldb::user_id_t> debugger_id;
4872 debugger_id =
m_target->GetDebugger().GetID();
4877 const uint32_t idx = ePropertyEnableSynthetic;
4879 idx, g_target_properties[idx].default_uint_value != 0);
4883 const uint32_t idx = ePropertyShowHexVariableValuesWithLeadingZeroes;
4885 idx, g_target_properties[idx].default_uint_value != 0);
4889 const uint32_t idx = ePropertyMaxZeroPaddingInFloatFormat;
4891 idx, g_target_properties[idx].default_uint_value);
4895 const uint32_t idx = ePropertyMaxChildrenCount;
4897 idx, g_target_properties[idx].default_uint_value);
4900std::pair<uint32_t, bool>
4902 const uint32_t idx = ePropertyMaxChildrenDepth;
4903 auto *option_value =
4905 bool is_default = !option_value->OptionWasSet();
4906 return {option_value->GetCurrentValue(), is_default};
4910 const uint32_t idx = ePropertyMaxSummaryLength;
4912 idx, g_target_properties[idx].default_uint_value);
4916 const uint32_t idx = ePropertyMaxMemReadSize;
4918 idx, g_target_properties[idx].default_uint_value);
4922 const uint32_t idx = ePropertyInputPath;
4927 const uint32_t idx = ePropertyInputPath;
4932 const uint32_t idx = ePropertyOutputPath;
4937 const uint32_t idx = ePropertyOutputPath;
4942 const uint32_t idx = ePropertyErrorPath;
4947 const uint32_t idx = ePropertyErrorPath;
4952 const uint32_t idx = ePropertyLanguage;
4957 const uint32_t idx = ePropertyExprPrefix;
4963 return llvm::StringRef(
4964 reinterpret_cast<const char *
>(data_sp->GetBytes()),
4965 data_sp->GetByteSize());
4971 const uint32_t idx = ePropertyExprErrorLimit;
4973 idx, g_target_properties[idx].default_uint_value);
4977 const uint32_t idx = ePropertyExprAllocAddress;
4979 idx, g_target_properties[idx].default_uint_value);
4983 const uint32_t idx = ePropertyExprAllocSize;
4985 idx, g_target_properties[idx].default_uint_value);
4989 const uint32_t idx = ePropertyExprAllocAlign;
4991 idx, g_target_properties[idx].default_uint_value);
4995 const uint32_t idx = ePropertyBreakpointUseAvoidList;
4997 idx, g_target_properties[idx].default_uint_value != 0);
5001 const uint32_t idx = ePropertyUseHexImmediates;
5003 idx, g_target_properties[idx].default_uint_value != 0);
5007 const uint32_t idx = ePropertyUseFastStepping;
5009 idx, g_target_properties[idx].default_uint_value != 0);
5013 const uint32_t idx = ePropertyDisplayExpressionsInCrashlogs;
5015 idx, g_target_properties[idx].default_uint_value != 0);
5019 const uint32_t idx = ePropertyLoadScriptFromSymbolFile;
5022 g_target_properties[idx].default_uint_value));
5026 const uint32_t idx = ePropertyLoadCWDlldbinitFile;
5029 g_target_properties[idx].default_uint_value));
5033 const uint32_t idx = ePropertyHexImmediateStyle;
5036 g_target_properties[idx].default_uint_value));
5040 const uint32_t idx = ePropertyMemoryModuleLoadLevel;
5043 g_target_properties[idx].default_uint_value));
5047 const uint32_t idx = ePropertyTrapHandlerNames;
5052 const uint32_t idx = ePropertyTrapHandlerNames;
5057 const uint32_t idx = ePropertyDisplayRuntimeSupportValues;
5059 idx, g_target_properties[idx].default_uint_value != 0);
5063 const uint32_t idx = ePropertyDisplayRuntimeSupportValues;
5068 const uint32_t idx = ePropertyDisplayRecognizedArguments;
5070 idx, g_target_properties[idx].default_uint_value != 0);
5074 const uint32_t idx = ePropertyDisplayRecognizedArguments;
5090 if (input_file_action) {
5095 if (output_file_action) {
5100 if (error_file_action) {
5106 launch_info.
GetFlags().
Test(lldb::eLaunchFlagInheritTCCFromParent));
5111 const uint32_t idx = ePropertyRequireHardwareBreakpoints;
5113 idx, g_target_properties[idx].default_uint_value != 0);
5117 const uint32_t idx = ePropertyRequireHardwareBreakpoints;
5122 const uint32_t idx = ePropertyAutoInstallMainExecutable;
5124 idx, g_target_properties[idx].default_uint_value != 0);
5158 m_launch_info.GetFlags().Set(lldb::eLaunchFlagDetachOnError);
5160 m_launch_info.GetFlags().Clear(lldb::eLaunchFlagDetachOnError);
5167 m_launch_info.GetFlags().Clear(lldb::eLaunchFlagDisableASLR);
5172 m_launch_info.GetFlags().Set(lldb::eLaunchFlagInheritTCCFromParent);
5174 m_launch_info.GetFlags().Clear(lldb::eLaunchFlagInheritTCCFromParent);
5179 m_launch_info.GetFlags().Set(lldb::eLaunchFlagDisableSTDIO);
5181 m_launch_info.GetFlags().Clear(lldb::eLaunchFlagDisableSTDIO);
5185 const uint32_t idx = ePropertyDebugUtilityExpression;
5187 idx, g_target_properties[idx].default_uint_value != 0);
5191 const uint32_t idx = ePropertyDebugUtilityExpression;
5207 return "Target::TargetEventData";
5257 return m_stats.ToJSON(*
this, options);
5275 lldb::BreakpointEventType eventKind) {
5277 std::shared_ptr<Breakpoint::BreakpointEventData> data_sp =
5278 std::make_shared<Breakpoint::BreakpointEventData>(
5279 eventKind, bp.shared_from_this());
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 double elapsed(const StatsTimepoint &start, const StatsTimepoint &end)
static Status installExecutable(const Installer &installer)
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.
static constexpr std::chrono::milliseconds default_timeout
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.
llvm::StringRef GetPath() 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)
lldb::ModuleSP GetModule() const
Get const accessor for the module pointer.
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 bool RemoveSharedModuleIfOrphaned(const lldb::ModuleWP module_ptr)
bool AppendIfNeeded(const lldb::ModuleSP &new_module, bool notify=true)
Append a module to the module list, if it is not already there.
static Status GetSharedModule(const ModuleSpec &module_spec, lldb::ModuleSP &module_sp, llvm::SmallVectorImpl< lldb::ModuleSP > *old_modules, bool *did_create_ptr, bool always_create=false, bool invoke_locate_callback=true)
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(std::shared_ptr< Target > 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.
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
ObjectSP GetValueForKey(llvm::StringRef key) const
void ForEach(std::function< bool(llvm::StringRef key, Object *object)> const &callback) const
Dictionary * GetAsDictionary()
virtual bool IsValid() const
void Dump(lldb_private::Stream &s, bool pretty_print=true) const
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 ModuleList GetModuleListFromEvent(const Event *event_ptr)
~TargetEventData() override
static const TargetEventData * GetEventDataFromEvent(const Event *event_ptr)
TargetEventData(const lldb::TargetSP &target_sp)
lldb::TargetSP m_target_sp
static lldb::TargetSP GetTargetFromEvent(const Event *event_ptr)
void ModulesDidLoad(ModuleList &module_list)
lldb::ThreadSP CalculateThread() override
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)
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
The globally unique ID assigned to 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.
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.
lldb::user_id_t m_target_unique_id
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
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)
bool IgnoreAllWatchpoints(uint32_t ignore_count)
void AddBreakpoint(lldb::BreakpointSP breakpoint_sp, bool internal)
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)
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.
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)
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
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.
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)