11#include "lldb/Host/Config.h"
44#include "llvm/Support/ErrorHandling.h"
45#include "llvm/Support/JSON.h"
46#include "llvm/Support/ScopedPrinter.h"
47#include "llvm/TargetParser/Triple.h"
61enum GDBRemoteServerError {
64 eErrorNoProcess = eErrorFirst,
233 bool &interrupt,
bool &quit) {
269 "%s: no process command line specified to launch", __FUNCTION__);
271 const bool should_forward_stdio =
278 if (should_forward_stdio) {
291 "process but one already exists");
301 SetEnabledExtensions(*m_current_process);
308 if (should_forward_stdio) {
313 "pid = {0}: setting up stdout/stderr redirection via $O "
314 "gdb-remote commands",
315 m_current_process->GetID());
318 auto terminal_fd = m_current_process->GetTerminalFileDescriptor();
319 if (terminal_fd >= 0) {
321 "ProcessGDBRemoteCommunicationServerLLGS::%s setting "
322 "inferior STDIO fd to %d",
323 __FUNCTION__, terminal_fd);
324 Status status = SetSTDIOFileDescriptor(terminal_fd);
329 "ProcessGDBRemoteCommunicationServerLLGS::%s ignoring "
330 "inferior STDIO since terminal fd reported as %d",
331 __FUNCTION__, terminal_fd);
335 "pid = {0} skipping stdout/stderr redirection via $O: inferior "
336 "will communicate over client-provided file descriptors",
337 m_current_process->GetID());
340 printf(
"Launched '%s' as process %" PRIu64
"...\n",
341 m_process_launch_info.GetArguments().GetArgumentAtIndex(0),
342 m_current_process->GetID());
349 LLDB_LOGF(log,
"GDBRemoteCommunicationServerLLGS::%s pid %" PRIu64,
356 "cannot attach to process %" PRIu64
357 " when another process with pid %" PRIu64
" is being debugged.",
364 llvm::errs() << llvm::formatv(
"failed to attach to process {0}: {1}\n", pid,
372 SetEnabledExtensions(*m_current_process);
375 auto terminal_fd = m_current_process->GetTerminalFileDescriptor();
376 if (terminal_fd >= 0) {
378 "ProcessGDBRemoteCommunicationServerLLGS::%s setting "
379 "inferior STDIO fd to %d",
380 __FUNCTION__, terminal_fd);
381 Status status = SetSTDIOFileDescriptor(terminal_fd);
386 "ProcessGDBRemoteCommunicationServerLLGS::%s ignoring "
387 "inferior STDIO since terminal fd reported as %d",
388 __FUNCTION__, terminal_fd);
391 printf(
"Attached to process %" PRIu64
"...\n", pid);
396 llvm::StringRef process_name,
bool include_existing) {
399 std::chrono::milliseconds polling_interval = std::chrono::milliseconds(1);
405 process_name, llvm::sys::path::Style::native);
408 if (include_existing) {
409 LLDB_LOG(log,
"including existing processes in search");
413 LLDB_LOG(log,
"placed '{0}' processes in the exclusion list.",
414 exclusion_list.size());
417 LLDB_LOG(log,
"waiting for '{0}' to appear", process_name);
419 auto is_in_exclusion_list =
421 for (
auto &excluded : exclusion_list) {
422 if (excluded.GetProcessID() == info.GetProcessID())
430 loop_process_list.clear();
433 llvm::erase_if(loop_process_list, is_in_exclusion_list);
436 if (loop_process_list.size() == 1) {
437 auto matching_process_pid = loop_process_list[0].GetProcessID();
438 LLDB_LOG(log,
"found pid {0}", matching_process_pid);
443 if (loop_process_list.size() > 1) {
446 "Multiple executables with name: '{0}' found. Pids: ",
448 for (
size_t i = 0; i < loop_process_list.size() - 1; ++i) {
449 error_stream.
Format(
"{0}, ", loop_process_list[i].GetProcessID());
451 error_stream.
Format(
"{0}.", loop_process_list.back().GetProcessID());
459 LLDB_LOG(log,
"sleep {0} seconds", polling_interval);
460 std::this_thread::sleep_for(polling_interval);
466 assert(process &&
"process cannot be NULL");
470 "GDBRemoteCommunicationServerLLGS::%s called with "
471 "NativeProcessProtocol pid %" PRIu64
", current state: %s",
472 __FUNCTION__, process->
GetID(),
480 assert(process &&
"process cannot be NULL");
486 LLDB_LOG(log,
"pid = {0}, failed to retrieve process exit status",
491 response.
PutHex8(GDBRemoteServerError::eErrorExitStatus);
495 LLDB_LOG(log,
"pid = {0}, returning exit type {1}", process->
GetID(),
504 response.
Format(
"{0:g}", *wait_status);
507 response.
Format(
";process:{0:x-}", process->
GetID());
515 uint32_t buf_size,
bool swap) {
518 for (i = buf_size - 1; i >= 0; i--)
521 for (i = 0; i < buf_size; i++)
542 switch (reg_info.
format) {
552 return "bytes-with-ascii";
556 return "char-printable";
568 return "hex-uppercase";
584 return "vector-char";
586 return "vector-sint64";
588 return "vector-float16";
590 return "vector-float64";
592 return "vector-sint8";
594 return "vector-uint8";
596 return "vector-sint16";
598 return "vector-uint16";
600 return "vector-sint32";
602 return "vector-uint32";
604 return "vector-float32";
606 return "vector-uint64";
608 return "vector-uint128";
610 return "complex-integer";
614 return "address-info";
618 return "instruction";
626 llvm_unreachable(
"Unknown register format");
671 response.
Printf(
"%" PRIx32, *reg_num);
673 response.
Printf(
"%" PRIu32, *reg_num);
685 reg_value_p = ®_value;
696 std::vector<uint8_t> zeros(reg_info.
byte_size,
'\0');
702static std::optional<json::Object>
708 json::Object register_object;
710#ifdef LLDB_JTHREADSINFO_FULL_REGISTER_SET
711 const auto expedited_regs =
714 const auto expedited_regs =
717 if (expedited_regs.empty())
720 for (
auto ®_num : expedited_regs) {
723 if (reg_info_p ==
nullptr) {
725 "%s failed to get register info for register index %" PRIu32,
726 __FUNCTION__, reg_num);
737 LLDB_LOGF(log,
"%s failed to read register '%s' index %" PRIu32
": %s",
739 reg_info_p->
name ? reg_info_p->
name :
"<unnamed-register>",
740 reg_num,
error.AsCString());
748 register_object.try_emplace(llvm::to_string(reg_num),
752 return register_object;
756 switch (stop_reason) {
770 return "processor trace";
778 return "async interrupt";
790static llvm::Expected<json::Array>
794 json::Array threads_array;
801 std::string description;
802 if (!thread.GetStopReason(tid_stop_info, description))
803 return llvm::make_error<llvm::StringError>(
804 "failed to get stop reason", llvm::inconvertibleErrorCode());
806 const int signum = tid_stop_info.
signo;
809 "GDBRemoteCommunicationServerLLGS::%s pid %" PRIu64
811 " got signal signo = %d, reason = %d, exc_type = %" PRIu64,
812 __FUNCTION__, process.
GetID(), tid, signum,
816 json::Object thread_obj;
820 thread_obj.try_emplace(
"registers", std::move(*registers));
823 thread_obj.try_emplace(
"tid",
static_cast<int64_t
>(tid));
826 thread_obj.try_emplace(
"signal", signum);
828 const std::string thread_name = thread.GetName();
829 if (!thread_name.empty())
830 thread_obj.try_emplace(
"name", thread_name);
834 thread_obj.try_emplace(
"reason", stop_reason);
836 if (!description.empty())
837 thread_obj.try_emplace(
"description", description);
841 thread_obj.try_emplace(
844 json::Array medata_array;
847 medata_array.push_back(
850 thread_obj.try_emplace(
"medata", std::move(medata_array));
852 threads_array.push_back(std::move(thread_obj));
854 return threads_array;
864 LLDB_LOG(log,
"preparing packet for pid {0} tid {1}", process.
GetID(),
870 std::string description;
871 if (!thread.GetStopReason(tid_stop_info, description))
882 int signum = tid_stop_info.
signo;
885 "pid {0}, tid {1}, got signal signo = {2}, reason = {3}, exc_type = {4}",
886 process.
GetID(), thread.GetID(), signum,
int(tid_stop_info.
reason),
890 response.
PutHex8(signum & 0xff);
898 const std::string thread_name = thread.GetName();
899 if (!thread_name.empty()) {
900 size_t thread_name_len = thread_name.length();
902 if (::strcspn(thread_name.c_str(),
"$#+-;:") == thread_name_len) {
924 uint32_t thread_num = 0;
928 response.
Printf(
"%" PRIx64, listed_thread.GetID());
938 if (thread_num > 1) {
939 const bool threads_with_valid_stop_info_only =
true;
945 unescaped_response.
AsRawOstream() << std::move(*threads_info);
950 "failed to prepare a jstopinfo field for pid {1}: {0}",
956 char delimiter =
':';
968 LLDB_LOGF(log,
"%s failed to read register '%s' index %" PRIu32
": %s",
970 reg_info_p->
name ? reg_info_p->
name :
"<unnamed-register>",
971 reg_to_read,
error.AsCString());
990 const auto expedited_regs =
993 for (
auto ®_num : expedited_regs) {
997 if (reg_info_p !=
nullptr && reg_info_p->
value_regs ==
nullptr) {
1000 if (
error.Success()) {
1001 response.
Printf(
"%.02x:", reg_num);
1007 "GDBRemoteCommunicationServerLLGS::%s failed to read "
1008 "register '%s' index %" PRIu32
": %s",
1010 reg_info_p->
name ? reg_info_p->
name :
"<unnamed-register>",
1011 reg_num,
error.AsCString());
1017 if (reason_str !=
nullptr) {
1018 response.
Printf(
"reason:%s;", reason_str);
1021 if (!description.empty()) {
1052 response.
Printf(
"%s:p%" PRIx64
".%" PRIx64
";", reason_str,
1069 if (response.
Empty())
1089 if (listed_thread.GetID() != thread_to_skip) {
1091 if (!stop_reply.
Empty())
1099 assert(process &&
"process cannot be NULL");
1102 LLDB_LOGF(log,
"GDBRemoteCommunicationServerLLGS::%s called", __FUNCTION__);
1108 "GDBRemoteCommunicationServerLLGS::%s failed to send stop "
1109 "notification for PID %" PRIu64
", state: eStateExited",
1110 __FUNCTION__, process->
GetID());
1141 assert(process &&
"process cannot be NULL");
1144 LLDB_LOGF(log,
"GDBRemoteCommunicationServerLLGS::%s called", __FUNCTION__);
1150 "GDBRemoteCommunicationServerLLGS::%s failed to send stop "
1151 "notification for PID %" PRIu64
", state: eStateExited",
1152 __FUNCTION__, process->
GetID());
1158 assert(process &&
"process cannot be NULL");
1162 "GDBRemoteCommunicationServerLLGS::%s called with "
1163 "NativeProcessProtocol pid %" PRIu64
", state: %s",
1193 "GDBRemoteCommunicationServerLLGS::%s didn't handle state "
1194 "change for pid %" PRIu64
", new state: %s",
1207 std::unique_ptr<NativeProcessProtocol> child_process) {
1219 bool interrupt =
false;
1224 std::chrono::microseconds(0),
error, interrupt, done);
1230 "GDBRemoteCommunicationServerLLGS::%s processing a packet "
1232 __FUNCTION__,
error.AsCString());
1240 std::unique_ptr<Connection> connection) {
1241 IOObjectSP read_object_sp = connection->GetReadObject();
1253 const llvm::json::Value &value) {
1254 std::string json_string;
1255 raw_string_ostream os(json_string);
1260 escaped_response.
PutEscapedBytes(json_string.c_str(), json_string.size());
1267 if ((buffer ==
nullptr) || (len == 0)) {
1286 std::unique_ptr<ConnectionFileDescriptor> conn_up(
1298 "failed to set connection for inferior I/O communication");
1320 LLDB_LOG(log,
"Failed to set up stdio forwarding: {0}",
error);
1334 buffer,
sizeof buffer, std::chrono::microseconds(0), status, &
error);
1345 "GDBRemoteCommunicationServerLLGS::%s Stopping stdio "
1346 "forwarding as communication returned status %d (error: "
1348 __FUNCTION__, status,
error.AsCString());
1380 Expected<TraceStopRequest> stop_request =
1381 json::parse<TraceStopRequest>(packet.
Peek(),
"TraceStopRequest");
1401 Expected<TraceStartRequest> request =
1402 json::parse<TraceStartRequest>(packet.
Peek(),
"TraceStartRequest");
1422 Expected<TraceGetStateRequest> request =
1423 json::parse<TraceGetStateRequest>(packet.
Peek(),
"TraceGetStateRequest");
1440 llvm::Expected<TraceGetBinaryDataRequest> request =
1441 llvm::json::parse<TraceGetBinaryDataRequest>(packet.
Peek(),
1442 "TraceGetBinaryDataRequest");
1446 if (Expected<std::vector<uint8_t>> bytes =
1463 std::vector<std::string> structured_data_plugins =
1467 llvm::json::Value(llvm::json::Array(structured_data_plugins)));
1524 LLDB_LOG(log,
"No debugged process found.");
1530 LLDB_LOG(log,
"Killing process {0}", it->first);
1533 LLDB_LOG(log,
"Failed to kill debugged process {0}: {1}", it->first,
1554 "vKill failed to parse the process id");
1572 packet.
SetFilePos(::strlen(
"QSetDisableASLR:"));
1583 packet.
SetFilePos(::strlen(
"QSetWorkingDir:"));
1625 LLDB_LOG(log,
"process {0} cannot be resumed (state={1})", process.
GetID(),
1644 LLDB_LOGF(log,
"GDBRemoteCommunicationServerLLGS::%s called", __FUNCTION__);
1649 "GDBRemoteCommunicationServerLLGS::%s no debugged process "
1661 const uint32_t signo =
1662 packet.
GetHexMaxU32(
false, std::numeric_limits<uint32_t>::max());
1663 if (signo == std::numeric_limits<uint32_t>::max())
1669 if (*packet.
Peek() ==
';')
1673 packet,
"unexpected content after $C{signal-number}");
1679 LLDB_LOG(log,
"process cannot be resumed (state={0})",
1700 static_cast<int>(signo)};
1704 resume_actions.
Append(action);
1710 LLDB_LOG(log,
"failed to send signal for process {0}: {1}",
1731 LLDB_LOGF(log,
"GDBRemoteCommunicationServerLLGS::%s called", __FUNCTION__);
1736 const bool has_continue_address = (packet.
GetBytesLeft() > 0);
1737 if (has_continue_address) {
1738 LLDB_LOG(log,
"not implemented for c[address] variant [{0} remains]",
1746 "GDBRemoteCommunicationServerLLGS::%s no debugged process "
1767 response.
Printf(
"vCont;c;C;s;S;t");
1788 LLDB_LOGF(log,
"GDBRemoteCommunicationServerLLGS::%s handling vCont packet",
1795 "GDBRemoteCommunicationServerLLGS::%s missing action from "
1801 if (::strcmp(packet.
Peek(),
";s") == 0) {
1807 std::unordered_map<lldb::pid_t, ResumeActionList> thread_actions;
1819 const char action = packet.
GetChar();
1823 if (thread_action.
signal == 0)
1825 packet,
"Could not parse signal in vCont packet C action");
1835 if (thread_action.
signal == 0)
1837 packet,
"Could not parse signal in vCont packet S action");
1868 pid = pid_tid->first;
1869 tid = pid_tid->second;
1875 packet,
"'t' action not supported for individual threads");
1881 LLDB_LOG(log,
"no process selected via Hc");
1890 thread_action.
tid = tid;
1895 packet,
"vCont: p-1 is not valid with a specific tid");
1897 thread_actions[process_it.first].Append(thread_action);
1899 thread_actions[pid].Append(thread_action);
1902 assert(thread_actions.size() >= 1);
1903 if (thread_actions.size() > 1 && !
m_non_stop)
1906 "Resuming multiple processes is supported in non-stop mode only");
1908 for (std::pair<lldb::pid_t, ResumeActionList> x : thread_actions) {
1911 LLDB_LOG(log,
"vCont failed for process {0}: process not debugged",
1928 assert(process_it->second.process_up);
1930 if (process_it->second.process_up->IsRunning()) {
1933 Status error = process_it->second.process_up->Interrupt();
1935 LLDB_LOG(log,
"vCont failed to halt process {0}: {1}", x.first,
1940 LLDB_LOG(log,
"halted process {0}", x.first);
1944 assert(thread_actions.size() == 1);
1960 LLDB_LOG(log,
"setting current thread id to {0}", tid);
1969 LLDB_LOG(log,
"setting continue thread id to {0}", tid);
1983 return x.front() !=
'W' && x.front() !=
'X';
1993 if (!stop_reply.
Empty())
2020 bool force_synchronous) {
2027 if (it.second.process_up->IsRunning())
2037 switch (process_state) {
2063 LLDB_LOG(log,
"pid {0}, current state reporting not handled: {1}",
2064 process.
GetID(), process_state);
2089 const uint32_t reg_index =
2090 packet.
GetHexMaxU32(
false, std::numeric_limits<uint32_t>::max());
2091 if (reg_index == std::numeric_limits<uint32_t>::max())
2122 if (!encoding.empty())
2123 response <<
"encoding:" << encoding <<
';';
2126 if (!format.empty())
2127 response <<
"format:" << format <<
';';
2129 const char *
const register_set_name =
2131 if (register_set_name)
2132 response <<
"set:" << register_set_name <<
';';
2136 response.
Printf(
"ehframe:%" PRIu32
";",
2140 response.
Printf(
"dwarf:%" PRIu32
";",
2144 if (!kind_generic.empty())
2145 response <<
"generic:" << kind_generic <<
';';
2170 LLDB_LOG(log,
"iterating over threads of process {0}", process.
GetID());
2172 LLDB_LOG(log,
"iterated thread tid={0}", thread.GetID());
2173 response.
PutChar(had_any ?
',' :
'm');
2186 bool had_any =
false;
2215 LLDB_LOG(log,
"failed, no thread available");
2222 std::vector<uint8_t> regs_buffer;
2227 if (reg_info ==
nullptr) {
2228 LLDB_LOG(log,
"failed to get register info for register index {0}",
2239 LLDB_LOG(log,
"failed to read register at index {0}", reg_num);
2266 const uint32_t reg_index =
2267 packet.
GetHexMaxU32(
false, std::numeric_limits<uint32_t>::max());
2268 if (reg_index == std::numeric_limits<uint32_t>::max()) {
2270 "GDBRemoteCommunicationServerLLGS::%s failed, could not "
2271 "parse register number from request \"%s\"",
2279 LLDB_LOG(log,
"failed, no thread available");
2290 "GDBRemoteCommunicationServerLLGS::%s failed, requested "
2291 "register %" PRIu32
" beyond register count %" PRIu32,
2299 "GDBRemoteCommunicationServerLLGS::%s failed, requested "
2300 "register %" PRIu32
" returned NULL",
2301 __FUNCTION__, reg_index);
2313 "GDBRemoteCommunicationServerLLGS::%s failed, read of "
2314 "requested register %" PRIu32
" (%s) failed: %s",
2315 __FUNCTION__, reg_index, reg_info->
name,
error.AsCString());
2319 const uint8_t *
const data =
2320 static_cast<const uint8_t *
>(reg_value.
GetBytes());
2323 "GDBRemoteCommunicationServerLLGS::%s failed to get data "
2324 "bytes from requested register %" PRIu32,
2325 __FUNCTION__, reg_index);
2330 for (uint32_t i = 0; i < reg_value.
GetByteSize(); ++i)
2346 const uint32_t reg_index =
2347 packet.
GetHexMaxU32(
false, std::numeric_limits<uint32_t>::max());
2348 if (reg_index == std::numeric_limits<uint32_t>::max()) {
2350 "GDBRemoteCommunicationServerLLGS::%s failed, could not "
2351 "parse register number from request \"%s\"",
2359 packet,
"P packet missing '=' char after register number");
2368 "GDBRemoteCommunicationServerLLGS::%s failed, no thread "
2369 "available (thread index 0)",
2379 "GDBRemoteCommunicationServerLLGS::%s failed, requested "
2380 "register %" PRIu32
" returned NULL",
2381 __FUNCTION__, reg_index);
2389 "GDBRemoteCommunicationServerLLGS::%s failed, requested "
2390 "register %" PRIu32
" beyond register count %" PRIu32,
2406 "GDBRemoteCommunicationServerLLGS::%s failed, write of "
2407 "requested register %" PRIu32
" (%s) failed: %s",
2408 __FUNCTION__, reg_index, reg_info->
name,
error.AsCString());
2423 "GDBRemoteCommunicationServerLLGS::%s failed, H command "
2424 "missing {g,c} variant",
2429 const char h_variant = packet.
GetChar();
2431 switch (h_variant) {
2443 "GDBRemoteCommunicationServerLLGS::%s failed, invalid $H variant %c",
2444 __FUNCTION__, h_variant);
2446 "H variant unsupported, should be c or g");
2450 auto pid_tid = packet.
GetPidTid(default_process ? default_process->
GetID()
2454 inconvertibleErrorCode(),
"Malformed thread-id"));
2463 inconvertibleErrorCode(),
"No current process and no PID provided"));
2469 inconvertibleErrorCode(),
2470 llvm::formatv(
"No process with PID {0} debugged", pid)));
2476 new_process_it->second.process_up->GetThreadByID(tid);
2479 "GDBRemoteCommunicationServerLLGS::%s failed, tid %" PRIu64
2487 switch (h_variant) {
2499 assert(
false &&
"unsupported $H variant - shouldn't get here");
2501 "H variant unsupported, should be c or g");
2516 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
2550 LLDB_LOG(log,
"failed, no process available");
2577 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
2600 const uint64_t byte_count = packet.
GetHexMaxU64(
false, 0);
2601 if (byte_count == 0) {
2603 "GDBRemoteCommunicationServerLLGS::%s nothing to read: "
2604 "zero-length packet",
2610 std::string buf(byte_count,
'\0');
2615 size_t bytes_read = 0;
2617 read_addr, &buf[0], byte_count, bytes_read);
2620 "ReadMemoryWithoutTrap({0}) read {1} of {2} requested bytes (error: {3})",
2621 read_addr, byte_count, bytes_read,
error);
2622 if (bytes_read == 0)
2627 char kind = packet.
GetChar(
'?');
2631 assert(kind ==
'm');
2632 for (
size_t i = 0; i < bytes_read; ++i)
2647 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
2662 Permissions perms = {};
2666 perms |= ePermissionsReadable;
2669 perms |= ePermissionsWritable;
2672 perms |= ePermissionsExecutable;
2696 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
2724 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
2747 const uint64_t byte_count = packet.
GetHexMaxU64(
false, 0);
2748 if (byte_count == 0) {
2749 LLDB_LOG(log,
"nothing to write: zero-length packet");
2756 packet,
"Comma sep missing in M packet after byte length");
2759 std::vector<uint8_t> buf(byte_count, 0);
2765 const uint64_t convert_count = packet.
GetHexBytes(buf, 0);
2766 if (convert_count != byte_count) {
2768 "pid {0} mem {1:x}: asked to write {2} bytes, but only found {3} "
2772 "not match hex-encoded content "
2777 size_t bytes_written = 0;
2781 LLDB_LOG(log,
"pid {0} mem {1:x}: failed to write. Error: {2}",
2786 if (bytes_written == 0) {
2787 LLDB_LOG(log,
"pid {0} mem {1:x}: wrote 0 of {2} requested bytes",
2811 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
2838 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
2844 packet.
SetFilePos(strlen(
"qMemoryRegionInfo:"));
2865 response.
Printf(
"start:%" PRIx64
";size:%" PRIx64
";",
2921 LLDB_LOG(log,
"failed, no process available");
2929 packet,
"Too short Z packet, missing software/hardware specifier");
2931 bool want_breakpoint =
true;
2932 bool want_hardware =
false;
2933 uint32_t watch_flags = 0;
2937 switch (stoppoint_type) {
2939 want_hardware =
false;
2940 want_breakpoint =
true;
2943 want_hardware =
true;
2944 want_breakpoint =
true;
2948 want_hardware =
true;
2949 want_breakpoint =
false;
2953 want_hardware =
true;
2954 want_breakpoint =
false;
2958 want_hardware =
true;
2959 want_breakpoint =
false;
2963 packet,
"Z packet had invalid software/hardware specifier");
2968 packet,
"Malformed Z packet, expecting comma after stoppoint type");
2977 packet,
"Malformed Z packet, expecting comma after address");
2980 const uint32_t size =
2981 packet.
GetHexMaxU32(
false, std::numeric_limits<uint32_t>::max());
2982 if (size == std::numeric_limits<uint32_t>::max())
2984 packet,
"Malformed Z packet, failed to parse size argument");
2986 if (want_breakpoint) {
2990 if (
error.Success())
2993 LLDB_LOG(log,
"pid {0} failed to set breakpoint: {1}",
2999 addr, size, watch_flags, want_hardware);
3000 if (
error.Success())
3003 LLDB_LOG(log,
"pid {0} failed to set watchpoint: {1}",
3015 LLDB_LOG(log,
"failed, no process available");
3023 packet,
"Too short z packet, missing software/hardware specifier");
3025 bool want_breakpoint =
true;
3026 bool want_hardware =
false;
3030 switch (stoppoint_type) {
3032 want_breakpoint =
true;
3033 want_hardware =
true;
3036 want_breakpoint =
true;
3039 want_breakpoint =
false;
3042 want_breakpoint =
false;
3045 want_breakpoint =
false;
3049 packet,
"z packet had invalid software/hardware specifier");
3054 packet,
"Malformed z packet, expecting comma after stoppoint type");
3063 packet,
"Malformed z packet, expecting comma after address");
3074 if (want_breakpoint) {
3078 if (
error.Success())
3081 LLDB_LOG(log,
"pid {0} failed to remove breakpoint: {1}",
3087 if (
error.Success())
3090 LLDB_LOG(log,
"pid {0} failed to remove watchpoint: {1}",
3105 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
3143llvm::Expected<std::unique_ptr<llvm::MemoryBuffer>>
3148 return llvm::createStringError(llvm::inconvertibleErrorCode(),
3149 "No thread available");
3157 response.
Printf(
"<?xml version=\"1.0\"?>\n");
3158 response.
Printf(
"<target version=\"1.0\">\n");
3162 response.
Printf(
"<architecture>%s</architecture>\n",
3169 response.
Indent(
"<feature>\n");
3172 if (registers_count)
3175 llvm::StringSet<> field_enums_seen;
3176 for (
int reg_index = 0; reg_index < registers_count; reg_index++) {
3182 "%s failed to get register info for register index %" PRIu32,
3183 "target.xml", reg_index);
3195 response.
Printf(
"<reg name=\"%s\" bitsize=\"%" PRIu32
3196 "\" regnum=\"%d\" ",
3206 if (!encoding.empty())
3207 response <<
"encoding=\"" << encoding <<
"\" ";
3210 if (!format.empty())
3211 response <<
"format=\"" << format <<
"\" ";
3216 const char *
const register_set_name =
3218 if (register_set_name)
3219 response <<
"group=\"" << register_set_name <<
"\" ";
3223 response.
Printf(
"ehframe_regnum=\"%" PRIu32
"\" ",
3228 response.
Printf(
"dwarf_regnum=\"%" PRIu32
"\" ",
3232 if (!kind_generic.empty())
3233 response <<
"generic=\"" << kind_generic <<
"\" ";
3243 response.
PutCString(
"invalidate_regnums=\"");
3251 if (registers_count)
3254 response.
Indent(
"</feature>\n");
3256 response.
Indent(
"</target>\n");
3257 return MemoryBuffer::getMemBufferCopy(response.
GetString(),
"target.xml");
3260llvm::Expected<std::unique_ptr<llvm::MemoryBuffer>>
3262 llvm::StringRef annex) {
3266 return llvm::createStringError(llvm::inconvertibleErrorCode(),
3267 "No process available");
3270 if (
object ==
"auxv") {
3273 if (!buffer_or_error)
3274 return llvm::errorCodeToError(buffer_or_error.getError());
3275 return std::move(*buffer_or_error);
3278 if (
object ==
"siginfo") {
3281 return llvm::createStringError(llvm::inconvertibleErrorCode(),
3282 "no current thread");
3284 auto buffer_or_error = thread->GetSiginfo();
3285 if (!buffer_or_error)
3286 return buffer_or_error.takeError();
3287 return std::move(*buffer_or_error);
3290 if (
object ==
"libraries-svr4") {
3293 return library_list.takeError();
3296 response.
Printf(
"<library-list-svr4 version=\"1.0\">");
3297 for (
auto const &library : *library_list) {
3298 response.
Printf(
"<library name=\"%s\" ",
3300 response.
Printf(
"lm=\"0x%" PRIx64
"\" ", library.link_map);
3301 response.
Printf(
"l_addr=\"0x%" PRIx64
"\" ", library.base_addr);
3302 response.
Printf(
"l_ld=\"0x%" PRIx64
"\" />", library.ld_addr);
3304 response.
Printf(
"</library-list-svr4>");
3305 return MemoryBuffer::getMemBufferCopy(response.
GetString(), __FUNCTION__);
3308 if (
object ==
"features" && annex ==
"target.xml")
3311 return llvm::make_error<UnimplementedError>();
3317 SmallVector<StringRef, 5> fields;
3319 StringRef(packet.
GetStringRef()).split(fields,
':', 4);
3320 if (fields.size() != 5)
3322 StringRef &xfer_object = fields[1];
3323 StringRef &xfer_action = fields[2];
3324 StringRef &xfer_annex = fields[3];
3326 if (xfer_action !=
"read")
3329 const uint64_t xfer_offset =
3330 offset_data.
GetHexMaxU64(
false, std::numeric_limits<uint64_t>::max());
3331 if (xfer_offset == std::numeric_limits<uint64_t>::max())
3334 if (offset_data.
GetChar() !=
',')
3336 "qXfer packet missing comma after offset");
3338 const uint64_t xfer_length =
3339 offset_data.
GetHexMaxU64(
false, std::numeric_limits<uint64_t>::max());
3340 if (xfer_length == std::numeric_limits<uint64_t>::max())
3344 std::string buffer_key = (xfer_object + xfer_action + xfer_annex).str();
3351 .insert(std::make_pair(buffer_key, std::move(*buffer_up)))
3357 bool done_with_buffer =
false;
3358 llvm::StringRef buffer = buffer_it->second->getBuffer();
3359 if (xfer_offset >= buffer.size()) {
3362 done_with_buffer =
true;
3365 buffer = buffer.drop_front(xfer_offset);
3368 if (xfer_length >= buffer.size()) {
3371 done_with_buffer =
true;
3375 buffer = buffer.take_front(xfer_length);
3381 if (done_with_buffer)
3393 packet.
SetFilePos(strlen(
"QSaveRegisterState"));
3400 packet,
"No thread specified in QSaveRegisterState packet");
3403 "No thread was is set with the Hg packet");
3413 LLDB_LOG(log,
"pid {0} failed to save all register values: {1}",
3421 "GetNextRegisterSaveID() returned an existing register save id");
3431 response.
Printf(
"%" PRIu32, save_id);
3441 packet.
SetFilePos(strlen(
"QRestoreRegisterState:"));
3444 packet,
"QRestoreRegisterState packet missing register save id");
3446 const uint32_t save_id = packet.
GetU32(0);
3448 LLDB_LOG(log,
"QRestoreRegisterState packet has malformed save id, "
3449 "expecting decimal uint32_t");
3458 packet,
"No thread specified in QRestoreRegisterState packet");
3461 "No thread was is set with the Hg packet");
3476 "pid {0} does not have a register set save buffer for id {1}",
3480 register_data_sp = it->second;
3488 LLDB_LOG(log,
"pid {0} failed to restore all register values: {1}",
3510 "vAttach failed to parse the process id");
3514 "GDBRemoteCommunicationServerLLGS::%s attempting to attach to "
3522 "GDBRemoteCommunicationServerLLGS::%s failed to attach to "
3523 "pid %" PRIu64
": %s\n",
3524 __FUNCTION__, pid,
error.AsCString());
3547 std::string process_name;
3550 "vAttachWait failed to parse process name");
3552 LLDB_LOG(log,
"attempting to attach to process named '{0}'", process_name);
3556 LLDB_LOG(log,
"failed to attach to process named '{0}': {1}", process_name,
3586 std::string process_name;
3589 "vAttachOrWait failed to parse process name");
3591 LLDB_LOG(log,
"attempting to attach to process named '{0}'", process_name);
3595 LLDB_LOG(log,
"failed to attach to process named '{0}': {1}", process_name,
3613 if (!s.consume_front(
"vRun;"))
3616 llvm::SmallVector<llvm::StringRef, 16> argv;
3619 for (llvm::StringRef hex_arg : argv) {
3624 LLDB_LOGF(log,
"LLGSPacketHandler::%s added arg: \"%s\"", __FUNCTION__,
3663 llvm::Error detach_error = llvm::Error::success();
3664 bool detached =
false;
3669 "GDBRemoteCommunicationServerLLGS::%s detaching %" PRId64,
3670 __FUNCTION__, it->first);
3671 if (llvm::Error e = it->second.process_up->Detach().ToError())
3672 detach_error = llvm::joinErrors(std::move(detach_error), std::move(e));
3703 packet.
SetFilePos(strlen(
"qThreadStopInfo"));
3707 "GDBRemoteCommunicationServerLLGS::%s failed, could not "
3708 "parse thread id from request \"%s\"",
3728 const bool threads_with_valid_stop_info_only =
false;
3729 llvm::Expected<json::Value> threads_info =
3731 if (!threads_info) {
3733 "failed to prepare a packet for pid {1}: {0}",
3752 packet.
SetFilePos(strlen(
"qWatchpointSupportInfo"));
3761 if (hw_debug_cap == std::nullopt)
3762 response.
Printf(
"num:0;");
3764 response.
Printf(
"num:%d;", hw_debug_cap->second);
3777 packet.
SetFilePos(strlen(
"qFileLoadAddress:"));
3781 std::string file_name;
3794 response.
PutHex64(file_load_address);
3801 std::vector<int> signals;
3807 int signal = packet.
GetS32(-1, 16);
3810 signals.push_back(signal);
3813 char separator = packet.
GetChar();
3814 if (separator ==
'\0')
3816 if (separator !=
';')
3818 " expected semicolon.");
3842 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
3852 const char *current_char = packet.
Peek();
3853 if (!current_char || *current_char ==
',')
3858 char previous_char = packet.
GetChar();
3859 current_char = packet.
Peek();
3861 if (previous_char !=
',' || (current_char && *current_char ==
':'))
3863 "Invalid addr,length pair in qMemTags packet");
3867 packet,
"Too short qMemtags: packet (looking for length)");
3871 const char *invalid_type_err =
"Invalid type field in qMemTags: packet";
3877 const char *first_type_char = packet.
Peek();
3878 if (first_type_char && (*first_type_char ==
'+' || *first_type_char ==
'-'))
3885 packet.
GetU64(std::numeric_limits<uint64_t>::max(), 16);
3888 raw_type > std::numeric_limits<uint32_t>::max() ||
3897 uint32_t raw_type_32 = raw_type;
3898 int32_t type =
reinterpret_cast<int32_t &
>(raw_type_32);
3901 std::vector<uint8_t> tags;
3923 "GDBRemoteCommunicationServerLLGS::%s failed, no process available",
3933 const char *current_char = packet.
Peek();
3934 if (!current_char || *current_char ==
',')
3939 char previous_char = packet.
GetChar();
3940 current_char = packet.
Peek();
3942 if (previous_char !=
',' || (current_char && *current_char ==
':'))
3944 "Invalid addr,length pair in QMemTags packet");
3948 packet,
"Too short QMemtags: packet (looking for length)");
3952 const char *invalid_type_err =
"Invalid type field in QMemTags: packet";
3957 const char *first_type_char = packet.
Peek();
3958 if (first_type_char && (*first_type_char ==
'+' || *first_type_char ==
'-'))
3966 packet.
GetU64(std::numeric_limits<uint64_t>::max(), 16);
3967 if (raw_type > std::numeric_limits<uint32_t>::max())
3972 uint32_t raw_type_32 = raw_type;
3973 int32_t type =
reinterpret_cast<int32_t &
>(raw_type_32);
3978 "Missing tag data in QMemTags: packet");
3981 const char *invalid_data_err =
"Invalid tag data in QMemTags: packet";
3988 std::vector<uint8_t> tag_data;
3993 tag_data.resize(byte_count);
3994 size_t converted_bytes = packet.
GetHexBytes(tag_data, 0);
3995 if (converted_bytes != byte_count) {
4013 std::string path_hint;
4016 assert(packet_str.starts_with(
"qSaveCore"));
4017 if (packet_str.consume_front(
"qSaveCore;")) {
4018 for (
auto x : llvm::split(packet_str,
';')) {
4019 if (x.consume_front(
"path-hint:"))
4043 assert(packet_str.starts_with(
"QNonStop:"));
4044 packet_str.consume_front(
"QNonStop:");
4045 if (packet_str ==
"0") {
4049 if (process_it.second.process_up->IsRunning()) {
4051 Status error = process_it.second.process_up->Interrupt();
4054 "while disabling nonstop, failed to halt process {0}: {1}",
4055 process_it.first,
error);
4069 }
else if (packet_str ==
"1") {
4081 std::deque<std::string> &queue) {
4125 return interrupt_res;
4137 inconvertibleErrorCode(),
"Malformed thread-id"));
4146 inconvertibleErrorCode(),
"No current process and no PID provided"));
4154 if (!new_process_it->second.process_up->GetThreadByID(tid))
4168 connection->Disconnect(&
error);
4170 if (
error.Success()) {
4172 "GDBRemoteCommunicationServerLLGS::%s disconnect process "
4173 "terminal stdio - SUCCESS",
4177 "GDBRemoteCommunicationServerLLGS::%s disconnect process "
4178 "terminal stdio - FAIL: %s",
4179 __FUNCTION__,
error.AsCString());
4198 else if (current_tid == 0) {
4210 "GDBRemoteCommunicationServerLLGS::%s gdb-remote parse "
4211 "error: expected ';' prior to start of thread suffix: packet "
4221 if (strncmp(packet.
Peek(),
"thread:", strlen(
"thread:")) != 0) {
4223 "GDBRemoteCommunicationServerLLGS::%s gdb-remote parse "
4224 "error: expected 'thread:' but not found, packet contents = "
4268 ->GetLoadedModuleFileSpec(module_path.c_str(), file_spec)
4279 llvm::StringRef value) {
4281 for (
const char &c : value) {
4304 const llvm::ArrayRef<llvm::StringRef> client_features) {
4305 std::vector<std::string> ret =
4307 ret.insert(ret.end(), {
4308 "QThreadSuffixSupported+",
4309 "QListThreadsInStopReply+",
4310 "qXfer:features:read+",
4317 if (
bool(plugin_features & Extension::pass_signals))
4318 ret.push_back(
"QPassSignals+");
4319 if (
bool(plugin_features & Extension::auxv))
4320 ret.push_back(
"qXfer:auxv:read+");
4321 if (
bool(plugin_features & Extension::libraries_svr4))
4322 ret.push_back(
"qXfer:libraries-svr4:read+");
4323 if (
bool(plugin_features & Extension::siginfo_read))
4324 ret.push_back(
"qXfer:siginfo:read+");
4325 if (
bool(plugin_features & Extension::memory_tagging))
4326 ret.push_back(
"memory-tagging+");
4327 if (
bool(plugin_features & Extension::savecore))
4328 ret.push_back(
"qSaveCore+");
4332 for (llvm::StringRef x : client_features)
4334 llvm::StringSwitch<Extension>(x)
4335 .Case(
"multiprocess+", Extension::multiprocess)
4336 .Case(
"fork-events+", Extension::fork)
4337 .Case(
"vfork-events+", Extension::vfork)
4352 ret.push_back(
"multiprocess+");
4354 ret.push_back(
"fork-events+");
4356 ret.push_back(
"vfork-events+");
4382 response.
Format(
"p{0:x-}.", pid);
4383 response.
Format(
"{0:x-}", tid);
4388 bool reverse_connect) {
4390 if (std::optional<URI> url =
URI::Parse(url_arg)) {
4391 if (reverse_connect)
4392 return url_arg.str();
4397 std::string new_url = llvm::StringSwitch<std::string>(url->scheme)
4398 .Case(
"tcp",
"listen")
4399 .Case(
"unix",
"unix-accept")
4400 .Case(
"unix-abstract",
"unix-abstract-accept")
4401 .Default(url->scheme.str());
4402 llvm::append_range(new_url, url_arg.substr(url->scheme.size()));
4406 std::string host_port = url_arg.str();
4409 if (url_arg.starts_with(
":"))
4410 host_port.insert(0,
"localhost");
4414 return (reverse_connect ?
"connect://" :
"listen://") + host_port;
4417 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,...)
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()
OptionalBool GetWritable() const
ConstString GetName() const
OptionalBool GetMemoryTagged() const
OptionalBool GetReadable() const
OptionalBool GetExecutable() const
OptionalBool IsShadowStack() 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)
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::@150217207351365026144342340310063367220052123157::@063112131000362061214367311025355347052261351334 exception
struct lldb_private::ThreadStopInfo::@150217207351365026144342340310063367220052123157::@160153054057323247234046020077052225105165155075 fork
union lldb_private::ThreadStopInfo::@150217207351365026144342340310063367220052123157 details
static std::optional< URI > Parse(llvm::StringRef uri)