diff options
Diffstat (limited to 'lldb/source/Plugins/Process/Linux/NativeThreadLinux.cpp')
| -rw-r--r-- | lldb/source/Plugins/Process/Linux/NativeThreadLinux.cpp | 34 | 
1 files changed, 34 insertions, 0 deletions
| diff --git a/lldb/source/Plugins/Process/Linux/NativeThreadLinux.cpp b/lldb/source/Plugins/Process/Linux/NativeThreadLinux.cpp index 134e6a0..c7c13a5 100644 --- a/lldb/source/Plugins/Process/Linux/NativeThreadLinux.cpp +++ b/lldb/source/Plugins/Process/Linux/NativeThreadLinux.cpp @@ -37,6 +37,11 @@  #include "Plugins/Process/Utility/RegisterContextLinux_mips64.h"  #include "Plugins/Process/Utility/RegisterInfoInterface.h" +#include <sys/syscall.h> +// Try to define a macro to encapsulate the tgkill syscall +#define tgkill(pid, tid, sig) \ +    syscall(SYS_tgkill, static_cast<::pid_t>(pid), static_cast<::pid_t>(tid), sig) +  using namespace lldb;  using namespace lldb_private;  using namespace lldb_private::process_linux; @@ -479,6 +484,35 @@ NativeThreadLinux::SetExited ()      m_stop_info.reason = StopReason::eStopReasonThreadExiting;  } +Error +NativeThreadLinux::RequestStop () +{ +    Log* log (GetLogIfAllCategoriesSet (LIBLLDB_LOG_THREAD)); + +    const auto process_sp = GetProcess(); +    if (! process_sp) +        return Error("Process is null."); + +    lldb::pid_t pid = process_sp->GetID(); +    lldb::tid_t tid = GetID(); + +    if (log) +        log->Printf ("NativeThreadLinux::%s requesting thread stop(pid: %" PRIu64 ", tid: %" PRIu64 ")", __FUNCTION__, pid, tid); + +    Error err; +    errno = 0; +    if (::tgkill (pid, tid, SIGSTOP) != 0) +    { +        err.SetErrorToErrno (); +        if (log) +            log->Printf ("NativeThreadLinux::%s tgkill(%" PRIu64 ", %" PRIu64 ", SIGSTOP) failed: %s", __FUNCTION__, pid, tid, err.AsCString ()); +    } +    else +        m_thread_context.stop_requested = true; + +    return err; +} +  void  NativeThreadLinux::MaybeLogStateChange (lldb::StateType new_state)  { | 
