diff options
author | Tankut Baris Aktemur <tankut.baris.aktemur@intel.com> | 2021-12-13 12:22:48 +0100 |
---|---|---|
committer | Tankut Baris Aktemur <tankut.baris.aktemur@intel.com> | 2021-12-13 12:22:48 +0100 |
commit | f24791b72e764ada576901c0e866bf7768773a16 (patch) | |
tree | d3e09e57eb5a5787b80d78f239fefa4ee27a6e74 /gdbserver | |
parent | 200fd2874d2c147539f756b29e15ebbafa81dfcf (diff) | |
download | gdb-f24791b72e764ada576901c0e866bf7768773a16.zip gdb-f24791b72e764ada576901c0e866bf7768773a16.tar.gz gdb-f24791b72e764ada576901c0e866bf7768773a16.tar.bz2 |
gdbserver: introduce scoped_restore_current_thread and switch_to_thread
Introduce a class for restoring the current thread and a function to
switch to the given thread. This is a preparation for a refactoring
that aims to remove direct assignments to 'current_thread'.
Diffstat (limited to 'gdbserver')
-rw-r--r-- | gdbserver/gdbthread.h | 22 | ||||
-rw-r--r-- | gdbserver/inferiors.cc | 21 |
2 files changed, 43 insertions, 0 deletions
diff --git a/gdbserver/gdbthread.h b/gdbserver/gdbthread.h index 7c293b1..315a4da 100644 --- a/gdbserver/gdbthread.h +++ b/gdbserver/gdbthread.h @@ -233,4 +233,26 @@ lwpid_of (const thread_info *thread) return thread->id.lwp (); } +/* Switch the current thread. */ + +void switch_to_thread (thread_info *thread); + +/* Save/restore current thread. */ + +class scoped_restore_current_thread +{ +public: + scoped_restore_current_thread (); + ~scoped_restore_current_thread (); + + DISABLE_COPY_AND_ASSIGN (scoped_restore_current_thread); + + /* Cancel restoring on scope exit. */ + void dont_restore () { m_dont_restore = true; } + +private: + bool m_dont_restore = false; + thread_info *m_thread; +}; + #endif /* GDBSERVER_GDBTHREAD_H */ diff --git a/gdbserver/inferiors.cc b/gdbserver/inferiors.cc index a636266..d44e40a 100644 --- a/gdbserver/inferiors.cc +++ b/gdbserver/inferiors.cc @@ -218,6 +218,14 @@ switch_to_thread (process_stratum_target *ops, ptid_t ptid) current_thread = find_thread_ptid (ptid); } +/* See gdbthread.h. */ + +void +switch_to_thread (thread_info *thread) +{ + current_thread = thread; +} + /* See inferiors.h. */ void @@ -243,3 +251,16 @@ set_inferior_cwd (std::string cwd) { current_inferior_cwd = std::move (cwd); } + +scoped_restore_current_thread::scoped_restore_current_thread () +{ + m_thread = current_thread; +} + +scoped_restore_current_thread::~scoped_restore_current_thread () +{ + if (m_dont_restore) + return; + + switch_to_thread (m_thread); +} |