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 GetRegisterContext()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 58*1e74e5e9SMichał Górny const NativeProcessLinux &GetProcess() const; 59*1e74e5e9SMichał Górny 60*1e74e5e9SMichał Górny llvm::Expected<std::unique_ptr<llvm::MemoryBuffer>> 61*1e74e5e9SMichał Górny GetSiginfo() const override; 62*1e74e5e9SMichał Górny 63af245d11STodd Fiala private: 64af245d11STodd Fiala // Interface for friend classes 65af245d11STodd Fiala 66f05b42e9SAdrian Prantl /// Resumes the thread. If \p signo is anything but 67605b51b8SPavel Labath /// LLDB_INVALID_SIGNAL_NUMBER, deliver that signal to the thread. 6897206d57SZachary Turner Status Resume(uint32_t signo); 69605b51b8SPavel Labath 70f05b42e9SAdrian Prantl /// Single steps the thread. If \p signo is anything but 71605b51b8SPavel Labath /// LLDB_INVALID_SIGNAL_NUMBER, deliver that signal to the thread. 7297206d57SZachary Turner Status SingleStep(uint32_t signo); 73af245d11STodd Fiala 74b9c1b51eSKate Stone void SetStoppedBySignal(uint32_t signo, const siginfo_t *info = nullptr); 75af245d11STodd Fiala 76511e5cdcSTodd Fiala /// Return true if the thread is stopped. 77511e5cdcSTodd Fiala /// If stopped by a signal, indicate the signo in the signo argument. 78511e5cdcSTodd Fiala /// Otherwise, return LLDB_INVALID_SIGNAL_NUMBER. 79b9c1b51eSKate Stone bool IsStopped(int *signo); 80511e5cdcSTodd Fiala 81b9c1b51eSKate Stone void SetStoppedByExec(); 82a9882ceeSTodd Fiala 83b9c1b51eSKate Stone void SetStoppedByBreakpoint(); 84af245d11STodd Fiala 85b9c1b51eSKate Stone void SetStoppedByWatchpoint(uint32_t wp_index); 8618fe6404SChaoren Lin 87b9c1b51eSKate Stone bool IsStoppedAtBreakpoint(); 88af245d11STodd Fiala 89b9c1b51eSKate Stone bool IsStoppedAtWatchpoint(); 9018fe6404SChaoren Lin 91b9c1b51eSKate Stone void SetStoppedByTrace(); 9228e57429SChaoren Lin 93fd0af0cfSMichał Górny void SetStoppedByFork(bool is_vfork, lldb::pid_t child_pid); 94fd0af0cfSMichał Górny 95fd0af0cfSMichał Górny void SetStoppedByVForkDone(); 96fd0af0cfSMichał Górny 97b9c1b51eSKate Stone void SetStoppedWithNoReason(); 98af245d11STodd Fiala 990b697561SWalter Erquinigo void SetStoppedByProcessorTrace(llvm::StringRef description); 1000b697561SWalter Erquinigo 101b9c1b51eSKate Stone void SetExited(); 102af245d11STodd Fiala 10397206d57SZachary Turner Status RequestStop(); 1048c8ff7afSPavel Labath 105af245d11STodd Fiala // Private interface 106b9c1b51eSKate Stone void MaybeLogStateChange(lldb::StateType new_state); 107af245d11STodd Fiala 108b9c1b51eSKate Stone void SetStopped(); 109605b51b8SPavel Labath 110d510b5f1SDavid Spickett /// Extend m_stop_description with logical and allocation tag values. 111d510b5f1SDavid Spickett /// If there is an error along the way just add the information we were able 112d510b5f1SDavid Spickett /// to get. 113d510b5f1SDavid Spickett void AnnotateSyncTagCheckFault(const siginfo_t *info); 114d510b5f1SDavid Spickett 115af245d11STodd Fiala // Member Variables 116af245d11STodd Fiala lldb::StateType m_state; 117af245d11STodd Fiala ThreadStopInfo m_stop_info; 118d37349f3SPavel Labath std::unique_ptr<NativeRegisterContextLinux> m_reg_context_up; 11928e57429SChaoren Lin std::string m_stop_description; 12018fe6404SChaoren Lin using WatchpointIndexMap = std::map<lldb::addr_t, uint32_t>; 12118fe6404SChaoren Lin WatchpointIndexMap m_watchpoint_index_map; 122d5ffbad2SOmair Javaid WatchpointIndexMap m_hw_break_index_map; 1237278496cSPavel Labath std::unique_ptr<SingleStepWorkaround> m_step_workaround; 124af245d11STodd Fiala }; 125db264a6dSTamas Berghammer } // namespace process_linux 126db264a6dSTamas Berghammer } // namespace lldb_private 127af245d11STodd Fiala 128af245d11STodd Fiala #endif // #ifndef liblldb_NativeThreadLinux_H_ 129