blob: c8fb6fccedf2e854eed86cda734d9ce4ea90e438 [file] [log] [blame]
Chris Lattner24943d22010-06-08 16:52:24 +00001//===-- ProcessGDBRemote.h --------------------------------------*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10#ifndef liblldb_ProcessGDBRemote_h_
11#define liblldb_ProcessGDBRemote_h_
12
13// C Includes
14
15// C++ Includes
16#include <list>
Greg Claytonc1f45872011-02-12 06:28:37 +000017#include <vector>
Chris Lattner24943d22010-06-08 16:52:24 +000018
19// Other libraries and framework includes
20#include "lldb/Core/ArchSpec.h"
21#include "lldb/Core/Broadcaster.h"
22#include "lldb/Core/Error.h"
23#include "lldb/Core/InputReader.h"
24#include "lldb/Core/StreamString.h"
Jim Ingham7508e732010-08-09 23:31:02 +000025#include "lldb/Core/StringList.h"
Chris Lattner24943d22010-06-08 16:52:24 +000026#include "lldb/Core/ThreadSafeValue.h"
27#include "lldb/Target/Process.h"
28#include "lldb/Target/Thread.h"
29
30#include "GDBRemoteCommunication.h"
Greg Clayton54e7afa2010-07-09 20:39:50 +000031#include "Utility/StringExtractor.h"
Chris Lattner24943d22010-06-08 16:52:24 +000032#include "GDBRemoteRegisterContext.h"
Chris Lattner24943d22010-06-08 16:52:24 +000033
34class ThreadGDBRemote;
35
36class ProcessGDBRemote : public lldb_private::Process
37{
38public:
39 //------------------------------------------------------------------
40 // Constructors and Destructors
41 //------------------------------------------------------------------
42 static Process*
43 CreateInstance (lldb_private::Target& target, lldb_private::Listener &listener);
44
45 static void
46 Initialize();
47
48 static void
49 Terminate();
50
51 static const char *
52 GetPluginNameStatic();
53
54 static const char *
55 GetPluginDescriptionStatic();
56
57 //------------------------------------------------------------------
58 // Constructors and Destructors
59 //------------------------------------------------------------------
60 ProcessGDBRemote(lldb_private::Target& target, lldb_private::Listener &listener);
61
62 virtual
63 ~ProcessGDBRemote();
64
65 //------------------------------------------------------------------
66 // Check if a given Process
67 //------------------------------------------------------------------
68 virtual bool
69 CanDebug (lldb_private::Target &target);
70
Greg Claytone4b9c1f2011-03-08 22:40:15 +000071// virtual uint32_t
72// ListProcessesMatchingName (const char *name, lldb_private::StringList &matches, std::vector<lldb::pid_t> &pids);
Jim Ingham7508e732010-08-09 23:31:02 +000073
Chris Lattner24943d22010-06-08 16:52:24 +000074 //------------------------------------------------------------------
75 // Creating a new process, or attaching to an existing one
76 //------------------------------------------------------------------
77 virtual lldb_private::Error
78 WillLaunch (lldb_private::Module* module);
79
80 virtual lldb_private::Error
81 DoLaunch (lldb_private::Module* module,
82 char const *argv[], // Can be NULL
83 char const *envp[], // Can be NULL
Greg Clayton452bf612010-08-31 18:35:14 +000084 uint32_t flags,
Chris Lattner24943d22010-06-08 16:52:24 +000085 const char *stdin_path, // Can be NULL
Greg Claytonde915be2011-01-23 05:56:20 +000086 const char *stdout_path, // Can be NULL
87 const char *stderr_path, // Can be NULL
88 const char *working_dir); // Can be NULL
Chris Lattner24943d22010-06-08 16:52:24 +000089
90 virtual void
91 DidLaunch ();
92
93 virtual lldb_private::Error
Greg Clayton20d338f2010-11-18 05:57:03 +000094 WillAttachToProcessWithID (lldb::pid_t pid);
Chris Lattner24943d22010-06-08 16:52:24 +000095
96 virtual lldb_private::Error
Greg Clayton20d338f2010-11-18 05:57:03 +000097 WillAttachToProcessWithName (const char *process_name, bool wait_for_launch);
Chris Lattner24943d22010-06-08 16:52:24 +000098
Greg Claytone71e2582011-02-04 01:58:07 +000099 virtual lldb_private::Error
100 DoConnectRemote (const char *remote_url);
101
Chris Lattner24943d22010-06-08 16:52:24 +0000102 lldb_private::Error
103 WillLaunchOrAttach ();
104
105 virtual lldb_private::Error
Greg Clayton54e7afa2010-07-09 20:39:50 +0000106 DoAttachToProcessWithID (lldb::pid_t pid);
Chris Lattner24943d22010-06-08 16:52:24 +0000107
108 virtual lldb_private::Error
Greg Clayton54e7afa2010-07-09 20:39:50 +0000109 DoAttachToProcessWithName (const char *process_name, bool wait_for_launch);
Chris Lattner24943d22010-06-08 16:52:24 +0000110
111 virtual void
112 DidAttach ();
113
114 //------------------------------------------------------------------
115 // PluginInterface protocol
116 //------------------------------------------------------------------
117 virtual const char *
118 GetPluginName();
119
120 virtual const char *
121 GetShortPluginName();
122
123 virtual uint32_t
124 GetPluginVersion();
125
Chris Lattner24943d22010-06-08 16:52:24 +0000126 //------------------------------------------------------------------
127 // Process Control
128 //------------------------------------------------------------------
129 virtual lldb_private::Error
130 WillResume ();
131
132 virtual lldb_private::Error
133 DoResume ();
134
135 virtual lldb_private::Error
Jim Ingham3ae449a2010-11-17 02:32:00 +0000136 DoHalt (bool &caused_stop);
Chris Lattner24943d22010-06-08 16:52:24 +0000137
138 virtual lldb_private::Error
139 WillDetach ();
140
141 virtual lldb_private::Error
142 DoDetach ();
143
144 virtual lldb_private::Error
145 DoSignal (int signal);
146
147 virtual lldb_private::Error
148 DoDestroy ();
149
150 virtual void
151 RefreshStateAfterStop();
152
153 //------------------------------------------------------------------
154 // Process Queries
155 //------------------------------------------------------------------
156 virtual bool
157 IsAlive ();
158
159 virtual lldb::addr_t
160 GetImageInfoAddress();
161
162 //------------------------------------------------------------------
163 // Process Memory
164 //------------------------------------------------------------------
165 virtual size_t
166 DoReadMemory (lldb::addr_t addr, void *buf, size_t size, lldb_private::Error &error);
167
168 virtual size_t
169 DoWriteMemory (lldb::addr_t addr, const void *buf, size_t size, lldb_private::Error &error);
170
171 virtual lldb::addr_t
172 DoAllocateMemory (size_t size, uint32_t permissions, lldb_private::Error &error);
173
174 virtual lldb_private::Error
175 DoDeallocateMemory (lldb::addr_t ptr);
176
177 //------------------------------------------------------------------
178 // Process STDIO
179 //------------------------------------------------------------------
180 virtual size_t
181 GetSTDOUT (char *buf, size_t buf_size, lldb_private::Error &error);
182
183 virtual size_t
184 GetSTDERR (char *buf, size_t buf_size, lldb_private::Error &error);
185
186 virtual size_t
187 PutSTDIN (const char *buf, size_t buf_size, lldb_private::Error &error);
188
189 //----------------------------------------------------------------------
190 // Process Breakpoints
191 //----------------------------------------------------------------------
192 virtual size_t
193 GetSoftwareBreakpointTrapOpcode (lldb_private::BreakpointSite *bp_site);
194
195 //----------------------------------------------------------------------
196 // Process Breakpoints
197 //----------------------------------------------------------------------
198 virtual lldb_private::Error
199 EnableBreakpoint (lldb_private::BreakpointSite *bp_site);
200
201 virtual lldb_private::Error
202 DisableBreakpoint (lldb_private::BreakpointSite *bp_site);
203
204 //----------------------------------------------------------------------
205 // Process Watchpoints
206 //----------------------------------------------------------------------
207 virtual lldb_private::Error
208 EnableWatchpoint (lldb_private::WatchpointLocation *wp_loc);
209
210 virtual lldb_private::Error
211 DisableWatchpoint (lldb_private::WatchpointLocation *wp_loc);
212
Jim Ingham55e01d82011-01-22 01:33:44 +0000213 virtual bool
214 StartNoticingNewThreads();
215
216 virtual bool
217 StopNoticingNewThreads();
Chris Lattner24943d22010-06-08 16:52:24 +0000218
219protected:
220 friend class ThreadGDBRemote;
221 friend class GDBRemoteCommunication;
222 friend class GDBRemoteRegisterContext;
223
224 bool
225 SetCurrentGDBRemoteThread (int tid);
226
227 bool
228 SetCurrentGDBRemoteThreadForRun (int tid);
229
230 //----------------------------------------------------------------------
231 // Accessors
232 //----------------------------------------------------------------------
233 bool
234 IsRunning ( lldb::StateType state )
235 {
236 return state == lldb::eStateRunning || IsStepping(state);
237 }
238
239 bool
240 IsStepping ( lldb::StateType state)
241 {
242 return state == lldb::eStateStepping;
243 }
244 bool
245 CanResume ( lldb::StateType state)
246 {
247 return state == lldb::eStateStopped;
248 }
249
250 bool
251 HasExited (lldb::StateType state)
252 {
253 return state == lldb::eStateExited;
254 }
255
256 bool
257 ProcessIDIsValid ( ) const;
258
Caroline Tice861efb32010-11-16 05:07:41 +0000259// static void
260// STDIOReadThreadBytesReceived (void *baton, const void *src, size_t src_len);
Chris Lattner24943d22010-06-08 16:52:24 +0000261
Caroline Tice861efb32010-11-16 05:07:41 +0000262// void
263// AppendSTDOUT (const char* s, size_t len);
Chris Lattner24943d22010-06-08 16:52:24 +0000264
Chris Lattner24943d22010-06-08 16:52:24 +0000265 void
266 Clear ( );
267
268 lldb_private::Flags &
269 GetFlags ()
270 {
271 return m_flags;
272 }
273
274 const lldb_private::Flags &
275 GetFlags () const
276 {
277 return m_flags;
278 }
279
280 uint32_t
281 UpdateThreadListIfNeeded ();
282
283 lldb_private::Error
Greg Clayton23cf0c72010-11-08 04:29:11 +0000284 StartDebugserverProcess (const char *debugserver_url, // The connection string to use in the spawned debugserver ("localhost:1234" or "/dev/tty...")
Chris Lattner24943d22010-06-08 16:52:24 +0000285 char const *inferior_argv[],
286 char const *inferior_envp[],
Greg Clayton23cf0c72010-11-08 04:29:11 +0000287 lldb::pid_t attach_pid, // If inferior inferior_argv == NULL, then attach to this pid
288 const char *attach_pid_name, // Wait for the next process to launch whose basename matches "attach_wait_name"
289 bool wait_for_launch, // Wait for the process named "attach_wait_name" to launch
Greg Claytona2f74232011-02-24 22:24:29 +0000290 const lldb_private::ArchSpec& arch_spec);
Chris Lattner24943d22010-06-08 16:52:24 +0000291
292 void
293 KillDebugserverProcess ();
294
295 void
Greg Clayton7e2f91c2011-01-29 07:10:55 +0000296 BuildDynamicRegisterInfo (bool force);
Chris Lattner24943d22010-06-08 16:52:24 +0000297
298 GDBRemoteCommunication &
299 GetGDBRemote()
300 {
301 return m_gdb_comm;
302 }
303
304 //------------------------------------------------------------------
305 /// Broadcaster event bits definitions.
306 //------------------------------------------------------------------
307 enum
308 {
309 eBroadcastBitAsyncContinue = (1 << 0),
310 eBroadcastBitAsyncThreadShouldExit = (1 << 1)
311 };
312
Chris Lattner24943d22010-06-08 16:52:24 +0000313 lldb_private::Flags m_flags; // Process specific flags (see eFlags enums)
Chris Lattner24943d22010-06-08 16:52:24 +0000314 lldb_private::Mutex m_stdio_mutex; // Multithreaded protection for stdio
Chris Lattner24943d22010-06-08 16:52:24 +0000315 GDBRemoteCommunication m_gdb_comm;
316 lldb::pid_t m_debugserver_pid;
Greg Clayton75ccf502010-08-21 02:22:51 +0000317 lldb::thread_t m_debugserver_thread;
Chris Lattner24943d22010-06-08 16:52:24 +0000318 StringExtractor m_last_stop_packet;
319 GDBRemoteDynamicRegisterInfo m_register_info;
320 lldb_private::Broadcaster m_async_broadcaster;
321 lldb::thread_t m_async_thread;
322 // Current GDB remote state. Any members added here need to be reset to
323 // proper default values in ResetGDBRemoteState ().
324 lldb::tid_t m_curr_tid; // Current gdb remote protocol thread index for all other operations
325 lldb::tid_t m_curr_tid_run; // Current gdb remote protocol thread index for continue, step, etc
326 uint32_t m_z0_supported:1; // Set to non-zero if Z0 and z0 packets are supported
Greg Claytonc1f45872011-02-12 06:28:37 +0000327 typedef std::vector<lldb::tid_t> tid_collection;
328 typedef std::vector< std::pair<lldb::tid_t,int> > tid_sig_collection;
329 tid_collection m_continue_c_tids; // 'c' for continue
330 tid_sig_collection m_continue_C_tids; // 'C' for continue with signal
331 tid_collection m_continue_s_tids; // 's' for step
332 tid_sig_collection m_continue_S_tids; // 'S' for step with signal
Chris Lattner24943d22010-06-08 16:52:24 +0000333 lldb::addr_t m_dispatch_queue_offsets_addr;
334 uint32_t m_packet_timeout;
335 size_t m_max_memory_size; // The maximum number of bytes to read/write when reading and writing memory
Chris Lattner24943d22010-06-08 16:52:24 +0000336 bool m_waiting_for_attach;
Jim Ingham7508e732010-08-09 23:31:02 +0000337 bool m_local_debugserver; // Is the debugserver process we are talking to local or on another machine.
Jim Ingham55e01d82011-01-22 01:33:44 +0000338 std::vector<lldb::user_id_t> m_thread_observation_bps;
Chris Lattner24943d22010-06-08 16:52:24 +0000339
340 void
341 ResetGDBRemoteState ();
342
343 bool
344 StartAsyncThread ();
345
346 void
347 StopAsyncThread ();
348
349 static void *
350 AsyncThread (void *arg);
351
352 static bool
353 MonitorDebugserverProcess (void *callback_baton,
354 lldb::pid_t pid,
355 int signo, // Zero for no signal
356 int exit_status); // Exit value of process if signal is zero
357
358 lldb::StateType
359 SetThreadStopInfo (StringExtractor& stop_packet);
360
361 void
362 DidLaunchOrAttach ();
363
364 lldb_private::Error
365 ConnectToDebugserver (const char *host_port);
366
367 const char *
368 GetDispatchQueueNameForThread (lldb::addr_t thread_dispatch_qaddr,
369 std::string &dispatch_queue_name);
370
371 static size_t
372 AttachInputReaderCallback (void *baton,
373 lldb_private::InputReader *reader,
374 lldb::InputReaderAction notification,
375 const char *bytes,
376 size_t bytes_len);
377
Greg Clayton72e1c782011-01-22 23:43:18 +0000378 lldb_private::Error
379 InterruptIfRunning (bool discard_thread_plans,
380 bool catch_stop_event,
Greg Clayton72e1c782011-01-22 23:43:18 +0000381 lldb::EventSP &stop_event_sp);
382
Chris Lattner24943d22010-06-08 16:52:24 +0000383private:
384 //------------------------------------------------------------------
385 // For ProcessGDBRemote only
386 //------------------------------------------------------------------
Jim Ingham55e01d82011-01-22 01:33:44 +0000387 static bool
388 NewThreadNotifyBreakpointHit (void *baton,
389 lldb_private::StoppointCallbackContext *context,
390 lldb::user_id_t break_id,
391 lldb::user_id_t break_loc_id);
392
Chris Lattner24943d22010-06-08 16:52:24 +0000393 DISALLOW_COPY_AND_ASSIGN (ProcessGDBRemote);
394
Chris Lattner24943d22010-06-08 16:52:24 +0000395};
396
397#endif // liblldb_ProcessGDBRemote_h_