11#include "lldb/Host/Config.h"
44#include "llvm/Support/ErrorExtras.h"
45#include "llvm/Support/ErrorHandling.h"
46#include "llvm/Support/JSON.h"
47#include "llvm/Support/ScopedPrinter.h"
48#include "llvm/TargetParser/Triple.h"
62enum GDBRemoteServerError {
65 eErrorNoProcess = eErrorFirst,
234 bool &interrupt,
bool &quit) {
270 "%s: no process command line specified to launch", __FUNCTION__);
272 const bool should_forward_stdio =
279 if (should_forward_stdio) {
292 "process but one already exists");
302 SetEnabledExtensions(*m_current_process);
309 if (should_forward_stdio) {
314 "pid = {0}: setting up stdout/stderr redirection via $O "
315 "gdb-remote commands",
316 m_current_process->GetID());
319 auto terminal_fd = m_current_process->GetTerminalFileDescriptor();
320 if (terminal_fd >= 0) {
322 "ProcessGDBRemoteCommunicationServerLLGS::%s setting "
323 "inferior STDIO fd to %d",
324 __FUNCTION__, terminal_fd);
325 Status status = SetSTDIOFileDescriptor(terminal_fd);
330 "ProcessGDBRemoteCommunicationServerLLGS::%s ignoring "
331 "inferior STDIO since terminal fd reported as %d",
332 __FUNCTION__, terminal_fd);
336 "pid = {0} skipping stdout/stderr redirection via $O: inferior "
337 "will communicate over client-provided file descriptors",
338 m_current_process->GetID());
341 printf(
"Launched '%s' as process %" PRIu64
"...\n",
342 m_process_launch_info.GetArguments().GetArgumentAtIndex(0),
343 m_current_process->GetID());
350 LLDB_LOGF(log,
"GDBRemoteCommunicationServerLLGS::%s pid %" PRIu64,
357 "cannot attach to process %" PRIu64
358 " when another process with pid %" PRIu64
" is being debugged.",
365 llvm::errs() << llvm::formatv(
"failed to attach to process {0}: {1}\n", pid,
373 SetEnabledExtensions(*m_current_process);
376 auto terminal_fd = m_current_process->GetTerminalFileDescriptor();
377 if (terminal_fd >= 0) {
379 "ProcessGDBRemoteCommunicationServerLLGS::%s setting "
380 "inferior STDIO fd to %d",
381 __FUNCTION__, terminal_fd);
382 Status status = SetSTDIOFileDescriptor(terminal_fd);
387 "ProcessGDBRemoteCommunicationServerLLGS::%s ignoring "
388 "inferior STDIO since terminal fd reported as %d",
389 __FUNCTION__, terminal_fd);
392 printf(
"Attached to process %" PRIu64
"...\n", pid);
397 llvm::StringRef process_name,
bool include_existing) {
400 std::chrono::milliseconds polling_interval = std::chrono::milliseconds(1);
406 process_name, llvm::sys::path::Style::native);
409 if (include_existing) {
410 LLDB_LOG(log,
"including existing processes in search");
414 LLDB_LOG(log,
"placed '{0}' processes in the exclusion list.",
415 exclusion_list.size());
418 LLDB_LOG(log,
"waiting for '{0}' to appear", process_name);
420 auto is_in_exclusion_list =
422 for (
auto &excluded : exclusion_list) {
423 if (excluded.GetProcessID() == info.GetProcessID())
431 loop_process_list.clear();
434 llvm::erase_if(loop_process_list, is_in_exclusion_list);
437 if (loop_process_list.size() == 1) {
438 auto matching_process_pid = loop_process_list[0].GetProcessID();
439 LLDB_LOG(log,
"found pid {0}", matching_process_pid);
444 if (loop_process_list.size() > 1) {
447 "Multiple executables with name: '{0}' found. Pids: ",
449 for (
size_t i = 0; i < loop_process_list.size() - 1; ++i) {
450 error_stream.
Format(
"{0}, ", loop_process_list[i].GetProcessID());
452 error_stream.
Format(
"{0}.", loop_process_list.back().GetProcessID());
460 LLDB_LOG(log,
"sleep {0} seconds", polling_interval);
461 std::this_thread::sleep_for(polling_interval);
467 assert(process &&
"process cannot be NULL");
470 "GDBRemoteCommunicationServerLLGS::%s called with "
471 "NativeProcessProtocol pid %" PRIu64
", current state: %s",
472 __FUNCTION__, process->
GetID(),
479 assert(process &&
"process cannot be NULL");
485 LLDB_LOG(log,
"pid = {0}, failed to retrieve process exit status",
490 response.
PutHex8(GDBRemoteServerError::eErrorExitStatus);
494 LLDB_LOG(log,
"pid = {0}, returning exit type {1}", process->
GetID(),
503 response.
Format(
"{0:g}", *wait_status);
506 response.
Format(
";process:{0:x-}", process->
GetID());
514 uint32_t buf_size,
bool swap) {
517 for (i = buf_size - 1; i >= 0; i--)
520 for (i = 0; i < buf_size; i++)
541 switch (reg_info.
format) {
551 return "bytes-with-ascii";
555 return "char-printable";
567 return "hex-uppercase";
583 return "vector-char";
585 return "vector-sint64";
587 return "vector-float16";
589 return "vector-float64";
591 return "vector-sint8";
593 return "vector-uint8";
595 return "vector-sint16";
597 return "vector-uint16";
599 return "vector-sint32";
601 return "vector-uint32";
603 return "vector-float32";
605 return "vector-uint64";
607 return "vector-uint128";
609 return "complex-integer";
613 return "address-info";
617 return "instruction";
625 llvm_unreachable(
"Unknown register format");
670 response.
Printf(
"%" PRIx32, *reg_num);
672 response.
Printf(
"%" PRIu32, *reg_num);
684 reg_value_p = ®_value;
695 std::vector<uint8_t> zeros(reg_info.
byte_size,
'\0');
701static std::optional<json::Object>
707 json::Object register_object;
709#ifdef LLDB_JTHREADSINFO_FULL_REGISTER_SET
710 const auto expedited_regs =
713 const auto expedited_regs =
716 if (expedited_regs.empty())
719 for (
auto ®_num : expedited_regs) {
722 if (reg_info_p ==
nullptr) {
724 "%s failed to get register info for register index %" PRIu32,
725 __FUNCTION__, reg_num);
736 LLDB_LOGF(log,
"%s failed to read register '%s' index %" PRIu32
": %s",
738 reg_info_p->
name ? reg_info_p->
name :
"<unnamed-register>",
739 reg_num,
error.AsCString());
747 register_object.try_emplace(llvm::to_string(reg_num),
751 return register_object;
755 switch (stop_reason) {
769 return "processor trace";
777 return "async interrupt";
789static llvm::Expected<json::Array>
793 json::Array threads_array;
800 std::string description;
801 if (!thread.GetStopReason(tid_stop_info, description))
802 return llvm::createStringError(
"failed to get stop reason");
804 const int signum = tid_stop_info.
signo;
806 "GDBRemoteCommunicationServerLLGS::%s pid %" PRIu64
808 " got signal signo = %d, reason = %d, exc_type = %" PRIu64,
809 __FUNCTION__, process.
GetID(), tid, signum, tid_stop_info.
reason,
812 json::Object thread_obj;
816 thread_obj.try_emplace(
"registers", std::move(*registers));
819 thread_obj.try_emplace(
"tid",
static_cast<int64_t
>(tid));
822 thread_obj.try_emplace(
"signal", signum);
824 const std::string thread_name = thread.GetName();
825 if (!thread_name.empty())
826 thread_obj.try_emplace(
"name", thread_name);
830 thread_obj.try_emplace(
"reason", stop_reason);
832 if (!description.empty())
833 thread_obj.try_emplace(
"description", description);
837 thread_obj.try_emplace(
840 json::Array medata_array;
843 medata_array.push_back(
846 thread_obj.try_emplace(
"medata", std::move(medata_array));
848 threads_array.push_back(std::move(thread_obj));
850 return threads_array;
860 LLDB_LOG(log,
"preparing packet for pid {0} tid {1}", process.
GetID(),
866 std::string description;
867 if (!thread.GetStopReason(tid_stop_info, description))
878 int signum = tid_stop_info.
signo;
881 "pid {0}, tid {1}, got signal signo = {2}, reason = {3}, exc_type = {4}",
882 process.
GetID(), thread.GetID(), signum,
int(tid_stop_info.
reason),
886 response.
PutHex8(signum & 0xff);
894 const std::string thread_name = thread.GetName();
895 if (!thread_name.empty()) {
896 size_t thread_name_len = thread_name.length();
898 if (::strcspn(thread_name.c_str(),
"$#+-;:") == thread_name_len) {
920 uint32_t thread_num = 0;
924 response.
Printf(
"%" PRIx64, listed_thread.GetID());
934 if (thread_num > 1) {
935 const bool threads_with_valid_stop_info_only =
true;
941 unescaped_response.
AsRawOstream() << std::move(*threads_info);
946 "failed to prepare a jstopinfo field for pid {1}: {0}",
952 char delimiter =
':';
964 LLDB_LOGF(log,
"%s failed to read register '%s' index %" PRIu32
": %s",
966 reg_info_p->
name ? reg_info_p->
name :
"<unnamed-register>",
967 reg_to_read,
error.AsCString());
986 const auto expedited_regs =
989 for (
auto ®_num : expedited_regs) {
993 if (reg_info_p !=
nullptr && reg_info_p->
value_regs ==
nullptr) {
996 if (
error.Success()) {
997 response.
Printf(
"%.02x:", reg_num);
1003 "GDBRemoteCommunicationServerLLGS::%s failed to read "
1004 "register '%s' index %" PRIu32
": %s",
1006 reg_info_p->
name ? reg_info_p->
name :
"<unnamed-register>",
1007 reg_num,
error.AsCString());
1013 if (reason_str !=
nullptr) {
1014 response.
Printf(
"reason:%s;", reason_str);
1017 if (!description.empty()) {
1048 response.
Printf(
"%s:p%" PRIx64
".%" PRIx64
";", reason_str,
1065 if (response.
Empty())
1085 if (listed_thread.GetID() != thread_to_skip) {
1087 if (!stop_reply.
Empty())
1095 assert(process &&
"process cannot be NULL");
1098 LLDB_LOGF(log,
"GDBRemoteCommunicationServerLLGS::%s called", __FUNCTION__);
1104 "GDBRemoteCommunicationServerLLGS::%s failed to send stop "
1105 "notification for PID %" PRIu64
", state: eStateExited",
1106 __FUNCTION__, process->
GetID());
1137 assert(process &&
"process cannot be NULL");
1140 LLDB_LOGF(log,
"GDBRemoteCommunicationServerLLGS::%s called", __FUNCTION__);
1146 "GDBRemoteCommunicationServerLLGS::%s failed to send stop "
1147 "notification for PID %" PRIu64
", state: eStateExited",
1148 __FUNCTION__, process->
GetID());
1154 assert(process &&
"process cannot be NULL");
1157 "GDBRemoteCommunicationServerLLGS::%s called with "
1158 "NativeProcessProtocol pid %" PRIu64
", state: %s",
1186 "GDBRemoteCommunicationServerLLGS::%s didn't handle state "
1187 "change for pid %" PRIu64
", new state: %s",
1199 std::unique_ptr<NativeProcessProtocol> child_process) {
1211 bool interrupt =
false;
1216 std::chrono::microseconds(0),
error, interrupt, done);
1222 "GDBRemoteCommunicationServerLLGS::%s processing a packet "
1224 __FUNCTION__,
error.AsCString());
1232 std::unique_ptr<Connection> connection) {
1233 IOObjectSP read_object_sp = connection->GetReadObject();
1245 const llvm::json::Value &value) {
1246 std::string json_string;
1247 raw_string_ostream os(json_string);
1252 escaped_response.
PutEscapedBytes(json_string.c_str(), json_string.size());
1259 if ((buffer ==
nullptr) || (len == 0)) {
1278 std::unique_ptr<ConnectionFileDescriptor> conn_up(
1290 "failed to set connection for inferior I/O communication");
1312 LLDB_LOG(log,
"Failed to set up stdio forwarding: {0}",
error);
1326 buffer,
sizeof buffer, std::chrono::microseconds(0), status, &
error);
1337 "GDBRemoteCommunicationServerLLGS::%s Stopping stdio "
1338 "forwarding as communication returned status %d (error: "
1340 __FUNCTION__, status,
error.AsCString());
1372 Expected<TraceStopRequest> stop_request =
1373 json::parse<TraceStopRequest>(packet.
Peek(),
"TraceStopRequest");
1393 Expected<TraceStartRequest> request =
1394 json::parse<TraceStartRequest>(packet.
Peek(),
"TraceStartRequest");
1414 Expected<TraceGetStateRequest> request =
1415 json::parse<TraceGetStateRequest>(packet.
Peek(),
"TraceGetStateRequest");
1432 llvm::Expected<TraceGetBinaryDataRequest> request =
1433 llvm::json::parse<TraceGetBinaryDataRequest>(packet.
Peek(),
1434 "TraceGetBinaryDataRequest");
1438 if (Expected<std::vector<uint8_t>> bytes =
1455 std::vector<std::string> structured_data_plugins =
1459 llvm::json::Value(llvm::json::Array(structured_data_plugins)));
1516 LLDB_LOG(log,
"No debugged process found.");
1522 LLDB_LOG(log,
"Killing process {0}", it->first);
1525 LLDB_LOG(log,
"Failed to kill debugged process {0}: {1}", it->first,
1546 "vKill failed to parse the process id");
1564 packet.
SetFilePos(::strlen(
"QSetDisableASLR:"));
1575 packet.
SetFilePos(::strlen(
"QSetWorkingDir:"));
1617 LLDB_LOG(log,
"process {0} cannot be resumed (state={1})", process.
GetID(),
1636 LLDB_LOGF(log,
"GDBRemoteCommunicationServerLLGS::%s called", __FUNCTION__);
1641 "GDBRemoteCommunicationServerLLGS::%s no debugged process "
1653 const uint32_t signo =
1654 packet.
GetHexMaxU32(
false, std::numeric_limits<uint32_t>::max());
1655 if (signo == std::numeric_limits<uint32_t>::max())
1661 if (*packet.
Peek() ==
';')
1665 packet,
"unexpected content after $C{signal-number}");
1671 LLDB_LOG(log,
"process cannot be resumed (state={0})",
1692 static_cast<int>(signo)};
1696 resume_actions.
Append(action);
1702 LLDB_LOG(log,
"failed to send signal for process {0}: {1}",
1723 LLDB_LOGF(log,
"GDBRemoteCommunicationServerLLGS::%s called", __FUNCTION__);
1728 const bool has_continue_address = (packet.
GetBytesLeft() > 0);
1729 if (has_continue_address) {
1730 LLDB_LOG(log,
"not implemented for c[address] variant [{0} remains]",
1738 "GDBRemoteCommunicationServerLLGS::%s no debugged process "
1759 response.
Printf(
"vCont;c;C;s;S;t");
1780 LLDB_LOGF(log,
"GDBRemoteCommunicationServerLLGS::%s handling vCont packet",
1787 "GDBRemoteCommunicationServerLLGS::%s missing action from "
1793 if (::strcmp(packet.
Peek(),
";s") == 0) {
1799 std::unordered_map<lldb::pid_t, ResumeActionList> thread_actions;
1811 const char action = packet.
GetChar();
1815 if (thread_action.
signal == 0)
1817 packet,
"Could not parse signal in vCont packet C action");
1827 if (thread_action.
signal == 0)
1829 packet,
"Could not parse signal in vCont packet S action");
1860 pid = pid_tid->first;
1861 tid = pid_tid->second;
1867 packet,
"'t' action not supported for individual threads");
1873 LLDB_LOG(log,
"no process selected via Hc");
1882 thread_action.
tid = tid;
1887 packet,
"vCont: p-1 is not valid with a specific tid");
1889 thread_actions[process_it.first].Append(thread_action);
1891 thread_actions[pid].Append(thread_action);
1894 assert(thread_actions.size() >= 1);
1895 if (thread_actions.size() > 1 && !
m_non_stop)
1898 "Resuming multiple processes is supported in non-stop mode only");
1900 for (std::pair<lldb::pid_t, ResumeActionList> x : thread_actions) {
1903 LLDB_LOG(log,
"vCont failed for process {0}: process not debugged",
1920 assert(process_it->second.process_up);
1922 if (process_it->second.process_up->IsRunning()) {
1925 Status error = process_it->second.process_up->Interrupt();
1927 LLDB_LOG(log,
"vCont failed to halt process {0}: {1}", x.first,
1932 LLDB_LOG(log,
"halted process {0}", x.first);
1936 assert(thread_actions.size() == 1);
1952 LLDB_LOG(log,
"setting current thread id to {0}", tid);
1961 LLDB_LOG(log,
"setting continue thread id to {0}", tid);
1975 return x.front() !=
'W' && x.front() !=
'X';
1985 if (!stop_reply.
Empty())
2012 bool force_synchronous) {
2019 if (it.second.process_up->IsRunning())
2029 switch (process_state) {
2055 LLDB_LOG(log,
"pid {0}, current state reporting not handled: {1}",
2056 process.
GetID(), process_state);
2081 const uint32_t reg_index =
2082 packet.
GetHexMaxU32(
false, std::numeric_limits<uint32_t>::max());
2083 if (reg_index == std::numeric_limits<uint32_t>::max())
2114 if (!encoding.empty())
2115 response <<
"encoding:" << encoding <<
';';
2118 if (!format.empty())
2119 response <<
"format:" << format <<
';';
2121 const char *
const register_set_name =
2123 if (register_set_name)
2124 response <<
"set:" << register_set_name <<
';';
2128 response.
Printf(
"ehframe:%" PRIu32
";",
2132 response.
Printf(
"dwarf:%" PRIu32
";",
2136 if (!kind_generic.empty())
2137 response <<
"generic:" << kind_generic <<
';';
2162 LLDB_LOG(log,
"iterating over threads of process {0}", process.
GetID());
2164 LLDB_LOG(log,
"iterated thread tid={0}", thread.GetID());
2165 response.
PutChar(had_any ?
',' :
'm');
2178 bool had_any =
false;
2207 LLDB_LOG(log,
"failed, no thread available");
2214 std::vector<uint8_t> regs_buffer;
2219 if (reg_info ==
nullptr) {
2220 LLDB_LOG(log,
"failed to get register info for register index {0}",
2231 LLDB_LOG(log,
"failed to read register at index {0}", reg_num);
2258 const uint32_t reg_index =
2259 packet.
GetHexMaxU32(
false, std::numeric_limits<uint32_t>::max());
2260 if (reg_index == std::numeric_limits<uint32_t>::max()) {
2262 "GDBRemoteCommunicationServerLLGS::%s failed, could not "
2263 "parse register number from request \"%s\"",
2271 LLDB_LOG(log,
"failed, no thread available");
2282 "GDBRemoteCommunicationServerLLGS::%s failed, requested "
2283 "register %" PRIu32
" beyond register count %" PRIu32,
2291 "GDBRemoteCommunicationServerLLGS::%s failed, requested "
2292 "register %" PRIu32
" returned NULL",
2293 __FUNCTION__, reg_index);
2305 "GDBRemoteCommunicationServerLLGS::%s failed, read of "
2306 "requested register %" PRIu32
" (%s) failed: %s",
2307 __FUNCTION__, reg_index, reg_info->
name,
error.AsCString());
2311 const uint8_t *
const data =
2312 static_cast<const uint8_t *
>(reg_value.
GetBytes());
2315 "GDBRemoteCommunicationServerLLGS::%s failed to get data "
2316 "bytes from requested register %" PRIu32,
2317 __FUNCTION__, reg_index);
2322 for (uint32_t i = 0; i < reg_value.
GetByteSize(); ++i)
2338 const uint32_t reg_index =
2339 packet.
GetHexMaxU32(
false, std::numeric_limits<uint32_t>::max());
2340 if (reg_index == std::numeric_limits<uint32_t>::max()) {
2342 "GDBRemoteCommunicationServerLLGS::%s failed, could not "
2343 "parse register number from request \"%s\"",
2351 packet,
"P packet missing '=' char after register number");
2360 "GDBRemoteCommunicationServerLLGS::%s failed, no thread "
2361 "available (thread index 0)",
2371 "GDBRemoteCommunicationServerLLGS::%s failed, requested "
2372 "register %" PRIu32
" returned NULL",
2373 __FUNCTION__, reg_index);
2381 "GDBRemoteCommunicationServerLLGS::%s failed, requested "
2382 "register %" PRIu32
" beyond register count %" PRIu32,
2398 "GDBRemoteCommunicationServerLLGS::%s failed, write of "
2399 "requested register %" PRIu32
" (%s) failed: %s",
2400 __FUNCTION__, reg_index, reg_info->
name,
error.AsCString());
2415 "GDBRemoteCommunicationServerLLGS::%s failed, H command "
2416 "missing {g,c} variant",
2421 const char h_variant = packet.
GetChar();
2423 switch (h_variant) {
2435 "GDBRemoteCommunicationServerLLGS::%s failed, invalid $H variant %c",
2436 __FUNCTION__, h_variant);
2438 "H variant unsupported, should be c or g");
2442 auto pid_tid = packet.
GetPidTid(default_process ? default_process->
GetID()
2454 llvm::createStringError(
"No current process and no PID provided"));
2460 llvm::createStringErrorV(
"No process with PID {0} debugged", pid));
2466 new_process_it->second.process_up->GetThreadByID(tid);
2469 "GDBRemoteCommunicationServerLLGS::%s failed, tid %" PRIu64
2477 switch (h_variant) {
2489 assert(
false &&
"unsupported $H variant - shouldn't get here");
2491 "H variant unsupported, should be c or g");
2506 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
2540 LLDB_LOG(log,
"failed, no process available");
2567 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
2590 const uint64_t byte_count = packet.
GetHexMaxU64(
false, 0);
2591 if (byte_count == 0) {
2593 "GDBRemoteCommunicationServerLLGS::%s nothing to read: "
2594 "zero-length packet",
2600 std::string buf(byte_count,
'\0');
2605 size_t bytes_read = 0;
2607 read_addr, &buf[0], byte_count, bytes_read);
2610 "ReadMemoryWithoutTrap({0}) read {1} of {2} requested bytes (error: {3})",
2611 read_addr, byte_count, bytes_read,
error);
2612 if (bytes_read == 0)
2617 char kind = packet.
GetChar(
'?');
2621 assert(kind ==
'm');
2622 for (
size_t i = 0; i < bytes_read; ++i)
2637 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
2652 Permissions perms = {};
2656 perms |= ePermissionsReadable;
2659 perms |= ePermissionsWritable;
2662 perms |= ePermissionsExecutable;
2686 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
2714 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
2737 const uint64_t byte_count = packet.
GetHexMaxU64(
false, 0);
2738 if (byte_count == 0) {
2739 LLDB_LOG(log,
"nothing to write: zero-length packet");
2746 packet,
"Comma sep missing in M packet after byte length");
2749 std::vector<uint8_t> buf(byte_count, 0);
2755 const uint64_t convert_count = packet.
GetHexBytes(buf, 0);
2756 if (convert_count != byte_count) {
2758 "pid {0} mem {1:x}: asked to write {2} bytes, but only found {3} "
2762 "not match hex-encoded content "
2767 size_t bytes_written = 0;
2771 LLDB_LOG(log,
"pid {0} mem {1:x}: failed to write. Error: {2}",
2776 if (bytes_written == 0) {
2777 LLDB_LOG(log,
"pid {0} mem {1:x}: wrote 0 of {2} requested bytes",
2801 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
2828 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
2834 packet.
SetFilePos(strlen(
"qMemoryRegionInfo:"));
2855 response.
Printf(
"start:%" PRIx64
";size:%" PRIx64
";",
2909 LLDB_LOG(log,
"failed, no process available");
2917 packet,
"Too short Z packet, missing software/hardware specifier");
2919 bool want_breakpoint =
true;
2920 bool want_hardware =
false;
2921 uint32_t watch_flags = 0;
2925 switch (stoppoint_type) {
2927 want_hardware =
false;
2928 want_breakpoint =
true;
2931 want_hardware =
true;
2932 want_breakpoint =
true;
2936 want_hardware =
true;
2937 want_breakpoint =
false;
2941 want_hardware =
true;
2942 want_breakpoint =
false;
2946 want_hardware =
true;
2947 want_breakpoint =
false;
2951 packet,
"Z packet had invalid software/hardware specifier");
2956 packet,
"Malformed Z packet, expecting comma after stoppoint type");
2965 packet,
"Malformed Z packet, expecting comma after address");
2968 const uint32_t size =
2969 packet.
GetHexMaxU32(
false, std::numeric_limits<uint32_t>::max());
2970 if (size == std::numeric_limits<uint32_t>::max())
2972 packet,
"Malformed Z packet, failed to parse size argument");
2974 if (want_breakpoint) {
2978 if (
error.Success())
2981 LLDB_LOG(log,
"pid {0} failed to set breakpoint: {1}",
2987 addr, size, watch_flags, want_hardware);
2988 if (
error.Success())
2991 LLDB_LOG(log,
"pid {0} failed to set watchpoint: {1}",
3003 LLDB_LOG(log,
"failed, no process available");
3011 packet,
"Too short z packet, missing software/hardware specifier");
3013 bool want_breakpoint =
true;
3014 bool want_hardware =
false;
3018 switch (stoppoint_type) {
3020 want_breakpoint =
true;
3021 want_hardware =
true;
3024 want_breakpoint =
true;
3027 want_breakpoint =
false;
3030 want_breakpoint =
false;
3033 want_breakpoint =
false;
3037 packet,
"z packet had invalid software/hardware specifier");
3042 packet,
"Malformed z packet, expecting comma after stoppoint type");
3051 packet,
"Malformed z packet, expecting comma after address");
3062 if (want_breakpoint) {
3066 if (
error.Success())
3069 LLDB_LOG(log,
"pid {0} failed to remove breakpoint: {1}",
3075 if (
error.Success())
3078 LLDB_LOG(log,
"pid {0} failed to remove watchpoint: {1}",
3093 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
3131llvm::Expected<std::unique_ptr<llvm::MemoryBuffer>>
3136 return llvm::createStringError(llvm::inconvertibleErrorCode(),
3137 "No thread available");
3145 response.
Printf(
"<?xml version=\"1.0\"?>\n");
3146 response.
Printf(
"<target version=\"1.0\">\n");
3150 response.
Printf(
"<architecture>%s</architecture>\n",
3157 response.
Indent(
"<feature>\n");
3160 if (registers_count)
3163 llvm::StringSet<> field_enums_seen;
3164 for (
int reg_index = 0; reg_index < registers_count; reg_index++) {
3170 "%s failed to get register info for register index %" PRIu32,
3171 "target.xml", reg_index);
3183 response.
Printf(
"<reg name=\"%s\" bitsize=\"%" PRIu32
3184 "\" regnum=\"%d\" ",
3194 if (!encoding.empty())
3195 response <<
"encoding=\"" << encoding <<
"\" ";
3198 if (!format.empty())
3199 response <<
"format=\"" << format <<
"\" ";
3204 const char *
const register_set_name =
3206 if (register_set_name)
3207 response <<
"group=\"" << register_set_name <<
"\" ";
3211 response.
Printf(
"ehframe_regnum=\"%" PRIu32
"\" ",
3216 response.
Printf(
"dwarf_regnum=\"%" PRIu32
"\" ",
3220 if (!kind_generic.empty())
3221 response <<
"generic=\"" << kind_generic <<
"\" ";
3231 response.
PutCString(
"invalidate_regnums=\"");
3239 if (registers_count)
3242 response.
Indent(
"</feature>\n");
3244 response.
Indent(
"</target>\n");
3245 return MemoryBuffer::getMemBufferCopy(response.
GetString(),
"target.xml");
3248llvm::Expected<std::unique_ptr<llvm::MemoryBuffer>>
3250 llvm::StringRef annex) {
3254 return llvm::createStringError(llvm::inconvertibleErrorCode(),
3255 "No process available");
3258 if (
object ==
"auxv") {
3261 if (!buffer_or_error)
3262 return llvm::errorCodeToError(buffer_or_error.getError());
3263 return std::move(*buffer_or_error);
3266 if (
object ==
"siginfo") {
3269 return llvm::createStringError(llvm::inconvertibleErrorCode(),
3270 "no current thread");
3272 auto buffer_or_error = thread->GetSiginfo();
3273 if (!buffer_or_error)
3274 return buffer_or_error.takeError();
3275 return std::move(*buffer_or_error);
3278 if (
object ==
"libraries-svr4") {
3281 return library_list.takeError();
3284 response.
Printf(
"<library-list-svr4 version=\"1.0\">");
3285 for (
auto const &library : *library_list) {
3286 response.
Printf(
"<library name=\"%s\" ",
3288 response.
Printf(
"lm=\"0x%" PRIx64
"\" ", library.link_map);
3289 response.
Printf(
"l_addr=\"0x%" PRIx64
"\" ", library.base_addr);
3290 response.
Printf(
"l_ld=\"0x%" PRIx64
"\" />", library.ld_addr);
3292 response.
Printf(
"</library-list-svr4>");
3293 return MemoryBuffer::getMemBufferCopy(response.
GetString(), __FUNCTION__);
3296 if (
object ==
"features" && annex ==
"target.xml")
3299 return llvm::make_error<UnimplementedError>();
3305 SmallVector<StringRef, 5> fields;
3307 StringRef(packet.
GetStringRef()).split(fields,
':', 4);
3308 if (fields.size() != 5)
3310 StringRef &xfer_object = fields[1];
3311 StringRef &xfer_action = fields[2];
3312 StringRef &xfer_annex = fields[3];
3314 if (xfer_action !=
"read")
3317 const uint64_t xfer_offset =
3318 offset_data.
GetHexMaxU64(
false, std::numeric_limits<uint64_t>::max());
3319 if (xfer_offset == std::numeric_limits<uint64_t>::max())
3322 if (offset_data.
GetChar() !=
',')
3324 "qXfer packet missing comma after offset");
3326 const uint64_t xfer_length =
3327 offset_data.
GetHexMaxU64(
false, std::numeric_limits<uint64_t>::max());
3328 if (xfer_length == std::numeric_limits<uint64_t>::max())
3332 std::string buffer_key = (xfer_object + xfer_action + xfer_annex).str();
3339 .insert(std::make_pair(buffer_key, std::move(*buffer_up)))
3345 bool done_with_buffer =
false;
3346 llvm::StringRef buffer = buffer_it->second->getBuffer();
3347 if (xfer_offset >= buffer.size()) {
3350 done_with_buffer =
true;
3353 buffer = buffer.drop_front(xfer_offset);
3356 if (xfer_length >= buffer.size()) {
3359 done_with_buffer =
true;
3363 buffer = buffer.take_front(xfer_length);
3369 if (done_with_buffer)
3381 packet.
SetFilePos(strlen(
"QSaveRegisterState"));
3388 packet,
"No thread specified in QSaveRegisterState packet");
3391 "No thread was is set with the Hg packet");
3401 LLDB_LOG(log,
"pid {0} failed to save all register values: {1}",
3409 "GetNextRegisterSaveID() returned an existing register save id");
3419 response.
Printf(
"%" PRIu32, save_id);
3429 packet.
SetFilePos(strlen(
"QRestoreRegisterState:"));
3432 packet,
"QRestoreRegisterState packet missing register save id");
3434 const uint32_t save_id = packet.
GetU32(0);
3436 LLDB_LOG(log,
"QRestoreRegisterState packet has malformed save id, "
3437 "expecting decimal uint32_t");
3446 packet,
"No thread specified in QRestoreRegisterState packet");
3449 "No thread was is set with the Hg packet");
3464 "pid {0} does not have a register set save buffer for id {1}",
3468 register_data_sp = it->second;
3476 LLDB_LOG(log,
"pid {0} failed to restore all register values: {1}",
3498 "vAttach failed to parse the process id");
3502 "GDBRemoteCommunicationServerLLGS::%s attempting to attach to "
3510 "GDBRemoteCommunicationServerLLGS::%s failed to attach to "
3511 "pid %" PRIu64
": %s\n",
3512 __FUNCTION__, pid,
error.AsCString());
3535 std::string process_name;
3538 "vAttachWait failed to parse process name");
3540 LLDB_LOG(log,
"attempting to attach to process named '{0}'", process_name);
3544 LLDB_LOG(log,
"failed to attach to process named '{0}': {1}", process_name,
3574 std::string process_name;
3577 "vAttachOrWait failed to parse process name");
3579 LLDB_LOG(log,
"attempting to attach to process named '{0}'", process_name);
3583 LLDB_LOG(log,
"failed to attach to process named '{0}': {1}", process_name,
3601 if (!s.consume_front(
"vRun;"))
3604 llvm::SmallVector<llvm::StringRef, 16> argv;
3607 for (llvm::StringRef hex_arg : argv) {
3612 LLDB_LOGF(log,
"LLGSPacketHandler::%s added arg: \"%s\"", __FUNCTION__,
3651 llvm::Error detach_error = llvm::Error::success();
3652 bool detached =
false;
3657 "GDBRemoteCommunicationServerLLGS::%s detaching %" PRId64,
3658 __FUNCTION__, it->first);
3659 if (llvm::Error e = it->second.process_up->Detach().ToError())
3660 detach_error = llvm::joinErrors(std::move(detach_error), std::move(e));
3691 packet.
SetFilePos(strlen(
"qThreadStopInfo"));
3695 "GDBRemoteCommunicationServerLLGS::%s failed, could not "
3696 "parse thread id from request \"%s\"",
3716 const bool threads_with_valid_stop_info_only =
false;
3717 llvm::Expected<json::Value> threads_info =
3719 if (!threads_info) {
3721 "failed to prepare a packet for pid {1}: {0}",
3740 packet.
SetFilePos(strlen(
"qWatchpointSupportInfo"));
3749 if (hw_debug_cap == std::nullopt)
3750 response.
Printf(
"num:0;");
3752 response.
Printf(
"num:%d;", hw_debug_cap->second);
3765 packet.
SetFilePos(strlen(
"qFileLoadAddress:"));
3769 std::string file_name;
3782 response.
PutHex64(file_load_address);
3789 std::vector<int> signals;
3795 int signal = packet.
GetS32(-1, 16);
3798 signals.push_back(signal);
3801 char separator = packet.
GetChar();
3802 if (separator ==
'\0')
3804 if (separator !=
';')
3806 " expected semicolon.");
3830 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
3840 const char *current_char = packet.
Peek();
3841 if (!current_char || *current_char ==
',')
3846 char previous_char = packet.
GetChar();
3847 current_char = packet.
Peek();
3849 if (previous_char !=
',' || (current_char && *current_char ==
':'))
3851 "Invalid addr,length pair in qMemTags packet");
3855 packet,
"Too short qMemtags: packet (looking for length)");
3859 const char *invalid_type_err =
"Invalid type field in qMemTags: packet";
3865 const char *first_type_char = packet.
Peek();
3866 if (first_type_char && (*first_type_char ==
'+' || *first_type_char ==
'-'))
3873 packet.
GetU64(std::numeric_limits<uint64_t>::max(), 16);
3876 raw_type > std::numeric_limits<uint32_t>::max() ||
3885 uint32_t raw_type_32 = raw_type;
3886 int32_t type =
reinterpret_cast<int32_t &
>(raw_type_32);
3889 std::vector<uint8_t> tags;
3911 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
3921 const char *current_char = packet.
Peek();
3922 if (!current_char || *current_char ==
',')
3927 char previous_char = packet.
GetChar();
3928 current_char = packet.
Peek();
3930 if (previous_char !=
',' || (current_char && *current_char ==
':'))
3932 "Invalid addr,length pair in QMemTags packet");
3936 packet,
"Too short QMemtags: packet (looking for length)");
3940 const char *invalid_type_err =
"Invalid type field in QMemTags: packet";
3945 const char *first_type_char = packet.
Peek();
3946 if (first_type_char && (*first_type_char ==
'+' || *first_type_char ==
'-'))
3954 packet.
GetU64(std::numeric_limits<uint64_t>::max(), 16);
3955 if (raw_type > std::numeric_limits<uint32_t>::max())
3960 uint32_t raw_type_32 = raw_type;
3961 int32_t type =
reinterpret_cast<int32_t &
>(raw_type_32);
3966 "Missing tag data in QMemTags: packet");
3969 const char *invalid_data_err =
"Invalid tag data in QMemTags: packet";
3976 std::vector<uint8_t> tag_data;
3981 tag_data.resize(byte_count);
3982 size_t converted_bytes = packet.
GetHexBytes(tag_data, 0);
3983 if (converted_bytes != byte_count) {
4001 std::string path_hint;
4004 assert(packet_str.starts_with(
"qSaveCore"));
4005 if (packet_str.consume_front(
"qSaveCore;")) {
4006 for (
auto x : llvm::split(packet_str,
';')) {
4007 if (x.consume_front(
"path-hint:"))
4031 assert(packet_str.starts_with(
"QNonStop:"));
4032 packet_str.consume_front(
"QNonStop:");
4033 if (packet_str ==
"0") {
4037 if (process_it.second.process_up->IsRunning()) {
4039 Status error = process_it.second.process_up->Interrupt();
4042 "while disabling nonstop, failed to halt process {0}: {1}",
4043 process_it.first,
error);
4057 }
else if (packet_str ==
"1") {
4069 std::deque<std::string> &queue) {
4113 return interrupt_res;
4133 llvm::createStringError(
"No current process and no PID provided"));
4141 if (!new_process_it->second.process_up->GetThreadByID(tid))
4155 connection->Disconnect(&
error);
4157 if (
error.Success()) {
4159 "GDBRemoteCommunicationServerLLGS::%s disconnect process "
4160 "terminal stdio - SUCCESS",
4164 "GDBRemoteCommunicationServerLLGS::%s disconnect process "
4165 "terminal stdio - FAIL: %s",
4166 __FUNCTION__,
error.AsCString());
4185 else if (current_tid == 0) {
4197 "GDBRemoteCommunicationServerLLGS::%s gdb-remote parse "
4198 "error: expected ';' prior to start of thread suffix: packet "
4208 if (strncmp(packet.
Peek(),
"thread:", strlen(
"thread:")) != 0) {
4210 "GDBRemoteCommunicationServerLLGS::%s gdb-remote parse "
4211 "error: expected 'thread:' but not found, packet contents = "
4255 ->GetLoadedModuleFileSpec(module_path.c_str(), file_spec)
4266 llvm::StringRef value) {
4268 for (
const char &c : value) {
4291 const llvm::ArrayRef<llvm::StringRef> client_features) {
4292 std::vector<std::string> ret =
4294 ret.insert(ret.end(), {
4295 "QThreadSuffixSupported+",
4296 "QListThreadsInStopReply+",
4297 "qXfer:features:read+",
4304 if (
bool(plugin_features & Extension::pass_signals))
4305 ret.push_back(
"QPassSignals+");
4306 if (
bool(plugin_features & Extension::auxv))
4307 ret.push_back(
"qXfer:auxv:read+");
4308 if (
bool(plugin_features & Extension::libraries_svr4))
4309 ret.push_back(
"qXfer:libraries-svr4:read+");
4310 if (
bool(plugin_features & Extension::siginfo_read))
4311 ret.push_back(
"qXfer:siginfo:read+");
4312 if (
bool(plugin_features & Extension::memory_tagging))
4313 ret.push_back(
"memory-tagging+");
4314 if (
bool(plugin_features & Extension::savecore))
4315 ret.push_back(
"qSaveCore+");
4319 for (llvm::StringRef x : client_features)
4321 llvm::StringSwitch<Extension>(x)
4322 .Case(
"multiprocess+", Extension::multiprocess)
4323 .Case(
"fork-events+", Extension::fork)
4324 .Case(
"vfork-events+", Extension::vfork)
4339 ret.push_back(
"multiprocess+");
4341 ret.push_back(
"fork-events+");
4343 ret.push_back(
"vfork-events+");
4369 response.
Format(
"p{0:x-}.", pid);
4370 response.
Format(
"{0:x-}", tid);
4375 bool reverse_connect) {
4377 if (std::optional<URI> url =
URI::Parse(url_arg)) {
4378 if (reverse_connect)
4379 return url_arg.str();
4384 std::string new_url = llvm::StringSwitch<std::string>(url->scheme)
4385 .Case(
"tcp",
"listen")
4386 .Case(
"unix",
"unix-accept")
4387 .Case(
"unix-abstract",
"unix-abstract-accept")
4388 .Default(url->scheme.str());
4389 llvm::append_range(new_url, url_arg.substr(url->scheme.size()));
4393 std::string host_port = url_arg.str();
4396 if (url_arg.starts_with(
":"))
4397 host_port.insert(0,
"localhost");
4401 return (reverse_connect ?
"connect://" :
"listen://") + host_port;
4404 return (reverse_connect ?
"unix-connect://" :
"unix-accept://") +
static const size_t reg_size
static llvm::raw_ostream & error(Stream &strm)
static llvm::StringRef GetEncodingNameOrEmpty(const RegisterInfo ®_info)
static llvm::StringRef GetFormatNameOrEmpty(const RegisterInfo ®_info)
static void WriteRegisterValueInHexFixedWidth(StreamString &response, NativeRegisterContext ®_ctx, const RegisterInfo ®_info, const RegisterValue *reg_value_p, lldb::ByteOrder byte_order)
static void AppendHexValue(StreamString &response, const uint8_t *buf, uint32_t buf_size, bool swap)
static std::optional< json::Object > GetRegistersAsJSON(NativeThreadProtocol &thread)
static const char * GetStopReasonString(StopReason stop_reason)
static void CollectRegNums(const uint32_t *reg_num, StreamString &response, bool usehex)
static bool ResumeActionListStopsAllThreads(ResumeActionList &actions)
static llvm::StringRef GetKindGenericOrEmpty(const RegisterInfo ®_info)
static llvm::Expected< json::Array > GetJSONThreadsInfo(NativeProcessProtocol &process, bool abridged)
#define LLDB_LOG(log,...)
The LLDB_LOG* macros defined below are the way to emit log messages.
#define LLDB_LOGF(log,...)
#define LLDB_LOG_ERROR(log, error,...)
void swap(lldb_private::NonNullSharedPtr< T > &lhs, lldb_private::NonNullSharedPtr< T > &rhs)
Specialized swap function for NonNullSharedPtr to enable argument-dependent lookup (ADL) and efficien...
An architecture specification class.
virtual void SetConnection(std::unique_ptr< Connection > connection)
Sets the connection that it to be used by this class.
A uniqued constant string class.
llvm::StringRef GetStringRef() const
Get the string value as a llvm::StringRef.
void SetFile(llvm::StringRef path, Style style)
Change the file specified with a new path.
size_t GetPath(char *path, size_t max_path_length, bool denormalize=true) const
Extract the full path to the file.
static FileSystem & Instance()
static bool GetProcessInfo(lldb::pid_t pid, ProcessInstanceInfo &proc_info)
static uint32_t FindProcesses(const ProcessInstanceInfoMatch &match_info, ProcessInstanceInfoList &proc_infos)
virtual void RequestTermination()
LazyBool GetReadable() const
ConstString GetName() const
LazyBool GetExecutable() const
LazyBool IsShadowStack() const
LazyBool GetWritable() const
LazyBool GetMemoryTagged() const
virtual std::optional< WaitStatus > GetExitStatus()
virtual void SetEnabledExtensions(Extension flags)
Method called in order to propagate the bitmap of protocol extensions supported by the client.
lldb::pid_t GetID() const
lldb::StateType GetState() const
NativeThreadProtocol * GetThreadByID(lldb::tid_t tid)
virtual Status Resume(const ResumeActionList &resume_actions)=0
lldb::tid_t GetCurrentThreadID() const
Extension
Extension flag constants, returned by Manager::GetSupportedExtensions() and passed to SetEnabledExten...
ThreadIterable Threads() const
uint32_t ConvertRegisterKindToRegisterNumber(uint32_t kind, uint32_t num) const
virtual uint32_t GetUserRegisterCount() const =0
virtual const RegisterInfo * GetRegisterInfoAtIndex(uint32_t reg) const =0
const char * GetRegisterSetNameForRegisterAtIndex(uint32_t reg_index) const
virtual Status WriteAllRegisterValues(const lldb::DataBufferSP &data_sp)=0
virtual Status ReadRegister(const RegisterInfo *reg_info, RegisterValue ®_value)=0
virtual bool RegisterOffsetIsDynamic() const
virtual Status ReadAllRegisterValues(lldb::WritableDataBufferSP &data_sp)=0
virtual std::vector< uint32_t > GetExpeditedRegisters(ExpeditedRegs expType) const
virtual Status WriteRegister(const RegisterInfo *reg_info, const RegisterValue ®_value)=0
FileSpec & GetExecutableFile()
void SetNameMatchType(NameMatch name_match_type)
ProcessInstanceInfo & GetProcessInfo()
void EnumsToXML(Stream &strm, llvm::StringSet<> &seen) const
Enum types must be defined before use, and GDBRemoteCommunicationServerLLGS view of the register type...
const std::string & GetID() const
void ToXML(Stream &strm) const
Output XML that describes this set of flags.
const void * GetBytes() const
uint32_t GetByteSize() const
const ResumeAction * GetActionForThread(lldb::tid_t tid, bool default_ok) const
void Append(const ResumeAction &action)
bool SetDefaultThreadActionIfNeeded(lldb::StateType action, int signal)
static llvm::Expected< HostAndPort > DecodeHostAndPort(llvm::StringRef host_and_port)
static Status FromErrorStringWithFormat(const char *format,...) __attribute__((format(printf
static Status FromErrorString(const char *str)
bool Fail() const
Test for error condition.
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.
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
llvm::StringRef GetString() const
A stream class that can stream formatted output to a file.
void Format(const char *format, Args &&... args)
Forwards the arguments to llvm::formatv and writes to the stream.
llvm::raw_ostream & AsRawOstream()
Returns a raw_ostream that forwards the data to this Stream object.
size_t Indent(llvm::StringRef s="")
Indent the current line in the stream.
size_t size_t PutHex8(uint8_t uvalue)
Append an uint8_t value in the hexadecimal format to the stream.
size_t PutStringAsRawHex8(llvm::StringRef s)
size_t PutHex64(uint64_t uvalue, lldb::ByteOrder byte_order=lldb::eByteOrderInvalid)
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 PutHex32(uint32_t uvalue, lldb::ByteOrder byte_order=lldb::eByteOrderInvalid)
void IndentLess(unsigned amount=2)
Decrement the current indentation level.
size_t PutBytesAsRawHex8(const void *src, size_t src_len, lldb::ByteOrder src_byte_order=lldb::eByteOrderInvalid, lldb::ByteOrder dst_byte_order=lldb::eByteOrderInvalid)
void IndentMore(unsigned amount=2)
Increment the current indentation level.
GDBRemoteCommunicationServerCommon()
virtual FileSpec FindModuleFile(const std::string &module_path, const ArchSpec &arch)
void RegisterMemberFunctionHandler(StringExtractorGDBRemote::ServerPacketType packet_type, PacketResult(T::*handler)(StringExtractorGDBRemote &packet))
static void CreateProcessInfoResponse_DebugServerStyle(const ProcessInstanceInfo &proc_info, StreamString &response)
Status m_process_launch_error
ProcessLaunchInfo m_process_launch_info
virtual std::vector< std::string > HandleFeatures(llvm::ArrayRef< llvm::StringRef > client_features)
PacketResult Handle_QMemTags(StringExtractorGDBRemote &packet)
PacketResult Handle_qVAttachOrWaitSupported(StringExtractorGDBRemote &packet)
PacketResult Handle_vStdio(StringExtractorGDBRemote &packet)
PacketResult HandleNotificationAck(std::deque< std::string > &queue)
PacketResult Handle_QSetDisableASLR(StringExtractorGDBRemote &packet)
void SetLaunchInfo(const ProcessLaunchInfo &info)
PacketResult SendONotification(const char *buffer, uint32_t len)
PacketResult Handle_D(StringExtractorGDBRemote &packet)
NativeProcessProtocol::Extension m_extensions_supported
PacketResult Handle_qMemTags(StringExtractorGDBRemote &packet)
void AddProcessThreads(StreamGDBRemote &response, NativeProcessProtocol &process, bool &had_any)
llvm::StringMap< std::unique_ptr< llvm::MemoryBuffer > > m_xfer_buffer_map
PacketResult SendStopReasonForState(NativeProcessProtocol &process, lldb::StateType process_state, bool force_synchronous)
void EnqueueStopReplyPackets(lldb::tid_t thread_to_skip)
PacketResult Handle_jLLDBTraceGetBinaryData(StringExtractorGDBRemote &packet)
PacketResult Handle_qfThreadInfo(StringExtractorGDBRemote &packet)
StreamString PrepareStopReplyPacketForThread(NativeThreadProtocol &thread)
uint8_t m_reg_bytes[RegisterValue::kMaxRegisterByteSize]
PacketResult Handle__m(StringExtractorGDBRemote &packet)
GDBRemoteCommunication::PacketResult SendStructuredDataPacket(const llvm::json::Value &value)
PacketResult Handle_g(StringExtractorGDBRemote &packet)
uint32_t m_next_saved_registers_id
void RegisterPacketHandlers()
PacketResult Handle_qMemoryRegionInfoSupported(StringExtractorGDBRemote &packet)
PacketResult Handle_qThreadStopInfo(StringExtractorGDBRemote &packet)
PacketResult Handle_c(StringExtractorGDBRemote &packet)
PacketResult Handle_QThreadSuffixSupported(StringExtractorGDBRemote &packet)
PacketResult Handle_interrupt(StringExtractorGDBRemote &packet)
PacketResult Handle_vKill(StringExtractorGDBRemote &packet)
std::unordered_map< lldb::pid_t, DebuggedProcess > m_debugged_processes
void InitializeDelegate(NativeProcessProtocol *process) override
FileSpec FindModuleFile(const std::string &module_path, const ArchSpec &arch) override
PacketResult Handle_vAttachOrWait(StringExtractorGDBRemote &packet)
PacketResult Handle_vAttach(StringExtractorGDBRemote &packet)
PacketResult Handle_stop_reason(StringExtractorGDBRemote &packet)
PacketResult Handle_jLLDBTraceSupported(StringExtractorGDBRemote &packet)
std::deque< std::string > m_stop_notification_queue
PacketResult Handle_qsThreadInfo(StringExtractorGDBRemote &packet)
PacketResult Handle_vStopped(StringExtractorGDBRemote &packet)
PacketResult Handle_z(StringExtractorGDBRemote &packet)
bool m_disabling_non_stop
lldb::tid_t GetContinueThreadID() const
PacketResult Handle_H(StringExtractorGDBRemote &packet)
void StopSTDIOForwarding()
PacketResult SendContinueSuccessResponse()
PacketResult Handle_jLLDBTraceGetState(StringExtractorGDBRemote &packet)
std::deque< std::string > m_stdio_notification_queue
bool m_list_threads_in_stop_reply
PacketResult Handle_qFileLoadAddress(StringExtractorGDBRemote &packet)
void NewSubprocess(NativeProcessProtocol *parent_process, std::unique_ptr< NativeProcessProtocol > child_process) override
PacketResult Handle_qC(StringExtractorGDBRemote &packet)
static std::string XMLEncodeAttributeValue(llvm::StringRef value)
NativeThreadProtocol * GetThreadFromSuffix(StringExtractorGDBRemote &packet)
Status SetSTDIOFileDescriptor(int fd)
lldb::tid_t GetCurrentThreadID() const
PacketResult Handle_QNonStop(StringExtractorGDBRemote &packet)
Status AttachToProcess(lldb::pid_t pid)
Attach to a process.
PacketResult SendWResponse(NativeProcessProtocol *process)
PacketResult Handle_s(StringExtractorGDBRemote &packet)
Status InitializeConnection(std::unique_ptr< Connection > connection)
bool m_thread_suffix_supported
void HandleInferiorState_Exited(NativeProcessProtocol *process)
lldb::tid_t m_continue_tid
PacketResult Handle_P(StringExtractorGDBRemote &packet)
PacketResult Handle_qSaveCore(StringExtractorGDBRemote &packet)
NativeProcessProtocol * m_current_process
void HandleInferiorState_Stopped(NativeProcessProtocol *process)
NativeProcessProtocol * m_continue_process
PacketResult Handle_vCont(StringExtractorGDBRemote &packet)
PacketResult Handle_vCont_actions(StringExtractorGDBRemote &packet)
PacketResult Handle_vCtrlC(StringExtractorGDBRemote &packet)
PacketResult Handle_jLLDBTraceStart(StringExtractorGDBRemote &packet)
Status LaunchProcess() override
Launch a process with the current launch settings.
PacketResult Handle_qGetWorkingDir(StringExtractorGDBRemote &packet)
void DataAvailableCallback()
PacketResult Handle_qStructuredDataPlugins(StringExtractorGDBRemote &packet)
PacketResult Handle_jThreadsInfo(StringExtractorGDBRemote &packet)
PacketResult Handle_M(StringExtractorGDBRemote &packet)
void DidExec(NativeProcessProtocol *process) override
PacketResult Handle_memory_read(StringExtractorGDBRemote &packet)
Status AttachWaitProcess(llvm::StringRef process_name, bool include_existing)
Wait to attach to a process with a given name.
PacketResult Handle_vAttachWait(StringExtractorGDBRemote &packet)
PacketResult ResumeProcess(NativeProcessProtocol &process, const ResumeActionList &actions)
PacketResult Handle_QListThreadsInStopReply(StringExtractorGDBRemote &packet)
PacketResult Handle_jLLDBTraceStop(StringExtractorGDBRemote &packet)
PacketResult Handle_T(StringExtractorGDBRemote &packet)
GDBRemoteCommunicationServerLLGS(MainLoop &mainloop, NativeProcessProtocol::Manager &process_manager)
PacketResult Handle_QSetWorkingDir(StringExtractorGDBRemote &packet)
PacketResult Handle_k(StringExtractorGDBRemote &packet)
PacketResult Handle_qXfer(StringExtractorGDBRemote &packet)
PacketResult SendStopReplyPacketForThread(NativeProcessProtocol &process, lldb::tid_t tid, bool force_synchronous)
void StartSTDIOForwarding()
PacketResult Handle_C(StringExtractorGDBRemote &packet)
PacketResult Handle__M(StringExtractorGDBRemote &packet)
void AppendThreadIDToResponse(Stream &response, lldb::pid_t pid, lldb::tid_t tid)
std::vector< std::string > HandleFeatures(const llvm::ArrayRef< llvm::StringRef > client_features) override
void ClearProcessSpecificData()
PacketResult Handle_Z(StringExtractorGDBRemote &packet)
PacketResult Handle_QPassSignals(StringExtractorGDBRemote &packet)
PacketResult Handle_qWatchpointSupportInfo(StringExtractorGDBRemote &packet)
void ProcessStateChanged(NativeProcessProtocol *process, lldb::StateType state) override
lldb::tid_t m_current_tid
void SetEnabledExtensions(NativeProcessProtocol &process)
std::unordered_map< uint32_t, lldb::DataBufferSP > m_saved_registers_map
PacketResult Handle_QRestoreRegisterState(StringExtractorGDBRemote &packet)
NativeProcessProtocol::Manager & m_process_manager
void SetContinueThreadID(lldb::tid_t tid)
PacketResult Handle_p(StringExtractorGDBRemote &packet)
PacketResult Handle_qRegisterInfo(StringExtractorGDBRemote &packet)
void SetCurrentThreadID(lldb::tid_t tid)
std::mutex m_saved_registers_mutex
PacketResult Handle_qProcessInfo(StringExtractorGDBRemote &packet)
PacketResult Handle_vRun(StringExtractorGDBRemote &packet)
MainLoop::ReadHandleUP m_stdio_handle_up
void MaybeCloseInferiorTerminalConnection()
MainLoop::ReadHandleUP m_network_handle_up
PacketResult Handle_qMemoryRegionInfo(StringExtractorGDBRemote &packet)
llvm::Expected< std::unique_ptr< llvm::MemoryBuffer > > ReadXferObject(llvm::StringRef object, llvm::StringRef annex)
PacketResult Handle_QSaveRegisterState(StringExtractorGDBRemote &packet)
std::recursive_mutex m_debugged_process_mutex
uint32_t GetNextSavedRegistersID()
Communication m_stdio_communication
llvm::Expected< std::unique_ptr< llvm::MemoryBuffer > > BuildTargetXml()
PacketResult Handle_I(StringExtractorGDBRemote &packet)
void RegisterPacketHandler(StringExtractorGDBRemote::ServerPacketType packet_type, PacketHandler handler)
PacketResult SendErrorResponse(const Status &error)
PacketResult SendIllFormedResponse(const StringExtractorGDBRemote &packet, const char *error_message)
PacketResult GetPacketAndSendResponse(Timeout< std::micro > timeout, Status &error, bool &interrupt, bool &quit)
PacketResult SendJSONResponse(const llvm::json::Value &value)
Serialize and send a JSON object response.
PacketResult SendUnimplementedResponse(const char *packet)
PacketResult SendOKResponse()
PacketResult SendNotificationPacketNoLock(llvm::StringRef notify_type, std::deque< std::string > &queue, llvm::StringRef payload)
PacketResult SendPacketNoLock(llvm::StringRef payload)
#define LLDB_REGNUM_GENERIC_RA
#define LLDB_REGNUM_GENERIC_ARG8
#define LLDB_INVALID_SIGNAL_NUMBER
#define LLDB_INVALID_THREAD_ID
#define LLDB_REGNUM_GENERIC_ARG6
#define LLDB_REGNUM_GENERIC_SP
#define LLDB_REGNUM_GENERIC_ARG4
#define LLDB_REGNUM_GENERIC_ARG3
#define LLDB_REGNUM_GENERIC_ARG1
#define LLDB_REGNUM_GENERIC_ARG7
#define LLDB_REGNUM_GENERIC_FLAGS
#define LLDB_INVALID_ADDRESS
#define LLDB_INVALID_REGNUM
#define LLDB_REGNUM_GENERIC_TP
#define LLDB_INVALID_PROCESS_ID
#define LLDB_REGNUM_GENERIC_ARG2
#define LLDB_REGNUM_GENERIC_PC
#define LLDB_REGNUM_GENERIC_FP
#define LLDB_REGNUM_GENERIC_ARG5
lldb::ByteOrder InlHostByteOrder()
std::string LLGSArgToURL(llvm::StringRef url_arg, bool reverse_connect)
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.
const char * StateAsCString(lldb::StateType state)
Converts a StateType to a C string.
std::vector< ProcessInstanceInfo > ProcessInstanceInfoList
std::shared_ptr< lldb_private::IOObject > IOObjectSP
ConnectionStatus
Connection Status Types.
@ eConnectionStatusError
Check GetError() for details.
@ eConnectionStatusInterrupted
Interrupted read.
@ eConnectionStatusTimedOut
Request timed out.
@ eConnectionStatusEndOfFile
End-of-file encountered.
@ eConnectionStatusSuccess
Success.
@ eConnectionStatusLostConnection
Lost connection while connected to a valid connection.
@ eConnectionStatusNoConnection
No connection.
@ 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...
StateType
Process and Thread States.
@ eStateUnloaded
Process is object is valid, but not currently loaded.
@ 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.
@ eStateLaunching
Process is in the process of launching.
@ 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.
@ eEncodingVector
vector registers
@ eEncodingUint
unsigned integer
@ eEncodingSint
signed integer
ByteOrder
Byte ordering definitions.
std::shared_ptr< lldb_private::DataBuffer > DataBufferSP
std::shared_ptr< lldb_private::WritableDataBuffer > WritableDataBufferSP
StopReason
Thread stop reasons.
@ eStopReasonInstrumentation
@ eStopReasonPlanComplete
@ eStopReasonHistoryBoundary
@ eStopReasonExec
Program was re-exec'ed.
@ eStopReasonInterrupt
Thread requested interrupt.
@ eStopReasonProcessorTrace
@ eStopReasonThreadExiting
@ eRegisterKindGeneric
insn ptr reg, stack ptr reg, etc not specific to any particular target
@ eRegisterKindDWARF
the register numbers seen DWARF
@ eRegisterKindEHFrame
the register numbers seen in eh_frame
BaseType GetRangeBase() const
SizeType GetByteSize() const
Every register is described in detail including its name, alternate name (optional),...
lldb::Encoding encoding
Encoding of the register bits.
const char * alt_name
Alternate name of this register, can be NULL.
uint32_t * value_regs
List of registers (terminated with LLDB_INVALID_REGNUM).
uint32_t byte_offset
The byte offset in the register context data where this register's value is found.
uint32_t byte_size
Size in bytes of the register.
uint32_t kinds[lldb::kNumRegisterKinds]
Holds all of the various register numbers for all register kinds.
const RegisterFlags * flags_type
If not nullptr, a type defined by XML descriptions.
const char * name
Name of this register, can't be NULL.
lldb::Format format
Default display format.
uint32_t * invalidate_regs
List of registers (terminated with LLDB_INVALID_REGNUM).
struct lldb_private::ThreadStopInfo::@116236113001137253323017204263037302160273237376::@034237007264067231263360140073224264215170222231 exception
struct lldb_private::ThreadStopInfo::@116236113001137253323017204263037302160273237376::@075376350020015165106375110034031012204332263127 fork
union lldb_private::ThreadStopInfo::@116236113001137253323017204263037302160273237376 details
static std::optional< URI > Parse(llvm::StringRef uri)