gdbserver: turn target ops 'multifs_{open, readlink, unlink}' into methods
[deliverable/binutils-gdb.git] / gdbserver / inferiors.cc
... / ...
CommitLineData
1/* Inferior process information for the remote server for GDB.
2 Copyright (C) 2002-2020 Free Software Foundation, Inc.
3
4 Contributed by MontaVista Software.
5
6 This file is part of GDB.
7
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 3 of the License, or
11 (at your option) any later version.
12
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
17
18 You should have received a copy of the GNU General Public License
19 along with this program. If not, see <http://www.gnu.org/licenses/>. */
20
21#include "server.h"
22#include "gdbsupport/common-inferior.h"
23#include "gdbthread.h"
24#include "dll.h"
25
26std::list<process_info *> all_processes;
27std::list<thread_info *> all_threads;
28
29struct thread_info *current_thread;
30
31/* The current working directory used to start the inferior. */
32static const char *current_inferior_cwd = NULL;
33
34struct thread_info *
35add_thread (ptid_t thread_id, void *target_data)
36{
37 struct thread_info *new_thread = XCNEW (struct thread_info);
38
39 new_thread->id = thread_id;
40 new_thread->last_resume_kind = resume_continue;
41 new_thread->last_status.kind = TARGET_WAITKIND_IGNORE;
42
43 all_threads.push_back (new_thread);
44
45 if (current_thread == NULL)
46 current_thread = new_thread;
47
48 new_thread->target_data = target_data;
49
50 return new_thread;
51}
52
53/* See gdbthread.h. */
54
55struct thread_info *
56get_first_thread (void)
57{
58 if (!all_threads.empty ())
59 return all_threads.front ();
60 else
61 return NULL;
62}
63
64struct thread_info *
65find_thread_ptid (ptid_t ptid)
66{
67 return find_thread ([&] (thread_info *thread) {
68 return thread->id == ptid;
69 });
70}
71
72/* Find a thread associated with the given PROCESS, or NULL if no
73 such thread exists. */
74
75static struct thread_info *
76find_thread_process (const struct process_info *const process)
77{
78 return find_any_thread_of_pid (process->pid);
79}
80
81/* See gdbthread.h. */
82
83struct thread_info *
84find_any_thread_of_pid (int pid)
85{
86 return find_thread (pid, [] (thread_info *thread) {
87 return true;
88 });
89}
90
91static void
92free_one_thread (thread_info *thread)
93{
94 free_register_cache (thread_regcache_data (thread));
95 free (thread);
96}
97
98void
99remove_thread (struct thread_info *thread)
100{
101 if (thread->btrace != NULL)
102 target_disable_btrace (thread->btrace);
103
104 discard_queued_stop_replies (ptid_of (thread));
105 all_threads.remove (thread);
106 free_one_thread (thread);
107 if (current_thread == thread)
108 current_thread = NULL;
109}
110
111void *
112thread_target_data (struct thread_info *thread)
113{
114 return thread->target_data;
115}
116
117struct regcache *
118thread_regcache_data (struct thread_info *thread)
119{
120 return thread->regcache_data;
121}
122
123void
124set_thread_regcache_data (struct thread_info *thread, struct regcache *data)
125{
126 thread->regcache_data = data;
127}
128
129void
130clear_inferiors (void)
131{
132 for_each_thread (free_one_thread);
133 all_threads.clear ();
134
135 clear_dlls ();
136
137 current_thread = NULL;
138}
139
140struct process_info *
141add_process (int pid, int attached)
142{
143 process_info *process = new process_info (pid, attached);
144
145 all_processes.push_back (process);
146
147 return process;
148}
149
150/* Remove a process from the common process list and free the memory
151 allocated for it.
152 The caller is responsible for freeing private data first. */
153
154void
155remove_process (struct process_info *process)
156{
157 clear_symbol_cache (&process->symbol_cache);
158 free_all_breakpoints (process);
159 gdb_assert (find_thread_process (process) == NULL);
160 all_processes.remove (process);
161 delete process;
162}
163
164process_info *
165find_process_pid (int pid)
166{
167 return find_process ([&] (process_info *process) {
168 return process->pid == pid;
169 });
170}
171
172/* Get the first process in the process list, or NULL if the list is empty. */
173
174process_info *
175get_first_process (void)
176{
177 if (!all_processes.empty ())
178 return all_processes.front ();
179 else
180 return NULL;
181}
182
183/* Return non-zero if there are any inferiors that we have created
184 (as opposed to attached-to). */
185
186int
187have_started_inferiors_p (void)
188{
189 return find_process ([] (process_info *process) {
190 return !process->attached;
191 }) != NULL;
192}
193
194/* Return non-zero if there are any inferiors that we have attached to. */
195
196int
197have_attached_inferiors_p (void)
198{
199 return find_process ([] (process_info *process) {
200 return process->attached;
201 }) != NULL;
202}
203
204struct process_info *
205get_thread_process (const struct thread_info *thread)
206{
207 return find_process_pid (thread->id.pid ());
208}
209
210struct process_info *
211current_process (void)
212{
213 gdb_assert (current_thread != NULL);
214 return get_thread_process (current_thread);
215}
216
217/* See gdbsupport/common-gdbthread.h. */
218
219void
220switch_to_thread (process_stratum_target *ops, ptid_t ptid)
221{
222 gdb_assert (ptid != minus_one_ptid);
223 current_thread = find_thread_ptid (ptid);
224}
225
226/* See gdbsupport/common-inferior.h. */
227
228const char *
229get_inferior_cwd ()
230{
231 return current_inferior_cwd;
232}
233
234/* See gdbsupport/common-inferior.h. */
235
236void
237set_inferior_cwd (const char *cwd)
238{
239 xfree ((void *) current_inferior_cwd);
240 if (cwd != NULL)
241 current_inferior_cwd = xstrdup (cwd);
242 else
243 current_inferior_cwd = NULL;
244}
This page took 0.02277 seconds and 4 git commands to generate.