9#include "lldb/Host/Config.h"
14#include <netinet/in.h>
16#include <sys/socket.h>
21#include <sys/sysctl.h>
89#include "llvm/ADT/STLExtras.h"
90#include "llvm/ADT/ScopeExit.h"
91#include "llvm/ADT/StringMap.h"
92#include "llvm/ADT/StringSwitch.h"
93#include "llvm/Support/ErrorExtras.h"
94#include "llvm/Support/FormatAdapters.h"
95#include "llvm/Support/Threading.h"
96#include "llvm/Support/raw_ostream.h"
99#define DEBUGSERVER_BASENAME "debugserver"
101#define DEBUGSERVER_BASENAME "lldb-server.exe"
103#define DEBUGSERVER_BASENAME "lldb-server"
123 llvm::consumeError(file.takeError());
127 ((
Process *)p)->DumpPluginHistory(stream);
133#define LLDB_PROPERTIES_processgdbremote
134#include "ProcessGDBRemoteProperties.inc"
137#define LLDB_PROPERTIES_processgdbremote
138#include "ProcessGDBRemotePropertiesEnum.inc"
143 static llvm::StringRef GetSettingName() {
147 PluginProperties() : Properties() {
148 m_collection_sp = std::make_shared<OptionValueProperties>(GetSettingName());
149 m_collection_sp->Initialize(g_processgdbremote_properties_def);
152 ~PluginProperties()
override =
default;
154 uint64_t GetPacketTimeout() {
155 const uint32_t idx = ePropertyPacketTimeout;
156 return GetPropertyAtIndexAs<uint64_t>(
157 idx, g_processgdbremote_properties[idx].default_uint_value);
160 bool SetPacketTimeout(uint64_t timeout) {
161 const uint32_t idx = ePropertyPacketTimeout;
162 return SetPropertyAtIndex(idx, timeout);
165 FileSpec GetTargetDefinitionFile()
const {
166 const uint32_t idx = ePropertyTargetDefinitionFile;
167 return GetPropertyAtIndexAs<FileSpec>(idx, {});
170 bool GetUseSVR4()
const {
171 const uint32_t idx = ePropertyUseSVR4;
172 return GetPropertyAtIndexAs<bool>(
173 idx, g_processgdbremote_properties[idx].default_uint_value != 0);
176 bool GetUseGPacketForReading()
const {
177 const uint32_t idx = ePropertyUseGPacketForReading;
178 return GetPropertyAtIndexAs<bool>(idx,
true);
182std::chrono::seconds ResumeTimeout() {
return std::chrono::seconds(5); }
187 static PluginProperties g_settings;
195#if defined(__APPLE__)
196#define LOW_PORT (IPPORT_RESERVED)
197#define HIGH_PORT (IPPORT_HIFIRSTAUTO)
199#define LOW_PORT (1024u)
200#define HIGH_PORT (49151u)
204 return "GDB Remote protocol based debugging plug-in.";
213 const FileSpec *crash_file_path,
bool can_connect) {
233 bool plugin_specified_by_name) {
234 if (plugin_specified_by_name)
238 Module *exe_module = target_sp->GetExecutableModulePointer();
242 switch (exe_objfile->
GetType()) {
266 :
Process(target_sp, listener_sp),
270 Listener::MakeListener(
"lldb.process.gdb-remote.async-listener")),
281 "async thread should exit");
283 "async thread continue");
285 "async thread did exit");
289 const uint32_t async_event_mask =
295 "ProcessGDBRemote::%s failed to listen for "
296 "m_async_broadcaster events",
300 const uint64_t timeout_seconds =
302 if (timeout_seconds > 0)
303 m_gdb_comm.SetPacketTimeout(std::chrono::seconds(timeout_seconds));
327std::shared_ptr<ThreadGDBRemote>
329 return std::make_shared<ThreadGDBRemote>(*
this, tid);
333 const FileSpec &target_definition_fspec) {
339 if (module_object_sp) {
342 "gdb-server-target-definition",
error));
344 if (target_definition_sp) {
346 target_definition_sp->GetValueForKey(
"host-info"));
348 if (
auto host_info_dict = target_object->GetAsDictionary()) {
350 host_info_dict->GetValueForKey(
"triple");
351 if (
auto triple_string_value = triple_value->GetAsString()) {
352 std::string triple_string =
353 std::string(triple_string_value->GetValue());
354 ArchSpec host_arch(triple_string.c_str());
363 target_definition_sp->GetValueForKey(
"breakpoint-pc-offset");
364 if (breakpoint_pc_offset_value) {
365 if (
auto breakpoint_pc_int_value =
366 breakpoint_pc_offset_value->GetAsSignedInteger())
371 *target_definition_sp,
GetTarget().GetArchitecture()) > 0) {
380 const llvm::StringRef &comma_separated_register_numbers,
381 std::vector<uint32_t> ®nums,
int base) {
383 for (llvm::StringRef x : llvm::split(comma_separated_register_numbers,
',')) {
385 if (llvm::to_integer(x, reg, base))
386 regnums.push_back(reg);
388 return regnums.size();
400 const auto host_packet_timeout =
m_gdb_comm.GetHostDefaultPacketTimeout();
401 if (host_packet_timeout > std::chrono::seconds(0)) {
419 if (target_definition_fspec) {
425 target_definition_fspec.
GetPath() +
436 if (remote_process_arch.
IsValid())
437 arch_to_use = remote_process_arch;
439 arch_to_use = remote_host_arch;
442 arch_to_use = target_arch;
445 if (!register_info_err) {
452 "Failed to read register information from target XML: {0}");
453 LLDB_LOG(log,
"Now trying to use qRegisterInfo instead.");
456 std::vector<DynamicRegisterInfo::Register> registers;
457 uint32_t reg_num = 0;
461 const int packet_len =
462 ::snprintf(packet,
sizeof(packet),
"qRegisterInfo%x", reg_num);
463 assert(packet_len < (
int)
sizeof(packet));
466 if (
m_gdb_comm.SendPacketAndWaitForResponse(packet, response) ==
470 llvm::StringRef name;
471 llvm::StringRef value;
475 if (name ==
"name") {
477 }
else if (name ==
"alt-name") {
479 }
else if (name ==
"bitsize") {
480 if (!value.getAsInteger(0, reg_info.
byte_size))
482 }
else if (name ==
"offset") {
484 }
else if (name ==
"encoding") {
488 }
else if (name ==
"format") {
492 llvm::StringSwitch<Format>(value)
534 }
else if (name ==
"set") {
536 }
else if (name ==
"gcc" || name ==
"ehframe") {
538 }
else if (name ==
"dwarf") {
540 }
else if (name ==
"generic") {
542 }
else if (name ==
"container-regs") {
544 }
else if (name ==
"invalidate-regs") {
550 registers.push_back(reg_info);
563 "the debug server supports Target Description XML but LLDB does "
564 "not have XML parsing enabled. Using \"qRegisterInfo\" was also "
565 "not possible. Register information may be incorrect or missing",
575 if (registers.empty()) {
577 if (!registers.empty())
580 "All other methods failed, using fallback register information.");
595 bool wait_for_launch) {
627 if (
m_gdb_comm.GetProcessArchitecture().IsValid()) {
630 if (
m_gdb_comm.GetHostArchitecture().IsValid()) {
641 "Process %" PRIu64
" was reported after connecting to "
642 "'%s', but state was not stopped: %s",
646 "Process %" PRIu64
" was reported after connecting to '%s', "
647 "but no stop reply packet was received",
648 pid, remote_url.str().c_str());
652 "ProcessGDBRemote::%s pid %" PRIu64
653 ": normalizing target architecture initial triple: %s "
654 "(GetTarget().GetArchitecture().IsValid() %s, "
655 "m_gdb_comm.GetHostArchitecture().IsValid(): %s)",
656 __FUNCTION__,
GetID(),
657 GetTarget().GetArchitecture().GetTriple().getTriple().c_str(),
659 m_gdb_comm.GetHostArchitecture().IsValid() ?
"true" :
"false");
665 if (
m_gdb_comm.GetProcessArchitecture().IsValid())
672 "ProcessGDBRemote::%s pid %" PRIu64
673 ": normalized target architecture triple: %s",
674 __FUNCTION__,
GetID(),
675 GetTarget().GetArchitecture().GetTriple().getTriple().c_str());
692 LLDB_LOGF(log,
"ProcessGDBRemote::%s() entered", __FUNCTION__);
694 uint32_t launch_flags = launch_info.
GetFlags().
Get();
717 if (stdin_file_spec || stdout_file_spec || stderr_file_spec)
719 "ProcessGDBRemote::%s provided with STDIO paths via "
720 "launch_info: stdin=%s, stdout=%s, stderr=%s",
722 stdin_file_spec ? stdin_file_spec.
GetPath().c_str() :
"<null>",
723 stdout_file_spec ? stdout_file_spec.
GetPath().c_str() :
"<null>",
724 stderr_file_spec ? stderr_file_spec.
GetPath().c_str() :
"<null>");
726 LLDB_LOGF(log,
"ProcessGDBRemote::%s no STDIO paths given via launch_info",
729 const bool disable_stdio = (launch_flags & eLaunchFlagDisableSTDIO) != 0;
730 if (stdin_file_spec || disable_stdio) {
745 if (
error.Success()) {
747 const bool disable_stdio = (launch_flags & eLaunchFlagDisableSTDIO) != 0;
752 if (!stdin_file_spec)
754 FileSpec::Style::native);
755 if (!stdout_file_spec)
757 FileSpec::Style::native);
758 if (!stderr_file_spec)
760 FileSpec::Style::native);
761 }
else if (platform_sp && platform_sp->IsHost()) {
766 if ((!stdin_file_spec || !stdout_file_spec || !stderr_file_spec) &&
770 if (!stdin_file_spec)
771 stdin_file_spec = secondary_name;
773 if (!stdout_file_spec)
774 stdout_file_spec = secondary_name;
776 if (!stderr_file_spec)
777 stderr_file_spec = secondary_name;
781 "ProcessGDBRemote::%s adjusted STDIO paths for local platform "
782 "(IsHost() is true) using secondary: stdin=%s, stdout=%s, "
785 stdin_file_spec ? stdin_file_spec.
GetPath().c_str() :
"<null>",
786 stdout_file_spec ? stdout_file_spec.
GetPath().c_str() :
"<null>",
787 stderr_file_spec ? stderr_file_spec.
GetPath().c_str() :
"<null>");
791 "ProcessGDBRemote::%s final STDIO paths after all "
792 "adjustments: stdin=%s, stdout=%s, stderr=%s",
794 stdin_file_spec ? stdin_file_spec.
GetPath().c_str() :
"<null>",
795 stdout_file_spec ? stdout_file_spec.
GetPath().c_str() :
"<null>",
796 stderr_file_spec ? stderr_file_spec.
GetPath().c_str() :
"<null>");
800 if (stdout_file_spec)
802 if (stderr_file_spec)
805 m_gdb_comm.SetDisableASLR(launch_flags & eLaunchFlagDisableASLR);
806 m_gdb_comm.SetDetachOnError(launch_flags & eLaunchFlagDetachOnError);
809 GetTarget().GetArchitecture().GetArchitectureName());
812 if (launch_event_data !=
nullptr && *launch_event_data !=
'\0')
813 m_gdb_comm.SendLaunchEventDataPacket(launch_event_data);
825 std::chrono::seconds(10));
832 if (llvm::Error err =
m_gdb_comm.LaunchProcess(args)) {
835 llvm::fmt_consume(std::move(err)));
842 LLDB_LOGF(log,
"failed to connect to debugserver: %s",
864 if (!disable_stdio) {
870 LLDB_LOGF(log,
"failed to connect to debugserver: %s",
error.AsCString());
880 if (!connect_url.empty()) {
881 LLDB_LOGF(log,
"ProcessGDBRemote::%s Connecting to %s", __FUNCTION__,
882 connect_url.str().c_str());
883 std::unique_ptr<ConnectionFileDescriptor> conn_up(
886 const uint32_t max_retry_count = 50;
887 uint32_t retry_count = 0;
896 if (retry_count >= max_retry_count)
899 std::this_thread::sleep_for(std::chrono::milliseconds(100));
923 m_gdb_comm.GetListThreadsInStopReplySupported();
930 auto handle_cmds = [&] (
const Args &args) ->
void {
934 entry.c_str(), response);
940 handle_cmds(platform_sp->GetExtraStartupCommands());
957 if (remote_process_arch.
IsValid()) {
958 process_arch = remote_process_arch;
959 LLDB_LOG(log,
"gdb-remote had process architecture, using {0} {1}",
963 process_arch =
m_gdb_comm.GetHostArchitecture();
965 "gdb-remote did not have process architecture, using gdb-remote "
966 "host architecture {0} {1}",
977 LLDB_LOG(log,
"analyzing target arch, currently {0} {1}",
989 if ((process_arch.
GetMachine() == llvm::Triple::arm ||
990 process_arch.
GetMachine() == llvm::Triple::thumb) &&
991 process_arch.
GetTriple().getVendor() == llvm::Triple::Apple) {
994 "remote process is ARM/Apple, "
995 "setting target arch to {0} {1}",
1000 const llvm::Triple &remote_triple = process_arch.
GetTriple();
1001 llvm::Triple new_target_triple = target_arch.
GetTriple();
1002 if (new_target_triple.getVendorName().size() == 0) {
1003 new_target_triple.setVendor(remote_triple.getVendor());
1005 if (new_target_triple.getOSName().size() == 0) {
1006 new_target_triple.setOS(remote_triple.getOS());
1008 if (new_target_triple.getEnvironmentName().size() == 0)
1009 new_target_triple.setEnvironment(remote_triple.getEnvironment());
1012 ArchSpec new_target_arch = target_arch;
1013 new_target_arch.
SetTriple(new_target_triple);
1019 "final target arch after adjustments for remote architecture: "
1038 m_gdb_comm.GetSupportedStructuredDataPlugins())
1047 if (platform_sp && platform_sp->IsConnected())
1059 UUID standalone_uuid;
1061 bool standalone_value_is_offset;
1062 if (
m_gdb_comm.GetProcessStandaloneBinary(standalone_uuid, standalone_value,
1063 standalone_value_is_offset)) {
1066 if (standalone_uuid.
IsValid()) {
1067 const bool force_symbol_search =
true;
1068 const bool notify =
true;
1069 const bool set_address_in_target =
true;
1070 const bool allow_memory_image_last_resort =
false;
1072 this,
"", standalone_uuid, standalone_value,
1073 standalone_value_is_offset, force_symbol_search, notify,
1074 set_address_in_target, allow_memory_image_last_resort);
1086 std::vector<addr_t> bin_addrs =
m_gdb_comm.GetProcessStandaloneBinaries();
1087 if (bin_addrs.size()) {
1089 const bool value_is_slide =
false;
1090 for (
addr_t addr : bin_addrs) {
1091 const bool notify =
true;
1098 .LoadPlatformBinaryAndSetup(
this, addr, notify))
1101 const bool force_symbol_search =
true;
1102 const bool set_address_in_target =
true;
1103 const bool allow_memory_image_last_resort =
false;
1106 this, llvm::StringRef(), uuid, addr, value_is_slide,
1107 force_symbol_search, notify, set_address_in_target,
1108 allow_memory_image_last_resort);
1118 std::optional<QOffsets> offsets =
m_gdb_comm.GetQOffsets();
1123 size_t(llvm::count(offsets->offsets, offsets->offsets[0])) ==
1124 offsets->offsets.size();
1128 bool changed =
false;
1129 module_sp->SetLoadAddress(
GetTarget(), offsets->offsets[0],
1134 m_process->GetTarget().ModulesDidLoad(list);
1148 LLDB_LOGF(log,
"ProcessGDBRemote::%s()", __FUNCTION__);
1154 if (
error.Success()) {
1158 const int packet_len =
1159 ::snprintf(packet,
sizeof(packet),
"vAttach;%" PRIx64, attach_pid);
1162 std::make_shared<EventDataBytes>(llvm::StringRef(packet, packet_len));
1177 if (process_name && process_name[0]) {
1179 if (
error.Success()) {
1185 if (!
m_gdb_comm.GetVAttachOrWaitSupported()) {
1200 auto data_sp = std::make_shared<EventDataBytes>(packet.
GetString());
1221llvm::Expected<std::string>
1226llvm::Expected<std::vector<uint8_t>>
1238 process_arch.
Clear();
1254 return m_gdb_comm.GetReverseStepSupported() ||
1261 LLDB_LOGF(log,
"ProcessGDBRemote::Resume(%s)",
1266 if (listener_sp->StartListeningForEvents(
1268 listener_sp->StartListeningForEvents(
1275 bool continue_packet_error =
false;
1289 std::string pid_prefix;
1291 pid_prefix = llvm::formatv(
"p{0:x-}.",
GetID());
1293 if (num_continue_c_tids == num_threads ||
1298 continue_packet.
Format(
"vCont;c:{0}-1", pid_prefix);
1306 for (tid_collection::const_iterator
1309 t_pos != t_end; ++t_pos)
1310 continue_packet.
Format(
";c:{0}{1:x-}", pid_prefix, *t_pos);
1312 continue_packet_error =
true;
1317 for (tid_sig_collection::const_iterator
1320 s_pos != s_end; ++s_pos)
1321 continue_packet.
Format(
";C{0:x-2}:{1}{2:x-}", s_pos->second,
1322 pid_prefix, s_pos->first);
1324 continue_packet_error =
true;
1329 for (tid_collection::const_iterator
1332 t_pos != t_end; ++t_pos)
1333 continue_packet.
Format(
";s:{0}{1:x-}", pid_prefix, *t_pos);
1335 continue_packet_error =
true;
1340 for (tid_sig_collection::const_iterator
1343 s_pos != s_end; ++s_pos)
1344 continue_packet.
Format(
";S{0:x-2}:{1}{2:x-}", s_pos->second,
1345 pid_prefix, s_pos->first);
1347 continue_packet_error =
true;
1350 if (continue_packet_error)
1351 continue_packet.
Clear();
1354 continue_packet_error =
true;
1360 if (num_continue_c_tids > 0) {
1361 if (num_continue_c_tids == num_threads) {
1365 continue_packet_error =
false;
1366 }
else if (num_continue_c_tids == 1 && num_continue_C_tids == 0 &&
1367 num_continue_s_tids == 0 && num_continue_S_tids == 0) {
1371 continue_packet_error =
false;
1375 if (continue_packet_error && num_continue_C_tids > 0) {
1376 if ((num_continue_C_tids + num_continue_c_tids) == num_threads &&
1377 num_continue_C_tids > 0 && num_continue_s_tids == 0 &&
1378 num_continue_S_tids == 0) {
1381 if (num_continue_C_tids > 1) {
1386 if (num_continue_C_tids > 1) {
1387 continue_packet_error =
false;
1390 continue_packet_error =
true;
1393 if (!continue_packet_error)
1397 continue_packet_error =
false;
1400 if (!continue_packet_error) {
1402 continue_packet.
Printf(
"C%2.2x", continue_signo);
1407 if (continue_packet_error && num_continue_s_tids > 0) {
1408 if (num_continue_s_tids == num_threads) {
1414 continue_packet_error =
false;
1415 }
else if (num_continue_c_tids == 0 && num_continue_C_tids == 0 &&
1416 num_continue_s_tids == 1 && num_continue_S_tids == 0) {
1420 continue_packet_error =
false;
1424 if (!continue_packet_error && num_continue_S_tids > 0) {
1425 if (num_continue_S_tids == num_threads) {
1428 continue_packet_error =
false;
1429 if (num_continue_S_tids > 1) {
1430 for (
size_t i = 1; i < num_threads; ++i) {
1432 continue_packet_error =
true;
1435 if (!continue_packet_error) {
1438 continue_packet.
Printf(
"S%2.2x", step_signo);
1440 }
else if (num_continue_c_tids == 0 && num_continue_C_tids == 0 &&
1441 num_continue_s_tids == 0 && num_continue_S_tids == 1) {
1445 continue_packet_error =
false;
1451 if (num_continue_s_tids > 0 || num_continue_S_tids > 0) {
1453 LLDB_LOGF(log,
"ProcessGDBRemote::DoResume: target does not "
1454 "support reverse-stepping");
1456 "target does not support reverse-stepping");
1459 if (num_continue_S_tids > 0) {
1462 "ProcessGDBRemote::DoResume: Signals not supported in reverse");
1464 "can't deliver signals while running in reverse");
1467 if (num_continue_s_tids > 1) {
1468 LLDB_LOGF(log,
"ProcessGDBRemote::DoResume: can't step multiple "
1469 "threads in reverse");
1471 "can't step multiple threads while reverse-stepping");
1477 if (!
m_gdb_comm.GetReverseContinueSupported()) {
1478 LLDB_LOGF(log,
"ProcessGDBRemote::DoResume: target does not "
1479 "support reverse-continue");
1481 "target does not support reverse execution of processes");
1484 if (num_continue_C_tids > 0) {
1487 "ProcessGDBRemote::DoResume: Signals not supported in reverse");
1489 "can't deliver signals while running in reverse");
1497 continue_packet_error =
false;
1500 if (continue_packet_error) {
1502 "can't make continue packet for this resume");
1507 "Trying to resume but the async thread is dead.");
1508 LLDB_LOGF(log,
"ProcessGDBRemote::DoResume: Trying to resume but the "
1509 "async thread is dead.");
1514 std::make_shared<EventDataBytes>(continue_packet.
GetString());
1517 if (!listener_sp->GetEvent(event_sp, ResumeTimeout())) {
1519 LLDB_LOGF(log,
"ProcessGDBRemote::DoResume: Resume timed out.");
1522 "Broadcast continue, but the async thread was "
1523 "killed before we got an ack back.");
1525 "ProcessGDBRemote::DoResume: Broadcast continue, but the "
1526 "async thread was killed before we got an ack back.");
1542 llvm::StringRef value) {
1548 auto pid_tid = thread_ids.
GetPidTid(pid);
1549 if (pid_tid && pid_tid->first == pid) {
1555 }
while (thread_ids.
GetChar() ==
',');
1561 llvm::StringRef value) {
1563 for (llvm::StringRef x : llvm::split(value,
',')) {
1565 if (llvm::to_integer(x,
pc, 16))
1577 if (thread_infos && thread_infos->
GetSize() > 0) {
1601 const llvm::StringRef stop_info_str = stop_info.
GetStringRef();
1604 const size_t thread_pcs_pos = stop_info_str.find(
";thread-pcs:");
1605 if (thread_pcs_pos != llvm::StringRef::npos) {
1606 const size_t start = thread_pcs_pos + strlen(
";thread-pcs:");
1607 const size_t end = stop_info_str.find(
';', start);
1608 if (end != llvm::StringRef::npos) {
1609 llvm::StringRef value = stop_info_str.substr(start, end - start);
1614 const size_t threads_pos = stop_info_str.find(
";threads:");
1615 if (threads_pos != llvm::StringRef::npos) {
1616 const size_t start = threads_pos + strlen(
";threads:");
1617 const size_t end = stop_info_str.find(
';', start);
1618 if (end != llvm::StringRef::npos) {
1619 llvm::StringRef value = stop_info_str.substr(start, end - start);
1627 bool sequence_mutex_unavailable =
false;
1629 if (sequence_mutex_unavailable) {
1644 if (num_thread_ids == 0) {
1650 ThreadList old_thread_list_copy(old_thread_list);
1651 if (num_thread_ids > 0) {
1652 for (
size_t i = 0; i < num_thread_ids; ++i) {
1659 thread_sp.get(), thread_sp->GetID());
1662 thread_sp.get(), thread_sp->GetID());
1672 size_t old_num_thread_ids = old_thread_list_copy.
GetSize(
false);
1673 for (
size_t i = 0; i < old_num_thread_ids; i++) {
1675 if (old_thread_sp) {
1676 lldb::tid_t old_thread_id = old_thread_sp->GetProtocolID();
1691 uint32_t pc_regnum = reg_ctx_sp->ConvertRegisterKindToRegisterNumber(
1704 if (thread_infos_sp) {
1708 const size_t n = thread_infos->
GetSize();
1709 for (
size_t i = 0; i < n; ++i) {
1715 if (tid == thread->GetID())
1744 if (
GetGDBRemote().GetThreadStopInfo(thread->GetProtocolID(), stop_packet))
1754 for (
const auto &pair : expedited_register_map) {
1758 reg_value_extractor.
GetHexBytes(buffer_sp->GetData(),
'\xcc');
1759 uint32_t lldb_regnum = gdb_reg_ctx_sp->ConvertRegisterKindToRegisterNumber(
1767 uint8_t signo,
const std::string &thread_name,
const std::string &reason,
1768 const std::string &description, uint32_t exc_type,
1769 const std::vector<addr_t> &exc_data,
addr_t thread_dispatch_qaddr,
1770 bool queue_vars_valid,
1772 LazyBool associated_with_dispatch_queue,
addr_t dispatch_queue_t,
1773 std::string &queue_name,
QueueKind queue_kind, uint64_t queue_serial) {
1797 reg_ctx_sp->InvalidateIfNeeded(
true);
1805 if (reg_ctx_sp->ReconfigureRegisterInfo()) {
1808 reg_ctx_sp->InvalidateAllRegisters();
1815 thread_sp->SetName(thread_name.empty() ?
nullptr : thread_name.c_str());
1820 if (queue_vars_valid)
1821 gdb_thread->
SetQueueInfo(std::move(queue_name), queue_kind, queue_serial,
1822 dispatch_queue_t, associated_with_dispatch_queue);
1833 StopInfoSP current_stop_info_sp = thread_sp->GetPrivateStopInfo(
false);
1835 current_stop_info_sp) {
1836 thread_sp->SetStopInfo(current_stop_info_sp);
1840 if (!thread_sp->StopInfoIsUpToDate()) {
1843 addr_t pc = thread_sp->GetRegisterContext()->GetPC();
1845 thread_sp->GetProcess()->GetBreakpointSiteList().FindByAddress(
pc);
1846 if (bp_site_sp && bp_site_sp->IsEnabled())
1847 thread_sp->SetThreadStoppedAtUnexecutedBP(
pc);
1849 if (exc_type != 0) {
1857 if (interrupt_thread)
1858 thread_sp = interrupt_thread;
1860 const size_t exc_data_size = exc_data.size();
1861 thread_sp->SetStopInfo(
1863 *thread_sp, exc_type, exc_data_size,
1864 exc_data_size >= 1 ? exc_data[0] : 0,
1865 exc_data_size >= 2 ? exc_data[1] : 0,
1866 exc_data_size >= 3 ? exc_data[2] : 0));
1869 bool handled =
false;
1870 bool did_exec =
false;
1873 if (!reason.empty() && reason !=
"none") {
1874 if (reason ==
"trace") {
1877 }
else if (reason ==
"breakpoint") {
1878 thread_sp->SetThreadHitBreakpointSite();
1886 if (bp_site_sp->ValidForThisThread(*thread_sp)) {
1887 thread_sp->SetStopInfo(
1889 *thread_sp, bp_site_sp->GetID()));
1892 thread_sp->SetStopInfo(invalid_stop_info_sp);
1895 }
else if (reason ==
"trap") {
1897 }
else if (reason ==
"watchpoint") {
1933 bool silently_continue =
false;
1943 silently_continue =
true;
1947 if (!wp_resource_sp) {
1949 LLDB_LOGF(log,
"failed to find watchpoint");
1956 watch_id = wp_resource_sp->GetConstituentAtIndex(0)->GetID();
1959 *thread_sp, watch_id, silently_continue));
1961 }
else if (reason ==
"exception") {
1963 *thread_sp, description.c_str()));
1965 }
else if (reason ==
"history boundary") {
1967 *thread_sp, description.c_str()));
1969 }
else if (reason ==
"exec") {
1971 thread_sp->SetStopInfo(
1974 }
else if (reason ==
"processor trace") {
1976 *thread_sp, description.c_str()));
1977 }
else if (reason ==
"fork") {
1982 thread_sp->SetStopInfo(
1985 }
else if (reason ==
"vfork") {
1991 *thread_sp, child_pid, child_tid));
1993 }
else if (reason ==
"vforkdone") {
1994 thread_sp->SetStopInfo(
2000 if (!handled && signo && !did_exec) {
2021 thread_sp->GetProcess()->GetBreakpointSiteList().FindByAddress(
2030 if (bp_site_sp->IsEnabled())
2031 thread_sp->SetThreadHitBreakpointSite();
2033 if (bp_site_sp->ValidForThisThread(*thread_sp)) {
2035 thread_sp->GetRegisterContext()->SetPC(
pc);
2036 thread_sp->SetStopInfo(
2038 *thread_sp, bp_site_sp->GetID()));
2041 thread_sp->SetStopInfo(invalid_stop_info_sp);
2047 thread_sp->SetStopInfo(
2051 *thread_sp, signo, description.c_str()));
2062 if (interrupt_thread)
2063 thread_sp = interrupt_thread;
2066 *thread_sp, signo, description.c_str()));
2070 if (!description.empty()) {
2073 const char *stop_info_desc = stop_info_sp->GetDescription();
2074 if (!stop_info_desc || !stop_info_desc[0])
2075 stop_info_sp->SetDescription(description.c_str());
2078 *thread_sp, description.c_str()));
2088 const std::string &description) {
2097 *thread_sp, signo, description.c_str()));
2106 static constexpr llvm::StringLiteral g_key_tid(
"tid");
2107 static constexpr llvm::StringLiteral g_key_name(
"name");
2108 static constexpr llvm::StringLiteral g_key_reason(
"reason");
2109 static constexpr llvm::StringLiteral g_key_metype(
"metype");
2110 static constexpr llvm::StringLiteral g_key_medata(
"medata");
2111 static constexpr llvm::StringLiteral g_key_qaddr(
"qaddr");
2112 static constexpr llvm::StringLiteral g_key_dispatch_queue_t(
2113 "dispatch_queue_t");
2114 static constexpr llvm::StringLiteral g_key_associated_with_dispatch_queue(
2115 "associated_with_dispatch_queue");
2116 static constexpr llvm::StringLiteral g_key_queue_name(
"qname");
2117 static constexpr llvm::StringLiteral g_key_queue_kind(
"qkind");
2118 static constexpr llvm::StringLiteral g_key_queue_serial_number(
"qserialnum");
2119 static constexpr llvm::StringLiteral g_key_registers(
"registers");
2120 static constexpr llvm::StringLiteral g_key_memory(
"memory");
2121 static constexpr llvm::StringLiteral g_key_description(
"description");
2122 static constexpr llvm::StringLiteral g_key_signal(
"signal");
2127 std::string thread_name;
2129 std::string description;
2130 uint32_t exc_type = 0;
2131 std::vector<addr_t> exc_data;
2134 bool queue_vars_valid =
false;
2137 std::string queue_name;
2139 uint64_t queue_serial_number = 0;
2144 thread_dict->
ForEach([
this, &tid, &expedited_register_map, &thread_name,
2145 &signo, &reason, &description, &exc_type, &exc_data,
2146 &thread_dispatch_qaddr, &queue_vars_valid,
2147 &associated_with_dispatch_queue, &dispatch_queue_t,
2148 &queue_name, &queue_kind, &queue_serial_number](
2149 llvm::StringRef key,
2151 if (key == g_key_tid) {
2154 }
else if (key == g_key_metype) {
2156 exc_type =
object->GetUnsignedIntegerValue(0);
2157 }
else if (key == g_key_medata) {
2162 exc_data.push_back(object->GetUnsignedIntegerValue());
2166 }
else if (key == g_key_name) {
2167 thread_name = std::string(object->GetStringValue());
2168 }
else if (key == g_key_qaddr) {
2169 thread_dispatch_qaddr =
2171 }
else if (key == g_key_queue_name) {
2172 queue_vars_valid =
true;
2173 queue_name = std::string(object->GetStringValue());
2174 }
else if (key == g_key_queue_kind) {
2175 std::string queue_kind_str = std::string(object->GetStringValue());
2176 if (queue_kind_str ==
"serial") {
2177 queue_vars_valid =
true;
2179 }
else if (queue_kind_str ==
"concurrent") {
2180 queue_vars_valid =
true;
2183 }
else if (key == g_key_queue_serial_number) {
2184 queue_serial_number =
object->GetUnsignedIntegerValue(0);
2185 if (queue_serial_number != 0)
2186 queue_vars_valid =
true;
2187 }
else if (key == g_key_dispatch_queue_t) {
2188 dispatch_queue_t =
object->GetUnsignedIntegerValue(0);
2190 queue_vars_valid =
true;
2191 }
else if (key == g_key_associated_with_dispatch_queue) {
2192 queue_vars_valid =
true;
2193 bool associated =
object->GetBooleanValue();
2198 }
else if (key == g_key_reason) {
2199 reason = std::string(object->GetStringValue());
2200 }
else if (key == g_key_description) {
2201 description = std::string(object->GetStringValue());
2202 }
else if (key == g_key_registers) {
2205 if (registers_dict) {
2207 [&expedited_register_map](llvm::StringRef key,
2210 if (llvm::to_integer(key, reg))
2211 expedited_register_map[reg] =
2212 std::string(object->GetStringValue());
2216 }
else if (key == g_key_memory) {
2222 if (mem_cache_dict) {
2225 "address", mem_cache_addr)) {
2227 llvm::StringRef str;
2232 const size_t byte_size = bytes.
GetStringRef().size() / 2;
2235 const size_t bytes_copied =
2237 if (bytes_copied == byte_size)
2248 }
else if (key == g_key_signal)
2254 reason, description, exc_type, exc_data,
2255 thread_dispatch_qaddr, queue_vars_valid,
2256 associated_with_dispatch_queue, dispatch_queue_t,
2257 queue_name, queue_kind, queue_serial_number);
2263 const char stop_type = stop_packet.
GetChar();
2264 switch (stop_type) {
2283 const uint8_t signo = stop_packet.
GetHexU8();
2284 llvm::StringRef key;
2285 llvm::StringRef value;
2286 std::string thread_name;
2288 std::string description;
2289 uint32_t exc_type = 0;
2290 std::vector<addr_t> exc_data;
2292 bool queue_vars_valid =
2296 std::string queue_name;
2298 uint64_t queue_serial_number = 0;
2302 if (key.compare(
"metype") == 0) {
2304 value.getAsInteger(16, exc_type);
2305 }
else if (key.compare(
"medata") == 0) {
2308 value.getAsInteger(16, x);
2309 exc_data.push_back(x);
2310 }
else if (key.compare(
"thread") == 0) {
2313 auto pid_tid = thread_id.
GetPidTid(pid);
2315 stop_pid = pid_tid->first;
2316 tid = pid_tid->second;
2319 }
else if (key.compare(
"threads") == 0) {
2320 std::lock_guard<std::recursive_mutex> guard(
2323 }
else if (key.compare(
"thread-pcs") == 0) {
2328 while (!value.empty()) {
2329 llvm::StringRef pc_str;
2330 std::tie(pc_str, value) = value.split(
',');
2331 if (pc_str.getAsInteger(16,
pc))
2335 }
else if (key.compare(
"jstopinfo") == 0) {
2344 }
else if (key.compare(
"hexname") == 0) {
2348 }
else if (key.compare(
"name") == 0) {
2349 thread_name = std::string(value);
2350 }
else if (key.compare(
"qaddr") == 0) {
2351 value.getAsInteger(16, thread_dispatch_qaddr);
2352 }
else if (key.compare(
"dispatch_queue_t") == 0) {
2353 queue_vars_valid =
true;
2354 value.getAsInteger(16, dispatch_queue_t);
2355 }
else if (key.compare(
"qname") == 0) {
2356 queue_vars_valid =
true;
2360 }
else if (key.compare(
"qkind") == 0) {
2361 queue_kind = llvm::StringSwitch<QueueKind>(value)
2366 }
else if (key.compare(
"qserialnum") == 0) {
2367 if (!value.getAsInteger(0, queue_serial_number))
2368 queue_vars_valid =
true;
2369 }
else if (key.compare(
"reason") == 0) {
2370 reason = std::string(value);
2371 }
else if (key.compare(
"description") == 0) {
2375 }
else if (key.compare(
"memory") == 0) {
2389 llvm::StringRef addr_str, bytes_str;
2390 std::tie(addr_str, bytes_str) = value.split(
'=');
2391 if (!addr_str.empty() && !bytes_str.empty()) {
2393 if (!addr_str.getAsInteger(0, mem_cache_addr)) {
2398 const size_t bytes_copied =
2400 if (bytes_copied == byte_size)
2404 }
else if (key.compare(
"watch") == 0 || key.compare(
"rwatch") == 0 ||
2405 key.compare(
"awatch") == 0) {
2408 value.getAsInteger(16, wp_addr);
2416 reason =
"watchpoint";
2418 ostr.
Printf(
"%" PRIu64, wp_addr);
2419 description = std::string(ostr.
GetString());
2420 }
else if (key.compare(
"swbreak") == 0 || key.compare(
"hwbreak") == 0) {
2421 reason =
"breakpoint";
2422 }
else if (key.compare(
"replaylog") == 0) {
2423 reason =
"history boundary";
2424 }
else if (key.compare(
"library") == 0) {
2430 }
else if (key.compare(
"fork") == 0 || key.compare(
"vfork") == 0) {
2436 LLDB_LOG(log,
"Invalid PID/TID to fork: {0}", value);
2442 ostr.
Printf(
"%" PRIu64
" %" PRIu64, pid_tid->first, pid_tid->second);
2443 description = std::string(ostr.
GetString());
2444 }
else if (key.compare(
"addressing_bits") == 0) {
2445 uint64_t addressing_bits;
2446 if (!value.getAsInteger(0, addressing_bits)) {
2449 }
else if (key.compare(
"low_mem_addressing_bits") == 0) {
2450 uint64_t addressing_bits;
2451 if (!value.getAsInteger(0, addressing_bits)) {
2454 }
else if (key.compare(
"high_mem_addressing_bits") == 0) {
2455 uint64_t addressing_bits;
2456 if (!value.getAsInteger(0, addressing_bits)) {
2459 }
else if (key.size() == 2 && ::isxdigit(key[0]) && ::isxdigit(key[1])) {
2461 if (!key.getAsInteger(16, reg))
2462 expedited_register_map[reg] = std::string(std::move(value));
2472 "Received stop for incorrect PID = {0} (inferior PID = {1})",
2492 tid, expedited_register_map, signo, thread_name, reason, description,
2493 exc_type, exc_data, thread_dispatch_qaddr, queue_vars_valid,
2494 associated_with_dispatch_queue, dispatch_queue_t, queue_name,
2495 queue_kind, queue_serial_number);
2562 LLDB_LOGF(log,
"ProcessGDBRemote::DoDetach(keep_stopped: %i)", keep_stopped);
2566 if (
error.Success())
2568 "ProcessGDBRemote::DoDetach() detach packet sent successfully");
2571 "ProcessGDBRemote::DoDetach() detach packet send failed: %s",
2572 error.AsCString() ?
error.AsCString() :
"<unknown error>");
2575 if (!
error.Success())
2590 LLDB_LOGF(log,
"ProcessGDBRemote::DoDestroy()");
2593 int exit_status = SIGABRT;
2594 std::string exit_string;
2601 exit_status = kill_res.get();
2602#if defined(__APPLE__)
2614 if (platform_sp && platform_sp->IsHost()) {
2617 reap_pid = waitpid(
GetID(), &status, WNOHANG);
2618 LLDB_LOGF(log,
"Reaped pid: %d, status: %d.\n", reap_pid, status);
2622 exit_string.assign(
"killed");
2624 exit_string.assign(llvm::toString(kill_res.takeError()));
2627 exit_string.assign(
"killed or interrupted while attaching.");
2633 exit_string.assign(
"destroying when not connected to debugserver");
2654 const bool did_exec =
2655 response.
GetStringRef().find(
";reason:exec;") != std::string::npos;
2658 LLDB_LOGF(log,
"ProcessGDBRemote::SetLastStopPacket () - detected exec");
2663 m_gdb_comm.ResetDiscoverableSettings(did_exec);
2688 LLDB_LOG_ERROR(log, list.takeError(),
"Failed to read module list: {0}.");
2690 addr = list->m_link_map;
2710 const size_t n = thread_infos->
GetSize();
2711 for (
size_t i = 0; i < n; ++i) {
2727 xPacketState x_state =
m_gdb_comm.GetxPacketState();
2730 size_t max_memory_size = x_state != xPacketState::Unimplemented
2733 if (size > max_memory_size) {
2737 size = max_memory_size;
2742 packet_len = ::snprintf(packet,
sizeof(packet),
"%c%" PRIx64
",%" PRIx64,
2743 x_state != xPacketState::Unimplemented ?
'x' :
'm',
2744 (uint64_t)addr, (uint64_t)size);
2745 assert(packet_len + 1 < (
int)
sizeof(packet));
2748 if (
m_gdb_comm.SendPacketAndWaitForResponse(packet, response,
2753 if (x_state != xPacketState::Unimplemented) {
2758 llvm::StringRef data_received = response.
GetStringRef();
2759 if (x_state == xPacketState::Prefixed &&
2760 !data_received.consume_front(
"b")) {
2762 "unexpected response to GDB server memory read packet '{0}': "
2764 packet, data_received);
2769 size_t memcpy_size = std::min(size, data_received.size());
2770 memcpy(buf, data_received.data(), memcpy_size);
2774 llvm::MutableArrayRef<uint8_t>((uint8_t *)buf, size),
'\xdd');
2778 "memory read failed for 0x%" PRIx64, addr);
2781 "GDB server does not support reading memory");
2784 "unexpected response to GDB server memory read packet '%s': '%s'",
2796 uint64_t max_packet_size,
2800 constexpr uint64_t range_overhead = 33;
2801 uint64_t current_size = 0;
2802 for (
auto [idx, range] : llvm::enumerate(ranges)) {
2803 uint64_t potential_size = current_size + range.size + range_overhead;
2804 if (potential_size > max_packet_size) {
2807 "MultiMemRead input has a range (base = {0:x}, size = {1}) "
2808 "bigger than the maximum allowed by remote",
2809 range.base, range.size);
2813 return ranges.size();
2816llvm::SmallVector<llvm::MutableArrayRef<uint8_t>>
2819 llvm::MutableArrayRef<uint8_t> buffer) {
2823 const llvm::ArrayRef<Range<lldb::addr_t, size_t>> original_ranges = ranges;
2824 llvm::SmallVector<llvm::MutableArrayRef<uint8_t>> memory_regions;
2826 while (!ranges.empty()) {
2827 uint64_t num_ranges =
2829 if (num_ranges == 0)
2832 auto ranges_for_request = ranges.take_front(num_ranges);
2833 ranges = ranges.drop_front(num_ranges);
2835 llvm::Expected<StringExtractorGDBRemote> response =
2839 "MultiMemRead error response: {0}");
2843 llvm::StringRef response_str = response->GetStringRef();
2844 const unsigned expected_num_ranges = ranges_for_request.size();
2846 response_str, buffer, expected_num_ranges, memory_regions)) {
2848 "MultiMemRead error parsing response: {0}");
2852 return memory_regions;
2855llvm::Expected<StringExtractorGDBRemote>
2858 std::string packet_str;
2859 llvm::raw_string_ostream stream(packet_str);
2860 stream <<
"MultiMemRead:ranges:";
2862 auto range_to_stream = [&](
auto range) {
2864 stream << llvm::formatv(
"{0:x-},{1:x-}", range.base, range.size);
2866 llvm::interleave(ranges, stream, range_to_stream,
",");
2871 m_gdb_comm.SendPacketAndWaitForResponse(packet_str.data(), response,
2874 return llvm::createStringErrorV(
"MultiMemRead failed to send packet: '{0}'",
2878 return llvm::createStringErrorV(
"MultiMemRead failed: '{0}'",
2882 return llvm::createStringErrorV(
"MultiMemRead unexpected response: '{0}'",
2889 llvm::StringRef response_str, llvm::MutableArrayRef<uint8_t> buffer,
2890 unsigned expected_num_ranges,
2893 auto [sizes_str, memory_data] = response_str.split(
';');
2894 if (sizes_str.size() == response_str.size())
2895 return llvm::createStringErrorV(
2896 "MultiMemRead response missing field separator ';' in: '{0}'",
2900 for (llvm::StringRef size_str : llvm::split(sizes_str,
',')) {
2902 if (size_str.getAsInteger(16, read_size))
2903 return llvm::createStringErrorV(
2904 "MultiMemRead response has invalid size string: {0}", size_str);
2906 if (memory_data.size() < read_size)
2907 return llvm::createStringErrorV(
"MultiMemRead response did not have "
2908 "enough data, requested sizes: {0}",
2911 llvm::StringRef region_to_read = memory_data.take_front(read_size);
2912 memory_data = memory_data.drop_front(read_size);
2914 assert(buffer.size() >= read_size);
2915 llvm::MutableArrayRef<uint8_t> region_to_write =
2916 buffer.take_front(read_size);
2917 buffer = buffer.drop_front(read_size);
2919 memcpy(region_to_write.data(), region_to_read.data(), read_size);
2920 memory_regions.push_back(region_to_write);
2923 return llvm::Error::success();
2927 return m_gdb_comm.GetMemoryTaggingSupported();
2930llvm::Expected<std::vector<uint8_t>>
2937 return llvm::createStringError(llvm::inconvertibleErrorCode(),
2938 "Error reading memory tags from remote");
2942 llvm::ArrayRef<uint8_t> tag_data = buffer_sp->GetData();
2943 std::vector<uint8_t> got;
2944 got.reserve(tag_data.size());
2945 std::copy(tag_data.begin(), tag_data.end(), std::back_inserter(got));
2951 const std::vector<uint8_t> &tags) {
2954 return m_gdb_comm.WriteMemoryTags(addr, len, type, tags);
2958 std::vector<ObjectFile::LoadableData> entries) {
2968 if (
error.Success())
2982 for (
size_t i = 0; i < size; ++i)
3007 if (blocksize == 0) {
3015 lldb::addr_t block_start_addr = addr - (addr % blocksize);
3016 size += (addr - block_start_addr);
3017 if ((size % blocksize) != 0)
3018 size += (blocksize - size % blocksize);
3034 auto overlap = last_range.GetRangeEnd() - range.
GetRangeBase();
3055 "flash erase failed for 0x%" PRIx64, addr);
3058 "GDB server does not support flashing");
3061 "unexpected response to GDB server flash erase packet '%s': '%s'",
3078 if (
m_gdb_comm.SendPacketAndWaitForResponse(
"vFlashDone", response,
3088 "GDB server does not support flashing");
3091 "unexpected response to GDB server flash done packet: '%s'",
3106 if (size > max_memory_size) {
3110 size = max_memory_size;
3130 if (!
error.Success())
3132 packet.
Printf(
"vFlashWrite:%" PRIx64
":", addr);
3135 packet.
Printf(
"M%" PRIx64
",%" PRIx64
":", addr, (uint64_t)size);
3148 "memory write failed for 0x%" PRIx64, addr);
3151 "GDB server does not support writing memory");
3154 "unexpected response to GDB server memory write packet '%s': '%s'",
3164 uint32_t permissions,
3170 allocated_addr =
m_gdb_comm.AllocateMemory(size, permissions);
3173 return allocated_addr;
3179 if (permissions & lldb::ePermissionsReadable)
3181 if (permissions & lldb::ePermissionsWritable)
3183 if (permissions & lldb::ePermissionsExecutable)
3192 "ProcessGDBRemote::%s no direct stub support for memory "
3193 "allocation, and InferiorCallMmap also failed - is stub "
3194 "missing register context save/restore capability?",
3201 "unable to allocate %" PRIu64
" bytes of memory with permissions %s",
3205 return allocated_addr;
3220 return m_gdb_comm.GetWatchpointReportedAfter();
3227 switch (supported) {
3232 "tried to deallocate memory without ever allocating memory");
3238 "unable to deallocate memory at 0x%" PRIx64, addr);
3250 "unable to deallocate memory at 0x%" PRIx64, addr);
3265 m_gdb_comm.SendStdinNotification(src, src_len);
3284 uint8_t error_no = gdb_comm.SendGDBStoppointTypePacket(
3287 if (error_no == 0) {
3290 return llvm::Error::success();
3293 if (error_no != UINT8_MAX)
3294 return llvm::createStringErrorV(
3295 "error sending the breakpoint request: {0}", error_no);
3296 return llvm::createStringError(
"error sending the breakpoint request");
3298 LLDB_LOG(log,
"Software breakpoints are unsupported");
3303 uint8_t error_no = gdb_comm.SendGDBStoppointTypePacket(
3306 if (error_no == 0) {
3309 return llvm::Error::success();
3312 if (error_no != UINT8_MAX)
3313 return llvm::createStringErrorV(
3314 "error sending the hardware breakpoint request: {0} "
3315 "(hardware breakpoint resources might be exhausted or unavailable)",
3317 return llvm::createStringError(
3318 "error sending the hardware breakpoint request "
3319 "(hardware breakpoint resources might be exhausted or unavailable)");
3321 LLDB_LOG(log,
"Hardware breakpoints are unsupported");
3325 return llvm::createStringError(
"hardware breakpoints are not supported");
3342 return error.takeError();
3349 return llvm::createStringError(
"unknown error");
3355 return llvm::createStringError(
"unknown error");
3359 return llvm::Error::success();
3363 assert(bp_site !=
nullptr);
3374 "ProcessGDBRemote::EnableBreakpointSite (size_id = %" PRIu64
3375 ") address = 0x%" PRIx64,
3376 site_id, (uint64_t)addr);
3381 "ProcessGDBRemote::EnableBreakpointSite (size_id = %" PRIu64
3382 ") address = 0x%" PRIx64
" -- SUCCESS (already enabled)",
3383 site_id, (uint64_t)addr);
3391 assert(bp_site !=
nullptr);
3396 "ProcessGDBRemote::DisableBreakpointSite (site_id = %" PRIu64
3397 ") addr = 0x%8.8" PRIx64,
3398 site_id, (uint64_t)addr);
3402 "ProcessGDBRemote::DisableBreakpointSite (site_id = %" PRIu64
3403 ") addr = 0x%8.8" PRIx64
" -- SUCCESS (already disabled)",
3404 site_id, (uint64_t)addr);
3415 bool read = wp_res_sp->WatchpointResourceRead();
3416 bool write = wp_res_sp->WatchpointResourceWrite();
3418 assert((read || write) &&
3419 "WatchpointResource type is neither read nor write");
3435 addr_t addr = wp_sp->GetLoadAddress();
3437 LLDB_LOGF(log,
"ProcessGDBRemote::EnableWatchpoint(watchID = %" PRIu64
")",
3439 if (wp_sp->IsEnabled()) {
3441 "ProcessGDBRemote::EnableWatchpoint(watchID = %" PRIu64
3442 ") addr = 0x%8.8" PRIx64
": watchpoint already enabled.",
3443 watchID, (uint64_t)addr);
3447 bool read = wp_sp->WatchpointRead();
3448 bool write = wp_sp->WatchpointWrite() || wp_sp->WatchpointModify();
3449 size_t size = wp_sp->GetByteSize();
3452 WatchpointHardwareFeature supported_features =
3455 std::vector<WatchpointResourceSP> resources =
3457 addr, size, read, write, supported_features, target_arch);
3482 bool set_all_resources =
true;
3483 std::vector<WatchpointResourceSP> succesfully_set_resources;
3484 for (
const auto &wp_res_sp : resources) {
3485 addr_t addr = wp_res_sp->GetLoadAddress();
3486 size_t size = wp_res_sp->GetByteSize();
3488 if (!
m_gdb_comm.SupportsGDBStoppointPacket(type) ||
3489 m_gdb_comm.SendGDBStoppointTypePacket(type,
true, addr, size,
3491 set_all_resources =
false;
3494 succesfully_set_resources.push_back(wp_res_sp);
3497 if (set_all_resources) {
3498 wp_sp->SetEnabled(
true, notify);
3499 for (
const auto &wp_res_sp : resources) {
3502 wp_res_sp->AddConstituent(wp_sp);
3510 for (
const auto &wp_res_sp : succesfully_set_resources) {
3511 addr_t addr = wp_res_sp->GetLoadAddress();
3512 size_t size = wp_res_sp->GetByteSize();
3514 m_gdb_comm.SendGDBStoppointTypePacket(type,
false, addr, size,
3518 "Setting one of the watchpoint resources failed");
3534 addr_t addr = wp_sp->GetLoadAddress();
3537 "ProcessGDBRemote::DisableWatchpoint (watchID = %" PRIu64
3538 ") addr = 0x%8.8" PRIx64,
3539 watchID, (uint64_t)addr);
3541 if (!wp_sp->IsEnabled()) {
3543 "ProcessGDBRemote::DisableWatchpoint (watchID = %" PRIu64
3544 ") addr = 0x%8.8" PRIx64
" -- SUCCESS (already disabled)",
3545 watchID, (uint64_t)addr);
3549 wp_sp->SetEnabled(
false, notify);
3553 if (wp_sp->IsHardware()) {
3554 bool disabled_all =
true;
3556 std::vector<WatchpointResourceSP> unused_resources;
3558 if (wp_res_sp->ConstituentsContains(wp_sp)) {
3560 addr_t addr = wp_res_sp->GetLoadAddress();
3561 size_t size = wp_res_sp->GetByteSize();
3562 if (
m_gdb_comm.SendGDBStoppointTypePacket(type,
false, addr, size,
3564 disabled_all =
false;
3566 wp_res_sp->RemoveConstituent(wp_sp);
3567 if (wp_res_sp->GetNumberOfConstituents() == 0)
3568 unused_resources.push_back(wp_res_sp);
3572 for (
auto &wp_res_sp : unused_resources)
3575 wp_sp->SetEnabled(
false, notify);
3578 "Failure disabling one of the watchpoint locations");
3591 LLDB_LOGF(log,
"ProcessGDBRemote::DoSignal (signal = %d)", signo);
3606 if (platform_sp && !platform_sp->IsHost())
3611 const char *error_string =
error.AsCString();
3612 if (error_string ==
nullptr)
3621 static FileSpec g_debugserver_file_spec;
3628 std::string env_debugserver_path = host_env.lookup(
"LLDB_DEBUGSERVER_PATH");
3629 if (!env_debugserver_path.empty()) {
3630 debugserver_file_spec.
SetFile(env_debugserver_path,
3631 FileSpec::Style::native);
3632 LLDB_LOG(log,
"gdb-remote stub exe path set from environment variable: {0}",
3633 env_debugserver_path);
3635 debugserver_file_spec = g_debugserver_file_spec;
3637 return debugserver_file_spec;
3640 debugserver_file_spec = HostInfo::GetSupportExeDir();
3641 if (debugserver_file_spec) {
3644 LLDB_LOG(log,
"found gdb-remote stub exe '{0}'", debugserver_file_spec);
3646 g_debugserver_file_spec = debugserver_file_spec;
3649 if (!debugserver_file_spec) {
3652 LLDB_LOG(log,
"could not find gdb-remote stub exe '{0}'",
3653 debugserver_file_spec);
3657 g_debugserver_file_spec.
Clear();
3660 return debugserver_file_spec;
3665 using namespace std::placeholders;
3675 const std::weak_ptr<ProcessGDBRemote> this_wp =
3676 std::static_pointer_cast<ProcessGDBRemote>(shared_from_this());
3683#if defined(__APPLE__)
3687 int mib[] = {CTL_KERN, KERN_PROC, KERN_PROC_PID,
3689 struct kinfo_proc processInfo;
3690 size_t bufsize =
sizeof(processInfo);
3691 if (sysctl(mib, (
unsigned)(
sizeof(mib) /
sizeof(
int)), &processInfo, &bufsize,
3694 if (processInfo.kp_proc.p_flag & P_TRANSLATED) {
3695 debugserver_path =
FileSpec(
"/Library/Apple/usr/libexec/oah/debugserver");
3702 "'. Please ensure it is properly installed "
3703 "and available in your PATH");
3718 debugserver_launch_info,
nullptr);
3723 LLDB_LOGF(log,
"failed to start debugserver process: %s",
3733 m_gdb_comm.SetConnection(std::make_unique<ConnectionFileDescriptor>(
3734 std::move(socket_pair->second)));
3748 std::weak_ptr<ProcessGDBRemote> process_wp,
lldb::pid_t debugserver_pid,
3757 "ProcessGDBRemote::%s(process_wp, pid=%" PRIu64
3758 ", signo=%i (0x%x), exit_status=%i)",
3759 __FUNCTION__, debugserver_pid, signo, signo, exit_status);
3761 std::shared_ptr<ProcessGDBRemote> process_sp = process_wp.lock();
3762 LLDB_LOGF(log,
"ProcessGDBRemote::%s(process = %p)", __FUNCTION__,
3763 static_cast<void *
>(process_sp.get()));
3764 if (!process_sp || process_sp->m_debugserver_pid != debugserver_pid)
3770 std::this_thread::sleep_for(std::chrono::milliseconds(500));
3774 const StateType state = process_sp->GetState();
3783 llvm::StringRef signal_name =
3784 process_sp->GetUnixSignals()->GetSignalAsStringRef(signo);
3786 if (!signal_name.empty())
3787 stream.
Format(format_str, signal_name);
3789 stream.
Format(format_str, signo);
3791 process_sp->SetExitStatus(-1, stream.
GetString());
3814 debugger, PluginProperties::GetSettingName())) {
3815 const bool is_global_setting =
true;
3818 "Properties for the gdb-remote process plug-in.", is_global_setting);
3825 LLDB_LOGF(log,
"ProcessGDBRemote::%s ()", __FUNCTION__);
3832 llvm::Expected<HostThread> async_thread =
3836 if (!async_thread) {
3838 "failed to launch host thread: {0}");
3844 "ProcessGDBRemote::%s () - Called when Async thread was "
3854 LLDB_LOGF(log,
"ProcessGDBRemote::%s ()", __FUNCTION__);
3869 "ProcessGDBRemote::%s () - Called when Async thread was not running.",
3875 LLDB_LOGF(log,
"ProcessGDBRemote::%s(pid = %" PRIu64
") thread starting...",
3876 __FUNCTION__,
GetID());
3894 "ProcessGDBRemote::%s(pid = %" PRIu64
3895 ") listener.WaitForEvent (NULL, event_sp)...",
3896 __FUNCTION__,
GetID());
3899 const uint32_t event_type = event_sp->GetType();
3902 "ProcessGDBRemote::%s(pid = %" PRIu64
3903 ") Got an event of type: %d...",
3904 __FUNCTION__,
GetID(), event_type);
3906 switch (event_type) {
3911 if (continue_packet) {
3912 const char *continue_cstr =
3913 (
const char *)continue_packet->
GetBytes();
3914 const size_t continue_cstr_len = continue_packet->
GetByteSize();
3916 "ProcessGDBRemote::%s(pid = %" PRIu64
3917 ") got eBroadcastBitAsyncContinue: %s",
3918 __FUNCTION__,
GetID(), continue_cstr);
3920 if (::strstr(continue_cstr,
"vAttach") ==
nullptr)
3927 llvm::StringRef(continue_cstr, continue_cstr_len),
3938 switch (stop_state) {
3951 int exit_status = response.
GetHexU8();
3952 std::string desc_string;
3954 llvm::StringRef desc_str;
3955 llvm::StringRef desc_token;
3957 if (desc_token !=
"description")
3972 if (::strstr(continue_cstr,
"vAttach") !=
nullptr &&
3975 "System Integrity Protection");
3976 }
else if (::strstr(continue_cstr,
"vAttach") !=
nullptr &&
3996 "ProcessGDBRemote::%s(pid = %" PRIu64
3997 ") got eBroadcastBitAsyncThreadShouldExit...",
3998 __FUNCTION__,
GetID());
4004 "ProcessGDBRemote::%s(pid = %" PRIu64
4005 ") got unknown event 0x%8.8x",
4006 __FUNCTION__,
GetID(), event_type);
4013 "ProcessGDBRemote::%s(pid = %" PRIu64
4014 ") listener.WaitForEvent (NULL, event_sp) => false",
4015 __FUNCTION__,
GetID());
4020 LLDB_LOGF(log,
"ProcessGDBRemote::%s(pid = %" PRIu64
") thread exiting...",
4021 __FUNCTION__,
GetID());
4053 LLDB_LOGF(log,
"Hit New Thread Notification breakpoint.");
4059 LLDB_LOG(log,
"Check if need to update ignored signals");
4073 LLDB_LOG(log,
"Signals' version hasn't changed. version={0}",
4078 auto signals_to_ignore =
4083 "Signals' version changed. old version={0}, new version={1}, "
4084 "signals ignored={2}, update result={3}",
4086 signals_to_ignore.size(),
error);
4088 if (
error.Success())
4103 platform_sp->SetThreadCreationBreakpoint(
GetTarget());
4106 log,
"Successfully created new thread notification breakpoint %i",
4111 LLDB_LOGF(log,
"Failed to create new thread notification breakpoint.");
4140 return_value =
m_gdb_comm.SendLaunchEventDataPacket(data, &was_supported);
4141 if (return_value != 0) {
4144 "Sending events is not supported for this process.");
4154 if (
m_gdb_comm.GetQXferAuxvReadSupported()) {
4155 llvm::Expected<std::string> response =
m_gdb_comm.ReadExtFeature(
"auxv",
"");
4157 buf = std::make_shared<DataBufferHeap>(response->c_str(),
4158 response->length());
4169 if (
m_gdb_comm.GetThreadExtendedInfoSupported()) {
4175 args_dict->GetAsDictionary()->AddIntegerItem(
"thread", tid);
4178 packet <<
"jThreadExtendedInfo:";
4179 args_dict->Dump(packet,
false);
4186 packet << (char)(0x7d ^ 0x20);
4195 if (!response.
Empty()) {
4208 args_dict->GetAsDictionary()->AddIntegerItem(
"image_list_address",
4209 image_list_address);
4210 args_dict->GetAsDictionary()->AddIntegerItem(
"image_count", image_count);
4217 std::string info_level_str;
4219 info_level_str =
"address-only";
4221 info_level_str =
"address-name";
4223 info_level_str =
"address-name-uuid";
4225 info_level_str =
"full";
4227 return info_level_str;
4234 args_dict->GetAsDictionary()->AddBooleanItem(
"fetch_all_solibs",
true);
4236 args_dict->GetAsDictionary()->AddBooleanItem(
"report_load_commands",
false);
4238 if (!info_level_str.empty())
4239 args_dict->GetAsDictionary()->AddStringItem(
"information-level",
4240 info_level_str.c_str());
4247 const std::vector<lldb::addr_t> &load_addresses) {
4251 for (
auto addr : load_addresses)
4252 addresses->AddIntegerItem(addr);
4254 args_dict->GetAsDictionary()->AddItem(
"solib_addresses", addresses);
4257 if (!info_level_str.empty())
4258 args_dict->GetAsDictionary()->AddStringItem(
"information-level",
4259 info_level_str.c_str());
4269 if (
m_gdb_comm.GetLoadedDynamicLibrariesInfosSupported()) {
4272 std::chrono::seconds(10));
4275 packet <<
"jGetLoadedDynamicLibrariesInfos:";
4276 args_dict->Dump(packet,
false);
4283 packet << (char)(0x7d ^ 0x20);
4292 if (!response.
Empty()) {
4305 if (
m_gdb_comm.GetDynamicLoaderProcessStateSupported()) {
4308 if (
m_gdb_comm.SendPacketAndWaitForResponse(
"jGetDyldProcessState",
4314 if (!response.
Empty()) {
4331 packet <<
"jGetSharedCacheInfo:";
4332 args_dict->Dump(packet,
false);
4341 if (response.
Empty())
4350 if (!dict->
HasKey(
"shared_cache_uuid"))
4352 llvm::StringRef uuid_str;
4354 uuid_str ==
"00000000-0000-0000-0000-000000000000")
4356 if (dict->
HasKey(
"shared_cache_path")) {
4370 HostInfo::SharedCacheIndexFiles(sc_path, uuid, sc_mode);
4381 return m_gdb_comm.ConfigureRemoteStructuredData(type_name, config_sp);
4394 const uint64_t reasonable_largeish_default = 128 * 1024;
4395 const uint64_t conservative_default = 512;
4398 uint64_t stub_max_size =
m_gdb_comm.GetRemoteMaxPacketSize();
4399 if (stub_max_size !=
UINT64_MAX && stub_max_size != 0) {
4405 if (stub_max_size > reasonable_largeish_default) {
4406 stub_max_size = reasonable_largeish_default;
4412 if (stub_max_size > 70)
4413 stub_max_size -= 32 + 32 + 6;
4418 LLDB_LOG(log,
"warning: Packet size is too small. "
4419 "LLDB may face problems while writing memory");
4430 uint64_t user_specified_max) {
4431 if (user_specified_max != 0) {
4459 module_spec = cached->second;
4460 return bool(module_spec);
4463 if (!
m_gdb_comm.GetModuleInfo(module_file_spec, arch, module_spec)) {
4464 LLDB_LOGF(log,
"ProcessGDBRemote::%s - failed to get module info for %s:%s",
4465 __FUNCTION__, module_file_spec.
GetPath().c_str(),
4472 module_spec.
Dump(stream);
4473 LLDB_LOGF(log,
"ProcessGDBRemote::%s - got module info for (%s:%s) : %s",
4474 __FUNCTION__, module_file_spec.
GetPath().c_str(),
4483 llvm::ArrayRef<FileSpec> module_file_specs,
const llvm::Triple &triple) {
4484 auto module_specs =
m_gdb_comm.GetModulesInfo(module_file_specs, triple);
4486 for (
const FileSpec &spec : module_file_specs)
4491 triple.getTriple())] = spec;
4505typedef std::vector<std::string> stringVec;
4507typedef std::vector<struct GdbServerRegisterInfo> GDBServerRegisterVec;
4508struct RegisterSetInfo {
4512typedef std::map<uint32_t, RegisterSetInfo> RegisterSetMap;
4514struct GdbServerTargetInfo {
4518 RegisterSetMap reg_set_map;
4535 std::map<uint64_t, FieldEnum::Enumerator> enumerators;
4538 "evalue", [&enumerators, &log](
const XMLNode &enumerator_node) {
4539 std::optional<llvm::StringRef> name;
4540 std::optional<uint64_t> value;
4543 [&name, &value, &log](
const llvm::StringRef &attr_name,
4544 const llvm::StringRef &attr_value) {
4545 if (attr_name ==
"name") {
4546 if (attr_value.size())
4549 LLDB_LOG(log,
"ProcessGDBRemote::ParseEnumEvalues "
4550 "Ignoring empty name in evalue");
4551 }
else if (attr_name ==
"value") {
4552 uint64_t parsed_value = 0;
4553 if (llvm::to_integer(attr_value, parsed_value))
4554 value = parsed_value;
4557 "ProcessGDBRemote::ParseEnumEvalues "
4558 "Invalid value \"{0}\" in "
4563 "ProcessGDBRemote::ParseEnumEvalues Ignoring "
4564 "unknown attribute "
4565 "\"{0}\" in evalue",
4573 enumerators.insert_or_assign(
4574 *value, FieldEnum::Enumerator(*value, name->str()));
4581 for (
auto [_, enumerator] : enumerators)
4582 final_enumerators.push_back(enumerator);
4584 return final_enumerators;
4588ParseEnums(XMLNode feature_node,
4589 llvm::StringMap<std::unique_ptr<FieldEnum>> ®isters_enum_types) {
4590 Log *log(
GetLog(GDBRLog::Process));
4594 "enum", [log, ®isters_enum_types](
const XMLNode &enum_node) {
4598 const llvm::StringRef &attr_value) {
4599 if (attr_name ==
"id")
4617 if (!enumerators.empty()) {
4619 "ProcessGDBRemote::ParseEnums Found enum type \"{0}\"",
4621 registers_enum_types.insert_or_assign(
4622 id, std::make_unique<FieldEnum>(
id, enumerators));
4631static std::vector<RegisterFlags::Field> ParseFlagsFields(
4632 XMLNode flags_node,
unsigned size,
4633 const llvm::StringMap<std::unique_ptr<FieldEnum>> ®isters_enum_types) {
4634 Log *log(
GetLog(GDBRLog::Process));
4635 const unsigned max_start_bit = size * 8 - 1;
4638 std::vector<RegisterFlags::Field> fields;
4640 ®isters_enum_types](
4643 std::optional<llvm::StringRef> name;
4644 std::optional<unsigned> start;
4645 std::optional<unsigned> end;
4646 std::optional<llvm::StringRef> type;
4649 &log](
const llvm::StringRef &attr_name,
4650 const llvm::StringRef &attr_value) {
4653 if (attr_name ==
"name") {
4656 "ProcessGDBRemote::ParseFlagsFields Found field node name \"{0}\"",
4659 }
else if (attr_name ==
"start") {
4660 unsigned parsed_start = 0;
4661 if (llvm::to_integer(attr_value, parsed_start)) {
4662 if (parsed_start > max_start_bit) {
4664 "ProcessGDBRemote::ParseFlagsFields Invalid start {0} in "
4667 parsed_start, max_start_bit);
4669 start = parsed_start;
4673 "ProcessGDBRemote::ParseFlagsFields Invalid start \"{0}\" in "
4677 }
else if (attr_name ==
"end") {
4678 unsigned parsed_end = 0;
4679 if (llvm::to_integer(attr_value, parsed_end))
4680 if (parsed_end > max_start_bit) {
4682 "ProcessGDBRemote::ParseFlagsFields Invalid end {0} in "
4685 parsed_end, max_start_bit);
4690 "ProcessGDBRemote::ParseFlagsFields Invalid end \"{0}\" in "
4694 }
else if (attr_name ==
"type") {
4699 "ProcessGDBRemote::ParseFlagsFields Ignoring unknown attribute "
4700 "\"{0}\" in field node",
4707 if (name && start && end) {
4711 "ProcessGDBRemote::ParseFlagsFields Start {0} > end {1} in field "
4712 "\"{2}\", ignoring",
4713 *start, *end, name->data());
4717 "ProcessGDBRemote::ParseFlagsFields Ignoring field \"{2}\" "
4719 "size > 64 bits, this is not supported",
4723 const FieldEnum *enum_type =
nullptr;
4724 if (type && !type->empty()) {
4725 auto found = registers_enum_types.find(*type);
4726 if (found != registers_enum_types.end()) {
4727 enum_type = found->second.get();
4730 uint64_t max_value =
4733 if (enumerator.m_value > max_value) {
4734 enum_type =
nullptr;
4737 "ProcessGDBRemote::ParseFlagsFields In enum \"{0}\" "
4738 "evalue \"{1}\" with value {2} exceeds the maximum value "
4739 "of field \"{3}\" ({4}), ignoring enum",
4740 type->data(), enumerator.m_name, enumerator.m_value,
4741 name->data(), max_value);
4747 "ProcessGDBRemote::ParseFlagsFields Could not find type "
4749 "for field \"{1}\", ignoring",
4750 type->data(), name->data());
4755 RegisterFlags::Field(name->str(), *start, *end, enum_type));
4766 XMLNode feature_node,
4767 llvm::StringMap<std::unique_ptr<RegisterFlags>> ®isters_flags_types,
4768 const llvm::StringMap<std::unique_ptr<FieldEnum>> ®isters_enum_types) {
4769 Log *log(
GetLog(GDBRLog::Process));
4773 [&log, ®isters_flags_types,
4774 ®isters_enum_types](
const XMLNode &flags_node) ->
bool {
4775 LLDB_LOG(log,
"ProcessGDBRemote::ParseFlags Found flags node \"{0}\"",
4778 std::optional<llvm::StringRef>
id;
4779 std::optional<unsigned> size;
4781 [&
id, &size, &log](
const llvm::StringRef &name,
4782 const llvm::StringRef &value) {
4785 }
else if (name ==
"size") {
4786 unsigned parsed_size = 0;
4787 if (llvm::to_integer(value, parsed_size))
4791 "ProcessGDBRemote::ParseFlags Invalid size \"{0}\" "
4797 "ProcessGDBRemote::ParseFlags Ignoring unknown "
4798 "attribute \"{0}\" in flags node",
4806 std::vector<RegisterFlags::Field> fields =
4807 ParseFlagsFields(flags_node, *size, registers_enum_types);
4808 if (fields.size()) {
4810 std::sort(fields.rbegin(), fields.rend());
4811 std::vector<RegisterFlags::Field>::const_iterator overlap =
4812 std::adjacent_find(fields.begin(), fields.end(),
4813 [](
const RegisterFlags::Field &lhs,
4814 const RegisterFlags::Field &rhs) {
4815 return lhs.Overlaps(rhs);
4819 if (overlap == fields.end()) {
4820 if (registers_flags_types.contains(*
id)) {
4834 "ProcessGDBRemote::ParseFlags Definition of flags "
4836 "previous definition, using original definition instead.",
4839 registers_flags_types.insert_or_assign(
4840 *
id, std::make_unique<RegisterFlags>(
id->str(), *size,
4841 std::move(fields)));
4845 std::vector<RegisterFlags::Field>::const_iterator next =
4849 "ProcessGDBRemote::ParseFlags Ignoring flags because fields "
4850 "{0} (start: {1} end: {2}) and {3} (start: {4} end: {5}) "
4852 overlap->GetName().c_str(), overlap->GetStart(),
4853 overlap->GetEnd(), next->GetName().c_str(), next->GetStart(),
4859 "ProcessGDBRemote::ParseFlags Ignoring definition of flags "
4860 "\"{0}\" because it contains no fields.",
4870 XMLNode feature_node, GdbServerTargetInfo &target_info,
4871 std::vector<DynamicRegisterInfo::Register> ®isters,
4872 llvm::StringMap<std::unique_ptr<RegisterFlags>> ®isters_flags_types,
4873 llvm::StringMap<std::unique_ptr<FieldEnum>> ®isters_enum_types) {
4877 Log *log(
GetLog(GDBRLog::Process));
4880 ParseEnums(feature_node, registers_enum_types);
4881 for (
const auto &enum_type : registers_enum_types)
4884 ParseFlags(feature_node, registers_flags_types, registers_enum_types);
4885 for (
const auto &flags : registers_flags_types)
4886 flags.second->DumpToLog(log);
4890 [&target_info, ®isters, ®isters_flags_types,
4891 log](
const XMLNode ®_node) ->
bool {
4892 std::string gdb_group;
4893 std::string gdb_type;
4894 DynamicRegisterInfo::Register reg_info;
4895 bool encoding_set =
false;
4896 bool format_set =
false;
4900 &encoding_set, &format_set, ®_info,
4901 log](
const llvm::StringRef &name,
4902 const llvm::StringRef &value) ->
bool {
4903 if (name ==
"name") {
4905 }
else if (name ==
"bitsize") {
4906 if (llvm::to_integer(value, reg_info.
byte_size))
4908 llvm::divideCeil(reg_info.
byte_size, CHAR_BIT);
4909 }
else if (name ==
"type") {
4910 gdb_type = value.str();
4911 }
else if (name ==
"group") {
4912 gdb_group = value.str();
4913 }
else if (name ==
"regnum") {
4915 }
else if (name ==
"offset") {
4917 }
else if (name ==
"altname") {
4919 }
else if (name ==
"encoding") {
4920 encoding_set =
true;
4922 }
else if (name ==
"format") {
4928 llvm::StringSwitch<lldb::Format>(value)
4939 }
else if (name ==
"group_id") {
4941 llvm::to_integer(value, set_id);
4942 RegisterSetMap::const_iterator pos =
4943 target_info.reg_set_map.find(set_id);
4944 if (pos != target_info.reg_set_map.end())
4945 reg_info.
set_name = pos->second.name;
4946 }
else if (name ==
"gcc_regnum" || name ==
"ehframe_regnum") {
4948 }
else if (name ==
"dwarf_regnum") {
4950 }
else if (name ==
"generic") {
4952 }
else if (name ==
"value_regnums") {
4955 }
else if (name ==
"invalidate_regnums") {
4960 "ProcessGDBRemote::ParseRegisters unhandled reg "
4961 "attribute %s = %s",
4962 name.data(), value.data());
4967 if (!gdb_type.empty()) {
4969 llvm::StringMap<std::unique_ptr<RegisterFlags>>::iterator it =
4970 registers_flags_types.find(gdb_type);
4971 if (it != registers_flags_types.end()) {
4972 auto flags_type = it->second.get();
4973 if (reg_info.
byte_size == flags_type->GetSize())
4978 "ProcessGDBRemote::ParseRegisters Size of register flags {0} "
4979 "({1} bytes) for register {2} does not match the register "
4980 "size ({3} bytes). Ignoring this set of flags.",
4981 flags_type->GetID().c_str(), flags_type->GetSize(),
4988 if (!gdb_type.empty() && !(encoding_set || format_set)) {
4989 if (llvm::StringRef(gdb_type).starts_with(
"int")) {
4992 }
else if (gdb_type ==
"data_ptr" || gdb_type ==
"code_ptr") {
4995 }
else if (gdb_type ==
"float" || gdb_type ==
"ieee_single" ||
4996 gdb_type ==
"ieee_double") {
4999 }
else if (gdb_type ==
"aarch64v" ||
5000 llvm::StringRef(gdb_type).starts_with(
"vec") ||
5001 gdb_type ==
"i387_ext" || gdb_type ==
"uint128" ||
5014 "ProcessGDBRemote::ParseRegisters Could not determine lldb"
5015 "format and encoding for gdb type %s",
5025 if (!gdb_group.empty()) {
5036 "ProcessGDBRemote::{0} Skipping zero bitsize register {1}",
5037 __FUNCTION__, reg_info.
name);
5039 registers.push_back(reg_info);
5054 ArchSpec &arch_to_use, std::string xml_filename,
5055 std::vector<DynamicRegisterInfo::Register> ®isters) {
5057 llvm::Expected<std::string> raw =
m_gdb_comm.ReadExtFeature(
"features", xml_filename);
5058 if (errorToBool(raw.takeError()))
5063 if (xml_document.
ParseMemory(raw->c_str(), raw->size(),
5064 xml_filename.c_str())) {
5065 GdbServerTargetInfo target_info;
5066 std::vector<XMLNode> feature_nodes;
5072 const XMLNode &node) ->
bool {
5073 llvm::StringRef name = node.
GetName();
5074 if (name ==
"architecture") {
5076 }
else if (name ==
"osabi") {
5078 }
else if (name ==
"xi:include" || name ==
"include") {
5081 target_info.includes.push_back(href);
5082 }
else if (name ==
"feature") {
5083 feature_nodes.push_back(node);
5084 }
else if (name ==
"groups") {
5086 "group", [&target_info](
const XMLNode &node) ->
bool {
5088 RegisterSetInfo set_info;
5091 [&set_id, &set_info](
const llvm::StringRef &name,
5092 const llvm::StringRef &value) ->
bool {
5095 llvm::to_integer(value, set_id);
5102 target_info.reg_set_map[set_id] = set_info;
5115 feature_nodes.push_back(feature_node);
5117 const XMLNode &node) ->
bool {
5118 llvm::StringRef name = node.
GetName();
5119 if (name ==
"xi:include" || name ==
"include") {
5122 target_info.includes.push_back(href);
5136 if (!arch_to_use.
IsValid() && !target_info.arch.empty()) {
5138 arch_to_use.
SetTriple(llvm::StringSwitch<std::string>(target_info.arch)
5139 .Case(
"i386:x86-64",
"x86_64")
5140 .Case(
"riscv:rv64",
"riscv64")
5141 .Case(
"riscv:rv32",
"riscv32")
5142 .Default(target_info.arch) +
5150 for (
auto &feature_node : feature_nodes) {
5151 ParseRegisters(feature_node, target_info, registers,
5155 for (
const auto &include : target_info.includes) {
5167 std::vector<DynamicRegisterInfo::Register> ®isters,
5169 std::map<uint32_t, uint32_t> remote_to_local_map;
5170 uint32_t remote_regnum = 0;
5171 for (
auto it : llvm::enumerate(registers)) {
5179 remote_to_local_map[remote_reg_info.
regnum_remote] = it.index();
5185 auto proc_to_lldb = [&remote_to_local_map](uint32_t process_regnum) {
5186 auto lldb_regit = remote_to_local_map.find(process_regnum);
5187 return lldb_regit != remote_to_local_map.end() ? lldb_regit->second
5191 llvm::transform(remote_reg_info.value_regs,
5192 remote_reg_info.value_regs.begin(), proc_to_lldb);
5193 llvm::transform(remote_reg_info.invalidate_regs,
5194 remote_reg_info.invalidate_regs.begin(), proc_to_lldb);
5201 abi_sp->AugmentRegisterInfo(registers);
5211 if (!
m_gdb_comm.GetQXferFeaturesReadSupported())
5212 return llvm::createStringError(
5213 llvm::inconvertibleErrorCode(),
5214 "the debug server does not support \"qXfer:features:read\"");
5217 return llvm::createStringError(
5218 llvm::inconvertibleErrorCode(),
5219 "the debug server supports \"qXfer:features:read\", but LLDB does not "
5220 "have XML parsing enabled (check LLLDB_ENABLE_LIBXML2)");
5230 std::vector<DynamicRegisterInfo::Register> registers;
5238 ? llvm::ErrorSuccess()
5239 : llvm::createStringError(
5240 llvm::inconvertibleErrorCode(),
5241 "the debug server did not describe any registers");
5247 return llvm::createStringError(llvm::inconvertibleErrorCode(),
5248 "XML parsing not available");
5251 LLDB_LOGF(log,
"ProcessGDBRemote::%s", __FUNCTION__);
5260 llvm::Expected<std::string> raw = comm.
ReadExtFeature(
"libraries-svr4",
"");
5262 return raw.takeError();
5265 LLDB_LOGF(log,
"parsing: %s", raw->c_str());
5268 if (!doc.
ParseMemory(raw->c_str(), raw->size(),
"noname.xml"))
5269 return llvm::createStringError(llvm::inconvertibleErrorCode(),
5270 "Error reading noname.xml");
5274 return llvm::createStringError(
5275 llvm::inconvertibleErrorCode(),
5276 "Error finding library-list-svr4 xml element");
5281 if (!main_lm.empty())
5285 "library", [log, &list](
const XMLNode &library) ->
bool {
5290 [&module](
const llvm::StringRef &name,
5291 const llvm::StringRef &value) ->
bool {
5294 module.set_name(value.str());
5295 else if (name ==
"lm") {
5297 llvm::to_integer(value, uint_value);
5298 module.set_link_map(uint_value);
5299 }
else if (name ==
"l_addr") {
5302 llvm::to_integer(value, uint_value);
5303 module.set_base(uint_value);
5306 module.set_base_is_offset(true);
5307 }
else if (name ==
"l_ld") {
5309 llvm::to_integer(value, uint_value);
5310 module.set_dynamic(uint_value);
5319 bool base_is_offset;
5321 module.get_name(name);
5322 module.get_link_map(lm);
5323 module.get_base(base);
5324 module.get_base_is_offset(base_is_offset);
5325 module.get_dynamic(ld);
5328 "found (link_map:0x%08" PRIx64
", base:0x%08" PRIx64
5329 "[%s], ld:0x%08" PRIx64
", name:'%s')",
5330 lm, base, (base_is_offset ?
"offset" :
"absolute"), ld,
5339 LLDB_LOGF(log,
"found %" PRId32
" modules in total",
5340 (
int)list.
m_list.size());
5344 llvm::Expected<std::string> raw = comm.
ReadExtFeature(
"libraries",
"");
5347 return raw.takeError();
5349 LLDB_LOGF(log,
"parsing: %s", raw->c_str());
5352 if (!doc.
ParseMemory(raw->c_str(), raw->size(),
"noname.xml"))
5353 return llvm::createStringError(llvm::inconvertibleErrorCode(),
5354 "Error reading noname.xml");
5358 return llvm::createStringError(llvm::inconvertibleErrorCode(),
5359 "Error finding library-list xml element");
5363 "library", [log, &list](
const XMLNode &library) ->
bool {
5367 module.set_name(name);
5376 llvm::to_integer(address, address_value);
5377 module.set_base(address_value);
5379 module.set_base_is_offset(false);
5384 bool base_is_offset;
5385 module.get_name(name);
5386 module.get_base(base);
5387 module.get_base_is_offset(base_is_offset);
5389 LLDB_LOGF(log,
"found (base:0x%08" PRIx64
"[%s], name:'%s')", base,
5390 (base_is_offset ?
"offset" :
"absolute"), name.c_str());
5398 LLDB_LOGF(log,
"found %" PRId32
" modules in total",
5399 (
int)list.
m_list.size());
5402 return llvm::createStringError(llvm::inconvertibleErrorCode(),
5403 "Remote libraries not supported");
5410 bool value_is_offset) {
5425 return module_list.takeError();
5431 std::string mod_name;
5434 bool mod_base_is_offset;
5437 valid &= modInfo.
get_name(mod_name);
5438 valid &= modInfo.
get_base(mod_base);
5451 if (module_sp.get())
5452 new_modules.
Append(module_sp);
5455 if (new_modules.
GetSize() > 0) {
5460 for (
size_t i = 0; i < loaded_modules.
GetSize(); ++i) {
5464 for (
size_t j = 0; j < new_modules.
GetSize(); ++j) {
5473 removed_modules.
Append(loaded_module);
5477 loaded_modules.
Remove(removed_modules);
5478 m_process->GetTarget().ModulesDidUnload(removed_modules,
false);
5494 m_process->GetTarget().ModulesDidLoad(new_modules);
5497 return llvm::ErrorSuccess();
5506 std::string file_path = file.
GetPath(
false);
5507 if (file_path.empty())
5528 "Fetching file load address from remote server returned an error");
5538 "Unknown error happened during sending the load address packet");
5559 std::string input = data.str();
5566 size_t found, pos = 0, len = input.length();
5567 while ((found = input.find(
end_delimiter, pos)) != std::string::npos) {
5569 input.substr(pos, found).c_str());
5570 std::string profile_data =
5585 std::map<uint64_t, uint32_t> new_thread_id_to_used_usec_map;
5587 llvm::raw_string_ostream output_stream(output);
5588 llvm::StringRef name, value;
5592 if (name.compare(
"thread_used_id") == 0) {
5594 uint64_t thread_id = threadIDHexExtractor.
GetHexMaxU64(
false, 0);
5596 bool has_used_usec =
false;
5597 uint32_t curr_used_usec = 0;
5598 llvm::StringRef usec_name, usec_value;
5599 uint32_t input_file_pos = profileDataExtractor.
GetFilePos();
5601 if (usec_name ==
"thread_used_usec") {
5602 has_used_usec =
true;
5603 usec_value.getAsInteger(0, curr_used_usec);
5607 profileDataExtractor.
SetFilePos(input_file_pos);
5611 if (has_used_usec) {
5612 uint32_t prev_used_usec = 0;
5613 std::map<uint64_t, uint32_t>::iterator iterator =
5616 prev_used_usec = iterator->second;
5618 uint32_t real_used_usec = curr_used_usec - prev_used_usec;
5620 bool good_first_time =
5621 (prev_used_usec == 0) && (real_used_usec > 250000);
5622 bool good_subsequent_time =
5623 (prev_used_usec > 0) &&
5626 if (good_first_time || good_subsequent_time) {
5630 output_stream << name <<
":";
5632 output_stream << index_id <<
";";
5634 output_stream << usec_name <<
":" << usec_value <<
";";
5637 llvm::StringRef local_name, local_value;
5643 new_thread_id_to_used_usec_map[thread_id] = curr_used_usec;
5646 output_stream << name <<
":" << value <<
";";
5649 output_stream << name <<
":" << value <<
";";
5684 return llvm::createStringError(llvm::inconvertibleErrorCode(),
5685 "qSaveCore returned an error");
5690 for (
auto x : llvm::split(response.
GetStringRef(),
';')) {
5691 if (x.consume_front(
"core-path:"))
5697 return llvm::createStringError(llvm::inconvertibleErrorCode(),
5698 "qSaveCore returned no core path");
5701 FileSpec remote_core{llvm::StringRef(path)};
5707 platform.
Unlink(remote_core);
5709 return error.ToError();
5715 return llvm::createStringError(llvm::inconvertibleErrorCode(),
5716 "Unable to send qSaveCore");
5728 "GDBRemoteCommunicationClientBase::%s() received $J packet "
5729 "but was not a StructuredData packet: packet starts with "
5741 json_sp->Dump(json_str,
true);
5744 "ProcessGDBRemote::%s() "
5745 "received Async StructuredData packet: %s",
5746 __FUNCTION__, json_str.
GetData());
5749 "ProcessGDBRemote::%s"
5750 "() received StructuredData packet:"
5760 if (structured_data_sp)
5768 "Tests packet speeds of various sizes to determine "
5769 "the performance characteristics of the GDB remote "
5774 "The number of packets to send of each varying size "
5775 "(default is 1000).",
5778 "The maximum number of bytes to send in a packet. Sizes "
5779 "increase in powers of 2 while the size is less than or "
5780 "equal to this option value. (default 1024).",
5783 "The maximum number of bytes to receive in a packet. Sizes "
5784 "increase in powers of 2 while the size is less than or "
5785 "equal to this option value. (default 1024).",
5788 "Print the output as JSON data for easy parsing.", false, true) {
5808 if (!output_stream_sp)
5809 output_stream_sp =
m_interpreter.GetDebugger().GetAsyncOutputStream();
5812 const uint32_t num_packets =
5814 const uint64_t max_send =
m_max_send.GetOptionValue().GetCurrentValue();
5815 const uint64_t max_recv =
m_max_recv.GetOptionValue().GetCurrentValue();
5816 const bool json =
m_json.GetOptionValue().GetCurrentValue();
5817 const uint64_t k_recv_amount =
5820 num_packets, max_send, max_recv, k_recv_amount, json,
5845 "Dumps the packet history buffer. ", nullptr) {}
5866 interpreter,
"process plugin packet xfer-size",
5867 "Maximum size that lldb will try to read/write one one chunk.",
5878 "amount to be transferred when "
5889 uint64_t user_specified_max = strtoul(packet_size,
nullptr, 10);
5890 if (errno == 0 && user_specified_max != 0) {
5905 "Send a custom packet through the GDB remote "
5906 "protocol and print the answer. "
5907 "The packet header and footer will automatically "
5908 "be added to the packet prior to sending and "
5909 "stripped from the result.",
5920 "'%s' takes a one or more packet content arguments",
5928 for (
size_t i = 0; i < argc; ++i) {
5935 output_strm.
Printf(
" packet: %s\n", packet_cstr);
5936 std::string response_str = std::string(response.
GetStringRef());
5938 if (strstr(packet_cstr,
"qGetProfileData") !=
nullptr) {
5942 if (response_str.empty())
5943 output_strm.
PutCString(
"response: \nerror: UNIMPLEMENTED\n");
5956 "Send a qRcmd packet through the GDB remote protocol "
5957 "and print the response. "
5958 "The argument passed to this command will be hex "
5959 "encoded into a valid 'qRcmd' packet, sent and the "
5960 "response will be printed.") {}
5966 if (command.empty()) {
5983 [&output_strm](llvm::StringRef output) { output_strm << output; });
5986 const std::string &response_str = std::string(response.
GetStringRef());
5988 if (response_str.empty())
5989 output_strm.
PutCString(
"response: \nerror: UNIMPLEMENTED\n");
6001 "Commands that deal with GDB remote packets.",
6030 interpreter,
"process plugin",
6031 "Commands for operating on a ProcessGDBRemote process.",
6032 "process plugin <subcommand> [<subcommand-options>]") {
6043 m_command_sp = std::make_shared<CommandObjectMultiwordProcessGDBRemote>(
6044 GetTarget().GetDebugger().GetCommandInterpreter());
6073 addr_t addr = wp_res_sp->GetLoadAddress();
6074 size_t size = wp_res_sp->GetByteSize();
6076 m_gdb_comm.SendGDBStoppointTypePacket(type, enable, addr, size,
6094 follow_pid = parent_pid;
6095 follow_tid = parent_tid;
6096 detach_pid = child_pid;
6097 detach_tid = child_tid;
6100 follow_pid = child_pid;
6101 follow_tid = child_tid;
6102 detach_pid = parent_pid;
6103 detach_tid = parent_tid;
6108 if (!
m_gdb_comm.SetCurrentThread(detach_tid, detach_pid)) {
6109 LLDB_LOG(log,
"ProcessGDBRemote::DidFork() unable to set pid/tid");
6123 if (!
m_gdb_comm.SetCurrentThread(follow_tid, follow_pid) ||
6124 !
m_gdb_comm.SetCurrentThreadForRun(follow_tid, follow_pid)) {
6125 LLDB_LOG(log,
"ProcessGDBRemote::DidFork() unable to reset pid/tid");
6129 LLDB_LOG(log,
"Detaching process {0}", detach_pid);
6132 LLDB_LOG(log,
"ProcessGDBRemote::DidFork() detach packet send failed: {0}",
6133 error.AsCString() ?
error.AsCString() :
"<unknown error>");
6151 "ProcessGDBRemote::DidFork() called for child_pid: {0}, child_tid {1}",
6152 child_pid, child_tid);
6164 detach_pid = child_pid;
6165 detach_tid = child_tid;
6168 detach_pid =
m_gdb_comm.GetCurrentProcessID();
6174 if (!
m_gdb_comm.SetCurrentThread(detach_tid, detach_pid)) {
6175 LLDB_LOG(log,
"ProcessGDBRemote::DidFork() unable to set pid/tid");
6183 if (!
m_gdb_comm.SetCurrentThread(child_tid, child_pid) ||
6184 !
m_gdb_comm.SetCurrentThreadForRun(child_tid, child_pid)) {
6185 LLDB_LOG(log,
"ProcessGDBRemote::DidFork() unable to reset pid/tid");
6191 LLDB_LOG(log,
"Detaching process {0}", detach_pid);
6195 "ProcessGDBRemote::DidFork() detach packet send failed: {0}",
6196 error.AsCString() ?
error.AsCString() :
"<unknown error>");
static llvm::raw_ostream & error(Stream &strm)
static PluginProperties & GetGlobalPluginProperties()
#define LLDB_LOG(log,...)
The LLDB_LOG* macros defined below are the way to emit log messages.
#define LLDB_LOGF_VERBOSE(log,...)
#define LLDB_LOGF(log,...)
#define LLDB_LOG_ERROR(log, error,...)
#define LLDB_LOG_VERBOSE(log,...)
#define LLDB_PLUGIN_DEFINE(PluginName)
static PluginProperties & GetGlobalPluginProperties()
static const char *const s_async_json_packet_prefix
#define DEBUGSERVER_BASENAME
static size_t SplitCommaSeparatedRegisterNumberString(const llvm::StringRef &comma_separated_register_numbers, std::vector< uint32_t > ®nums, int base)
static const char * end_delimiter
static llvm::Error DoDisableBreakpointSite(ProcessGDBRemote &proc, BreakpointSite &bp_site)
Disable a single breakpoint site directly by sending the appropriate z packet or restoring the origin...
static GDBStoppointType GetGDBStoppointType(const WatchpointResourceSP &wp_res_sp)
static StructuredData::ObjectSP ParseStructuredDataPacket(llvm::StringRef packet)
static std::string BinaryInformationLevelToJSONKey(BinaryInformationLevel info_level)
static uint64_t ComputeNumRangesMultiMemRead(uint64_t max_packet_size, llvm::ArrayRef< Range< lldb::addr_t, size_t > > ranges)
Returns the number of ranges that is safe to request using MultiMemRead while respecting max_packet_s...
static llvm::Error DoEnableBreakpointSite(ProcessGDBRemote &proc, BreakpointSite &bp_site)
Enable a single breakpoint site by trying Z0 (software), then Z1 (hardware), then manual memory write...
static FileSpec GetDebugserverPath(Platform &platform)
static const int end_delimiter_len
CommandObjectMultiwordProcessGDBRemote(CommandInterpreter &interpreter)
~CommandObjectMultiwordProcessGDBRemote() override=default
void DoExecute(Args &command, CommandReturnObject &result) override
~CommandObjectProcessGDBRemotePacketHistory() override=default
CommandObjectProcessGDBRemotePacketHistory(CommandInterpreter &interpreter)
~CommandObjectProcessGDBRemotePacketMonitor() override=default
void DoExecute(llvm::StringRef command, CommandReturnObject &result) override
CommandObjectProcessGDBRemotePacketMonitor(CommandInterpreter &interpreter)
CommandObjectProcessGDBRemotePacketSend(CommandInterpreter &interpreter)
~CommandObjectProcessGDBRemotePacketSend() override=default
void DoExecute(Args &command, CommandReturnObject &result) override
~CommandObjectProcessGDBRemotePacketXferSize() override=default
void DoExecute(Args &command, CommandReturnObject &result) override
CommandObjectProcessGDBRemotePacketXferSize(CommandInterpreter &interpreter)
~CommandObjectProcessGDBRemotePacket() override=default
CommandObjectProcessGDBRemotePacket(CommandInterpreter &interpreter)
Options * GetOptions() override
OptionGroupBoolean m_json
void DoExecute(Args &command, CommandReturnObject &result) override
~CommandObjectProcessGDBRemoteSpeedTest() override=default
OptionGroupOptions m_option_group
OptionGroupUInt64 m_max_send
OptionGroupUInt64 m_num_packets
CommandObjectProcessGDBRemoteSpeedTest(CommandInterpreter &interpreter)
OptionGroupUInt64 m_max_recv
static lldb::ABISP FindPlugin(lldb::ProcessSP process_sp, const ArchSpec &arch)
A class which holds the metadata from a remote stub/corefile note about how many bits are used for ad...
void SetHighmemAddressableBits(uint32_t highmem_addressing_bits)
void SetAddressableBits(uint32_t addressing_bits)
When a single value is available for the number of bits.
void SetLowmemAddressableBits(uint32_t lowmem_addressing_bits)
An architecture specification class.
bool IsValid() const
Tests if this ArchSpec is valid.
void Clear()
Clears the object state.
llvm::Triple & GetTriple()
Architecture triple accessor.
bool SetTriple(const llvm::Triple &triple)
Architecture triple setter.
bool IsCompatibleMatch(const ArchSpec &rhs) const
Shorthand for IsMatch(rhs, CompatibleMatch).
llvm::Triple::ArchType GetMachine() const
Returns a machine family for the current architecture.
const char * GetArchitectureName() const
Returns a static string representing the current architecture.
A command line argument class.
static lldb::Encoding StringToEncoding(llvm::StringRef s, lldb::Encoding fail_value=lldb::eEncodingInvalid)
static uint32_t StringToGenericRegister(llvm::StringRef s)
size_t GetArgumentCount() const
Gets the number of arguments left in this command object.
void ReplaceArgumentAtIndex(size_t idx, llvm::StringRef arg_str, char quote_char='\0')
Replaces the argument value at index idx to arg_str if idx is a valid argument index.
const char * GetArgumentAtIndex(size_t idx) const
Gets the NULL terminated C string argument pointer for the argument at index idx.
Class that manages the actual breakpoint that will be inserted into the running program.
BreakpointSite::Type GetType() const
void SetType(BreakpointSite::Type type)
bool IsEnabled() const
Tells whether the current breakpoint site is enabled or not.
void SetEnabled(bool enabled)
Sets whether the current breakpoint site is enabled or not.
bool LoadSubCommand(llvm::StringRef cmd_name, const lldb::CommandObjectSP &command_obj) override
CommandObjectMultiword(CommandInterpreter &interpreter, const char *name, const char *help=nullptr, const char *syntax=nullptr, uint32_t flags=0)
friend class CommandInterpreter
CommandObjectParsed(CommandInterpreter &interpreter, const char *name, const char *help=nullptr, const char *syntax=nullptr, uint32_t flags=0)
CommandObjectRaw(CommandInterpreter &interpreter, llvm::StringRef name, llvm::StringRef help="", llvm::StringRef syntax="", uint32_t flags=0)
void AddSimpleArgumentList(lldb::CommandArgumentType arg_type, ArgumentRepetitionType repetition_type=eArgRepeatPlain)
CommandInterpreter & m_interpreter
void SetStatus(lldb::ReturnStatus status)
void SetImmediateOutputStream(const lldb::StreamSP &stream_sp)
void AppendErrorWithFormat(const char *format,...) __attribute__((format(printf
lldb::StreamSP GetImmediateOutputStream() const
Stream & GetOutputStream()
A uniqued constant string class.
void SetCString(const char *cstr)
Set the C string value.
void SetString(llvm::StringRef s)
A subclass of DataBuffer that stores a data buffer on the heap.
static void ReportWarning(std::string message, std::optional< lldb::user_id_t > debugger_id=std::nullopt, std::once_flag *once=nullptr)
Report warning events.
static void ReportError(std::string message, std::optional< lldb::user_id_t > debugger_id=std::nullopt, std::once_flag *once=nullptr)
Report error events.
ScriptInterpreter * GetScriptInterpreter(bool can_create=true, std::optional< lldb::ScriptLanguage > language={})
static lldb::ModuleSP LoadBinaryWithUUIDAndAddress(Process *process, llvm::StringRef name, UUID uuid, lldb::addr_t value, bool value_is_offset, bool force_symbol_search, bool notify, bool set_address_in_target, bool allow_memory_image_last_resort)
Find/load a binary into lldb given a UUID and the address where it is loaded in memory,...
virtual lldb::ModuleSP LoadModuleAtAddress(const lldb_private::FileSpec &file, lldb::addr_t link_map_addr, lldb::addr_t base_addr, bool base_addr_is_offset)
Locates or creates a module given by file and updates/loads the resulting module at the virtual base ...
static DynamicLoader * FindPlugin(Process *process, llvm::StringRef plugin_name)
Find a dynamic loader plugin for a given process.
const void * GetBytes() const
static const EventDataBytes * GetEventDataFromEvent(const Event *event_ptr)
size_t GetByteSize() const
std::vector< Enumerator > Enumerators
const Enumerators & GetEnumerators() const
void DumpToLog(Log *log) const
Represents a file descriptor action to be performed during process launch.
Action GetAction() const
Get the type of action.
const FileSpec & GetFileSpec() const
Get the file specification for open actions.
void SetFile(llvm::StringRef path, Style style)
Change the file specified with a new path.
void AppendPathComponent(llvm::StringRef component)
size_t GetPath(char *path, size_t max_path_length, bool denormalize=true) const
Extract the full path to the file.
void Clear()
Clears the object state.
static const char * DEV_NULL
bool Exists(const FileSpec &file_spec) const
Returns whether the given file exists.
int Open(const char *path, int flags, int mode=0600)
Wraps open in a platform-independent way.
static FileSystem & Instance()
void Resolve(llvm::SmallVectorImpl< char > &path, bool force_make_absolute=false)
Resolve path to make it canonical.
ValueType Get() const
Get accessor for all flags.
static Environment GetEnvironment()
static void Kill(lldb::pid_t pid, int signo)
static lldb::ListenerSP MakeListener(const char *name)
bool get_name(std::string &out) const
bool get_link_map(lldb::addr_t &out) const
bool get_base_is_offset(bool &out) const
bool get_base(lldb::addr_t &out) const
void add(const LoadedModuleInfo &mod)
std::vector< LoadedModuleInfo > m_list
void PutCString(const char *cstr)
LazyBool GetFlash() const
lldb::offset_t GetBlocksize() const
lldb::SymbolSharedCacheUse GetSharedCacheBinaryLoading() const
A collection class for Module objects.
bool AppendIfNeeded(const lldb::ModuleSP &new_module, bool notify=true)
Append a module to the module list, if it is not already there.
static ModuleListProperties & GetGlobalModuleListProperties()
bool Remove(const lldb::ModuleSP &module_sp, bool notify=true)
Remove a module from the module list.
lldb::ModuleSP GetModuleAtIndex(size_t idx) const
Get the module shared pointer for the module at index idx.
void Append(const lldb::ModuleSP &module_sp, bool notify=true)
Append a module to the module list.
size_t GetSize() const
Gets the size of the module list.
void ForEach(std::function< IterationAction(const lldb::ModuleSP &module_sp)> const &callback) const
Applies 'callback' to each module in this ModuleList.
void Dump(Stream &strm) const
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.
@ 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.
@ eTypeJIT
JIT code that has symbols, sections and possibly debug info.
A command line option parsing protocol class.
static bool RegisterPlugin(llvm::StringRef name, llvm::StringRef description, ABICreateInstance create_callback)
static bool CreateSettingForProcessPlugin(Debugger &debugger, const lldb::OptionValuePropertiesSP &properties_sp, llvm::StringRef description, bool is_global_property)
static lldb::OptionValuePropertiesSP GetSettingForProcessPlugin(Debugger &debugger, llvm::StringRef setting_name)
static bool UnregisterPlugin(ABICreateInstance create_callback)
bool GetIgnoreExisting() const
bool GetDetachOnError() const
bool GetWaitForLaunch() const
void SetExecutableFile(const FileSpec &exe_file, bool add_exe_file_as_first_arg)
lldb::pid_t GetProcessID() const
FileSpec & GetExecutableFile()
uint32_t GetUserID() const
Environment & GetEnvironment()
void SetUserID(uint32_t uid)
const char * GetLaunchEventData() const
const FileAction * GetFileActionForFD(int fd) const
void SetMonitorProcessCallback(Host::MonitorChildProcessCallback callback)
void SetLaunchInSeparateProcessGroup(bool separate)
const FileSpec & GetWorkingDirectory() const
Args GetExtraStartupCommands() const
FollowForkMode GetFollowForkMode() const
std::chrono::seconds GetInterruptTimeout() const
A plug-in interface definition class for debugging a process.
StopPointSiteList< lldb_private::BreakpointSite > & GetBreakpointSiteList()
virtual Status DisableSoftwareBreakpoint(BreakpointSite *bp_site)
lldb::pid_t GetID() const
Returns the pid of the process or LLDB_INVALID_PROCESS_ID if there is no known pid.
ThreadList & GetThreadList()
void SetAddressableBitMasks(AddressableBits bit_masks)
Process(lldb::TargetSP target_sp, lldb::ListenerSP listener_sp)
Construct with a shared pointer to a target, and the Process listener.
void SetUnixSignals(lldb::UnixSignalsSP &&signals_sp)
virtual void ModulesDidLoad(ModuleList &module_list)
void ResumePrivateStateThread()
void MapSupportedStructuredDataPlugins(const StructuredData::Array &supported_type_names)
Loads any plugins associated with asynchronous structured data and maps the relevant supported type n...
virtual SystemRuntime * GetSystemRuntime()
Get the system runtime plug-in for this process.
std::map< uint64_t, uint32_t > m_thread_id_to_index_id_map
lldb::StateType GetPrivateState() const
lldb::DynamicLoaderUP m_dyld_up
virtual Status WriteObjectFile(std::vector< ObjectFile::LoadableData > entries)
StopPointSiteList< lldb_private::WatchpointResource > m_watchpoint_resource_list
Watchpoint resources currently in use.
void AppendSTDOUT(const char *s, size_t len)
bool HasAssignedIndexIDToThread(uint64_t sb_thread_id)
lldb::ByteOrder GetByteOrder() const
void UpdateThreadListIfNeeded()
bool IsValid() const
Return whether this object is valid (i.e.
virtual void DidExec()
Called after a process re-execs itself.
void BroadcastAsyncProfileData(const std::string &one_profile_data)
lldb::UnixSignalsSP m_unix_signals_sp
lldb::tid_t m_interrupt_tid
virtual Status EnableSoftwareBreakpoint(BreakpointSite *bp_site)
bool RouteAsyncStructuredData(const StructuredData::ObjectSP object_sp)
Route the incoming structured data dictionary to the right plugin.
virtual bool IsAlive()
Check if a process is still alive.
ThreadList m_thread_list_real
The threads for this process as are known to the protocol we are debugging with.
void SetID(lldb::pid_t new_pid)
Sets the stored pid.
uint32_t AssignIndexIDToThread(uint64_t thread_id)
virtual bool SetExitStatus(int exit_status, llvm::StringRef exit_string)
Set accessor for the process exit status (return code).
MemoryCache m_memory_cache
uint32_t GetAddressByteSize() const
uint32_t GetStopID() const
void SetPrivateState(lldb::StateType state)
lldb::StateType GetPublicState() const
void SetSTDIOFileDescriptor(int file_descriptor)
Associates a file descriptor with the process' STDIO handling and configures an asynchronous reading ...
virtual void Finalize(bool destructing)
This object is about to be destroyed, do any necessary cleanup.
ThreadList m_thread_list
The threads for this process as the user will see them.
const lldb::UnixSignalsSP & GetUnixSignals()
std::weak_ptr< Target > m_target_wp
The target that owns this process.
virtual llvm::SmallVector< llvm::MutableArrayRef< uint8_t > > ReadMemoryRanges(llvm::ArrayRef< Range< lldb::addr_t, size_t > > ranges, llvm::MutableArrayRef< uint8_t > buffer)
Read from multiple memory ranges and write the results into buffer.
Status GetMemoryRegionInfo(lldb::addr_t load_addr, MemoryRegionInfo &range_info)
Locate the memory region that contains load_addr.
friend class DynamicLoader
size_t GetSoftwareBreakpointTrapOpcode(BreakpointSite *bp_site)
ThreadedCommunication m_stdio_communication
Target & GetTarget()
Get the target object pointer for this module.
lldb::OptionValuePropertiesSP GetValueProperties() const
A pseudo terminal helper class.
llvm::Error OpenFirstAvailablePrimary(int oflag)
Open the first available pseudo terminal.
@ invalid_fd
Invalid file descriptor value.
int GetPrimaryFileDescriptor() const
The primary file descriptor accessor.
int ReleasePrimaryFileDescriptor()
Release the primary file descriptor.
std::string GetSecondaryName() const
Get the name of the secondary pseudo terminal.
uint64_t GetMaxValue() const
The maximum unsigned value that could be contained in this field.
unsigned GetSizeInBits() const
Get size of the field in bits. Will always be at least 1.
virtual StructuredData::DictionarySP GetDynamicSettings(StructuredData::ObjectSP plugin_module_sp, Target *target, const char *setting_name, lldb_private::Status &error)
virtual StructuredData::ObjectSP LoadPluginModule(const FileSpec &file_spec, lldb_private::Status &error)
Status CompleteSending(lldb::pid_t child_pid)
shared_fd_t GetSendableFD()
static llvm::Expected< Pair > CreatePair(std::optional< SocketProtocol > protocol=std::nullopt)
static Status FromErrorStringWithFormat(const char *format,...) __attribute__((format(printf
static Status FromErrorString(const char *str)
bool Fail() const
Test for error condition.
const char * AsCString(const char *default_error_str="unknown error") const
Get the error string associated with the current error.
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.
static lldb::StopInfoSP CreateStopReasonWithMachException(Thread &thread, uint32_t exc_type, uint32_t exc_data_count, uint64_t exc_code, uint64_t exc_sub_code, uint64_t exc_sub_sub_code, bool pc_already_adjusted=true, bool adjust_pc_if_needed=false)
static lldb::StopInfoSP CreateStopReasonToTrace(Thread &thread)
static lldb::StopInfoSP CreateStopReasonVFork(Thread &thread, lldb::pid_t child_pid, lldb::tid_t child_tid)
static lldb::StopInfoSP CreateStopReasonWithInterrupt(Thread &thread, int signo, const char *description)
static lldb::StopInfoSP CreateStopReasonWithSignal(Thread &thread, int signo, const char *description=nullptr, std::optional< int > code=std::nullopt)
static lldb::StopInfoSP CreateStopReasonFork(Thread &thread, lldb::pid_t child_pid, lldb::tid_t child_tid)
static lldb::StopInfoSP CreateStopReasonVForkDone(Thread &thread)
static lldb::StopInfoSP CreateStopReasonWithWatchpointID(Thread &thread, lldb::break_id_t watch_id, bool silently_continue=false)
static lldb::StopInfoSP CreateStopReasonWithException(Thread &thread, const char *description)
static lldb::StopInfoSP CreateStopReasonWithBreakpointSiteID(Thread &thread, lldb::break_id_t break_id)
static lldb::StopInfoSP CreateStopReasonHistoryBoundary(Thread &thread, const char *description)
static lldb::StopInfoSP CreateStopReasonProcessorTrace(Thread &thread, const char *description)
static lldb::StopInfoSP CreateStopReasonWithExec(Thread &thread)
void ForEach(std::function< void(StopPointSite *)> const &callback)
General Outline: When we hit a breakpoint we need to package up whatever information is needed to eva...
lldb::break_id_t GetID() const
virtual lldb::addr_t GetLoadAddress() const
bool HardwareRequired() const
int PutEscapedBytes(const void *s, size_t src_len)
Output a block of data to the stream performing GDB-remote escaping.
const char * GetData() const
void Flush() override
Flush the stream.
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.
size_t PutStringAsRawHex8(llvm::StringRef s)
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.
size_t PutBytesAsRawHex8(const void *src, size_t src_len, lldb::ByteOrder src_byte_order=lldb::eByteOrderInvalid, lldb::ByteOrder dst_byte_order=lldb::eByteOrderInvalid)
ObjectSP GetItemAtIndex(size_t idx) const
bool ForEach(std::function< bool(Object *object)> const &foreach_callback) const
bool GetValueForKeyAsInteger(llvm::StringRef key, IntType &result) const
bool GetValueForKeyAsString(llvm::StringRef key, llvm::StringRef &result) const
ObjectSP GetValueForKey(llvm::StringRef key) const
bool HasKey(llvm::StringRef key) const
void ForEach(std::function< bool(llvm::StringRef key, Object *object)> const &callback) const
Dictionary * GetAsDictionary()
std::shared_ptr< Dictionary > DictionarySP
std::shared_ptr< Object > ObjectSP
static ObjectSP ParseJSON(llvm::StringRef json_text)
std::shared_ptr< Array > ArraySP
A plug-in interface definition class for system runtimes.
virtual void AddThreadExtendedInfoPacketHints(lldb_private::StructuredData::ObjectSP dict)
Add key-value pairs to the StructuredData dictionary object with information debugserver may need whe...
Module * GetExecutableModulePointer()
Debugger & GetDebugger() const
bool SetArchitecture(const ArchSpec &arch_spec, bool set_platform=false, bool merge=true)
Set the architecture for this target.
lldb::ModuleSP GetExecutableModule()
Gets the module for the main executable.
lldb::PlatformSP GetPlatform()
const ArchSpec & GetArchitecture() const
void SetExecutableModule(lldb::ModuleSP &module_sp, LoadDependentFiles load_dependent_files=eLoadDependentsDefault)
Set the main executable module.
bool MergeArchitecture(const ArchSpec &arch_spec)
void AddThreadSortedByIndexID(const lldb::ThreadSP &thread_sp)
static llvm::Expected< HostThread > LaunchThread(llvm::StringRef name, std::function< lldb::thread_result_t()> thread_function, size_t min_stack_byte_size=0)
uint32_t GetSize(bool can_update=true)
lldb::ThreadSP GetThreadAtIndex(uint32_t idx, bool can_update=true)
lldb::ThreadSP RemoveThreadByProtocolID(lldb::tid_t tid, bool can_update=true)
Represents UUID's of various sizes.
bool SetFromStringRef(llvm::StringRef str)
static lldb::UnixSignalsSP Create(const ArchSpec &arch)
static std::vector< lldb::WatchpointResourceSP > AtomizeWatchpointRequest(lldb::addr_t addr, size_t size, bool read, bool write, WatchpointHardwareFeature supported_features, ArchSpec &arch)
Convert a user's watchpoint request into an array of memory regions, each region watched by one hardw...
XMLNode GetRootElement(const char *required_name=nullptr)
bool ParseMemory(const char *xml, size_t xml_length, const char *url="untitled.xml")
void ForEachChildElement(NodeCallback const &callback) const
llvm::StringRef GetName() const
bool GetElementText(std::string &text) const
std::string GetAttributeValue(const char *name, const char *fail_value=nullptr) const
void ForEachChildElementWithName(const char *name, NodeCallback const &callback) const
XMLNode FindFirstChildElementWithName(const char *name) const
void ForEachAttribute(AttributeCallback const &callback) const
@ eBroadcastBitRunPacketSent
PacketResult SendPacketAndReceiveResponseWithOutputSupport(llvm::StringRef payload, StringExtractorGDBRemote &response, std::chrono::seconds interrupt_timeout, llvm::function_ref< void(llvm::StringRef)> output_callback)
PacketResult SendPacketAndWaitForResponse(llvm::StringRef payload, StringExtractorGDBRemote &response, std::chrono::seconds interrupt_timeout=std::chrono::seconds(0), bool sync_on_timeout=true)
lldb::StateType SendContinuePacketAndWaitForResponse(ContinueDelegate &delegate, const UnixSignals &signals, llvm::StringRef payload, std::chrono::seconds interrupt_timeout, StringExtractorGDBRemote &response)
llvm::Expected< std::string > ReadExtFeature(llvm::StringRef object, llvm::StringRef annex)
void TestPacketSpeed(const uint32_t num_packets, uint32_t max_send, uint32_t max_recv, uint64_t recv_amount, bool json, Stream &strm)
bool GetQXferLibrariesSVR4ReadSupported()
bool GetQXferLibrariesReadSupported()
void DumpHistory(Stream &strm)
Status FlashErase(lldb::addr_t addr, size_t size)
Status DisableWatchpoint(lldb::WatchpointSP wp_sp, bool notify=true) override
friend class ThreadGDBRemote
DataExtractor GetAuxvData() override
GDBRemoteCommunicationClient & GetGDBRemote()
Status DoConnectRemote(llvm::StringRef remote_url) override
Attach to a remote system via a URL.
void HandleAsyncStructuredDataPacket(llvm::StringRef data) override
Process asynchronously-received structured data.
void KillDebugserverProcess()
Status DoDestroy() override
Status LaunchAndConnectToDebugserver(const ProcessInfo &process_info)
StructuredData::ObjectSP m_jstopinfo_sp
virtual std::shared_ptr< ThreadGDBRemote > CreateThread(lldb::tid_t tid)
StructuredData::ObjectSP GetLoadedDynamicLibrariesInfos(lldb::addr_t image_list_address, lldb::addr_t image_count) override
Retrieve the list of shared libraries that are loaded for this process This method is used on pre-mac...
StructuredData::ObjectSP m_shared_cache_info_sp
StructuredData::ObjectSP m_jthreadsinfo_sp
lldb::StateType SetThreadStopInfo(StringExtractor &stop_packet)
static void MonitorDebugserverProcess(std::weak_ptr< ProcessGDBRemote > process_wp, lldb::pid_t pid, int signo, int exit_status)
StructuredData::ObjectSP GetSharedCacheInfo() override
Status DisableBreakpointSite(BreakpointSite *bp_site) override
Status EnableWatchpoint(lldb::WatchpointSP wp_sp, bool notify=true) override
Status DoSignal(int signal) override
Sends a process a UNIX signal signal.
Status DoDeallocateMemory(lldb::addr_t ptr) override
Actually deallocate memory in the process.
Broadcaster m_async_broadcaster
bool ParsePythonTargetDefinition(const FileSpec &target_definition_fspec)
bool StopNoticingNewThreads() override
Call this to turn off the stop & notice new threads mode.
static bool NewThreadNotifyBreakpointHit(void *baton, StoppointCallbackContext *context, lldb::user_id_t break_id, lldb::user_id_t break_loc_id)
void DumpPluginHistory(Stream &s) override
The underlying plugin might store the low-level communication history for this session.
FlashRangeVector m_erased_flash_ranges
Status DoDetach(bool keep_stopped) override
Detaches from a running or stopped process.
lldb::addr_t DoAllocateMemory(size_t size, uint32_t permissions, Status &error) override
Actually allocate memory in the process.
tid_sig_collection m_continue_C_tids
bool HasErased(FlashRange range)
std::optional< bool > DoGetWatchpointReportedAfter() override
Provide an override value in the subclass for lldb's CPU-based logic for whether watchpoint exception...
Status WillLaunchOrAttach()
std::optional< uint32_t > GetWatchpointSlotCount() override
Get the number of watchpoints supported by this target.
GDBRemoteCommunicationClient m_gdb_comm
llvm::Expected< std::vector< uint8_t > > DoReadMemoryTags(lldb::addr_t addr, size_t len, int32_t type) override
Does the final operation to read memory tags.
llvm::DenseMap< ModuleCacheKey, ModuleSpec, ModuleCacheInfo > m_cached_module_specs
Status DoWillAttachToProcessWithID(lldb::pid_t pid) override
Called before attaching to a process.
friend class GDBRemoteCommunicationClient
Status DoResume(lldb::RunDirection direction) override
Resumes all of a process's threads as configured using the Thread run control functions.
Status DoGetMemoryRegionInfo(lldb::addr_t load_addr, MemoryRegionInfo ®ion_info) override
DoGetMemoryRegionInfo is called by GetMemoryRegionInfo after it has removed non address bits from loa...
void DidForkSwitchSoftwareBreakpoints(bool enable)
void DidLaunchOrAttach(ArchSpec &process_arch)
size_t UpdateThreadIDsFromStopReplyThreadsValue(llvm::StringRef value)
FlashRangeVector::Entry FlashRange
Status GetFileLoadAddress(const FileSpec &file, bool &is_loaded, lldb::addr_t &load_addr) override
Try to find the load address of a file.
MMapMap m_addr_to_mmap_size
bool GetThreadStopInfoFromJSON(ThreadGDBRemote *thread, const StructuredData::ObjectSP &thread_infos_sp)
void DidLaunch() override
Called after launching a process.
void SetUserSpecifiedMaxMemoryTransferSize(uint64_t user_specified_max)
void AddRemoteRegisters(std::vector< DynamicRegisterInfo::Register > ®isters, const ArchSpec &arch_to_use)
Status UpdateAutomaticSignalFiltering() override
void HandleAsyncStdout(llvm::StringRef out) override
static llvm::StringRef GetPluginDescriptionStatic()
tid_sig_collection m_continue_S_tids
bool m_allow_flash_writes
lldb::BreakpointSP m_thread_create_bp_sp
std::map< uint32_t, std::string > ExpeditedRegisterMap
llvm::Error TraceStop(const TraceStopRequest &request) override
Stop tracing a live process or its threads.
StructuredData::ObjectSP GetExtendedInfoForThread(lldb::tid_t tid)
lldb::ThreadSP HandleThreadAsyncInterrupt(uint8_t signo, const std::string &description) override
Handle thread specific async interrupt and return the original thread that requested the async interr...
llvm::Expected< LoadedModuleInfoList > GetLoadedModuleList() override
Query remote GDBServer for a detailed loaded library list.
bool m_waiting_for_attach
llvm::Error GetGDBServerRegisterInfo(ArchSpec &arch)
Status DoAttachToProcessWithID(lldb::pid_t pid, const ProcessAttachInfo &attach_info) override
Attach to an existing process using a process ID.
void HandleStopReply() override
llvm::StringMap< std::unique_ptr< FieldEnum > > m_registers_enum_types
Status EstablishConnectionIfNeeded(const ProcessInfo &process_info)
llvm::SmallVector< llvm::MutableArrayRef< uint8_t > > ReadMemoryRanges(llvm::ArrayRef< Range< lldb::addr_t, size_t > > ranges, llvm::MutableArrayRef< uint8_t > buf) override
Override of ReadMemoryRanges that uses MultiMemRead to optimize this operation.
bool UpdateThreadIDList()
static llvm::StringRef GetPluginNameStatic()
void DidFork(lldb::pid_t child_pid, lldb::tid_t child_tid) override
Called after a reported fork.
Status DoHalt(bool &caused_stop) override
Halts a running process.
uint64_t m_last_signals_version
llvm::Expected< TraceSupportedResponse > TraceSupported() override
Get the processor tracing type supported for this process.
llvm::Error TraceStart(const llvm::json::Value &request) override
Start tracing a process or its threads.
void ParseExpeditedRegisters(ExpeditedRegisterMap &expedited_register_map, lldb::ThreadSP thread_sp)
void WillPublicStop() override
Called when the process is about to broadcast a public stop.
Status SendEventData(const char *data) override
bool StartNoticingNewThreads() override
Call this to set the lldb in the mode where it breaks on new thread creations, and then auto-restarts...
DynamicLoader * GetDynamicLoader() override
Get the dynamic loader plug-in for this process.
void RemoveNewThreadBreakpoints()
Remove the breakpoints associated with thread creation from the Target.
ArchSpec GetSystemArchitecture() override
Get the system architecture for this process.
Status ConfigureStructuredData(llvm::StringRef type_name, const StructuredData::ObjectSP &config_sp) override
Configure asynchronous structured data feature.
void DidVFork(lldb::pid_t child_pid, lldb::tid_t child_tid) override
Called after a reported vfork.
bool SupportsReverseDirection() override
Reports whether this process supports reverse execution.
void DidExec() override
Called after a process re-execs itself.
size_t PutSTDIN(const char *buf, size_t buf_size, Status &error) override
Puts data into this process's STDIN.
static void DebuggerInitialize(Debugger &debugger)
tid_collection m_thread_ids
Status DoAttachToProcessWithName(const char *process_name, const ProcessAttachInfo &attach_info) override
Attach to an existing process using a partial process name.
GDBRemoteDynamicRegisterInfoSP m_register_info_sp
std::string m_partial_profile_data
StructuredData::ObjectSP GetLoadedDynamicLibrariesInfos_sender(StructuredData::ObjectSP args)
void MaybeLoadExecutableModule()
std::vector< lldb::addr_t > m_thread_pcs
bool CanDebug(lldb::TargetSP target_sp, bool plugin_specified_by_name) override
Check if a plug-in instance can debug the file in module.
void SetThreadPc(const lldb::ThreadSP &thread_sp, uint64_t index)
std::recursive_mutex m_async_thread_state_mutex
Status ConnectToDebugserver(llvm::StringRef host_port)
void SetUnixSignals(const lldb::UnixSignalsSP &signals_sp)
void RefreshStateAfterStop() override
Currently called as part of ShouldStop.
uint64_t m_remote_stub_max_memory_size
size_t DoReadMemory(lldb::addr_t addr, void *buf, size_t size, Status &error) override
Actually do the reading of memory from a process.
std::optional< StringExtractorGDBRemote > m_last_stop_packet
CommandObject * GetPluginCommandObject() override
Return a multi-word command object that can be used to expose plug-in specific commands.
int64_t m_breakpoint_pc_offset
size_t DoWriteMemory(lldb::addr_t addr, const void *buf, size_t size, Status &error) override
Actually do the writing of memory to a process.
Status DoLaunch(Module *exe_module, ProcessLaunchInfo &launch_info) override
Launch a new process.
lldb::CommandObjectSP m_command_sp
void DidVForkDone() override
Called after reported vfork completion.
std::string HarmonizeThreadIdsForProfileData(StringExtractorGDBRemote &inputStringExtractor)
bool GetGDBServerRegisterInfoXMLAndProcess(ArchSpec &arch_to_use, std::string xml_filename, std::vector< DynamicRegisterInfo::Register > ®isters)
bool m_use_g_packet_for_reading
Status DoWillAttachToProcessWithName(const char *process_name, bool wait_for_launch) override
Called before attaching to a process.
static std::chrono::seconds GetPacketTimeout()
lldb::ListenerSP m_async_listener_sp
std::pair< std::string, std::string > ModuleCacheKey
bool CalculateThreadStopInfo(ThreadGDBRemote *thread)
tid_collection m_continue_c_tids
bool SupportsMemoryTagging() override
Check whether the process supports memory tagging.
void BuildDynamicRegisterInfo(bool force)
tid_collection m_continue_s_tids
size_t UpdateThreadPCsFromStopReplyThreadsValue(llvm::StringRef value)
~ProcessGDBRemote() override
llvm::VersionTuple GetHostOSVersion() override
Sometimes the connection to a process can detect the host OS version that the process is running on.
lldb::tid_t m_initial_tid
llvm::Expected< StringExtractorGDBRemote > SendMultiMemReadPacket(llvm::ArrayRef< Range< lldb::addr_t, size_t > > ranges)
std::map< uint64_t, uint32_t > m_thread_id_to_used_usec_map
Status DoWriteMemoryTags(lldb::addr_t addr, size_t len, int32_t type, const std::vector< uint8_t > &tags) override
Does the final operation to write memory tags.
llvm::Error ParseMultiMemReadPacket(llvm::StringRef response_str, llvm::MutableArrayRef< uint8_t > buffer, unsigned expected_num_ranges, llvm::SmallVectorImpl< llvm::MutableArrayRef< uint8_t > > &memory_regions)
llvm::Expected< std::vector< uint8_t > > TraceGetBinaryData(const TraceGetBinaryDataRequest &request) override
Get binary data given a trace technology and a data identifier.
Status EnableBreakpointSite(BreakpointSite *bp_site) override
void ModulesDidLoad(ModuleList &module_list) override
ProcessGDBRemote(lldb::TargetSP target_sp, lldb::ListenerSP listener_sp)
uint32_t m_vfork_in_progress_count
@ eBroadcastBitAsyncContinue
@ eBroadcastBitAsyncThreadShouldExit
@ eBroadcastBitAsyncThreadDidExit
Status WillResume() override
Called before resuming to a process.
std::mutex m_shared_cache_info_mutex
lldb::ModuleSP LoadModuleAtAddress(const FileSpec &file, lldb::addr_t link_map, lldb::addr_t base_addr, bool value_is_offset)
void SetLastStopPacket(const StringExtractorGDBRemote &response)
lldb::thread_result_t AsyncThread()
Status WriteObjectFile(std::vector< ObjectFile::LoadableData > entries) override
llvm::Error LoadModules() override
Sometimes processes know how to retrieve and load shared libraries.
uint64_t m_max_memory_size
void HandleAsyncMisc(llvm::StringRef data) override
lldb::addr_t GetImageInfoAddress() override
Get the image information address for the current process.
bool DoUpdateThreadList(ThreadList &old_thread_list, ThreadList &new_thread_list) override
Update the thread list following process plug-in's specific logic.
static lldb::ProcessSP CreateInstance(lldb::TargetSP target_sp, lldb::ListenerSP listener_sp, const FileSpec *crash_file_path, bool can_connect)
void PrefetchModuleSpecs(llvm::ArrayRef< FileSpec > module_file_specs, const llvm::Triple &triple) override
llvm::VersionTuple GetHostMacCatalystVersion() override
void DidForkSwitchHardwareTraps(bool enable)
HostThread m_async_thread
StructuredData::ObjectSP GetDynamicLoaderProcessState() override
bool GetModuleSpec(const FileSpec &module_file_spec, const ArchSpec &arch, ModuleSpec &module_spec) override
Try to fetch the module specification for a module with the given file name and architecture.
llvm::StringMap< std::unique_ptr< RegisterFlags > > m_registers_flags_types
Status DoWillLaunch(Module *module) override
Called before launching to a process.
void DidAttach(ArchSpec &process_arch) override
Called after attaching a process.
llvm::Expected< bool > SaveCore(llvm::StringRef outfile) override
Save core dump into the specified file.
std::atomic< lldb::pid_t > m_debugserver_pid
llvm::Expected< std::string > TraceGetState(llvm::StringRef type) override
Get the current tracing state of the process and its threads.
bool IsAlive() override
Check if a process is still alive.
void SetQueueLibdispatchQueueAddress(lldb::addr_t dispatch_queue_t) override
void SetQueueInfo(std::string &&queue_name, lldb::QueueKind queue_kind, uint64_t queue_serial, lldb::addr_t dispatch_queue_t, lldb_private::LazyBool associated_with_libdispatch_queue)
void SetThreadDispatchQAddr(lldb::addr_t thread_dispatch_qaddr)
lldb::RegisterContextSP GetRegisterContext() override
void SetAssociatedWithLibdispatchQueue(lldb_private::LazyBool associated_with_libdispatch_queue) override
bool PrivateSetRegisterValue(uint32_t reg, llvm::ArrayRef< uint8_t > data)
#define LLDB_INVALID_SITE_ID
#define LLDB_INVALID_WATCH_ID
#define LLDB_INVALID_SIGNAL_NUMBER
#define LLDB_INVALID_THREAD_ID
#define UNUSED_IF_ASSERT_DISABLED(x)
#define LLDB_INVALID_ADDRESS
#define LLDB_INVALID_REGNUM
#define LLDB_INVALID_PROCESS_ID
#define LLDB_REGNUM_GENERIC_PC
lldb::ByteOrder InlHostByteOrder()
std::vector< DynamicRegisterInfo::Register > GetFallbackRegisters(const ArchSpec &arch_to_use)
A class that represents a running process on the host machine.
Log * GetLog(Cat mask)
Retrieve the Log object for the channel associated with the given log enum.
bool InferiorCallMunmap(Process *proc, lldb::addr_t addr, lldb::addr_t length)
bool InferiorCallMmap(Process *proc, lldb::addr_t &allocated_addr, lldb::addr_t addr, lldb::addr_t length, unsigned prot, unsigned flags, lldb::addr_t fd, lldb::addr_t offset)
const char * StateAsCString(lldb::StateType state)
Converts a StateType to a C string.
const char * GetPermissionsAsCString(uint32_t permissions)
void DumpProcessGDBRemotePacketHistory(void *p, const char *path)
std::shared_ptr< lldb_private::ABI > ABISP
std::shared_ptr< lldb_private::BreakpointSite > BreakpointSiteSP
RunDirection
Execution directions.
std::shared_ptr< lldb_private::Thread > ThreadSP
std::shared_ptr< lldb_private::CommandObject > CommandObjectSP
ConnectionStatus
Connection Status Types.
@ eConnectionStatusSuccess
Success.
std::shared_ptr< lldb_private::UnixSignals > UnixSignalsSP
@ eFormatCString
NULL terminated C strings.
@ eFormatCharArray
Print characters with no single quotes, used for character arrays that can contain non printable char...
@ eFormatInstruction
Disassemble an opcode.
@ eFormatVoid
Do not print this.
@ eFormatComplex
Floating point complex type.
@ eFormatHexFloat
ISO C99 hex float string.
@ eFormatOSType
OS character codes encoded into an integer 'PICT' 'text' etc...
@ eFormatAddressInfo
Describe what an address points to (func + offset with file/line, symbol + offset,...
@ eFormatCharPrintable
Only printable characters, '.' if not printable.
@ eFormatComplexInteger
Integer complex type.
@ eFormatFloat128
Disambiguate between 128-bit long double (which uses eFormatFloat) and __float128 (which uses eFormat...
std::shared_ptr< lldb_private::Platform > PlatformSP
StateType
Process and Thread States.
@ eStateUnloaded
Process is object is valid, but not currently loaded.
@ eStateConnected
Process is connected to remote debug services, but not launched or attached to anything yet.
@ eStateDetached
Process has been detached and can't be examined.
@ eStateStopped
Process or thread is stopped and can be examined.
@ eStateSuspended
Process or thread is in a suspended state as far as the debugger is concerned while other processes o...
@ eStateRunning
Process or thread is running and can't be examined.
@ eStateAttaching
Process is currently trying to attach.
@ eStateExited
Process has exited and can't be examined.
@ eStateStepping
Process or thread is in the process of stepping and can not be examined.
@ eStateCrashed
Process or thread has crashed and can be examined.
@ eSymbolSharedCacheUseInferiorSharedCacheOnly
@ eSymbolSharedCacheUseHostAndInferiorSharedCache
std::shared_ptr< lldb_private::Stream > StreamSP
std::shared_ptr< lldb_private::Process > ProcessSP
Encoding
Register encoding definitions.
@ eEncodingVector
vector registers
@ eEncodingUint
unsigned integer
std::shared_ptr< lldb_private::Event > EventSP
@ eReturnStatusSuccessFinishResult
@ eArgTypeUnsignedInteger
std::shared_ptr< lldb_private::Watchpoint > WatchpointSP
std::shared_ptr< lldb_private::Listener > ListenerSP
std::shared_ptr< lldb_private::WatchpointResource > WatchpointResourceSP
std::shared_ptr< lldb_private::DataBuffer > DataBufferSP
std::shared_ptr< lldb_private::StopInfo > StopInfoSP
std::shared_ptr< lldb_private::WritableDataBuffer > WritableDataBufferSP
BinaryInformationLevel
When the Process plugin can retrieve information about all binaries loaded in the target process,...
@ eBinaryInformationLevelAddrName
@ eBinaryInformationLevelAddrNameUUID
@ eBinaryInformationLevelFull
@ eBinaryInformationLevelAddrOnly
std::shared_ptr< lldb_private::Target > TargetSP
std::shared_ptr< lldb_private::RegisterContext > RegisterContextSP
std::shared_ptr< lldb_private::Module > ModuleSP
@ eRegisterKindGeneric
insn ptr reg, stack ptr reg, etc not specific to any particular target
@ eRegisterKindProcessPlugin
num used by the process plugin - e.g.
const RegisterFlags * flags_type
std::vector< uint32_t > value_regs
std::vector< uint32_t > invalidate_regs
static Status ToFormat(const char *s, lldb::Format &format, size_t *byte_size_ptr)
BaseType GetRangeBase() const
SizeType GetByteSize() const
void SetRangeBase(BaseType b)
Set the start value for the range, and keep the same size.
BaseType GetRangeEnd() const
void SetByteSize(SizeType s)
jLLDBTraceGetBinaryData gdb-remote packet
jLLDBTraceStop gdb-remote packet