blob: 74905d0e6461b0bff0dc02e71771b7ec1564c6a1 [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>
17
18// Other libraries and framework includes
19#include "lldb/Core/ArchSpec.h"
20#include "lldb/Core/Broadcaster.h"
21#include "lldb/Core/Error.h"
22#include "lldb/Core/InputReader.h"
23#include "lldb/Core/StreamString.h"
Jim Ingham7508e732010-08-09 23:31:02 +000024#include "lldb/Core/StringList.h"
Chris Lattner24943d22010-06-08 16:52:24 +000025#include "lldb/Core/ThreadSafeValue.h"
26#include "lldb/Target/Process.h"
27#include "lldb/Target/Thread.h"
28
29#include "GDBRemoteCommunication.h"
Greg Clayton54e7afa2010-07-09 20:39:50 +000030#include "Utility/StringExtractor.h"
Chris Lattner24943d22010-06-08 16:52:24 +000031#include "GDBRemoteRegisterContext.h"
Chris Lattner24943d22010-06-08 16:52:24 +000032
33class ThreadGDBRemote;
34
35class ProcessGDBRemote : public lldb_private::Process
36{
37public:
38 //------------------------------------------------------------------
39 // Constructors and Destructors
40 //------------------------------------------------------------------
41 static Process*
42 CreateInstance (lldb_private::Target& target, lldb_private::Listener &listener);
43
44 static void
45 Initialize();
46
47 static void
48 Terminate();
49
50 static const char *
51 GetPluginNameStatic();
52
53 static const char *
54 GetPluginDescriptionStatic();
55
56 //------------------------------------------------------------------
57 // Constructors and Destructors
58 //------------------------------------------------------------------
59 ProcessGDBRemote(lldb_private::Target& target, lldb_private::Listener &listener);
60
61 virtual
62 ~ProcessGDBRemote();
63
64 //------------------------------------------------------------------
65 // Check if a given Process
66 //------------------------------------------------------------------
67 virtual bool
68 CanDebug (lldb_private::Target &target);
69
Jim Ingham7508e732010-08-09 23:31:02 +000070 virtual uint32_t
71 ListProcessesMatchingName (const char *name, lldb_private::StringList &matches, std::vector<lldb::pid_t> &pids);
72
Chris Lattner24943d22010-06-08 16:52:24 +000073 //------------------------------------------------------------------
74 // Creating a new process, or attaching to an existing one
75 //------------------------------------------------------------------
76 virtual lldb_private::Error
77 WillLaunch (lldb_private::Module* module);
78
79 virtual lldb_private::Error
80 DoLaunch (lldb_private::Module* module,
81 char const *argv[], // Can be NULL
82 char const *envp[], // Can be NULL
Greg Clayton452bf612010-08-31 18:35:14 +000083 uint32_t flags,
Chris Lattner24943d22010-06-08 16:52:24 +000084 const char *stdin_path, // Can be NULL
85 const char *stdout_path, // Can be NULL
86 const char *stderr_path); // Can be NULL
87
88 virtual void
89 DidLaunch ();
90
91 virtual lldb_private::Error
Greg Clayton20d338f2010-11-18 05:57:03 +000092 WillAttachToProcessWithID (lldb::pid_t pid);
Chris Lattner24943d22010-06-08 16:52:24 +000093
94 virtual lldb_private::Error
Greg Clayton20d338f2010-11-18 05:57:03 +000095 WillAttachToProcessWithName (const char *process_name, bool wait_for_launch);
Chris Lattner24943d22010-06-08 16:52:24 +000096
97 lldb_private::Error
98 WillLaunchOrAttach ();
99
100 virtual lldb_private::Error
Greg Clayton54e7afa2010-07-09 20:39:50 +0000101 DoAttachToProcessWithID (lldb::pid_t pid);
Chris Lattner24943d22010-06-08 16:52:24 +0000102
103 virtual lldb_private::Error
Greg Clayton54e7afa2010-07-09 20:39:50 +0000104 DoAttachToProcessWithName (const char *process_name, bool wait_for_launch);
Chris Lattner24943d22010-06-08 16:52:24 +0000105
106 virtual void
107 DidAttach ();
108
109 //------------------------------------------------------------------
110 // PluginInterface protocol
111 //------------------------------------------------------------------
112 virtual const char *
113 GetPluginName();
114
115 virtual const char *
116 GetShortPluginName();
117
118 virtual uint32_t
119 GetPluginVersion();
120
121 virtual void
122 GetPluginCommandHelp (const char *command, lldb_private::Stream *strm);
123
124 virtual lldb_private::Error
125 ExecutePluginCommand (lldb_private::Args &command, lldb_private::Stream *strm);
126
127 virtual lldb_private::Log *
128 EnablePluginLogging (lldb_private::Stream *strm, lldb_private::Args &command);
129
130 //------------------------------------------------------------------
131 // Process Control
132 //------------------------------------------------------------------
133 virtual lldb_private::Error
134 WillResume ();
135
136 virtual lldb_private::Error
137 DoResume ();
138
139 virtual lldb_private::Error
Jim Ingham3ae449a2010-11-17 02:32:00 +0000140 DoHalt (bool &caused_stop);
Chris Lattner24943d22010-06-08 16:52:24 +0000141
142 virtual lldb_private::Error
143 WillDetach ();
144
145 virtual lldb_private::Error
146 DoDetach ();
147
148 virtual lldb_private::Error
149 DoSignal (int signal);
150
151 virtual lldb_private::Error
152 DoDestroy ();
153
154 virtual void
155 RefreshStateAfterStop();
156
157 //------------------------------------------------------------------
158 // Process Queries
159 //------------------------------------------------------------------
160 virtual bool
161 IsAlive ();
162
163 virtual lldb::addr_t
164 GetImageInfoAddress();
165
166 //------------------------------------------------------------------
167 // Process Memory
168 //------------------------------------------------------------------
169 virtual size_t
170 DoReadMemory (lldb::addr_t addr, void *buf, size_t size, lldb_private::Error &error);
171
172 virtual size_t
173 DoWriteMemory (lldb::addr_t addr, const void *buf, size_t size, lldb_private::Error &error);
174
175 virtual lldb::addr_t
176 DoAllocateMemory (size_t size, uint32_t permissions, lldb_private::Error &error);
177
178 virtual lldb_private::Error
179 DoDeallocateMemory (lldb::addr_t ptr);
180
181 //------------------------------------------------------------------
182 // Process STDIO
183 //------------------------------------------------------------------
184 virtual size_t
185 GetSTDOUT (char *buf, size_t buf_size, lldb_private::Error &error);
186
187 virtual size_t
188 GetSTDERR (char *buf, size_t buf_size, lldb_private::Error &error);
189
190 virtual size_t
191 PutSTDIN (const char *buf, size_t buf_size, lldb_private::Error &error);
192
193 //----------------------------------------------------------------------
194 // Process Breakpoints
195 //----------------------------------------------------------------------
196 virtual size_t
197 GetSoftwareBreakpointTrapOpcode (lldb_private::BreakpointSite *bp_site);
198
199 //----------------------------------------------------------------------
200 // Process Breakpoints
201 //----------------------------------------------------------------------
202 virtual lldb_private::Error
203 EnableBreakpoint (lldb_private::BreakpointSite *bp_site);
204
205 virtual lldb_private::Error
206 DisableBreakpoint (lldb_private::BreakpointSite *bp_site);
207
208 //----------------------------------------------------------------------
209 // Process Watchpoints
210 //----------------------------------------------------------------------
211 virtual lldb_private::Error
212 EnableWatchpoint (lldb_private::WatchpointLocation *wp_loc);
213
214 virtual lldb_private::Error
215 DisableWatchpoint (lldb_private::WatchpointLocation *wp_loc);
216
Chris Lattner24943d22010-06-08 16:52:24 +0000217 virtual lldb_private::DynamicLoader *
218 GetDynamicLoader ();
219
220protected:
221 friend class ThreadGDBRemote;
222 friend class GDBRemoteCommunication;
223 friend class GDBRemoteRegisterContext;
224
225 bool
226 SetCurrentGDBRemoteThread (int tid);
227
228 bool
229 SetCurrentGDBRemoteThreadForRun (int tid);
230
231 //----------------------------------------------------------------------
232 // Accessors
233 //----------------------------------------------------------------------
234 bool
235 IsRunning ( lldb::StateType state )
236 {
237 return state == lldb::eStateRunning || IsStepping(state);
238 }
239
240 bool
241 IsStepping ( lldb::StateType state)
242 {
243 return state == lldb::eStateStepping;
244 }
245 bool
246 CanResume ( lldb::StateType state)
247 {
248 return state == lldb::eStateStopped;
249 }
250
251 bool
252 HasExited (lldb::StateType state)
253 {
254 return state == lldb::eStateExited;
255 }
256
257 bool
258 ProcessIDIsValid ( ) const;
259
Caroline Tice861efb32010-11-16 05:07:41 +0000260// static void
261// STDIOReadThreadBytesReceived (void *baton, const void *src, size_t src_len);
Chris Lattner24943d22010-06-08 16:52:24 +0000262
Caroline Tice861efb32010-11-16 05:07:41 +0000263// void
264// AppendSTDOUT (const char* s, size_t len);
Chris Lattner24943d22010-06-08 16:52:24 +0000265
Chris Lattner24943d22010-06-08 16:52:24 +0000266 void
267 Clear ( );
268
269 lldb_private::Flags &
270 GetFlags ()
271 {
272 return m_flags;
273 }
274
275 const lldb_private::Flags &
276 GetFlags () const
277 {
278 return m_flags;
279 }
280
281 uint32_t
282 UpdateThreadListIfNeeded ();
283
284 lldb_private::Error
Greg Clayton23cf0c72010-11-08 04:29:11 +0000285 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 +0000286 char const *inferior_argv[],
287 char const *inferior_envp[],
288 const char *stdin_path,
Greg Clayton23cf0c72010-11-08 04:29:11 +0000289 bool launch_process, // Set to true if we are going to be launching a the process
290 lldb::pid_t attach_pid, // If inferior inferior_argv == NULL, then attach to this pid
291 const char *attach_pid_name, // Wait for the next process to launch whose basename matches "attach_wait_name"
292 bool wait_for_launch, // Wait for the process named "attach_wait_name" to launch
Caroline Ticebd666012010-12-03 18:46:09 +0000293 uint32_t launch_flags,
Chris Lattner24943d22010-06-08 16:52:24 +0000294 lldb_private::ArchSpec& arch_spec);
295
296 void
297 KillDebugserverProcess ();
298
299 void
300 BuildDynamicRegisterInfo ();
301
302 GDBRemoteCommunication &
303 GetGDBRemote()
304 {
305 return m_gdb_comm;
306 }
307
308 //------------------------------------------------------------------
309 /// Broadcaster event bits definitions.
310 //------------------------------------------------------------------
311 enum
312 {
313 eBroadcastBitAsyncContinue = (1 << 0),
314 eBroadcastBitAsyncThreadShouldExit = (1 << 1)
315 };
316
317
318 std::auto_ptr<lldb_private::DynamicLoader> m_dynamic_loader_ap;
319 lldb_private::Flags m_flags; // Process specific flags (see eFlags enums)
Chris Lattner24943d22010-06-08 16:52:24 +0000320 lldb_private::Mutex m_stdio_mutex; // Multithreaded protection for stdio
Chris Lattner24943d22010-06-08 16:52:24 +0000321 GDBRemoteCommunication m_gdb_comm;
322 lldb::pid_t m_debugserver_pid;
Greg Clayton75ccf502010-08-21 02:22:51 +0000323 lldb::thread_t m_debugserver_thread;
Chris Lattner24943d22010-06-08 16:52:24 +0000324 StringExtractor m_last_stop_packet;
325 GDBRemoteDynamicRegisterInfo m_register_info;
326 lldb_private::Broadcaster m_async_broadcaster;
327 lldb::thread_t m_async_thread;
328 // Current GDB remote state. Any members added here need to be reset to
329 // proper default values in ResetGDBRemoteState ().
330 lldb::tid_t m_curr_tid; // Current gdb remote protocol thread index for all other operations
331 lldb::tid_t m_curr_tid_run; // Current gdb remote protocol thread index for continue, step, etc
332 uint32_t m_z0_supported:1; // Set to non-zero if Z0 and z0 packets are supported
333 lldb_private::StreamString m_continue_packet;
334 lldb::addr_t m_dispatch_queue_offsets_addr;
335 uint32_t m_packet_timeout;
336 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 +0000337 bool m_waiting_for_attach;
Jim Ingham7508e732010-08-09 23:31:02 +0000338 bool m_local_debugserver; // Is the debugserver process we are talking to local or on another machine.
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
378private:
379 //------------------------------------------------------------------
380 // For ProcessGDBRemote only
381 //------------------------------------------------------------------
382 DISALLOW_COPY_AND_ASSIGN (ProcessGDBRemote);
383
Chris Lattner24943d22010-06-08 16:52:24 +0000384};
385
386#endif // liblldb_ProcessGDBRemote_h_