75#include "llvm/ADT/STLExtras.h"
76#include "llvm/ADT/ScopeExit.h"
77#include "llvm/ADT/SetVector.h"
78#include "llvm/Support/ErrorExtras.h"
79#include "llvm/Support/ThreadPool.h"
91struct ExecutableInstaller {
94 : m_platform{platform}, m_module{module},
95 m_local_file{m_module->GetFileSpec()},
96 m_remote_file{m_module->GetRemoteInstallFileSpec()} {}
98 void setupRemoteFile()
const { m_module->SetPlatformFileSpec(m_remote_file); }
102 const FileSpec m_local_file;
103 const FileSpec m_remote_file;
106struct MainExecutableInstaller {
109 ProcessLaunchInfo &launch_info)
110 : m_platform{platform}, m_module{module},
111 m_local_file{m_module->GetFileSpec()},
113 getRemoteFileSpec(m_platform, target, m_module, m_local_file)},
114 m_launch_info{launch_info} {}
116 void setupRemoteFile()
const {
117 m_module->SetPlatformFileSpec(m_remote_file);
120 m_platform->SetFilePermissions(m_remote_file, 0700 );
125 const FileSpec m_local_file;
126 const FileSpec m_remote_file;
131 const FileSpec &local_file) {
132 FileSpec remote_file =
module->GetRemoteInstallFileSpec();
133 if (remote_file || !target->GetAutoInstallMainExecutable())
139 remote_file = platform->GetRemoteWorkingDirectory();
145 ProcessLaunchInfo &m_launch_info;
151template <
typename Installer>
153 if (!installer.m_local_file || !installer.m_remote_file)
156 Status error = installer.m_platform->Install(installer.m_local_file,
157 installer.m_remote_file);
161 installer.setupRemoteFile();
176 static constexpr llvm::StringLiteral class_name(
"lldb.target");
208 static_cast<void *
>(
this));
211 "Target::Target created with architecture {0} ({1})",
213 target_arch.
GetTriple().getTriple().c_str());
221 LLDB_LOG(log,
"{0} Target::~Target()",
static_cast<void *
>(
this));
233 if (breakpoint_sp->IsInternal())
247 elem.second->CopyIntoNewTarget(*
this);
248 if (new_override_up->Validate())
284 llvm::consumeError(
m_process_sp->FlushDelayedBreakpoints());
286 std::unique_lock<std::recursive_mutex> lock;
317 llvm::StringRef plugin_name,
324 listener_sp, crash_file, can_connect);
331 const char *repl_options,
bool can_create) {
339 language = *single_lang;
340 }
else if (repl_languages.
Empty()) {
342 "LLDB isn't configured with REPL support for any languages.");
346 "Multiple possible REPL languages. Please specify a language.");
351 REPLMap::iterator pos =
m_repl_map.find(language);
359 "Couldn't find an existing REPL for %s, and can't create a new one",
374 "Couldn't create a REPL for %s",
388 std::lock_guard<std::recursive_mutex> guard(
m_mutex);
395 const bool notify =
false;
419 return abi_sp->GetPluginName();
452 shared_lib_filter.
Append(main_module_sp->GetFileSpec());
453 llvm::SetVector<std::string, std::vector<std::string>,
454 std::unordered_set<std::string>>
463 if (!entryPointName.empty())
464 entryPointNamesSet.insert(entryPointName);
466 if (entryPointNamesSet.empty()) {
472 nullptr, entryPointNamesSet.takeVector(),
473 eFunctionNameTypeFull,
483 bp_sp->SetOneShot(
true);
490 const std::unordered_set<std::string> &function_names,
494 containingModules, source_file_spec_list));
498 nullptr, std::move(source_regex), function_names,
499 !
static_cast<bool>(move_to_nearest_code)));
505 const FileSpec &file, uint32_t line_no,
508 LazyBool skip_prologue,
bool internal,
512 std::optional<llvm::StringRef> removed_prefix_opt =
514 if (!removed_prefix_opt)
515 remapped_file = file;
519 switch (inline_strategy) {
540 compile_unit_list.
Append(remapped_file);
553 !
static_cast<bool>(move_to_nearest_code));
558 nullptr, offset, skip_prologue, location_spec, removed_prefix_opt));
585 std::make_shared<SearchFilterForUnconstrainedSearches>(
588 std::make_shared<BreakpointResolverAddress>(
nullptr, addr);
595 bool request_hardware) {
597 std::make_shared<SearchFilterForUnconstrainedSearches>(
600 std::make_shared<BreakpointResolverAddress>(
nullptr,
Address(file_addr),
608 const FileSpecList *containingSourceFiles,
const char *func_name,
609 FunctionNameType func_name_type_mask,
LanguageType language,
611 bool internal,
bool hardware) {
615 containingModules, containingSourceFiles));
624 offset, offset_is_insn_count, skip_prologue));
633 const std::vector<std::string> &func_names,
634 FunctionNameType func_name_type_mask,
636 LazyBool skip_prologue,
bool internal,
bool hardware) {
638 size_t num_names = func_names.size();
641 containingModules, containingSourceFiles));
649 new BreakpointResolverName(
nullptr, func_names, func_name_type_mask,
650 language, offset, skip_prologue));
659 const char *func_names[],
size_t num_names,
660 FunctionNameType func_name_type_mask,
662 LazyBool skip_prologue,
bool internal,
bool hardware) {
666 containingModules, containingSourceFiles));
678 nullptr, func_names, num_names, func_name_type_mask, language, offset,
680 resolver_sp->SetOffset(offset);
689 if (containingModule !=
nullptr) {
692 filter_sp = std::make_shared<SearchFilterByModule>(shared_from_this(),
697 std::make_shared<SearchFilterForUnconstrainedSearches>(
707 if (containingModules && containingModules->
GetSize() != 0) {
710 filter_sp = std::make_shared<SearchFilterByModuleList>(shared_from_this(),
715 std::make_shared<SearchFilterForUnconstrainedSearches>(
725 if (containingSourceFiles ==
nullptr || containingSourceFiles->
GetSize() == 0)
729 if (containingModules ==
nullptr) {
733 filter_sp = std::make_shared<SearchFilterByModuleListAndCU>(
734 shared_from_this(),
FileSpecList(), *containingSourceFiles);
736 filter_sp = std::make_shared<SearchFilterByModuleListAndCU>(
737 shared_from_this(), *containingModules, *containingSourceFiles);
746 bool internal,
bool hardware) {
748 containingModules, containingSourceFiles));
751 :
static_cast<bool>(skip_prologue);
753 nullptr, std::move(func_regex), requested_language, 0,
skip));
760 bool catch_bp,
bool throw_bp,
bool internal,
763 *
this, language, catch_bp, throw_bp, internal);
764 if (exc_bkpt_sp && additional_args) {
766 if (precondition_sp && additional_args) {
768 *
error = precondition_sp->ConfigurePrecondition(*additional_args);
770 precondition_sp->ConfigurePrecondition(*additional_args);
777 const llvm::StringRef class_name,
const FileSpecList *containingModules,
778 const FileSpecList *containingSourceFiles,
bool internal,
785 containingSourceFiles && containingSourceFiles->
GetSize() > 0;
786 bool has_modules = containingModules && containingModules->
GetSize() > 0;
788 if (has_files && has_modules) {
790 containingSourceFiles);
791 }
else if (has_files) {
794 }
else if (has_modules) {
797 filter_sp = std::make_shared<SearchFilterForUnconstrainedSearches>(
808 bool internal,
bool request_hardware,
809 bool resolve_indirect_symbols) {
811 if (filter_sp && resolver_sp) {
819 resolver_sp = overridden_sp;
822 bp_sp.reset(
new Breakpoint(*
this, filter_sp, resolver_sp, hardware,
823 resolve_indirect_symbols));
824 resolver_sp->SetBreakpoint(bp_sp);
842 LLDB_LOGF(log,
"Target::%s (internal = %s) => break_id = %s\n",
843 __FUNCTION__, bp_sp->IsInternal() ?
"yes" :
"no", s.
GetData());
846 bp_sp->ResolveBreakpoint();
877 bp_sp->AddName(name);
882 std::make_pair(bp_name->GetName(), std::move(bp_name)));
888 if (!
error.Success())
893 return iter->second.get();
898 "Breakpoint name \"{0}\" doesn't exist and can_create is false.", name);
903 .insert(std::make_pair(
904 name, std::make_unique<BreakpointName>(name.
GetStringRef().str())))
905 .first->second.get();
912 const char *name_cstr = name.
AsCString(
nullptr);
915 bp_sp->RemoveName(name_cstr);
921 bp_sp->RemoveName(name.
AsCString(
nullptr));
933 llvm::Expected<std::vector<BreakpointSP>> expected_vector =
936 if (!expected_vector) {
938 llvm::toString(expected_vector.takeError()));
942 for (
auto bp_sp : *expected_vector)
949 names.push_back(bp_name_entry.first.GetString());
954llvm::Expected<lldb::user_id_t>
957 llvm::StringRef description) {
958 if (class_name.empty())
966 std::string(class_name), impl));
967 llvm::Error
error = new_override_up->Validate();
975 std::vector<lldb::user_id_t> &idxs) {
977 stream <<
"No overrides.\n";
981 bool empty = idxs.empty();
982 bool print_first =
true;
984 auto idx_pos = llvm::find(idxs, elem.first);
985 if (empty || idx_pos != idxs.end()) {
988 stream <<
"ID Description\n";
989 stream <<
"---- -----------\n";
992 stream.
Format(
"{0,4} {1}\n", elem.first, elem.second->GetDescription());
1004 std::optional<uint32_t> num_supported_hardware_watchpoints =
1009 if (!num_supported_hardware_watchpoints)
1012 if (*num_supported_hardware_watchpoints == 0) {
1014 "Target supports (%u) hardware watchpoint slots.\n",
1015 *num_supported_hardware_watchpoints);
1028 "Target::%s (addr = 0x%8.8" PRIx64
" size = %" PRIu64
1030 __FUNCTION__, addr, (uint64_t)size, kind);
1041 "cannot set a watchpoint with watch_size of 0");
1044 "invalid watch address: %" PRIu64, addr);
1060 const bool notify =
false;
1065 addr = abi->FixDataAddress(addr);
1079 std::unique_lock<std::recursive_mutex> lock;
1083 size_t old_size = matched_sp->GetByteSize();
1089 if (size == old_size && kind == old_type) {
1091 wp_sp->SetEnabled(
false, notify);
1100 wp_sp = std::make_shared<Watchpoint>(*
this, addr, size, type);
1101 wp_sp->SetWatchpointType(kind, notify);
1106 LLDB_LOGF(log,
"Target::%s (creation of watchpoint %s with id = %u)\n",
1107 __FUNCTION__,
error.Success() ?
"succeeded" :
"failed",
1122 LLDB_LOGF(log,
"Target::%s \n", __FUNCTION__);
1131 LLDB_LOGF(log,
"Target::%s (internal_also = %s)\n", __FUNCTION__,
1132 internal_also ?
"yes" :
"no");
1143 LLDB_LOGF(log,
"Target::%s (internal_also = %s)\n", __FUNCTION__,
1144 internal_also ?
"yes" :
"no");
1153 LLDB_LOGF(log,
"Target::%s", __FUNCTION__);
1160 LLDB_LOGF(log,
"Target::%s (internal_also = %s)\n", __FUNCTION__,
1161 internal_also ?
"yes" :
"no");
1170 LLDB_LOGF(log,
"Target::%s", __FUNCTION__);
1177 LLDB_LOGF(log,
"Target::%s (break_id = %i, internal = %s)\n", __FUNCTION__,
1197 LLDB_LOGF(log,
"Target::%s (break_id = %i, internal = %s)\n", __FUNCTION__,
1207 bp_sp->SetEnabled(
false);
1215 LLDB_LOGF(log,
"Target::%s (break_id = %i, internal = %s)\n", __FUNCTION__,
1226 bp_sp->SetEnabled(
true);
1246 std::string path(file.
GetPath());
1254 if (
error.Success()) {
1255 break_store_ptr = input_data_sp->GetAsArray();
1256 if (!break_store_ptr) {
1258 "Tried to append to invalid input file %s", path.c_str());
1264 if (!break_store_ptr) {
1265 break_store_sp = std::make_shared<StructuredData::Array>();
1266 break_store_ptr = break_store_sp.get();
1273 lldb::eFilePermissionsFileDefault);
1280 std::unique_lock<std::recursive_mutex> lock;
1286 size_t num_breakpoints = breakpoints.
GetSize();
1287 for (
size_t i = 0; i < num_breakpoints; i++) {
1292 break_store_ptr->
AddItem(bkpt_save_sp);
1296 std::unordered_set<lldb::break_id_t> processed_bkpts;
1297 const size_t count = bp_ids.
GetSize();
1298 for (
size_t i = 0; i < count; ++i) {
1304 std::pair<std::unordered_set<lldb::break_id_t>::iterator,
bool>
1305 insert_result = processed_bkpts.insert(bp_id);
1306 if (!insert_result.second)
1313 if (!bkpt_save_sp) {
1315 "Unable to serialize breakpoint %d", bp_id);
1318 break_store_ptr->
AddItem(bkpt_save_sp);
1323 break_store_ptr->
Dump(out_file,
false);
1330 std::vector<std::string> no_names;
1335 std::vector<std::string> &names,
1337 std::unique_lock<std::recursive_mutex> lock;
1343 if (!
error.Success()) {
1345 }
else if (!input_data_sp || !input_data_sp->IsValid()) {
1347 "Invalid JSON from input file: %s.", file.
GetPath().c_str());
1354 "Invalid breakpoint data from input file: %s.", file.
GetPath().c_str());
1358 size_t num_bkpts = bkpt_array->
GetSize();
1359 size_t num_names = names.size();
1361 for (
size_t i = 0; i < num_bkpts; i++) {
1367 "Invalid breakpoint data for element %zu from input file: %s.", i,
1378 shared_from_this(), bkpt_data_sp,
error);
1379 if (!
error.Success()) {
1381 "Error restoring breakpoint %zu from %s: %s.", i,
1397 LLDB_LOGF(log,
"Target::%s\n", __FUNCTION__);
1426 LLDB_LOGF(log,
"Target::%s\n", __FUNCTION__);
1453 LLDB_LOGF(log,
"Target::%s\n", __FUNCTION__);
1479 LLDB_LOGF(log,
"Target::%s\n", __FUNCTION__);
1485 wp_sp->ResetHitCount();
1493 LLDB_LOGF(log,
"Target::%s\n", __FUNCTION__);
1499 wp_sp->ResetHistoricValues();
1508 LLDB_LOGF(log,
"Target::%s\n", __FUNCTION__);
1517 wp_sp->SetIgnoreCount(ignore_count);
1525 LLDB_LOGF(log,
"Target::%s (watch_id = %i)\n", __FUNCTION__, watch_id);
1544 LLDB_LOGF(log,
"Target::%s (watch_id = %i)\n", __FUNCTION__, watch_id);
1563 LLDB_LOGF(log,
"Target::%s (watch_id = %i)\n", __FUNCTION__, watch_id);
1578 uint32_t ignore_count) {
1580 LLDB_LOGF(log,
"Target::%s (watch_id = %i)\n", __FUNCTION__, watch_id);
1587 wp_sp->SetIgnoreCount(ignore_count);
1594 std::lock_guard<std::recursive_mutex> lock(
m_images.GetMutex());
1606 return m_images.GetModuleAtIndex(0);
1633 if (executable_sp) {
1636 pid = proc->GetID();
1640 info->
uuid = executable_sp->GetUUID();
1642 info->
triple = executable_sp->GetArchitecture().GetTriple().getTriple();
1648 info->
uuid = executable_sp->GetUUID();
1654 executable_sp->GetFileSpec().GetPath().c_str());
1656 const bool notify =
true;
1662 if (!
m_arch.GetSpec().IsValid()) {
1663 m_arch = executable_sp->GetArchitecture();
1665 "Target::SetExecutableModule setting architecture to {0} ({1}) "
1666 "based on executable file",
1667 m_arch.GetSpec().GetArchitectureName(),
1668 m_arch.GetSpec().GetTriple().getTriple());
1671 ObjectFile *executable_objfile = executable_sp->GetObjectFile();
1672 bool load_dependents =
true;
1673 switch (load_dependent_files) {
1675 load_dependents = executable_sp->IsExecutable();
1678 load_dependents =
true;
1681 load_dependents =
false;
1685 if (executable_objfile && load_dependents) {
1688 std::mutex dependent_files_mutex;
1693 auto GetDependentModules = [&](
FileSpec dependent_file_spec) {
1694 FileSpec platform_dependent_file_spec;
1696 m_platform_sp->GetFileWithUUID(dependent_file_spec,
nullptr,
1697 platform_dependent_file_spec);
1699 platform_dependent_file_spec = dependent_file_spec;
1704 if (image_module_sp) {
1706 ObjectFile *objfile = image_module_sp->GetObjectFile();
1712 std::lock_guard<std::mutex> guard(dependent_files_mutex);
1713 dependent_files_copy = dependent_files;
1718 const size_t previous_dependent_files =
1719 dependent_files_copy.
GetSize();
1724 std::lock_guard<std::mutex> guard(dependent_files_mutex);
1725 for (
size_t i = previous_dependent_files;
1726 i < dependent_files_copy.
GetSize(); ++i)
1737 for (uint32_t i = 0; i < dependent_files.
GetSize(); i++) {
1743 std::lock_guard<std::mutex> guard(dependent_files_mutex);
1744 for (; i < dependent_files.
GetSize(); i++)
1745 task_group.async(GetDependentModules,
1758 bool missing_local_arch = !
m_arch.GetSpec().IsValid();
1759 bool replace_local_arch =
true;
1760 bool compatible_local_arch =
false;
1769 if (!platform_sp || !platform_sp->IsCompatibleArchitecture(
1773 GetDebugger().GetPlatformList().GetOrCreate(other, {},
1775 arch_platform_sp->SetLocateModuleCallback(
1776 platform_sp->GetLocateModuleCallback());
1779 other = platform_arch;
1785 if (!missing_local_arch) {
1786 if (merge &&
m_arch.GetSpec().IsCompatibleMatch(arch_spec)) {
1789 if (
m_arch.GetSpec().IsCompatibleMatch(other)) {
1790 compatible_local_arch =
true;
1793 replace_local_arch =
false;
1798 if (compatible_local_arch || missing_local_arch) {
1802 if (replace_local_arch)
1805 "Target::SetArchitecture merging compatible arch; arch "
1807 m_arch.GetSpec().GetArchitectureName(),
1808 m_arch.GetSpec().GetTriple().getTriple());
1816 "Target::SetArchitecture changing architecture to %s (%s) from %s (%s)",
1818 arch_spec.
GetTriple().getTriple().c_str(),
1819 m_arch.GetSpec().GetArchitectureName(),
1820 m_arch.GetSpec().GetTriple().getTriple().c_str());
1827 if (executable_sp) {
1829 "Target::SetArchitecture Trying to select executable file "
1830 "architecture %s (%s)",
1832 arch_spec.
GetTriple().getTriple().c_str());
1833 ModuleSpec module_spec(executable_sp->GetFileSpec(), other);
1834 module_spec.
SetTarget(shared_from_this());
1838 if (!
error.Fail() && executable_sp) {
1849 if (
m_arch.GetSpec().IsCompatibleMatch(arch_spec)) {
1854 "Target::MergeArchitecture target has arch %s, merging with "
1856 m_arch.GetSpec().GetTriple().getTriple().c_str(),
1857 arch_spec.
GetTriple().getTriple().c_str());
1878 my_module_list.
Append(module_sp);
1888 my_module_list.
Append(module_sp);
1901 old_module_sp, new_module_sp);
1913 const size_t num_images = module_list.
GetSize();
1915 std::list<Status> errors;
1917 for (
const auto &err : errors)
1920 for (
size_t idx = 0; idx < num_images; ++idx) {
1932 std::make_shared<TargetEventData>(shared_from_this(), module_list);
1941 runtime->SymbolsDidLoad(module_list);
1948 std::make_shared<TargetEventData>(shared_from_this(), module_list);
1957 std::make_shared<TargetEventData>(shared_from_this(), module_list);
1971 const bool should_flush_type_systems =
1973 auto *object_file =
module.GetObjectFile();
1978 auto type = object_file->GetType();
1982 return module.FileHasChanged() &&
1983 (type == ObjectFile::eTypeObjectFile ||
1984 type == ObjectFile::eTypeExecutable ||
1985 type == ObjectFile::eTypeSharedLibrary);
1988 if (should_flush_type_systems)
1996 const FileSpec &module_file_spec) {
2001 size_t num_modules = matchingModules.
GetSize();
2005 if (num_modules > 0) {
2006 for (
size_t i = 0; i < num_modules; i++) {
2021 return m_platform_sp->ModuleIsExcludedForUnconstrainedSearches(*
this,
2033 if (section_sp->IsEncrypted()) {
2037 ModuleSP module_sp(section_sp->GetModule());
2039 ObjectFile *objfile = section_sp->GetModule()->GetObjectFile();
2042 section_sp.get(), addr.
GetOffset(), dst, dst_len);
2047 "error reading data from section %s",
2048 section_sp->GetName().GetCString());
2055 "address doesn't contain a section that points to a "
2056 "section in a object file");
2064 bool *did_read_live_memory) {
2066 if (did_read_live_memory)
2067 *did_read_live_memory =
false;
2080 size_t bytes_read = 0;
2087 if (section_load_list.
IsEmpty()) {
2093 m_images.ResolveFileAddress(file_addr, resolved_addr);
2106 resolved_addr = fixed_addr;
2111 std::unique_ptr<uint8_t[]> file_cache_read_buffer;
2112 size_t file_cache_bytes_read = 0;
2118 auto permissions =
Flags(section_sp->GetPermissions());
2119 bool is_readonly = !permissions.Test(ePermissionsWritable) &&
2120 permissions.Test(ePermissionsReadable);
2122 file_cache_bytes_read =
2124 if (file_cache_bytes_read == dst_len)
2125 return file_cache_bytes_read;
2126 else if (file_cache_bytes_read > 0) {
2127 file_cache_read_buffer =
2128 std::make_unique<uint8_t[]>(file_cache_bytes_read);
2129 std::memcpy(file_cache_read_buffer.get(), dst, file_cache_bytes_read);
2141 if (addr_module_sp && addr_module_sp->GetFileSpec())
2143 "{0:F}[{1:x+}] can't be resolved, {0:F} is not currently loaded",
2147 "0x%" PRIx64
" can't be resolved", resolved_addr.
GetFileAddress());
2150 if (bytes_read != dst_len) {
2151 if (
error.Success()) {
2152 if (bytes_read == 0)
2154 "read memory from 0x%" PRIx64
" failed", load_addr);
2157 "only %" PRIu64
" of %" PRIu64
2158 " bytes were read from memory at 0x%" PRIx64,
2159 (uint64_t)bytes_read, (uint64_t)dst_len, load_addr);
2164 *load_addr_ptr = load_addr;
2165 if (did_read_live_memory)
2166 *did_read_live_memory =
true;
2172 if (file_cache_read_buffer && file_cache_bytes_read > 0) {
2175 std::memcpy(dst, file_cache_read_buffer.get(), file_cache_bytes_read);
2176 return file_cache_bytes_read;
2198 out_str.append(buf, length);
2201 if (length ==
sizeof(buf) - 1)
2202 curr_addr += length;
2207 return out_str.size();
2211 size_t dst_max_len,
Status &result_error,
2212 bool force_live_memory) {
2213 size_t total_cstr_len = 0;
2214 if (dst && dst_max_len) {
2215 result_error.
Clear();
2217 memset(dst, 0, dst_max_len);
2224 const size_t cache_line_size = 512;
2226 size_t bytes_left = dst_max_len - 1;
2227 char *curr_dst = dst;
2229 while (bytes_left > 0) {
2230 addr_t cache_line_bytes_left =
2231 cache_line_size - (curr_addr % cache_line_size);
2233 std::min<addr_t>(bytes_left, cache_line_bytes_left);
2235 size_t bytes_read =
ReadMemory(address, curr_dst, bytes_to_read,
error,
2238 if (bytes_read == 0) {
2239 result_error = std::move(
error);
2240 dst[total_cstr_len] =
'\0';
2243 const size_t len = strlen(curr_dst);
2245 total_cstr_len += len;
2247 if (len < bytes_to_read)
2250 curr_dst += bytes_read;
2251 curr_addr += bytes_read;
2252 bytes_left -= bytes_read;
2259 result_error.
Clear();
2261 return total_cstr_len;
2269 return cache_line_size - (load_addr % cache_line_size);
2279 size_t type_width,
bool force_live_memory) {
2280 if (!dst || !max_bytes || !type_width || max_bytes < type_width)
2283 size_t total_bytes_read = 0;
2287 memset(dst, 0, max_bytes);
2288 size_t bytes_left = max_bytes - type_width;
2290 const char terminator[4] = {
'\0',
'\0',
'\0',
'\0'};
2291 assert(
sizeof(terminator) >= type_width &&
"Attempting to validate a "
2292 "string with more than 4 bytes "
2296 char *curr_dst = dst;
2299 while (bytes_left > 0 &&
error.Success()) {
2303 ReadMemory(address, curr_dst, bytes_to_read,
error, force_live_memory);
2305 if (bytes_read == 0)
2310 size_t aligned_start = total_bytes_read - total_bytes_read % type_width;
2311 for (
size_t i = aligned_start;
2312 i + type_width <= total_bytes_read + bytes_read; i += type_width)
2313 if (::memcmp(&dst[i], terminator, type_width) == 0) {
2318 total_bytes_read += bytes_read;
2319 curr_dst += bytes_read;
2320 address.
Slide(bytes_read);
2321 bytes_left -= bytes_read;
2323 return total_bytes_read;
2327 bool is_signed,
Scalar &scalar,
2329 bool force_live_memory) {
2332 if (byte_size <=
sizeof(uval)) {
2335 if (bytes_read == byte_size) {
2337 m_arch.GetSpec().GetAddressByteSize());
2340 scalar = data.
GetMaxU32(&offset, byte_size);
2342 scalar = data.
GetMaxU64(&offset, byte_size);
2352 "byte size of %u is too large for integer scalar type", byte_size);
2358 size_t integer_byte_size,
2360 bool force_live_memory) {
2369 size_t integer_byte_size,
2371 bool force_live_memory) {
2381 bool force_live_memory) {
2384 false, scalar,
error, force_live_memory)) {
2388 if (section_load_list.
IsEmpty()) {
2391 m_images.ResolveFileAddress(pointer_vm_addr, pointer_addr);
2402 pointer_addr.
SetOffset(pointer_vm_addr);
2410 bool notify,
Status *error_ptr) {
2417 module_spec.
SetTarget(shared_from_this());
2419 if (std::optional<FileSpec> remapped_obj_file =
2430 module_sp =
m_images.FindFirstModule(module_spec);
2433 llvm::SmallVector<ModuleSP, 1>
2436 bool did_create_module =
false;
2446 module_spec, module_sp, symbol_file_spec, &did_create_module);
2476 transformed_spec.
SetTarget(shared_from_this());
2478 &old_modules, &did_create_module);
2495 &old_modules, &did_create_module);
2503 module_spec,
m_process_sp.get(), module_sp, &old_modules,
2504 &did_create_module);
2515 ObjectFile *objfile = module_sp->GetObjectFile();
2531 "debug info files aren't valid target "
2532 "modules, please specify an executable");
2539 "stub libraries aren't valid target "
2540 "modules, please specify an executable");
2545 "unsupported file type, please specify an executable");
2564 m_images.FindModules(module_spec_copy, found_modules);
2566 old_modules.push_back(found_module);
2573 if (symbol_file_spec)
2574 module_sp->SetSymbolFileFileSpec(symbol_file_spec);
2576 llvm::SmallVector<ModuleSP, 1> replaced_modules;
2577 for (
ModuleSP &old_module_sp : old_modules) {
2578 if (
m_images.GetIndexForModule(old_module_sp.get()) !=
2580 if (replaced_modules.empty())
2581 m_images.ReplaceModule(old_module_sp, module_sp);
2585 replaced_modules.push_back(std::move(old_module_sp));
2589 if (replaced_modules.size() > 1) {
2602 auto dump = [&message](
Module &dump_module) ->
void {
2603 UUID dump_uuid = dump_module.GetUUID();
2607 message <<
" (uuid ";
2610 dump_uuid.
Dump(message);
2612 message <<
"not specified";
2617 message <<
"New module ";
2620 << llvm::formatv(
" simultaneously replaced {0} old modules: ",
2621 replaced_modules.size());
2622 for (
ModuleSP &replaced_module_sp : replaced_modules)
2623 dump(*replaced_module_sp);
2629 if (replaced_modules.empty())
2630 m_images.Append(module_sp, notify);
2632 for (
ModuleSP &old_module_sp : replaced_modules) {
2633 auto old_module_wp = old_module_sp->weak_from_this();
2634 old_module_sp.reset();
2642 *error_ptr = std::move(
error);
2671llvm::Expected<lldb::TypeSystemSP>
2673 bool create_on_demand) {
2675 return llvm::createStringError(
"invalid target");
2688 if (languages_for_expressions.
Empty())
2689 return llvm::createStringError(
2690 "No expression support for any languages");
2701 uint32_t byte_size) {
2708std::vector<lldb::TypeSystemSP>
2716 std::vector<lldb::TypeSystemSP> scratch_type_systems;
2721 for (
auto bit : languages_for_expressions.
bitvector.set_bits()) {
2723 auto type_system_or_err =
2725 if (!type_system_or_err)
2728 "Language '{1}' has expression support but no scratch type "
2729 "system available: {0}",
2732 if (
auto ts = *type_system_or_err)
2733 scratch_type_systems.push_back(ts);
2736 std::sort(scratch_type_systems.begin(), scratch_type_systems.end());
2737 scratch_type_systems.erase(llvm::unique(scratch_type_systems),
2738 scratch_type_systems.end());
2739 return scratch_type_systems;
2746 if (
auto err = type_system_or_err.takeError()) {
2749 "Unable to get persistent expression state for language {1}: {0}",
2754 if (
auto ts = *type_system_or_err)
2755 return ts->GetPersistentExpressionState();
2758 "Unable to get persistent expression state for language {}:",
2764 llvm::StringRef expr, llvm::StringRef prefix,
SourceLanguage language,
2768 auto type_system_or_err =
2770 if (
auto err = type_system_or_err.takeError()) {
2772 "Could not find type system for language %s: %s",
2774 llvm::toString(std::move(err)).c_str());
2778 auto ts = *type_system_or_err;
2781 "Type system for language %s is no longer live",
2786 auto *user_expr = ts->GetUserExpression(expr, prefix, language, desired_type,
2790 "Could not create an expression for language %s",
2801 if (
auto err = type_system_or_err.takeError()) {
2803 "Could not find type system for language %s: %s",
2805 llvm::toString(std::move(err)).c_str());
2808 auto ts = *type_system_or_err;
2811 "Type system for language %s is no longer live",
2815 auto *persistent_fn = ts->GetFunctionCaller(return_type, function_address,
2816 arg_value_list, name);
2819 "Could not create an expression for language %s",
2822 return persistent_fn;
2825llvm::Expected<std::unique_ptr<UtilityFunction>>
2830 if (!type_system_or_err)
2831 return type_system_or_err.takeError();
2832 auto ts = *type_system_or_err;
2834 return llvm::createStringError(
2835 llvm::StringRef(
"Type system for language ") +
2837 llvm::StringRef(
" is no longer live"));
2838 std::unique_ptr<UtilityFunction> utility_fn =
2839 ts->CreateUtilityFunction(std::move(expression), std::move(name));
2841 return llvm::createStringError(
2842 llvm::StringRef(
"Could not create an expression for language") +
2846 if (!utility_fn->Install(diagnostics, exe_ctx))
2848 "Could not install utility function:");
2850 return std::move(utility_fn);
2871 "setting target's default architecture to {0} ({1})",
2878 if (llvm::to_integer(label, n))
2879 return llvm::createStringError(
"cannot use integer as target label");
2883 if (target_sp && target_sp->GetLabel() == label) {
2884 return llvm::createStringErrorV(
2885 "Cannot use label '{0}' since it's set in target #{1}.", label, i);
2890 return llvm::Error::success();
2899 Target *target =
nullptr;
2900 if (sc_ptr !=
nullptr)
2902 if (target ==
nullptr && exe_ctx_ptr)
2912 result_valobj_sp.reset();
2917 m_stats.GetExpressionStats().NotifyFailure();
2918 return execution_results;
2924 llvm::scope_exit on_exit([
this, old_suppress_value]() {
2942 if (expr[0] ==
'$') {
2943 auto type_system_or_err =
2945 if (
auto err = type_system_or_err.takeError()) {
2947 "Unable to get scratch type system");
2949 auto ts = *type_system_or_err;
2952 "Scratch type system is no longer live: {0}");
2955 ts->GetPersistentExpressionState()->GetVariable(expr);
2958 if (persistent_var_sp) {
2959 result_valobj_sp = persistent_var_sp->GetValueObject();
2966 if (
ThreadSP thread_sp = exe_ctx.GetThreadSP()) {
2967 if (thread_sp->IsAnyProviderActive()) {
2975 result_valobj_sp, fixed_expression, ctx_obj);
2979 m_stats.GetExpressionStats().NotifySuccess();
2981 m_stats.GetExpressionStats().NotifyFailure();
2982 return execution_results;
2988 [name, &variable_sp](
TypeSystemSP type_system) ->
bool {
2989 auto ts = type_system.get();
2993 ts->GetPersistentExpressionState()) {
2994 variable_sp = persistent_state->GetVariable(name);
3009 auto ts = type_system.get();
3014 ts->GetPersistentExpressionState()) {
3015 address = persistent_state->LookupSymbol(name);
3028 const bool has_primary_executable = exe_module && exe_module->
GetObjectFile();
3029 if (has_primary_executable) {
3036 const size_t num_images = modules.
GetSize();
3037 for (
size_t idx = 0; idx < num_images; ++idx) {
3039 if (!module_sp || !module_sp->GetObjectFile())
3042 Address entry_addr = module_sp->GetObjectFile()->GetEntryPointAddress();
3048 if (!has_primary_executable)
3049 return llvm::createStringError(
3050 "No primary executable found and could not find entry point address in "
3051 "any executable module");
3053 return llvm::createStringError(
3054 "Could not find entry point address for primary executable module \"" +
3062 ? arch_plugin->GetCallableLoadAddress(load_addr, addr_class)
3069 return arch_plugin ? arch_plugin->GetOpcodeLoadAddress(load_addr, addr_class)
3075 return arch_plugin ? arch_plugin->GetBreakableLoadAddress(addr, *
this) : addr;
3078llvm::Expected<lldb::DisassemblerSP>
3080 const char *flavor_string) {
3082 bool force_live_memory =
true;
3085 const size_t bytes_read =
3087 force_live_memory, &load_addr);
3090 return llvm::createStringErrorV(
3092 "Target::ReadInstructions failed to read memory at {:x}"),
3096 if (!flavor_string || flavor_string[0] ==
'\0') {
3101 if (arch == llvm::Triple::x86 || arch == llvm::Triple::x86_64)
3129 stop_hook_sp.reset(
new StopHookCoded(shared_from_this(), new_uid));
3136 return stop_hook_sp;
3148 return (num_removed != 0);
3156 StopHookCollection::iterator specified_hook_iter;
3159 found_hook = (*specified_hook_iter).second;
3164 bool active_state) {
3165 StopHookCollection::iterator specified_hook_iter;
3170 (*specified_hook_iter).second->SetIsActive(active_state);
3175 StopHookCollection::iterator pos, end =
m_stop_hooks.end();
3177 (*pos).second->SetIsActive(active_state);
3186const std::vector<Target::StopHookSP>
3191 std::vector<StopHookSP> stop_hooks;
3193 stop_hooks.push_back(hook);
3211 auto is_active = [at_initial_stop](
StopHookSP hook) {
3212 bool should_run_now = (!at_initial_stop || hook->GetRunAtInitialStop());
3213 return hook->IsActive() && should_run_now;
3217 std::vector<StopHookSP> active_hooks;
3221 if (is_active(hook))
3222 active_hooks.push_back(hook);
3226 std::vector<HookSP> active_unified_hooks;
3227 for (
auto &[_, hook] :
m_hooks) {
3229 (!at_initial_stop || hook->GetRunAtInitialStop()))
3230 active_unified_hooks.push_back(hook);
3233 if (active_hooks.empty() && active_unified_hooks.empty())
3242 uint32_t last_natural_stop =
m_process_sp->GetModIDRef().GetLastNaturalStopID();
3246 std::vector<ExecutionContext> exc_ctx_with_reasons;
3249 size_t num_threads = cur_threadlist.
GetSize();
3250 for (
size_t i = 0; i < num_threads; i++) {
3252 if (cur_thread_sp->ThreadStoppedForAReason()) {
3254 exc_ctx_with_reasons.emplace_back(
m_process_sp.get(), cur_thread_sp.get(),
3255 cur_frame_sp.get());
3264 size_t num_exe_ctx = exc_ctx_with_reasons.size();
3265 if (num_exe_ctx == 0) {
3266 if (at_initial_stop && num_threads > 0) {
3268 exc_ctx_with_reasons.emplace_back(
3270 thread_to_use_sp->GetStackFrameAtIndex(0).get());
3280 llvm::scope_exit on_exit([output_sp] { output_sp->Flush(); });
3282 size_t num_hooks_with_output = llvm::count_if(
3283 active_hooks, [](
auto h) {
return !h->GetSuppressOutput(); });
3284 num_hooks_with_output += llvm::count_if(
3285 active_unified_hooks, [](
auto h) {
return !h->GetSuppressOutput(); });
3286 bool print_hook_header = (num_hooks_with_output > 1);
3287 bool print_thread_header = (num_exe_ctx > 1);
3288 bool should_stop =
false;
3289 bool requested_continue =
false;
3296 for (
auto cur_hook_sp : active_hooks) {
3297 bool any_thread_matched =
false;
3298 for (
auto exc_ctx : exc_ctx_with_reasons) {
3299 if (!cur_hook_sp->ExecutionContextPasses(exc_ctx))
3302 bool suppress_output = cur_hook_sp->GetSuppressOutput();
3303 if (print_hook_header && !any_thread_matched && !suppress_output) {
3307 output_sp->Printf(
"\n- Hook %" PRIu64
" (%s)\n", cur_hook_sp->GetID(),
3310 output_sp->Printf(
"\n- Hook %" PRIu64
"\n", cur_hook_sp->GetID());
3311 any_thread_matched =
true;
3314 if (print_thread_header && !suppress_output)
3315 output_sp->Printf(
"-- Thread %d\n",
3316 exc_ctx.GetThreadPtr()->GetIndexID());
3318 auto result = cur_hook_sp->HandleStop(exc_ctx, output_sp);
3321 if (cur_hook_sp->GetAutoContinue())
3322 requested_continue =
true;
3327 requested_continue =
true;
3336 output_sp->Printf(
"\nAborting stop hooks, hook %" PRIu64
3337 " set the program running.\n"
3338 " Consider using '-G true' to make "
3339 "stop hooks auto-continue.\n",
3340 cur_hook_sp->GetID());
3350 for (
auto cur_hook_sp : active_unified_hooks) {
3351 bool any_thread_matched =
false;
3352 for (
auto exc_ctx : exc_ctx_with_reasons) {
3353 if (!cur_hook_sp->ExecutionContextPasses(exc_ctx))
3356 bool suppress_output = cur_hook_sp->GetSuppressOutput();
3357 if (print_hook_header && !any_thread_matched && !suppress_output) {
3361 output_sp->Printf(
"\n- Hook %" PRIu64
" (%s)\n", cur_hook_sp->GetID(),
3364 output_sp->Printf(
"\n- Hook %" PRIu64
"\n", cur_hook_sp->GetID());
3365 any_thread_matched =
true;
3368 if (print_thread_header && !suppress_output)
3369 output_sp->Printf(
"-- Thread %d\n",
3370 exc_ctx.GetThreadPtr()->GetIndexID());
3372 auto result = cur_hook_sp->HandleStop(exc_ctx, output_sp);
3375 if (cur_hook_sp->GetAutoContinue())
3376 requested_continue =
true;
3381 requested_continue =
true;
3386 output_sp->Printf(
"\nAborting stop hooks, hook %" PRIu64
3387 " set the program running.\n"
3388 " Consider using '-G true' to make "
3389 "stop hooks auto-continue.\n",
3390 cur_hook_sp->GetID());
3398 if (requested_continue && !should_stop) {
3401 if (
error.Success()) {
3402 LLDB_LOG(log,
"Resuming from RunStopHooks");
3405 LLDB_LOG(log,
"Resuming from RunStopHooks failed: {0}",
error);
3418 return *g_settings_ptr;
3424 if (!platform_sp || !platform_sp->IsRemote() || !platform_sp->IsConnected())
3434 MainExecutableInstaller installer{platform_sp, module_sp,
3435 shared_from_this(), *launch_info};
3438 ExecutableInstaller installer{platform_sp, module_sp};
3450 uint32_t stop_id,
bool allow_section_end) {
3457 return m_images.ResolveFileAddress(file_addr, resolved_addr);
3461 addr_t new_section_load_addr,
3462 bool warn_multiple) {
3463 const addr_t old_section_load_addr =
3466 if (old_section_load_addr != new_section_load_addr) {
3467 uint32_t stop_id = 0;
3470 stop_id = process_sp->GetStopID();
3474 stop_id, section_sp, new_section_load_addr, warn_multiple))
3481 size_t section_unload_count = 0;
3482 size_t num_modules = module_list.
GetSize();
3483 for (
size_t i = 0; i < num_modules; ++i) {
3484 section_unload_count +=
3487 return section_unload_count;
3491 uint32_t stop_id = 0;
3494 stop_id = process_sp->GetStopID();
3497 SectionList *sections = module_sp->GetSectionList();
3498 size_t section_unload_count = 0;
3501 for (uint32_t i = 0; i < num_sections; ++i) {
3506 return section_unload_count;
3510 uint32_t stop_id = 0;
3513 stop_id = process_sp->GetStopID();
3521 uint32_t stop_id = 0;
3524 stop_id = process_sp->GetStopID();
3555 m_stats.SetLaunchOrAttachTime();
3559 LLDB_LOGF(log,
"Target::%s() called for %s", __FUNCTION__,
3571 state = process_sp->GetState();
3573 "Target::%s the process exists, and its current state is %s",
3576 LLDB_LOGF(log,
"Target::%s the process instance doesn't currently exist.",
3589 const bool synchronous_execution =
3597 if (launch_info.
GetFlags().
Test(eLaunchFlagLaunchInTTY))
3599 "can't launch in tty when launching through a remote connection");
3617 LLDB_LOGF(log,
"Target::%s asking the platform to debug the process",
3631 "Target::%s the platform doesn't know how to debug a "
3632 "process, getting a process plugin to do this for us.",
3651 if (!
error.Success())
3657 bool rebroadcast_first_stop =
3658 !synchronous_execution &&
3664 state =
m_process_sp->WaitForProcessToStop(std::nullopt, &first_stop_event_sp,
3665 rebroadcast_first_stop,
3669 if (rebroadcast_first_stop) {
3672 assert(first_stop_event_sp);
3681 if (launch_info.
GetFlags().
Test(eLaunchFlagStopAtEntry))
3683 if (synchronous_execution)
3690 if (!
error.Success()) {
3692 "process resume at entry point failed: %s",
error.AsCString());
3696 bool with_shell = !!launch_info.
GetShell();
3698 const char *exit_desc =
m_process_sp->GetExitDescription();
3700 if (exit_desc && exit_desc[0])
3701 desc =
" (" + std::string(exit_desc) +
')';
3704 "process exited with status %i%s\n"
3705 "'r' and 'run' are aliases that default to launching through a "
3707 "Try launching without going through a shell by using "
3708 "'process launch'.",
3709 exit_status, desc.c_str());
3712 "process exited with status %i%s", exit_status, desc.c_str());
3716 "initial process state wasn't stopped: %s",
StateAsCString(state));
3728 return llvm::createStringError(llvm::inconvertibleErrorCode(),
3729 "A process is required for tracing");
3731 return llvm::createStringError(llvm::inconvertibleErrorCode(),
3732 "A trace already exists for the target");
3734 llvm::Expected<TraceSupportedResponse> trace_type =
3737 return llvm::createStringError(
3738 llvm::inconvertibleErrorCode(),
"Tracing is not supported. %s",
3739 llvm::toString(trace_type.takeError()).c_str());
3740 if (llvm::Expected<TraceSP> trace_sp =
3744 return llvm::createStringError(
3745 llvm::inconvertibleErrorCode(),
3746 "Couldn't create a Trace object for the process. %s",
3747 llvm::toString(trace_sp.takeError()).c_str());
3758 Progress attach_progress(
"Waiting to attach to process");
3759 m_stats.SetLaunchOrAttachTime();
3763 state = process_sp->GetState();
3776 if (old_exec_module_sp)
3778 old_exec_module_sp->GetPlatformFileSpec().GetFilename());
3782 "no process specified, create a target with a file, or "
3783 "specify the --pid or --name");
3787 const auto platform_sp =
3790 const bool async = attach_info.
GetAsync();
3808 plugin_name,
nullptr,
false);
3811 "failed to create process using plugin '{0}'",
3812 plugin_name.empty() ?
"<empty>" : plugin_name);
3816 if (hijack_listener_sp)
3817 process_sp->HijackProcessEvents(hijack_listener_sp);
3818 error = process_sp->Attach(attach_info);
3821 if (
error.Success() && process_sp) {
3823 process_sp->RestoreProcessEvents();
3826 state = process_sp->WaitForProcessToStop(
3829 process_sp->RestoreProcessEvents();
3836 const char *exit_desc = process_sp->GetExitDescription();
3841 "process did not stop (no such process or permission problem?)");
3842 process_sp->Destroy(
false);
3852 return llvm::createStringError(
"invalid frame provider descriptor");
3854 llvm::StringRef name = descriptor.
GetName();
3856 return llvm::createStringError(
3857 "frame provider descriptor has no class name");
3860 std::unique_lock<std::recursive_mutex> guard(
3864 uint32_t descriptor_hash = descriptor.
GetHash();
3866 if (entry.second.GetHash() == descriptor_hash)
3868 llvm::formatv(
"frame provider idx={0} with the same class name and "
3869 "arguments is already registered",
3870 entry.second.GetID())
3876 new_descriptor.
SetID(descriptor_id);
3881 return descriptor_id;
3886 bool removed =
false;
3888 std::lock_guard<std::recursive_mutex> guard(
3900 std::lock_guard<std::recursive_mutex> guard(
3909const llvm::MapVector<uint32_t, ScriptedFrameProviderDescriptor> &
3911 std::lock_guard<std::recursive_mutex> guard(
3920 for (
ThreadSP thread_sp : process_sp->Threads()) {
3922 thread_sp->ClearScriptedFrameProvider();
3925 auto data_sp = std::make_shared<Thread::ThreadEventData>(thread_sp);
3937 const bool default_to_use_pty =
3941 "have platform={0}, platform_sp->IsHost()={1}, default_to_use_pty={2}",
3943 platform_sp ? (platform_sp->IsHost() ?
"true" :
"false") :
"n/a",
3944 default_to_use_pty);
3951 LLDB_LOG(log,
"at least one of stdin/stdout/stderr was not set, evaluating "
3952 "default handling");
3961 LLDB_LOG(log,
"eLaunchFlagDisableSTDIO set, adding suppression action "
3962 "for stdin, stdout and stderr");
3982 LLDB_LOG(log,
"target stdin='{0}', target stdout='{1}', stderr='{2}'",
3983 in_file_spec, out_file_spec, err_file_spec);
3987 LLDB_LOG(log,
"appended stdin open file action for {0}", in_file_spec);
3990 if (out_file_spec) {
3992 LLDB_LOG(log,
"appended stdout open file action for {0}",
3996 if (err_file_spec) {
3998 LLDB_LOG(log,
"appended stderr open file action for {0}",
4002 if (default_to_use_pty) {
4005 ::getenv(
"LLDB_LAUNCH_FLAG_USE_PIPES")) {
4006 llvm::Error Err = info.SetUpPipeRedirection();
4008 "SetUpPipeRedirection failed: {0}");
4013 "SetUpPtyRedirection failed: {0}");
4033 elem.notify = notify;
4043 = signals_sp->GetSignalNumberFromName(elem.first().str().c_str());
4048 signals_sp->SetShouldSuppress(signo,
false);
4050 signals_sp->SetShouldSuppress(signo,
true);
4053 signals_sp->SetShouldNotify(signo,
true);
4055 signals_sp->SetShouldNotify(signo,
false);
4058 signals_sp->SetShouldStop(signo,
true);
4060 signals_sp->SetShouldStop(signo,
false);
4069 = signals_sp->GetSignalNumberFromName(elem.first().str().c_str());
4075 signals_sp->ResetSignal(signo, do_stop, do_notify, do_pass);
4086 warning_stream_sp->Printf(
"Target signal '%s' not found in process\n",
4087 elem.first().str().c_str());
4100 signals_sp = process_sp->GetUnixSignals();
4103 const char *signal_name = entry.c_str();
4117 strm.
Printf(
"NAME PASS STOP NOTIFY\n");
4118 strm.
Printf(
"=========== ======= ======= =======\n");
4120 auto str_for_lazy = [] (
LazyBool lazy) ->
const char * {
4126 llvm_unreachable(
"Fully covered switch above!");
4130 bool print_it =
false;
4131 for (
size_t idx = 0; idx < num_args; idx++) {
4138 strm.
Printf(
"%-11s ", elem.first().str().c_str());
4139 strm.
Printf(
"%s %s %s\n", str_for_lazy(elem.second.pass),
4140 str_for_lazy(elem.second.stop),
4141 str_for_lazy(elem.second.notify));
4172 bool will_run =
true;
4196 s.
Indent(
"State: enabled\n");
4198 s.
Indent(
"State: disabled\n");
4201 s.
Indent(
"AutoContinue on\n");
4231 uint32_t num_commands =
m_commands.GetSize();
4232 for (uint32_t i = 0; i < num_commands; i++) {
4244 const std::vector<std::string> &strings) {
4245 for (
auto string : strings)
4252 assert(exc_ctx.
GetTargetPtr() &&
"Can't call PerformAction on a context "
4289 GetTarget()->GetDebugger().GetScriptInterpreter();
4290 if (!script_interp) {
4298 "ScriptedStopHook::%s () - ERROR: %s", __FUNCTION__,
4299 "Script interpreter couldn't create Scripted Stop Hook Interface");
4310 if (!object_sp || !object_sp->IsValid()) {
4312 "ScriptedStopHook::%s () - ERROR: %s", __FUNCTION__,
4313 "Failed to create valid script object");
4323 assert(exc_ctx.
GetTargetPtr() &&
"Can't call HandleStop on a context "
4329 lldb::StreamSP stream = std::make_shared<lldb_private::StreamString>();
4330 auto should_stop_or_err =
m_interface_sp->HandleStop(exc_ctx, stream);
4331 output_sp->PutCString(
4333 if (!should_stop_or_err) {
4335 "scripted stop hook HandleStop failed: {0}");
4357 s.
Format(
"{0}\n", class_name);
4366 if (!as_dict || !as_dict->IsValid())
4369 uint32_t num_keys = as_dict->GetSize();
4376 auto print_one_element = [&s](llvm::StringRef key,
4379 s.
Format(
"{0} : {1}\n", key, object->GetStringValue());
4383 as_dict->ForEach(print_one_element);
4415 bool will_run =
true;
4436 std::string fires_on;
4440 if (!fires_on.empty())
4442 fires_on +=
"unload";
4445 if (!fires_on.empty())
4449 if (!fires_on.empty()) {
4451 s.
Printf(
"Triggers: %s\n", fires_on.c_str());
4464 s.
Indent(
"AutoContinue on\n");
4500 s.
Indent(
"Commands: \n");
4502 for (uint32_t i = 0; i <
m_commands.GetSize(); i++) {
4519 const std::vector<std::string> &strings) {
4520 for (
const auto &
string : strings)
4535 Debugger &debugger = target_sp->GetDebugger();
4538 if (target_sp->GetProcessSP())
4539 exe_ctx.
SetContext(target_sp->GetProcessSP());
4566 assert(exc_ctx.
GetTargetPtr() &&
"Can't call HandleStop on a context "
4601 GetTarget()->GetDebugger().GetScriptInterpreter();
4608 "ScriptedHook::%s () - ERROR: %s", __FUNCTION__,
4609 "Script interpreter couldn't create Scripted Hook Interface");
4617 if (!object_sp || !object_sp->IsValid())
4619 "ScriptedHook::%s () - ERROR: %s", __FUNCTION__,
4620 "Failed to create valid script object");
4627 "hook class implements none of the expected methods "
4628 "(handle_module_loaded, handle_module_unloaded, handle_stop)");
4630 if (methods.handle_module_loaded)
4632 if (methods.handle_module_unloaded)
4634 if (methods.handle_stop)
4644 StreamSP stream = std::make_shared<StreamString>();
4653 StreamSP stream = std::make_shared<StreamString>();
4661 assert(exc_ctx.
GetTargetPtr() &&
"Can't call HandleStop on a context "
4667 lldb::StreamSP stream = std::make_shared<lldb_private::StreamString>();
4668 auto should_stop_or_err =
m_interface_sp->HandleStop(exc_ctx, stream);
4670 if (!should_stop_or_err)
4696 s.
Format(
"{0}\n", class_name);
4702 if (as_dict && as_dict->IsValid() && as_dict->GetSize() > 0) {
4706 auto print_one_element = [&s](llvm::StringRef key,
4709 s.
Format(
"{0} : {1}\n", key, object->GetStringValue());
4713 as_dict->ForEach(print_one_element);
4731 hook_sp.reset(
new HookScripted(shared_from_this(), new_uid));
4746 size_t num_removed =
m_hooks.erase(uid);
4747 return (num_removed != 0);
4753 auto iter =
m_hooks.find(uid);
4756 return iter->second;
4763 std::advance(iter, index);
4764 return iter->second;
4768 auto iter =
m_hooks.find(uid);
4771 iter->second->SetIsEnabled(enabled);
4776 for (
auto &[_, hook] :
m_hooks)
4777 hook->SetIsEnabled(enabled);
4788 std::vector<HookSP> active_hooks;
4789 for (
auto &[_, hook_sp] :
m_hooks) {
4790 if (hook_sp->IsEnabled() && hook_sp->FiresOn(trigger))
4791 active_hooks.push_back(hook_sp);
4794 if (active_hooks.empty())
4799 for (
auto &hook_sp : active_hooks) {
4801 hook_sp->HandleModuleLoaded(output_sp);
4803 hook_sp->HandleModuleUnloaded(output_sp);
4812 "no-dynamic-values",
4813 "Don't calculate the dynamic type of values",
4818 "Calculate the dynamic type of values "
4819 "even if you have to run the target.",
4824 "Calculate the dynamic type of values, but don't run the target.",
4836 "Never look for inline breakpoint locations (fastest). This setting "
4837 "should only be used if you know that no inlining occurs in your"
4843 "Only check for inline breakpoint locations when setting breakpoints "
4844 "in header files, but not when setting breakpoint in implementation "
4845 "source files (default).",
4850 "Always look for inline breakpoint locations when setting file and "
4851 "line breakpoints (slower but most accurate).",
4865 "Disassembler default (currently att).",
4870 "Intel disassembler flavor.",
4875 "AT&T disassembler flavor.",
4883 "Never import the 'std' C++ module in the expression parser.",
4888 "Retry evaluating expressions with an imported 'std' C++ module if they"
4889 " failed to parse without the module. This allows evaluating more "
4890 "complex expressions involving C++ standard library types."
4895 "Always import the 'std' C++ module. This allows evaluating more "
4896 "complex expressions involving C++ standard library types. This feature"
4901static constexpr OptionEnumValueElement
4906 "Automatically determine the most appropriate method for the "
4910 "Prefer using the realized classes struct."},
4912 "Prefer using the CopyRealizedClassList API."},
4914 "Prefer using the GetRealizedClassList API."},
4921 "C-style (0xffff).",
4926 "Asm-style (0ffffh).",
4934 "Load debug scripts inside symbol files",
4939 "Do not load debug scripts inside symbol files.",
4944 "Warn about debug scripts inside symbol files but do not load them.",
4949 "Load debug scripts inside trusted symbol files, and warn about "
4950 "scripts from untrusted symbol files.",
4958 "Load .lldbinit files from current directory",
4963 "Do not load .lldbinit files from current directory",
4968 "Warn about loading .lldbinit files from current directory",
4976 "Load minimal information when loading modules from memory. Currently "
4977 "this setting loads sections only.",
4982 "Load partial information when loading modules from memory. Currently "
4983 "this setting loads sections and function bounds.",
4988 "Load complete information when loading modules from memory. Currently "
4989 "this setting loads sections and all symbols.",
4993#define LLDB_PROPERTIES_target
4994#include "TargetProperties.inc"
4997#define LLDB_PROPERTIES_target
4998#include "TargetPropertiesEnum.inc"
5003 :
public Cloneable<TargetOptionValueProperties, OptionValueProperties> {
5014 Target *target = exe_ctx->GetTargetPtr();
5019 if (
this != target_properties)
5028#define LLDB_PROPERTIES_target_experimental
5029#include "TargetProperties.inc"
5032#define LLDB_PROPERTIES_target_experimental
5033#include "TargetPropertiesEnum.inc"
5037 :
public Cloneable<TargetExperimentalOptionValueProperties,
5038 OptionValueProperties> {
5075 m_collection_sp->SetValueChangedCallback(ePropertyDetachOnError, [
this] {
5088 std::make_unique<TargetExperimentalProperties>();
5091 "Experimental settings - setting these won't produce "
5092 "errors if the setting is not present.",
5095 m_collection_sp = std::make_shared<TargetOptionValueProperties>(
"target");
5098 std::make_unique<TargetExperimentalProperties>();
5101 "Experimental settings - setting these won't produce "
5102 "errors if the setting is not present.",
5105 "process",
"Settings specific to processes.",
true,
5132 exp_property->
GetValue()->GetAsProperties();
5135 return std::nullopt;
5148 exp_property->
GetValue()->GetAsProperties();
5160 exp_property->
GetValue()->GetAsProperties();
5166 const uint32_t idx = ePropertyDefaultArch;
5171 const uint32_t idx = ePropertyDefaultArch;
5176 const uint32_t idx = ePropertyMoveToNearestCode;
5178 idx, g_target_properties[idx].default_uint_value != 0);
5182 const uint32_t idx = ePropertyPreferDynamic;
5185 g_target_properties[idx].default_uint_value));
5189 const uint32_t idx = ePropertyPreferDynamic;
5195 "Interrupted checking preload symbols")) {
5198 const uint32_t idx = ePropertyPreloadSymbols;
5200 idx, g_target_properties[idx].default_uint_value != 0);
5204 const uint32_t idx = ePropertyPreloadSymbols;
5209 const uint32_t idx = ePropertyDisableASLR;
5211 idx, g_target_properties[idx].default_uint_value != 0);
5215 const uint32_t idx = ePropertyDisableASLR;
5220 const uint32_t idx = ePropertyInheritTCC;
5222 idx, g_target_properties[idx].default_uint_value != 0);
5226 const uint32_t idx = ePropertyInheritTCC;
5231 const uint32_t idx = ePropertyDetachOnError;
5233 idx, g_target_properties[idx].default_uint_value != 0);
5237 const uint32_t idx = ePropertyDetachOnError;
5242 const uint32_t idx = ePropertyDisableSTDIO;
5244 idx, g_target_properties[idx].default_uint_value != 0);
5248 const uint32_t idx = ePropertyDisableSTDIO;
5252 const uint32_t idx = ePropertyLaunchWorkingDir;
5254 idx, g_target_properties[idx].default_cstr_value);
5258 const uint32_t idx = ePropertyParallelModuleLoad;
5260 idx, g_target_properties[idx].default_uint_value != 0);
5264 const uint32_t idx = ePropertyDisassemblyFlavor;
5265 const char *return_value;
5270 g_target_properties[idx].default_uint_value));
5273 return return_value;
5277 const uint32_t idx = ePropertyDisassemblyCPU;
5279 idx, g_target_properties[idx].default_cstr_value);
5280 return str.empty() ? nullptr : str.data();
5284 const uint32_t idx = ePropertyDisassemblyFeatures;
5286 idx, g_target_properties[idx].default_cstr_value);
5287 return str.empty() ? nullptr : str.data();
5291 const uint32_t idx = ePropertyInlineStrategy;
5294 static_cast<InlineStrategy>(g_target_properties[idx].default_uint_value));
5300 const uint32_t idx = ePropertySourceRealpathPrefixes;
5305 const uint32_t idx = ePropertyArg0;
5307 idx, g_target_properties[idx].default_cstr_value);
5311 const uint32_t idx = ePropertyArg0;
5317 const uint32_t idx = ePropertyRunArgs;
5322 const uint32_t idx = ePropertyRunArgs;
5332 ePropertyInheritEnv,
5333 g_target_properties[ePropertyInheritEnv].default_uint_value != 0)) {
5334 if (
auto platform_sp =
m_target->GetPlatform()) {
5335 Environment platform_env = platform_sp->GetEnvironment();
5336 for (
const auto &KV : platform_env)
5337 env[KV.first()] = KV.second;
5341 Args property_unset_env;
5343 property_unset_env);
5344 for (
const auto &var : property_unset_env)
5345 env.erase(var.ref());
5348 m_collection_sp->GetPropertyAtIndexAsArgs(ePropertyEnvVars, property_env);
5350 env[KV.first()] = KV.second;
5366 ePropertyInheritEnv,
5367 g_target_properties[ePropertyInheritEnv].default_uint_value != 0))
5371 if (platform_sp ==
nullptr)
5374 Environment platform_environment = platform_sp->GetEnvironment();
5375 for (
const auto &KV : platform_environment)
5376 environment[KV.first()] = KV.second;
5378 Args property_unset_environment;
5380 property_unset_environment);
5381 for (
const auto &var : property_unset_environment)
5382 environment.erase(var.ref());
5388 Args property_environment;
5390 property_environment);
5392 for (
const auto &KV :
Environment(property_environment))
5393 environment[KV.first()] = KV.second;
5400 const uint32_t idx = ePropertyEnvVars;
5405 const uint32_t idx = ePropertySkipPrologue;
5407 idx, g_target_properties[idx].default_uint_value != 0);
5411 const uint32_t idx = ePropertySourceMap;
5414 assert(option_value);
5419 const uint32_t idx = ePropertyObjectMap;
5422 assert(option_value);
5427 const uint32_t idx = ePropertyAutoSourceMapRelative;
5429 idx, g_target_properties[idx].default_uint_value != 0);
5433 const uint32_t idx = ePropertyExecutableSearchPaths;
5436 assert(option_value);
5441 const uint32_t idx = ePropertyExecutableSearchPaths;
5446 const uint32_t idx = ePropertyDebugFileSearchPaths;
5451 const uint32_t idx = ePropertyClangModuleSearchPaths;
5456 const uint32_t idx = ePropertyAutoImportClangModules;
5458 idx, g_target_properties[idx].default_uint_value != 0);
5462 const uint32_t idx = ePropertyImportStdModule;
5465 g_target_properties[idx].default_uint_value));
5469 const uint32_t idx = ePropertyDynamicClassInfoHelper;
5472 g_target_properties[idx].default_uint_value));
5476 const uint32_t idx = ePropertyAutoApplyFixIts;
5478 idx, g_target_properties[idx].default_uint_value != 0);
5482 const uint32_t idx = ePropertyRetriesWithFixIts;
5484 idx, g_target_properties[idx].default_uint_value);
5488 const uint32_t idx = ePropertyNotifyAboutFixIts;
5490 idx, g_target_properties[idx].default_uint_value != 0);
5494 const uint32_t idx = ePropertySaveObjectsDir;
5504 bool exists = instance.
Exists(new_dir);
5505 bool is_directory = instance.
IsDirectory(new_dir);
5506 std::string path = new_dir.
GetPath(
true);
5507 bool writable = llvm::sys::fs::can_write(path);
5508 if (exists && is_directory && writable)
5516 llvm::raw_string_ostream os(buffer);
5517 os <<
"JIT object dir '" << path <<
"' ";
5519 os <<
"does not exist";
5520 else if (!is_directory)
5521 os <<
"is not a directory";
5523 os <<
"is not writable";
5525 std::optional<lldb::user_id_t> debugger_id;
5527 debugger_id =
m_target->GetDebugger().GetID();
5532 const uint32_t idx = ePropertyEnableSynthetic;
5534 idx, g_target_properties[idx].default_uint_value != 0);
5538 const uint32_t idx = ePropertyShowHexVariableValuesWithLeadingZeroes;
5540 idx, g_target_properties[idx].default_uint_value != 0);
5544 const uint32_t idx = ePropertyMaxZeroPaddingInFloatFormat;
5546 idx, g_target_properties[idx].default_uint_value);
5550 const uint32_t idx = ePropertyMaxChildrenCount;
5552 idx, g_target_properties[idx].default_uint_value);
5555std::pair<uint32_t, bool>
5557 const uint32_t idx = ePropertyMaxChildrenDepth;
5558 auto *option_value =
5560 bool is_default = !option_value->OptionWasSet();
5561 return {option_value->GetCurrentValue(), is_default};
5565 const uint32_t idx = ePropertyMaxSummaryLength;
5567 idx, g_target_properties[idx].default_uint_value);
5571 const uint32_t idx = ePropertyMaxMemReadSize;
5573 idx, g_target_properties[idx].default_uint_value);
5577 const uint32_t idx = ePropertyInputPath;
5582 const uint32_t idx = ePropertyInputPath;
5587 const uint32_t idx = ePropertyOutputPath;
5592 const uint32_t idx = ePropertyOutputPath;
5597 const uint32_t idx = ePropertyErrorPath;
5602 const uint32_t idx = ePropertyErrorPath;
5607 const uint32_t idx = ePropertyLanguage;
5612 const uint32_t idx = ePropertyExprPrefix;
5618 return llvm::StringRef(
5619 reinterpret_cast<const char *
>(data_sp->GetBytes()),
5620 data_sp->GetByteSize());
5626 const uint32_t idx = ePropertyExprErrorLimit;
5628 idx, g_target_properties[idx].default_uint_value);
5632 const uint32_t idx = ePropertyExprAllocAddress;
5634 idx, g_target_properties[idx].default_uint_value);
5638 const uint32_t idx = ePropertyExprAllocSize;
5640 idx, g_target_properties[idx].default_uint_value);
5644 const uint32_t idx = ePropertyExprAllocAlign;
5646 idx, g_target_properties[idx].default_uint_value);
5650 const uint32_t idx = ePropertyBreakpointUseAvoidList;
5652 idx, g_target_properties[idx].default_uint_value != 0);
5656 const uint32_t idx = ePropertyUseHexImmediates;
5658 idx, g_target_properties[idx].default_uint_value != 0);
5662 const uint32_t idx = ePropertyUseFastStepping;
5664 idx, g_target_properties[idx].default_uint_value != 0);
5668 const uint32_t idx = ePropertyDisplayExpressionsInCrashlogs;
5670 idx, g_target_properties[idx].default_uint_value != 0);
5674 const uint32_t idx = ePropertyLoadScriptFromSymbolFile;
5677 g_target_properties[idx].default_uint_value));
5682 const uint32_t idx = ePropertyLoadScriptFromSymbolFile;
5687 const uint32_t idx = ePropertyLoadCWDlldbinitFile;
5690 g_target_properties[idx].default_uint_value));
5694 const uint32_t idx = ePropertyHexImmediateStyle;
5697 g_target_properties[idx].default_uint_value));
5701 const uint32_t idx = ePropertyMemoryModuleLoadLevel;
5704 g_target_properties[idx].default_uint_value));
5708 const uint32_t idx = ePropertyTrapHandlerNames;
5713 const uint32_t idx = ePropertyTrapHandlerNames;
5718 const uint32_t idx = ePropertyDisplayRuntimeSupportValues;
5720 idx, g_target_properties[idx].default_uint_value != 0);
5724 const uint32_t idx = ePropertyDisplayRuntimeSupportValues;
5729 const uint32_t idx = ePropertyDisplayRecognizedArguments;
5731 idx, g_target_properties[idx].default_uint_value != 0);
5735 const uint32_t idx = ePropertyDisplayRecognizedArguments;
5751 if (input_file_action) {
5756 if (output_file_action) {
5761 if (error_file_action) {
5767 launch_info.
GetFlags().
Test(lldb::eLaunchFlagInheritTCCFromParent));
5772 const uint32_t idx = ePropertyRequireHardwareBreakpoints;
5774 idx, g_target_properties[idx].default_uint_value != 0);
5778 const uint32_t idx = ePropertyRequireHardwareBreakpoints;
5783 const uint32_t idx = ePropertyAutoInstallMainExecutable;
5785 idx, g_target_properties[idx].default_uint_value != 0);
5819 m_launch_info.GetFlags().Set(lldb::eLaunchFlagDetachOnError);
5821 m_launch_info.GetFlags().Clear(lldb::eLaunchFlagDetachOnError);
5828 m_launch_info.GetFlags().Clear(lldb::eLaunchFlagDisableASLR);
5833 m_launch_info.GetFlags().Set(lldb::eLaunchFlagInheritTCCFromParent);
5835 m_launch_info.GetFlags().Clear(lldb::eLaunchFlagInheritTCCFromParent);
5840 m_launch_info.GetFlags().Set(lldb::eLaunchFlagDisableSTDIO);
5842 m_launch_info.GetFlags().Clear(lldb::eLaunchFlagDisableSTDIO);
5846 const uint32_t idx = ePropertyDebugUtilityExpression;
5848 idx, g_target_properties[idx].default_uint_value != 0);
5852 const uint32_t idx = ePropertyDebugUtilityExpression;
5857 const uint32_t idx = ePropertyCheckValueObjectOwnership;
5859 idx, g_target_properties[idx].default_uint_value != 0);
5863 const uint32_t idx = ePropertyCheckValueObjectOwnership;
5867std::optional<LoadScriptFromSymFile>
5869 llvm::StringRef module_name)
const {
5870 auto *dict =
m_collection_sp->GetPropertyAtIndexAsOptionValueDictionary(
5871 ePropertyAutoLoadScriptsForModules);
5873 return std::nullopt;
5877 return std::nullopt;
5884 auto *dict =
m_collection_sp->GetPropertyAtIndexAsOptionValueDictionary(
5885 ePropertyAutoLoadScriptsForModules);
5889 dict->SetValueForKey(module_name,
5890 std::make_shared<OptionValueEnumeration>(
5911 return "Target::TargetEventData";
5948 return created_target_sp;
5974 return m_stats.ToJSON(*
this, options);
5992 lldb::BreakpointEventType eventKind) {
5994 std::shared_ptr<Breakpoint::BreakpointEventData> data_sp =
5995 std::make_shared<Breakpoint::BreakpointEventData>(
5996 eventKind, bp.shared_from_this());
6012 if (
auto platform_fspecs_or_err =
6014 fspecs.
Append(*platform_fspecs_or_err);
6017 platform_fspecs_or_err.takeError(),
6018 "Skipping safe auto-load: {0}");
6023 for (
const auto &fspec :
6038 if (option_name.empty())
6039 return llvm::createStringError(
"can't set an option with an empty name");
6044 return llvm::createStringErrorV(
"trying to override existing option '{0}' "
6045 "of type '{1}' with a boolean value",
6046 option_name, existing_sp->GetType());
6050 return llvm::Error::success();
6054 llvm::StringRef option_name)
const {
6057 if (!opts.
HasKey(option_name))
6058 return llvm::createStringErrorV(
"option '{0}' does not exist", option_name);
6062 return llvm::createStringErrorV(
"failed to get option '{0}' as boolean",
6084 "c++-ignore-context-qualifiers";
6097 return llvm::cantFail(
static void dump(const StructuredData::Array &array, Stream &s)
static llvm::raw_ostream & error(Stream &strm)
#define INTERRUPT_REQUESTED(debugger,...)
This handy define will keep you from having to generate a report for the interruption by hand.
#define LLDB_LOG(log,...)
The LLDB_LOG* macros defined below are the way to emit log messages.
#define LLDB_LOGF(log,...)
#define LLDB_LOG_ERROR(log, error,...)
static void skip(TSLexer *lexer)
static double elapsed(const StatsTimepoint &start, const StatsTimepoint &end)
static Status installExecutable(const Installer &installer)
constexpr llvm::StringLiteral s_cpp_ignore_context_qualifiers_option
static constexpr OptionEnumValueElement g_dynamic_class_info_helper_value_types[]
static bool CheckIfWatchpointsSupported(Target *target, Status &error)
static constexpr OptionEnumValueElement g_load_cwd_lldbinit_values[]
static 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)
llvm::StringRef 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.
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.
const char * AsCString(const char *value_if_empty) 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.
static const FileSpecList & GetDefaultSafeAutoLoadPaths()
void SetAsyncExecution(bool async)
CommandInterpreter & GetCommandInterpreter()
lldb::StreamUP GetAsyncErrorStream()
TargetList & GetTargetList()
Get accessor for the target list.
static void ReportWarning(std::string message, std::optional< lldb::user_id_t > debugger_id=std::nullopt, std::once_flag *once=nullptr)
Report warning events.
static llvm::ThreadPoolInterface & GetThreadPool()
Shared thread pool. Use only with ThreadPoolTaskGroup.
static void ReportError(std::string message, std::optional< lldb::user_id_t > debugger_id=std::nullopt, std::once_flag *once=nullptr)
Report error events.
PlatformList & GetPlatformList()
lldb::ListenerSP GetListener()
llvm::Error GetAsError(lldb::ExpressionResults result, llvm::Twine message={}) const
Returns an ExpressionError with arg as error code.
static lldb::DisassemblerSP DisassembleBytes(const ArchSpec &arch, const char *plugin_name, const char *flavor, const char *cpu, const char *features, const Address &start, const void *bytes, size_t length, uint32_t max_num_instructions, bool data_from_file)
A class that measures elapsed time in an exception safe way.
EvaluateExpressionOptions()
bool GetCppIgnoreContextQualifiers() const
void SetCppIgnoreContextQualifiers(bool value)
const StructuredData::Dictionary & GetLanguageOptions() const
llvm::Expected< bool > GetBooleanLanguageOption(llvm::StringRef option_name) const
Get the language-plugin specific boolean option called option_name.
void SetTryAllThreads(bool try_others=true)
void SetStopOthers(bool stop_others=true)
llvm::Error SetBooleanLanguageOption(llvm::StringRef option_name, bool value)
Set language-plugin specific option called option_name to the specified boolean value.
StructuredData::DictionarySP m_language_options_sp
Dictionary mapping names of language-plugin specific options to values.
virtual llvm::StringRef GetFlavor() const =0
"lldb/Target/ExecutionContextScope.h" Inherit from this if your object can reconstruct its execution ...
virtual void CalculateExecutionContext(ExecutionContext &exe_ctx)=0
Reconstruct the object's execution context into sc.
"lldb/Target/ExecutionContext.h" A class that contains an execution context.
void Clear()
Clear the object's state.
void SetTargetPtr(Target *target)
Set accessor to set only the target shared pointer from a target pointer.
StackFrame * GetFramePtr() const
Returns a pointer to the frame object.
void SetContext(const lldb::TargetSP &target_sp, bool get_process)
Target * GetTargetPtr() const
Returns a pointer to the target object.
Thread & GetThreadRef() const
Returns a reference to the thread object.
Represents a file descriptor action to be performed during process launch.
const FileSpec & GetFileSpec() const
Get the file specification for open actions.
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)
const ConstString & GetFilename() const
Filename string const get accessor.
void SetFilename(llvm::StringRef filename)
Filename string set 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.
void SetDirectory(llvm::StringRef directory)
Directory string set accessor.
bool IsSourceImplementationFile() const
Returns true if the filespec represents an implementation source file (files with a "....
bool Exists(const FileSpec &file_spec) const
Returns whether the given file exists.
bool IsDirectory(const FileSpec &file_spec) const
Returns whether the given path is a directory.
static FileSystem & Instance()
bool IsValid() const override
IsValid.
bool Test(ValueType bit) const
Test a single flag bit.
ValueType Set(ValueType mask)
Set one or more flags by logical OR'ing mask with the current flags.
Encapsulates a function that can be called.
static lldb::BreakpointSP CreateExceptionBreakpoint(Target &target, lldb::LanguageType language, bool catch_bp, bool throw_bp, bool is_internal=false)
static LanguageSet GetLanguagesSupportingREPLs()
static Language * FindPlugin(lldb::LanguageType language)
static const char * GetNameForLanguageType(lldb::LanguageType language)
Returns the internal LLDB name for the specified language.
static LanguageSet GetLanguagesSupportingTypeSystemsForExpressions()
virtual llvm::StringRef GetUserEntryPointName() const
static std::set< lldb::LanguageType > GetSupportedLanguages()
static lldb::ListenerSP MakeListener(const char *name)
A collection class for Module objects.
bool AnyOf(std::function< bool(lldb_private::Module &module)> const &callback) const
Returns true if 'callback' returns true for one of the modules in this ModuleList.
static Status GetSharedModule(const ModuleSpec &module_spec, lldb::ModuleSP &module_sp, llvm::SmallVectorImpl< lldb::ModuleSP > *old_modules, bool *did_create_ptr, bool invoke_locate_callback=true)
static bool RemoveSharedModuleIfOrphaned(const lldb::ModuleWP module_ptr)
void PreloadSymbols(bool parallelize) const
For each module in this ModuleList, preload its symbols.
bool AppendIfNeeded(const lldb::ModuleSP &new_module, bool notify=true)
Append a module to the module list, if it is not already there.
void FindModules(const ModuleSpec &module_spec, ModuleList &matching_module_list) const
Finds modules whose file specification matches module_spec.
lldb::ModuleSP GetModuleAtIndex(size_t idx) const
Get the module shared pointer for the module at index idx.
void Append(const lldb::ModuleSP &module_sp, bool notify=true)
Append a module to the module list.
bool LoadScriptingResourcesInTarget(Target *target, std::list< Status > &errors, bool continue_on_error=true)
size_t GetSize() const
Gets the size of the module list.
void ForEach(std::function< IterationAction(const lldb::ModuleSP &module_sp)> const &callback) const
Applies 'callback' to each module in this ModuleList.
void SetTarget(lldb::TargetSP target)
Set the target to be used when resolving a module.
A class that describes an executable image and its associated object and symbol files.
virtual ObjectFile * GetObjectFile()
Get the object file representation for the current architecture.
const FileSpec & GetFileSpec() const
Get const accessor for the module file specification.
A plug-in interface definition class for object file parsers.
virtual uint32_t GetDependentModules(FileSpecList &file_list)=0
Extract the dependent modules from an object file.
virtual lldb_private::Address GetEntryPointAddress()
Returns the address of the Entry Point in this object file - if the object file doesn't have an entry...
@ eTypeExecutable
A normal executable.
@ eTypeDebugInfo
An object file that contains only debug information.
@ eTypeStubLibrary
A library that can be linked against but not used for execution.
@ eTypeObjectFile
An intermediate object file.
@ eTypeDynamicLinker
The platform's dynamic linker executable.
@ eTypeCoreFile
A core file that has a checkpoint of a program's execution state.
@ eTypeSharedLibrary
A shared library that can be used during execution.
virtual size_t ReadSectionData(Section *section, lldb::offset_t section_offset, void *dst, size_t dst_len)
void AppendCurrentValue(const FileSpec &value)
const lldb::DataBufferSP & GetFileContents()
PathMappingList & GetCurrentValue()
auto GetPropertyAtIndexAs(size_t idx, const ExecutionContext *exe_ctx=nullptr) const
Property * ProtectedGetPropertyAtIndex(size_t idx)
bool SetPropertyAtIndex(size_t idx, T t, const ExecutionContext *exe_ctx=nullptr) const
static lldb::OptionValuePropertiesSP CreateLocalCopy(const Properties &global_properties)
bool RemapPath(ConstString path, ConstString &new_path) const
std::optional< llvm::StringRef > ReverseRemapPath(const FileSpec &file, FileSpec &fixed) const
Perform reverse source path remap for input file.
static std::unique_ptr< Architecture > CreateArchitectureInstance(const ArchSpec &arch)
static lldb::RegisterTypeBuilderSP GetRegisterTypeBuilder(Target &target)
static PolicyStack & Get()
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::ScriptedHookInterfaceSP CreateScriptedHookInterface()
virtual lldb::ScriptedStopHookInterfaceSP CreateScriptedStopHookInterface()
size_t GetNumSections(uint32_t depth) const
lldb::SectionSP GetSectionAtIndex(size_t idx) const
void Dump(Stream &s, Target *target)
bool ResolveLoadAddress(lldb::addr_t load_addr, Address &so_addr, bool allow_section_end=false) const
lldb::addr_t GetSectionLoadAddress(const lldb::SectionSP §ion_sp) const
"lldb/Core/SourceLocationSpec.h" A source location specifier class.
Class that provides a registry of known stack frame recognizers.
virtual const SymbolContext & GetSymbolContext(lldb::SymbolContextItem resolve_scope)
Provide a SymbolContext for this StackFrame's current pc value.
void Clear()
Clear the object state.
static Status FromErrorStringWithFormat(const char *format,...) __attribute__((format(printf
static Status FromErrorString(const char *str)
bool Fail() const
Test for error condition.
static Status static Status FromErrorStringWithFormatv(const char *format, Args &&...args)
static Status FromError(llvm::Error error)
Avoid using this in new code. Migrate APIs to llvm::Expected instead.
bool Success() const
Test for success condition.
const char * GetData() const
llvm::StringRef GetString() const
A stream class that can stream formatted output to a file.
void Format(const char *format, Args &&... args)
Forwards the arguments to llvm::formatv and writes to the stream.
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 SetObjectSP(const StructuredData::ObjectSP &obj)
void AddItem(const ObjectSP &item)
ObjectSP GetItemAtIndex(size_t idx) const
bool GetValueForKeyAsBoolean(llvm::StringRef key, bool &result) const
ObjectSP GetValueForKey(llvm::StringRef key) const
bool HasKey(llvm::StringRef key) const
void Dump(lldb_private::Stream &s, bool pretty_print=true) const
A class which can hold structured data.
std::shared_ptr< Dictionary > DictionarySP
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.
bool SymbolContextMatches(const SymbolContext &sc)
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
bool GetCheckValueObjectOwnership() const
uint64_t GetExprAllocAlign() const
MemoryModuleLoadLevel GetMemoryModuleLoadLevel() const
llvm::StringRef GetArg0() const
uint32_t GetMaximumMemReadSize() const
void SetRunArguments(const Args &args)
FileSpec GetStandardErrorPath() const
void SetLoadScriptFromSymbolFile(LoadScriptFromSymFile load_style)
Set the target-wide target.load-script-from-symbol-file setting.
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
void SetAutoLoadScriptsForModule(llvm::StringRef module_name, LoadScriptFromSymFile load_style)
Set the LoadScriptFromSymFile for a module called module_name (excluding file extension).
RealpathPrefixes GetSourceRealpathPrefixes() const
void SetCheckValueObjectOwnership(bool check)
uint64_t GetNumberOfRetriesWithFixits() const
uint64_t GetExprAllocSize() const
std::optional< LoadScriptFromSymFile > GetAutoLoadScriptsForModule(llvm::StringRef module_name) 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)
void GetDescription(Stream &s, lldb::DescriptionLevel level) const override
void SetActionFromString(const std::string &string)
Populate the command list by splitting a single string on newlines.
void SetActionFromStrings(const std::vector< std::string > &strings)
Populate the command list from a vector of individual command strings.
void HandleModuleLoaded(lldb::StreamSP output) override
StringList & GetCommands()
Return the list of commands that this hook runs.
StopHook::StopHookResult HandleStop(ExecutionContext &exe_ctx, lldb::StreamSP output) override
Called when the process stops.
void HandleModuleUnloaded(lldb::StreamSP output) override
llvm::StringRef GetScriptClassName() const
Status SetScriptCallback(const ScriptedMetadata &scripted_metadata)
void HandleModuleLoaded(lldb::StreamSP output) override
StopHook::StopHookResult HandleStop(ExecutionContext &exe_ctx, lldb::StreamSP output) override
Called when the process stops.
void GetDescription(Stream &s, lldb::DescriptionLevel level) const override
lldb::ScriptedHookInterfaceSP m_interface_sp
void HandleModuleUnloaded(lldb::StreamSP output) override
ThreadSpec * GetThreadSpecifier()
lldb::SymbolContextSpecifierSP m_sc_specifier_sp
bool ExecutionContextPasses(const ExecutionContext &exe_ctx)
Check if the execution context passes the specifier and thread spec filters.
void GetFilterDescription(Stream &s, lldb::DescriptionLevel level) const
Print the filter portion of the description (AutoContinue, Specifier, ThreadSpec).
lldb::TargetSP & GetTarget()
SymbolContextSpecifier * GetSCSpecifier()
lldb::TargetSP m_target_sp
virtual void GetDescription(Stream &s, lldb::DescriptionLevel level) const
void SetSCSpecifier(SymbolContextSpecifier *specifier)
Set the symbol context specifier. The hook takes ownership.
void SetThreadSpecifier(ThreadSpec *specifier)
Set the thread specifier. The hook takes ownership.
std::unique_ptr< ThreadSpec > m_thread_spec_up
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
StopHookResult HandleStop(ExecutionContext &exc_ctx, lldb::StreamSP output) override
Status SetScriptCallback(const ScriptedMetadata &scripted_metadata)
void GetSubclassDescription(Stream &s, lldb::DescriptionLevel level) const override
llvm::StringRef GetScriptClassName() const
lldb::ScriptedStopHookInterfaceSP m_interface_sp
SymbolContextSpecifier * GetSpecifier()
void SetSpecifier(SymbolContextSpecifier *specifier)
std::unique_ptr< ThreadSpec > m_thread_spec_up
void SetThreadSpecifier(ThreadSpec *specifier)
ThreadSpec * GetThreadSpecifier()
lldb::TargetSP m_target_sp
StopHook(const StopHook &rhs)
bool ExecutionContextPasses(const ExecutionContext &exe_ctx)
lldb::TargetSP & GetTarget()
lldb::SymbolContextSpecifierSP m_specifier_sp
virtual void GetSubclassDescription(Stream &s, lldb::DescriptionLevel level) const =0
void GetDescription(Stream &s, lldb::DescriptionLevel level) const
void Dump(Stream *s) const override
static llvm::StringRef GetFlavorString()
static lldb::TargetSP GetCreatedTargetFromEvent(const Event *event_ptr)
static ModuleList GetModuleListFromEvent(const Event *event_ptr)
~TargetEventData() override
static const TargetEventData * GetEventDataFromEvent(const Event *event_ptr)
lldb::TargetSP m_created_target_sp
TargetEventData(const lldb::TargetSP &target_sp)
lldb::TargetSP m_target_sp
static lldb::TargetSP GetTargetFromEvent(const Event *event_ptr)
void ModulesDidLoad(ModuleList &module_list)
This call may preload module symbols, and may do so in parallel depending on the following target set...
void DescribeBreakpointOverrides(Stream &stream, std::vector< lldb::user_id_t > &idxs)
Describe the breakpoint overrides.
lldb::ThreadSP CalculateThread() override
llvm::Expected< uint32_t > AddScriptedFrameProviderDescriptor(const ScriptedFrameProviderDescriptor &descriptor)
Add or update a scripted frame provider descriptor for this target.
StopHookCollection m_stop_hooks
Module * GetExecutableModulePointer()
void Dump(Stream *s, lldb::DescriptionLevel description_level)
Dump a description of this object to a Stream.
bool m_suppress_stop_hooks
void DisableAllBreakpoints(bool internal_also=false)
bool RemoveHookByID(lldb::user_id_t uid)
lldb::WatchpointSP CreateWatchpoint(lldb::addr_t addr, size_t size, const CompilerType *type, uint32_t kind, Status &error)
void ApplyNameToBreakpoints(BreakpointName &bp_name)
lldb::user_id_t m_hook_next_id
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::BreakpointResolverSP CheckBreakpointOverrides(lldb::BreakpointResolverSP original_sp)
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)
uint32_t m_next_frame_provider_id
CompilerType GetRegisterType(const std::string &name, const lldb_private::RegisterFlags &flags, uint32_t byte_size)
BreakpointNameList m_breakpoint_names
lldb_private::SummaryStatisticsCache & GetSummaryStatisticsCache()
const llvm::MapVector< uint32_t, ScriptedFrameProviderDescriptor > & GetScriptedFrameProviderDescriptors() const
Get all scripted frame provider descriptors for this target.
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::user_id_t AddBreakpointResolverOverride(BreakpointResolverOverrideUP override_up)
Add a breakpoint override resolver. This version can't fail.
lldb::ProcessSP m_process_sp
Debugger & GetDebugger() const
lldb::SearchFilterSP m_search_filter_sp
PersistentExpressionState * GetPersistentExpressionStateForLanguage(lldb::LanguageType language)
void UpdateSignalsFromDummy(lldb::UnixSignalsSP signals_sp, lldb::StreamSP warning_stream_sp)
Updates the signals in signals_sp using the stored dummy signals.
bool m_is_dummy_target
Used to not run stop hooks for expressions.
static bool UpdateSignalFromDummy(lldb::UnixSignalsSP signals_sp, const DummySignalElement &element)
PathMappingList m_image_search_paths
bool ModuleIsExcludedForUnconstrainedSearches(const FileSpec &module_spec)
Return whether this FileSpec corresponds to a module that should be considered for general searches.
lldb::StackFrameSP CalculateStackFrame() override
SectionLoadList & GetSectionLoadList()
lldb::addr_t GetPersistentSymbol(ConstString name)
void PrimeFromDummyTarget(Target &target)
bool RemoveScriptedFrameProviderDescriptor(uint32_t id)
Remove a scripted frame provider descriptor by id.
lldb::RegisterTypeBuilderSP m_register_type_builder_sp
static void SettingsTerminate()
bool EnableWatchpointByID(lldb::watch_id_t watch_id)
HookSP CreateHook(Hook::HookKind kind)
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 SetHookEnabledStateByID(lldb::user_id_t uid, bool enabled)
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)
llvm::MapVector< uint32_t, ScriptedFrameProviderDescriptor > m_frame_provider_descriptors
Map of scripted frame provider descriptors for this target.
lldb::ModuleSP GetOrCreateModule(const ModuleSpec &module_spec, bool notify, Status *error_ptr=nullptr)
Find a binary on the system and return its Module, or return an existing Module that is already in th...
static bool ResetSignalFromDummy(lldb::UnixSignalsSP signals_sp, const DummySignalElement &element)
Architecture * GetArchitecturePlugin() const
llvm::json::Value ReportStatistics(const lldb_private::StatisticsOptions &options)
Get metrics associated with this target in JSON format.
FunctionCaller * GetFunctionCallerForLanguage(lldb::LanguageType language, const CompilerType &return_type, const Address &function_address, const ValueList &arg_value_list, const char *name, Status &error)
void EnableAllBreakpoints(bool internal_also=false)
Status Launch(ProcessLaunchInfo &launch_info, Stream *stream)
bool DisableBreakpointByID(lldb::break_id_t break_id)
lldb::BreakpointSP CreateBreakpointAtUserEntry(Status &error)
BreakpointName * FindBreakpointName(ConstString name, bool can_create, Status &error)
llvm::Expected< lldb::TraceSP > CreateTrace()
Create a Trace object for the current target using the using the default supported tracing technology...
lldb::TraceSP m_trace_sp
An optional lldb_private::Trace object containing processor trace information of this target.
bool RemoveAllWatchpoints(bool end_to_end=true)
bool ReadPointerFromMemory(const Address &addr, Status &error, Address &pointer_addr, bool force_live_memory=false)
void UndoCreateStopHook(lldb::user_id_t uid)
If you tried to create a stop hook, and that failed, call this to remove the stop hook,...
WatchpointList m_watchpoint_list
BreakpointList m_breakpoint_list
lldb::SourceManagerUP m_source_manager_up
bool RemoveWatchpointByID(lldb::watch_id_t watch_id)
bool ResolveLoadAddress(lldb::addr_t load_addr, Address &so_addr, uint32_t stop_id=SectionLoadHistory::eStopIDNow, bool allow_section_end=false)
size_t ReadStringFromMemory(const Address &addr, char *dst, size_t max_bytes, Status &error, size_t type_width, bool force_live_memory=true)
Read a NULL terminated string from memory.
HookSP GetHookByID(lldb::user_id_t uid)
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)
void SetAllHooksEnabledState(bool enabled)
std::recursive_mutex m_mutex
An API mutex that is used by the lldb::SB* classes make the SB interface thread safe.
std::recursive_mutex m_frame_provider_descriptors_mutex
lldb::user_id_t m_target_unique_id
The globally unique ID assigned to this target.
void ModulesDidUnload(ModuleList &module_list, bool delete_locations)
void CalculateExecutionContext(ExecutionContext &exe_ctx) override
Reconstruct the object's execution context into sc.
llvm::Expected< lldb::DisassemblerSP > ReadInstructions(const Address &start_addr, uint32_t count, const char *flavor_string=nullptr)
llvm::Expected< lldb::TraceSP > GetTraceOrCreate()
If a Trace object is present, this returns it, otherwise a new Trace is created with Trace::CreateTra...
void NotifyModuleUpdated(const ModuleList &module_list, const lldb::ModuleSP &old_module_sp, const lldb::ModuleSP &new_module_sp) override
SummaryStatisticsCache m_summary_statistics_cache
Status SerializeBreakpointsToFile(const FileSpec &file, const BreakpointIDList &bp_ids, bool append)
void DidExec()
Called as the last function in Process::DidExec().
void SaveScriptedLaunchInfo(lldb_private::ProcessInfo &process_info)
lldb::user_id_t m_stop_hook_next_id
void RemoveAllStopHooks()
static FileSpecList GetDefaultExecutableSearchPaths()
lldb::BreakpointSP CreateExceptionBreakpoint(enum lldb::LanguageType language, bool catch_bp, bool throw_bp, bool internal, Args *additional_args=nullptr, Status *additional_args_error=nullptr)
void NotifyBreakpointChanged(Breakpoint &bp, lldb::BreakpointEventType event_kind)
Sends a breakpoint notification event.
lldb::SearchFilterSP GetSearchFilterForModule(const FileSpec *containingModule)
llvm::StringMapEntry< DummySignalValues > DummySignalElement
std::recursive_mutex & GetAPIMutex()
static llvm::StringRef GetStaticBroadcasterClass()
static FileSpecList GetDefaultDebugFileSearchPaths()
void EnableAllowedBreakpoints()
virtual size_t ReadMemory(const Address &addr, void *dst, size_t dst_len, Status &error, bool force_live_memory=false, lldb::addr_t *load_addr_ptr=nullptr, bool *did_read_live_memory=nullptr)
llvm::Error SetLabel(llvm::StringRef label)
Set a label for a target.
uint32_t m_latest_stop_hook_id
void RunModuleHooks(bool is_load)
std::map< lldb::user_id_t, BreakpointResolverOverrideUP > m_breakpoint_overrides
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.
void UndoCreateHook(lldb::user_id_t uid)
Removes the most recently created hook.
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.
FileSpecList GetSafeAutoLoadPaths() const
Get the list of paths that LLDB will consider automatically loading scripting resources from.
static TargetProperties & GetGlobalProperties()
Status Install(ProcessLaunchInfo *launch_info)
HookSP GetHookAtIndex(size_t index)
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.
std::unique_ptr< BreakpointResolverOverride > BreakpointResolverOverrideUP
const ModuleList & GetImages() const
Get accessor for the images for this process.
const ArchSpec & GetArchitecture() const
WatchpointList & GetWatchpointList()
@ eBroadcastBitModulesLoaded
@ eBroadcastBitSymbolsLoaded
@ eBroadcastBitModulesUnloaded
@ eBroadcastBitWatchpointChanged
@ eBroadcastBitBreakpointChanged
@ eBroadcastBitNewTargetCreated
bool EnableBreakpointByID(lldb::break_id_t break_id)
uint64_t ReadUnsignedIntegerFromMemory(const Address &addr, size_t integer_byte_size, uint64_t fail_value, Status &error, bool force_live_memory=false)
void InvalidateThreadFrameProviders()
Invalidate all potentially cached frame providers for all threads and trigger a stack changed event f...
bool IgnoreAllWatchpoints(uint32_t ignore_count)
void AddBreakpoint(lldb::BreakpointSP breakpoint_sp, bool internal)
std::string m_target_session_name
The target session name for this target, used to name debugging sessions in DAP.
TypeSystemMap m_scratch_type_system_map
void AddBreakpointName(std::unique_ptr< BreakpointName > bp_name)
SectionLoadHistory m_section_load_history
void GetBreakpointNames(std::vector< std::string > &names)
bool IsDummyTarget() const
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.
void ClearScriptedFrameProviderDescriptors()
Clear all scripted frame provider descriptors for this target.
lldb::WatchpointSP m_last_created_watchpoint
Status CreateBreakpointsFromFile(const FileSpec &file, BreakpointIDList &new_bps)
void SetREPL(lldb::LanguageType language, lldb::REPLSP repl_sp)
void SetExecutableModule(lldb::ModuleSP &module_sp, LoadDependentFiles load_dependent_files=eLoadDependentsDefault)
Set the main executable module.
lldb::StackFrameRecognizerManagerUP m_frame_recognizer_manager_up
Stores the frame recognizers of this target.
lldb::REPLSP GetREPL(Status &err, lldb::LanguageType language, const char *repl_options, bool can_create)
std::shared_ptr< Hook > HookSP
UserExpression * GetUserExpressionForLanguage(llvm::StringRef expr, llvm::StringRef prefix, SourceLanguage language, Expression::ResultType desired_type, const EvaluateExpressionOptions &options, ValueObject *ctx_obj, Status &error)
ModuleList m_images
The list of images for this process (shared libraries and anything dynamically loaded).
lldb::ProcessSP CalculateProcess() override
void PrintDummySignals(Stream &strm, Args &signals)
Print all the signals set in this target.
void SetPlatform(const lldb::PlatformSP &platform_sp)
bool SetSectionLoadAddress(const lldb::SectionSP §ion, lldb::addr_t load_addr, bool warn_multiple=false)
Status Attach(ProcessAttachInfo &attach_info, Stream *stream)
static void SetDefaultArchitecture(const ArchSpec &arch)
lldb::BreakpointSP m_last_created_breakpoint
void RemoveNameFromBreakpoint(lldb::BreakpointSP &bp_sp, ConstString name)
bool RemoveStopHookByID(lldb::user_id_t uid)
static void SettingsInitialize()
bool EnableAllWatchpoints(bool end_to_end=true)
std::recursive_mutex m_private_mutex
When the private state thread calls SB API's - usually because it is running OS plugin or Python Thre...
lldb::ExpressionResults EvaluateExpression(llvm::StringRef expression, ExecutionContextScope *exe_scope, lldb::ValueObjectSP &result_valobj_sp, const EvaluateExpressionOptions &options=EvaluateExpressionOptions(), std::string *fixed_expression=nullptr, ValueObject *ctx_obj=nullptr)
bool MergeArchitecture(const ArchSpec &arch_spec)
uint32_t GetSize(bool can_update=true)
lldb::ThreadSP GetThreadAtIndex(uint32_t idx, bool can_update=true)
@ eBroadcastBitStackChanged
static llvm::Expected< lldb::TraceSP > FindPluginForLiveProcess(llvm::StringRef plugin_name, Process &process)
Find a trace plug-in to trace a live process.
Represents UUID's of various sizes.
void Dump(Stream &s) const
Encapsulates a one-time expression for use in lldb.
static lldb::ExpressionResults Evaluate(ExecutionContext &exe_ctx, const EvaluateExpressionOptions &options, llvm::StringRef expr_cstr, llvm::StringRef expr_prefix, lldb::ValueObjectSP &result_valobj_sp, std::string *fixed_expression=nullptr, ValueObject *ctx_obj=nullptr)
Evaluate one expression in the scratch context of the target passed in the exe_ctx and return its res...
void GetListMutex(std::unique_lock< std::recursive_mutex > &lock)
Sets the passed in Locker to hold the Watchpoint List mutex.
uint8_t * GetBytes()
Get a pointer to the data.
#define LLDB_WATCH_TYPE_WRITE
#define LLDB_INVALID_BREAK_ID
#define LLDB_INVALID_SIGNAL_NUMBER
#define LLDB_INVALID_INDEX32
#define LLDB_WATCH_TYPE_IS_VALID(type)
#define LLDB_BREAK_ID_IS_INTERNAL(bid)
#define LLDB_WATCH_TYPE_MODIFY
#define LLDB_WATCH_TYPE_READ
#define LLDB_INVALID_ADDRESS
#define LLDB_INVALID_PROCESS_ID
#define LLDB_INVALID_INDEX64
@ 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
@ eLoadScriptFromSymFileTrusted
@ 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.
LanguageType
Programming language type.
@ eLanguageTypeMipsAssembler
Mips_Assembler.
@ eLanguageTypeUnknown
Unknown or invalid language value.
@ eLanguageTypeC
Non-standardized C, such as K&R.
std::shared_ptr< lldb_private::Stream > StreamSP
std::shared_ptr< lldb_private::Breakpoint > BreakpointSP
ExpressionResults
The results of expression evaluation.
std::shared_ptr< lldb_private::Process > ProcessSP
std::shared_ptr< lldb_private::BreakpointPrecondition > BreakpointPreconditionSP
std::shared_ptr< lldb_private::Event > EventSP
ReturnStatus
Command Return Status Types.
@ eReturnStatusSuccessContinuingResult
@ eReturnStatusSuccessContinuingNoResult
std::shared_ptr< lldb_private::Watchpoint > WatchpointSP
std::shared_ptr< lldb_private::Listener > ListenerSP
std::shared_ptr< lldb_private::DataBuffer > DataBufferSP
std::shared_ptr< lldb_private::Section > SectionSP
std::shared_ptr< lldb_private::Target > TargetSP
@ eStructuredDataTypeBoolean
std::shared_ptr< lldb_private::Module > ModuleSP
std::shared_ptr< lldb_private::OptionValue > OptionValueSP
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.
Describes what view of the process a thread should see and what operations it is allowed to perform.
@ Private
Parent (unwinder) frames, private state, private run lock.
This struct contains the metadata needed to instantiate a frame provider and optional filters to cont...
llvm::StringRef GetName() const
Get the name of this descriptor (the scripted class name).
uint32_t GetHash() const
Get the content-based hash from ScriptedMetadata.
void SetID(uint32_t id)
Set the monotonically increasing ID for this descriptor.
bool IsValid() const
Check if this descriptor has valid metadata for script-based providers.
A type-erased pair of llvm::dwarf::SourceLanguageName and version.
lldb::LanguageType AsLanguageType() const
llvm::StringRef GetDescription() const
static TestingProperties & GetGlobalTestingProperties()
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)