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 
17b6dbe9a9SPavel Labath #include <csignal>
1818fe6404SChaoren Lin #include <map>
190e1d729bSPavel Labath #include <memory>
207572caf4SRichard Smith #include <string>
2118fe6404SChaoren Lin 
22db264a6dSTamas Berghammer namespace lldb_private {
23db264a6dSTamas Berghammer namespace process_linux {
24db264a6dSTamas Berghammer 
25af245d11STodd Fiala class NativeProcessLinux;
26af245d11STodd Fiala 
27b9c1b51eSKate Stone class NativeThreadLinux : public NativeThreadProtocol {
28af245d11STodd Fiala   friend class NativeProcessLinux;
29af245d11STodd Fiala 
30af245d11STodd Fiala public:
3182abefa4SPavel Labath   NativeThreadLinux(NativeProcessLinux &process, lldb::tid_t tid);
32af245d11STodd Fiala 
33af245d11STodd Fiala   // ---------------------------------------------------------------------
34af245d11STodd Fiala   // NativeThreadProtocol Interface
35af245d11STodd Fiala   // ---------------------------------------------------------------------
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 
56af245d11STodd Fiala private:
57af245d11STodd Fiala   // ---------------------------------------------------------------------
58af245d11STodd Fiala   // Interface for friend classes
59af245d11STodd Fiala   // ---------------------------------------------------------------------
60af245d11STodd Fiala 
61*f05b42e9SAdrian 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 
65*f05b42e9SAdrian 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 
88b9c1b51eSKate Stone   void SetStoppedWithNoReason();
89af245d11STodd Fiala 
90b9c1b51eSKate Stone   void SetExited();
91af245d11STodd Fiala 
9297206d57SZachary Turner   Status RequestStop();
938c8ff7afSPavel Labath 
94af245d11STodd Fiala   // ---------------------------------------------------------------------
95af245d11STodd Fiala   // Private interface
96af245d11STodd Fiala   // ---------------------------------------------------------------------
97b9c1b51eSKate Stone   void MaybeLogStateChange(lldb::StateType new_state);
98af245d11STodd Fiala 
99b9c1b51eSKate Stone   NativeProcessLinux &GetProcess();
100605b51b8SPavel Labath 
101b9c1b51eSKate Stone   void SetStopped();
102605b51b8SPavel Labath 
103af245d11STodd Fiala   // ---------------------------------------------------------------------
104af245d11STodd Fiala   // Member Variables
105af245d11STodd Fiala   // ---------------------------------------------------------------------
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