1af245d11STodd Fiala //===-- NativeThreadLinux.h ----------------------------------- -*- C++ -*-===// 2af245d11STodd Fiala // 32946cd70SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 42946cd70SChandler Carruth // See https://llvm.org/LICENSE.txt for license information. 52946cd70SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6af245d11STodd Fiala // 7af245d11STodd Fiala //===----------------------------------------------------------------------===// 8af245d11STodd Fiala 9af245d11STodd Fiala #ifndef liblldb_NativeThreadLinux_H_ 10af245d11STodd Fiala #define liblldb_NativeThreadLinux_H_ 11af245d11STodd Fiala 12d37349f3SPavel Labath #include "Plugins/Process/Linux/NativeRegisterContextLinux.h" 13d37349f3SPavel Labath #include "Plugins/Process/Linux/SingleStepCheck.h" 142fe1d0abSChaoren Lin #include "lldb/Host/common/NativeThreadProtocol.h" 15b9c1b51eSKate Stone #include "lldb/lldb-private-forward.h" 16af245d11STodd Fiala 170b697561SWalter Erquinigo #include "llvm/ADT/StringRef.h" 180b697561SWalter Erquinigo 19b6dbe9a9SPavel Labath #include <csignal> 2018fe6404SChaoren Lin #include <map> 210e1d729bSPavel Labath #include <memory> 227572caf4SRichard Smith #include <string> 2318fe6404SChaoren Lin 24db264a6dSTamas Berghammer namespace lldb_private { 25db264a6dSTamas Berghammer namespace process_linux { 26db264a6dSTamas Berghammer 27af245d11STodd Fiala class NativeProcessLinux; 28af245d11STodd Fiala 29b9c1b51eSKate Stone class NativeThreadLinux : public NativeThreadProtocol { 30af245d11STodd Fiala friend class NativeProcessLinux; 31af245d11STodd Fiala 32af245d11STodd Fiala public: 3382abefa4SPavel Labath NativeThreadLinux(NativeProcessLinux &process, lldb::tid_t tid); 34af245d11STodd Fiala 35af245d11STodd Fiala // NativeThreadProtocol Interface 36b9c1b51eSKate Stone std::string GetName() override; 37af245d11STodd Fiala 38b9c1b51eSKate Stone lldb::StateType GetState() override; 39af245d11STodd Fiala 40b9c1b51eSKate Stone bool GetStopReason(ThreadStopInfo &stop_info, 41b9c1b51eSKate Stone std::string &description) override; 42af245d11STodd Fiala 43d37349f3SPavel Labath NativeRegisterContextLinux &GetRegisterContext() override { 44d37349f3SPavel Labath return *m_reg_context_up; 45d37349f3SPavel Labath } 46af245d11STodd Fiala 4797206d57SZachary Turner Status SetWatchpoint(lldb::addr_t addr, size_t size, uint32_t watch_flags, 48b9c1b51eSKate Stone bool hardware) override; 49af245d11STodd Fiala 5097206d57SZachary Turner Status RemoveWatchpoint(lldb::addr_t addr) override; 51af245d11STodd Fiala 5297206d57SZachary Turner Status SetHardwareBreakpoint(lldb::addr_t addr, size_t size) override; 53d5ffbad2SOmair Javaid 5497206d57SZachary Turner Status RemoveHardwareBreakpoint(lldb::addr_t addr) override; 55d5ffbad2SOmair Javaid 5688a5b35dSMuhammad Omair Javaid NativeProcessLinux &GetProcess(); 5788a5b35dSMuhammad Omair Javaid 58af245d11STodd Fiala private: 59af245d11STodd Fiala // Interface for friend classes 60af245d11STodd Fiala 61f05b42e9SAdrian Prantl /// Resumes the thread. If \p signo is anything but 62605b51b8SPavel Labath /// LLDB_INVALID_SIGNAL_NUMBER, deliver that signal to the thread. 6397206d57SZachary Turner Status Resume(uint32_t signo); 64605b51b8SPavel Labath 65f05b42e9SAdrian Prantl /// Single steps the thread. If \p signo is anything but 66605b51b8SPavel Labath /// LLDB_INVALID_SIGNAL_NUMBER, deliver that signal to the thread. 6797206d57SZachary Turner Status SingleStep(uint32_t signo); 68af245d11STodd Fiala 69b9c1b51eSKate Stone void SetStoppedBySignal(uint32_t signo, const siginfo_t *info = nullptr); 70af245d11STodd Fiala 71511e5cdcSTodd Fiala /// Return true if the thread is stopped. 72511e5cdcSTodd Fiala /// If stopped by a signal, indicate the signo in the signo argument. 73511e5cdcSTodd Fiala /// Otherwise, return LLDB_INVALID_SIGNAL_NUMBER. 74b9c1b51eSKate Stone bool IsStopped(int *signo); 75511e5cdcSTodd Fiala 76b9c1b51eSKate Stone void SetStoppedByExec(); 77a9882ceeSTodd Fiala 78b9c1b51eSKate Stone void SetStoppedByBreakpoint(); 79af245d11STodd Fiala 80b9c1b51eSKate Stone void SetStoppedByWatchpoint(uint32_t wp_index); 8118fe6404SChaoren Lin 82b9c1b51eSKate Stone bool IsStoppedAtBreakpoint(); 83af245d11STodd Fiala 84b9c1b51eSKate Stone bool IsStoppedAtWatchpoint(); 8518fe6404SChaoren Lin 86b9c1b51eSKate Stone void SetStoppedByTrace(); 8728e57429SChaoren Lin 88*fd0af0cfSMichał Górny void SetStoppedByFork(bool is_vfork, lldb::pid_t child_pid); 89*fd0af0cfSMichał Górny 90*fd0af0cfSMichał Górny void SetStoppedByVForkDone(); 91*fd0af0cfSMichał Górny 92b9c1b51eSKate Stone void SetStoppedWithNoReason(); 93af245d11STodd Fiala 940b697561SWalter Erquinigo void SetStoppedByProcessorTrace(llvm::StringRef description); 950b697561SWalter Erquinigo 96b9c1b51eSKate Stone void SetExited(); 97af245d11STodd Fiala 9897206d57SZachary Turner Status RequestStop(); 998c8ff7afSPavel Labath 100af245d11STodd Fiala // Private interface 101b9c1b51eSKate Stone void MaybeLogStateChange(lldb::StateType new_state); 102af245d11STodd Fiala 103b9c1b51eSKate Stone void SetStopped(); 104605b51b8SPavel Labath 105af245d11STodd Fiala // Member Variables 106af245d11STodd Fiala lldb::StateType m_state; 107af245d11STodd Fiala ThreadStopInfo m_stop_info; 108d37349f3SPavel Labath std::unique_ptr<NativeRegisterContextLinux> m_reg_context_up; 10928e57429SChaoren Lin std::string m_stop_description; 11018fe6404SChaoren Lin using WatchpointIndexMap = std::map<lldb::addr_t, uint32_t>; 11118fe6404SChaoren Lin WatchpointIndexMap m_watchpoint_index_map; 112d5ffbad2SOmair Javaid WatchpointIndexMap m_hw_break_index_map; 1137278496cSPavel Labath std::unique_ptr<SingleStepWorkaround> m_step_workaround; 114af245d11STodd Fiala }; 115db264a6dSTamas Berghammer } // namespace process_linux 116db264a6dSTamas Berghammer } // namespace lldb_private 117af245d11STodd Fiala 118af245d11STodd Fiala #endif // #ifndef liblldb_NativeThreadLinux_H_ 119