38#include "llvm/Support/ConvertUTF.h"
39#include "llvm/Support/ErrorExtras.h"
40#include "llvm/Support/Format.h"
41#include "llvm/Support/Threading.h"
42#include "llvm/Support/raw_ostream.h"
57std::string GetProcessExecutableName(
HANDLE process_handle) {
58 std::vector<wchar_t> file_name;
59 DWORD file_name_size = MAX_PATH;
63 file_name.resize(file_name_size);
64 copied = ::GetModuleFileNameExW(process_handle,
nullptr, file_name.data(),
66 }
while (copied >= file_name_size);
67 file_name.resize(copied);
69 llvm::convertWideToUTF8(file_name.data(), result);
73std::string GetProcessExecutableName(DWORD pid) {
74 std::string file_name;
76 ::OpenProcess(PROCESS_QUERY_INFORMATION | PROCESS_VM_READ, FALSE, pid);
77 if (process_handle !=
nullptr) {
78 file_name = GetProcessExecutableName(process_handle);
79 ::CloseHandle(process_handle);
97 llvm::StringRef use_lldb_server = ::getenv(
"LLDB_USE_LLDB_SERVER");
98 return use_lldb_server.equals_insensitive(
"on") ||
99 use_lldb_server.equals_insensitive(
"yes") ||
100 use_lldb_server.equals_insensitive(
"1") ||
101 use_lldb_server.equals_insensitive(
"true");
117 return "Process plugin for Windows";
136 LLDB_LOG(log,
"bp_site = {0:x}, id={1}, addr={2:x}", bp_site,
140 if (!
error.Success())
147 LLDB_LOG(log,
"bp_site = {0:x}, id={1}, addr={2:x}", bp_site,
152 if (!
error.Success())
167 LLDB_LOG(log,
"process {0} is in state {1}. Resuming for detach...",
171 LLDB_LOG(log,
"resuming {0} threads for detach.",
176 auto thread = std::static_pointer_cast<TargetThreadWindows>(
178 Status result = thread->DoResume();
182 "Trying to resume thread at index {0}, but failed with "
201 "error: process {0} in state = {1}, but "
202 "cannot detach it in this state.",
203 GetID(), private_state);
232 llvm::sys::ScopedLock lock(
m_mutex);
236 "{0} does not support reverse execution of processes",
GetPluginName());
243 LLDB_LOG(log,
"process {0} is in state {1}. Resuming...",
251 auto thread = std::static_pointer_cast<TargetThreadWindows>(
253 Status result = thread->DoResume();
258 "Trying to resume thread at index {0}, but failed with error {1}.",
271 if (active_exception) {
279 LLDB_LOG(log,
"error: process {0} is in state {1}. Returning...",
305 llvm::sys::ScopedLock lock(
m_mutex);
321 const int addr_min_width = 2 + 8;
323 const std::vector<ULONG_PTR> &args = exception->GetExceptionArguments();
324 switch (exception->GetExceptionCode()) {
325 case EXCEPTION_ACCESS_VIOLATION: {
330 const int access_violation_code = args[0];
332 switch (access_violation_code) {
334 stream <<
"Access violation reading";
337 stream <<
"Access violation writing";
340 stream <<
"User-mode data execution prevention (DEP) violation at";
343 stream <<
"Unknown access violation (code " << access_violation_code
347 stream <<
" location "
348 << llvm::format_hex(access_violation_address, addr_min_width);
351 case EXCEPTION_IN_PAGE_ERROR: {
356 const int page_load_error_code = args[0];
358 const DWORD underlying_code = args[2];
359 switch (page_load_error_code) {
361 stream <<
"In page error reading";
364 stream <<
"In page error writing";
367 stream <<
"User-mode data execution prevention (DEP) violation at";
370 stream <<
"Unknown page loading error (code " << page_load_error_code
374 stream <<
" location "
375 << llvm::format_hex(page_load_error_address, addr_min_width)
376 <<
" (status code " << llvm::format_hex(underlying_code, 8) <<
")";
384 llvm::sys::ScopedLock lock(
m_mutex);
387 LLDB_LOG(log,
"no active session. Returning...");
393 std::weak_ptr<ExceptionRecord> exception_record =
396 if (!active_exception) {
398 "there is no active exception in process {0}. Why is the "
405 m_thread_list.SetSelectedThreadByID(active_exception->GetThreadID());
411 uint64_t
pc = register_context->GetPC();
417 stop_thread->SetThreadStoppedAtUnexecutedBP(
pc);
419 switch (active_exception->GetExceptionCode()) {
420 case EXCEPTION_SINGLE_STEP: {
422 stop_thread->GetRegisterContext().get());
427 "Single-stepped onto a watchpoint in process {0} at address "
428 "{1:x} with watchpoint {2}",
432 stop_thread->SetStopInfo(stop_info);
437 LLDB_LOG(log,
"single stepping thread {0}", stop_thread->GetID());
439 stop_thread->SetStopInfo(stop_info);
444 case EXCEPTION_BREAKPOINT: {
445 int breakpoint_size = 1;
446 switch (
GetTarget().GetArchitecture().GetMachine()) {
447 case llvm::Triple::aarch64:
451 case llvm::Triple::arm:
452 case llvm::Triple::thumb:
456 case llvm::Triple::x86:
457 case llvm::Triple::x86_64:
462 LLDB_LOG(log,
"Unknown breakpoint size for architecture");
467 pc = register_context->GetPC() - breakpoint_size;
472 "detected breakpoint in process {0} at address {1:x} with "
473 "breakpoint site {2}",
477 stop_thread->SetThreadHitBreakpointSite();
478 if (site->ValidForThisThread(*stop_thread)) {
480 "Breakpoint site {0} is valid for this thread ({1:x}), "
481 "creating stop info.",
482 site->GetID(), stop_thread->GetID());
485 *stop_thread, site->GetID());
486 register_context->SetPC(
pc);
489 "Breakpoint site {0} is not valid for this thread, "
490 "creating empty stop info.",
493 stop_thread->SetStopInfo(stop_info);
499 "No breakpoint site matches for this thread. __debugbreak()? "
500 "Creating stop info with the exception.");
509 llvm::raw_string_ostream desc_stream(desc);
510 desc_stream <<
"Exception "
511 << llvm::format_hex(active_exception->GetExceptionCode(), 8)
512 <<
" encountered at address "
513 << llvm::format_hex(active_exception->GetExceptionAddress(), 8);
518 stop_thread->SetStopInfo(stop_info);
526 bool plugin_specified_by_name) {
527 if (plugin_specified_by_name)
531 ModuleSP exe_module_sp(target_sp->GetExecutableModule());
532 if (exe_module_sp.get())
545 int continued_threads = 0;
546 int exited_threads = 0;
551 auto exited_thread_iter =
553 if (exited_thread_iter ==
m_session_data->m_exited_threads.end()) {
569 new_thread_list.
AddThread(thread_info.second);
576 LLDB_LOG(log,
"{0} new threads, {1} old threads, {2} exited threads.",
577 new_threads, continued_threads, exited_threads);
600 return HostInfo::GetArchitecture();
605 size_t bytes_read = 0;
612 size_t bytes_written = 0;
614 return bytes_written;
653 LLDB_LOG(log,
"Process {0} exited with code {1}",
GetID(), exit_code);
657 m_pty->SetStopping(
true);
665 ModuleSP executable_module = target->GetExecutableModule();
667 unloaded_modules.
Append(executable_module);
668 target->ModulesDidUnload(unloaded_modules,
true);
685 for (
int consec_empty = 0; consec_empty < 3;) {
690 if (!::PeekNamedPipe(pipe,
nullptr, 0,
nullptr, &avail,
nullptr))
697 if (consec_empty < 3)
706 LLDB_LOG(log,
"Debugger connected to process {0}. Image base = {1:x}",
707 debugger->GetProcess().GetProcessId(), image_base);
711 const DWORD pid = debugger->GetProcess().GetProcessId();
712 const std::string file_name = GetProcessExecutableName(pid);
713 if (file_name.empty()) {
717 FileSpec executable_file(file_name);
722 GetTarget().GetOrCreateModule(module_spec, true , &error);
730 dyld->OnLoadModule(module,
ModuleSpec(), image_base);
736 llvm::sys::ScopedLock lock(
m_mutex);
738 const HostThread &host_main_thread = debugger->GetMainThread();
740 std::make_shared<TargetThreadWindows>(*
this, host_main_thread);
743 main_thread->SetID(
id);
752 llvm::sys::ScopedLock lock(
m_mutex);
763 "Debugger thread reported exception {0:x} at address {1:x}, "
764 "but there is no session.",
778 case EXCEPTION_BREAKPOINT:
785 "Hit loader breakpoint at address {0:x}, setting initial stop event.",
790 LLDB_LOG(log,
"Hit non-loader breakpoint at address {0:x}.",
801 case EXCEPTION_SINGLE_STEP:
808 "Debugger thread reported exception {0:x} at address {1:x} "
809 "(first_chance={2})",
824 llvm::sys::ScopedLock lock(
m_mutex);
826 ThreadSP thread = std::make_shared<TargetThreadWindows>(*
this, new_thread);
829 tid_t id = native_new_thread.GetThreadId();
834 for (
const std::map<int, WatchpointInfo>::value_type &p :
m_watchpoints) {
836 thread->GetRegisterContext().get());
838 p.second.size, p.second.read,
844 llvm::sys::ScopedLock lock(
m_mutex);
864 dyld->OnLoadModule(
nullptr, module_spec, module_addr);
869 dyld->OnUnloadModule(module_addr);
874 uint16_t length_lower_word) {
877 llvm::SmallVector<char, 256> buffer;
879 ReadDebugString(debug_string_addr, is_unicode, length_lower_word, buffer);
882 "Failed to read debug string at {1:x} (size & 0xffff={2}, "
884 debug_string_addr, length_lower_word, is_unicode);
891 assert(buffer.size() % 2 == 0);
892 llvm::ArrayRef<unsigned short> utf16(
893 reinterpret_cast<const unsigned short *
>(buffer.data()),
896 if (!llvm::convertUTF16ToUTF8String(utf16, out)) {
897 LLDB_LOG(log,
"Debug string is not valid Utf 16");
909 uint16_t length_lower_word,
911 if (is_unicode && length_lower_word % 2 != 0)
912 return llvm::createStringError(
913 "Utf16 string can't have uneven size in bytes");
915 const auto is_zero_terminated = [&] {
918 return output.size() >= 2 && output.back() == 0 &&
919 output[output.size() - 2] == 0;
921 return !output.empty() && output.back() == 0;
929 size_t start = length_lower_word == 0 ? 1 : 0;
930 for (
size_t i = start; i < 16; ++i) {
931 output.resize_for_overwrite(length_lower_word + i * (1 << 16));
932 size_t chunk_size = i == 0 ? length_lower_word : (1 << 16);
933 lldb::addr_t addr = debug_string_addr + output.size_in_bytes() - chunk_size;
939 return error.takeError();
941 if (bytes_read != chunk_size) {
942 return llvm::createStringErrorV(
943 "Expected to read {0} bytes, but read {1}", chunk_size, bytes_read);
946 if (is_zero_terminated())
950 if (!is_zero_terminated())
951 return llvm::createStringError(
"String is 1 MiB or larger");
954 output.pop_back_n(is_unicode ? 2 : 1);
955 return llvm::Error::success();
959 llvm::sys::ScopedLock lock(
m_mutex);
966 "Error {0} occurred during debugging. Unexpected behavior "
977 "Error {0} occurred launching the process before the initial stop. {1}",
990 auto exc =
m_session_data->m_debugger->GetActiveException().lock();
993 return exc->GetExceptionCode();
999 if (wp_sp->IsEnabled()) {
1000 wp_sp->SetEnabled(
true, notify);
1012 "Can't find free slot for watchpoint %i", wp_sp->GetID());
1015 info.
address = wp_sp->GetLoadAddress();
1016 info.
size = wp_sp->GetByteSize();
1017 info.
read = wp_sp->WatchpointRead();
1018 info.
write = wp_sp->WatchpointWrite() || wp_sp->WatchpointModify();
1023 thread->GetRegisterContext().get());
1027 "Can't enable watchpoint %i on thread 0x%llx", wp_sp->GetID(),
1036 thread->GetRegisterContext().get());
1045 wp_sp->SetEnabled(
true, notify);
1053 if (!wp_sp->IsEnabled()) {
1054 wp_sp->SetEnabled(
false, notify);
1061 "Info about watchpoint %i is not found", wp_sp->GetID());
1068 thread->GetRegisterContext().get());
1069 if (!reg_ctx->RemoveHardwareBreakpoint(it->second.slot_id)) {
1071 "Can't disable watchpoint %i on thread 0x%llx", wp_sp->GetID(),
1082 wp_sp->SetEnabled(
false, notify);
1096 CreateEvent(nullptr, FALSE,
1105 std::lock_guard<std::mutex> guard(
m_mutex);
1121 DWORD bytesAvailable = 0;
1122 if (PeekNamedPipe(hStdin,
nullptr, 0,
nullptr, &bytesAvailable,
nullptr)) {
1123 if (bytesAvailable > 0)
1128 INPUT_RECORD inputRecord;
1130 if (!PeekConsoleInput(hStdin, &inputRecord, 1, &numRead))
1131 return llvm::createStringError(
"failed to peek standard input");
1136 if (inputRecord.EventType == KEY_EVENT &&
1137 inputRecord.Event.KeyEvent.bKeyDown &&
1138 inputRecord.Event.KeyEvent.uChar.AsciiChar != 0)
1141 if (!ReadConsoleInput(hStdin, &inputRecord, 1, &numRead))
1142 return llvm::createStringError(
"failed to read standard input");
1159 bool isConsole = GetConsoleMode(hStdin, &consoleMode) != 0;
1164 DWORD oldConsoleMode = consoleMode;
1165 SetConsoleMode(hStdin,
1166 consoleMode & ~ENABLE_LINE_INPUT & ~ENABLE_ECHO_INPUT);
1170 std::lock_guard<std::mutex> guard(
m_mutex);
1175 DWORD result = WaitForMultipleObjects(2, waitHandles, FALSE, INFINITE);
1179 case WAIT_OBJECT_0: {
1182 if (!hasInputOrErr) {
1185 "failed to process debuggee's IO: {0}");
1190 if (!*hasInputOrErr)
1196 if (!ReadFile(hStdin, &ch, 1, &read,
nullptr) || read != 1)
1200 if (!WriteFile(
m_write_file, &ch, 1, &written,
nullptr) || written != 1)
1204 case WAIT_OBJECT_0 + 1: {
1221 SetConsoleMode(hStdin, oldConsoleMode);
1225 std::lock_guard<std::mutex> guard(
m_mutex);
1267 if (
m_pty ==
nullptr)
1270 std::make_unique<ConnectionConPTY>(
m_pty));
1281 this,
m_pty->GetSTDINHandle());
static llvm::raw_ostream & error(Stream &strm)
#define LLDB_LOG(log,...)
The LLDB_LOG* macros defined below are the way to emit log messages.
#define LLDB_LOG_ERROR(log, error,...)
#define LLDB_LOG_VERBOSE(log,...)
#define LLDB_PLUGIN_DEFINE_ADV(ClassName, PluginName)
A section + offset based address class.
lldb::addr_t GetLoadAddress(Target *target) const
Get the load address.
bool IsValid() const
Check if the object state is valid.
An architecture specification class.
Class that manages the actual breakpoint that will be inserted into the running program.
static llvm::StringRef GetPluginNameStatic()
static DynamicLoader * FindPlugin(Process *process, llvm::StringRef plugin_name)
Find a dynamic loader plugin for a given process.
DWORD GetExceptionCode() const
lldb::addr_t GetExceptionAddress() const
bool Exists(const FileSpec &file_spec) const
Returns whether the given file exists.
static FileSystem & Instance()
void Resolve(llvm::SmallVectorImpl< char > &path, bool force_make_absolute=false)
Resolve path to make it canonical.
An abstract base class for files.
HostNativeThread & GetNativeThread()
bool Interrupt() override
NativeFile m_read_file
Read from this file (usually actual STDIN for LLDB)
void SetIsRunning(bool running)
~IOHandlerProcessSTDIOWindows() override
llvm::Expected< bool > ConsoleHasTextInput(const HANDLE hStdin)
Peek the console for input.
std::atomic< ControlOp > m_pending_op
HANDLE m_write_file
Write to this file (usually the primary pty for getting io to debuggee)
IOHandlerProcessSTDIOWindows(Process *process, HANDLE conpty_input)
IOHandler(Debugger &debugger, IOHandler::Type type)
A collection class for Module objects.
void Append(const lldb::ModuleSP &module_sp, bool notify=true)
Append a module to the module list.
A class that describes an executable image and its associated object and symbol files.
A plug-in interface definition class for object file parsers.
virtual lldb_private::Address GetImageInfoAddress(Target *target)
Similar to Process::GetImageInfoAddress().
static bool RegisterPlugin(llvm::StringRef name, llvm::StringRef description, ABICreateInstance create_callback)
static bool UnregisterPlugin(ABICreateInstance create_callback)
Status WriteMemory(lldb::addr_t addr, const void *buf, size_t size, size_t &bytes_written)
Status DestroyProcess(lldb::StateType process_state)
Status LaunchProcess(ProcessLaunchInfo &launch_info, DebugDelegateSP delegate)
Status GetMemoryRegionInfo(lldb::addr_t load_addr, MemoryRegionInfo &range_info)
std::unique_ptr< ProcessWindowsData > m_session_data
Status AllocateMemory(size_t size, uint32_t permissions, lldb::addr_t &addr)
Status AttachProcess(lldb::pid_t pid, const ProcessAttachInfo &attach_info, DebugDelegateSP delegate)
lldb::pid_t GetDebuggedProcessId() const
Status ReadMemory(lldb::addr_t addr, void *buf, size_t size, size_t &bytes_read)
virtual void OnExitProcess(uint32_t exit_code)
Status HaltProcess(bool &caused_stop)
Status DeallocateMemory(lldb::addr_t addr)
lldb::pid_t GetProcessID() const
std::shared_ptr< PTY > TakePTY()
void OnLoadDll(const ModuleSpec &module_spec, lldb::addr_t module_addr) override
ProcessWindows(lldb::TargetSP target_sp, lldb::ListenerSP listener_sp)
bool DoUpdateThreadList(ThreadList &old_thread_list, ThreadList &new_thread_list) override
Update the thread list following process plug-in's specific logic.
void RefreshStateAfterStop() override
Currently called as part of ShouldStop.
void OnDebuggerConnected(lldb::addr_t image_base) override
Status DoDeallocateMemory(lldb::addr_t ptr) override
Actually deallocate memory in the process.
Status DoDestroy() override
std::shared_ptr< PTY > m_pty
Status EnableBreakpointSite(BreakpointSite *bp_site) override
void DrainProcessStdout()
Block until the stdio read thread has surfaced everything currently buffered in the ConPTY/pipe to th...
void SetPseudoConsoleHandle() override
void DidLaunch() override
Called after launching a process.
std::optional< uint32_t > GetWatchpointSlotCount() override
Get the number of watchpoints supported by this target.
Status DoResume(lldb::RunDirection direction) override
Resumes all of a process's threads as configured using the Thread run control functions.
void OnUnloadDll(lldb::addr_t module_addr) override
DynamicLoaderWindowsDYLD * GetDynamicLoader() override
Get the dynamic loader plug-in for this process.
void OnDebugString(lldb::addr_t debug_string_addr, bool is_unicode, uint16_t length_lower_word) override
Status DisableWatchpoint(lldb::WatchpointSP wp_sp, bool notify=true) override
bool IsAlive() override
Check if a process is still alive.
Status DoGetMemoryRegionInfo(lldb::addr_t vm_addr, MemoryRegionInfo &info) override
DoGetMemoryRegionInfo is called by GetMemoryRegionInfo after it has removed non address bits from loa...
void OnCreateThread(const HostThread &thread) override
static llvm::StringRef GetPluginDescriptionStatic()
size_t DoWriteMemory(lldb::addr_t vm_addr, const void *buf, size_t size, Status &error) override
Actually do the writing of memory to a process.
llvm::StringRef GetPluginName() override
Status DoLaunch(Module *exe_module, ProcessLaunchInfo &launch_info) override
Launch a new process.
size_t DoReadMemory(lldb::addr_t vm_addr, void *buf, size_t size, Status &error) override
Actually do the reading of memory from a process.
bool CanDebug(lldb::TargetSP target_sp, bool plugin_specified_by_name) override
Check if a plug-in instance can debug the file in module.
static llvm::StringRef GetPluginNameStatic()
llvm::Error ReadDebugString(lldb::addr_t debug_string_addr, bool is_unicode, uint16_t length_lower_word, llvm::SmallVectorImpl< char > &output)
void DidAttach(lldb_private::ArchSpec &arch_spec) override
Called after attaching a process.
void OnExitProcess(uint32_t exit_code) override
static lldb::ProcessSP CreateInstance(lldb::TargetSP target_sp, lldb::ListenerSP listener_sp, const FileSpec *, bool can_connect)
void OnExitThread(lldb::tid_t thread_id, uint32_t exit_code) override
Status DoAttachToProcessWithID(lldb::pid_t pid, const lldb_private::ProcessAttachInfo &attach_info) override
Attach to an existing process using a process ID.
lldb::addr_t GetImageInfoAddress() override
Get the image information address for the current process.
ExceptionResult OnDebugException(bool first_chance, const ExceptionRecord &record) override
std::map< lldb::break_id_t, WatchpointInfo > m_watchpoints
std::optional< DWORD > GetActiveExceptionCode() const
Returns the exception code of the active (current) debug exception, or std::nullopt if there is no ac...
void OnDebuggerError(const Status &error, uint32_t type) override
ArchSpec GetSystemArchitecture() override
Get the system architecture for this process.
Status DoDetach(bool keep_stopped) override
Detaches from a running or stopped process.
std::vector< lldb::break_id_t > m_watchpoint_ids
lldb::addr_t DoAllocateMemory(size_t size, uint32_t permissions, Status &error) override
Actually allocate memory in the process.
Status DisableBreakpointSite(BreakpointSite *bp_site) override
Status DoHalt(bool &caused_stop) override
Halts a running process.
Status EnableWatchpoint(lldb::WatchpointSP wp_sp, bool notify=true) override
A plug-in interface definition class for debugging a process.
lldb::IOHandlerSP m_process_input_reader
std::mutex m_process_input_reader_mutex
StopPointSiteList< lldb_private::BreakpointSite > & GetBreakpointSiteList()
virtual Status DisableSoftwareBreakpoint(BreakpointSite *bp_site)
lldb::pid_t GetID() const
Returns the pid of the process or LLDB_INVALID_PROCESS_ID if there is no known pid.
Process(lldb::TargetSP target_sp, lldb::ListenerSP listener_sp)
Construct with a shared pointer to a target, and the Process listener.
lldb::StateType GetPrivateState() const
lldb::DynamicLoaderUP m_dyld_up
bool IsBreakpointSitePhysicallyEnabled(const BreakpointSite &site)
void AppendSTDOUT(const char *s, size_t len)
lldb::TargetSP CalculateTarget() override
virtual Status EnableSoftwareBreakpoint(BreakpointSite *bp_site)
void SetID(lldb::pid_t new_pid)
Sets the stored pid.
virtual bool SetExitStatus(int exit_status, llvm::StringRef exit_string)
Set accessor for the process exit status (return code).
static void STDIOReadThreadBytesReceived(void *baton, const void *src, size_t src_len)
void SetPrivateState(lldb::StateType state)
ThreadList m_thread_list
The threads for this process as the user will see them.
ThreadedCommunication m_stdio_communication
Target & GetTarget()
Get the target object pointer for this module.
static constexpr uint32_t GetNumHardwareBreakpointSlots()
uint32_t GetTriggeredHardwareBreakpointSlotId()
bool RemoveHardwareBreakpoint(uint32_t slot)
bool AddHardwareBreakpoint(uint32_t slot, lldb::addr_t address, uint32_t size, bool read, bool write)
static Status FromErrorStringWithFormat(const char *format,...) __attribute__((format(printf
static Status FromErrorString(const char *str)
bool Fail() const
Test for error condition.
static Status static Status FromErrorStringWithFormatv(const char *format, Args &&...args)
static lldb::StopInfoSP CreateStopReasonToTrace(Thread &thread)
static lldb::StopInfoSP CreateStopReasonWithWatchpointID(Thread &thread, lldb::break_id_t watch_id, bool silently_continue=false)
static lldb::StopInfoSP CreateStopReasonWithException(Thread &thread, const char *description)
static lldb::StopInfoSP CreateStopReasonWithBreakpointSiteID(Thread &thread, lldb::break_id_t break_id)
StopPointSiteSP FindByAddress(lldb::addr_t addr)
Returns a shared pointer to the site at address addr.
lldb::break_id_t GetID() const
virtual lldb::addr_t GetLoadAddress() const
bool HardwareRequired() const
lldb::ModuleSP GetExecutableModule()
Gets the module for the main executable.
void SetExecutableModule(lldb::ModuleSP &module_sp, LoadDependentFiles load_dependent_files=eLoadDependentsDefault)
Set the main executable module.
void AddThread(const lldb::ThreadSP &thread_sp)
virtual ThreadIterable Threads()
#define LLDB_INVALID_BREAK_ID
#define LLDB_INVALID_INDEX32
#define LLDB_INVALID_ADDRESS
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.
HostThreadPosix HostNativeThread
std::shared_ptr< DebuggerThread > DebuggerThreadSP
bool StateIsRunningState(lldb::StateType state)
Check if a state represents a state where the process or thread is running.
NativeFilePosix NativeFile
std::shared_ptr< IDebugDelegate > DebugDelegateSP
std::shared_ptr< ExceptionRecord > ExceptionRecordSP
static void DumpAdditionalExceptionInformation(llvm::raw_ostream &stream, const ExceptionRecordSP &exception)
static bool ShouldUseLLDBServer()
std::shared_ptr< lldb_private::BreakpointSite > BreakpointSiteSP
RunDirection
Execution directions.
std::shared_ptr< lldb_private::Thread > ThreadSP
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.
@ eStateRunning
Process or thread is running and can't be examined.
@ eStateExited
Process has exited and can't be examined.
@ eStateCrashed
Process or thread has crashed and can be examined.
std::shared_ptr< lldb_private::Process > ProcessSP
std::shared_ptr< lldb_private::Watchpoint > WatchpointSP
std::shared_ptr< lldb_private::Listener > ListenerSP
std::shared_ptr< lldb_private::StopInfo > StopInfoSP
std::shared_ptr< lldb_private::Target > TargetSP
std::shared_ptr< lldb_private::RegisterContext > RegisterContextSP
std::shared_ptr< lldb_private::Module > ModuleSP