blob: ee87924a9a9c4e27242dbf8e3e1d423e87b00d95 [file] [log] [blame]
Chris Lattner24943d22010-06-08 16:52:24 +00001//===-- SBProcess.cpp -------------------------------------------*- 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
Eli Friedman7a62c8b2010-06-09 07:44:37 +000010#include "lldb/API/SBProcess.h"
Chris Lattner24943d22010-06-08 16:52:24 +000011
12#include "lldb/lldb-defines.h"
13#include "lldb/lldb-types.h"
14
Jim Ingham84cdc152010-06-15 19:49:27 +000015#include "lldb/Interpreter/Args.h"
Greg Clayton1a3083a2010-10-06 03:53:16 +000016#include "lldb/Core/Debugger.h"
Caroline Tice7826c882010-10-26 03:11:13 +000017#include "lldb/Core/Log.h"
Chris Lattner24943d22010-06-08 16:52:24 +000018#include "lldb/Core/State.h"
19#include "lldb/Core/Stream.h"
20#include "lldb/Core/StreamFile.h"
21#include "lldb/Target/Process.h"
Chris Lattner24943d22010-06-08 16:52:24 +000022#include "lldb/Target/RegisterContext.h"
Greg Clayton63094e02010-06-23 01:19:29 +000023#include "lldb/Target/Target.h"
24#include "lldb/Target/Thread.h"
Chris Lattner24943d22010-06-08 16:52:24 +000025
26// Project includes
27
Eli Friedman7a62c8b2010-06-09 07:44:37 +000028#include "lldb/API/SBBroadcaster.h"
Eli Friedman7a62c8b2010-06-09 07:44:37 +000029#include "lldb/API/SBCommandReturnObject.h"
Greg Clayton0a8dcac2012-02-24 05:03:03 +000030#include "lldb/API/SBDebugger.h"
Eli Friedman7a62c8b2010-06-09 07:44:37 +000031#include "lldb/API/SBEvent.h"
Greg Clayton0a8dcac2012-02-24 05:03:03 +000032#include "lldb/API/SBFileSpec.h"
Eli Friedman7a62c8b2010-06-09 07:44:37 +000033#include "lldb/API/SBThread.h"
Caroline Tice98f930f2010-09-20 05:20:02 +000034#include "lldb/API/SBStream.h"
Eli Friedman7a62c8b2010-06-09 07:44:37 +000035#include "lldb/API/SBStringList.h"
Chris Lattner24943d22010-06-08 16:52:24 +000036
37using namespace lldb;
38using namespace lldb_private;
39
40
Chris Lattner24943d22010-06-08 16:52:24 +000041SBProcess::SBProcess () :
Greg Clayton63094e02010-06-23 01:19:29 +000042 m_opaque_sp()
Chris Lattner24943d22010-06-08 16:52:24 +000043{
44}
45
46
47//----------------------------------------------------------------------
48// SBProcess constructor
49//----------------------------------------------------------------------
50
51SBProcess::SBProcess (const SBProcess& rhs) :
Greg Clayton63094e02010-06-23 01:19:29 +000052 m_opaque_sp (rhs.m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000053{
54}
55
56
57SBProcess::SBProcess (const lldb::ProcessSP &process_sp) :
Greg Clayton63094e02010-06-23 01:19:29 +000058 m_opaque_sp (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000059{
60}
61
Greg Clayton538eb822010-11-05 23:17:00 +000062const SBProcess&
63SBProcess::operator = (const SBProcess& rhs)
64{
65 if (this != &rhs)
66 m_opaque_sp = rhs.m_opaque_sp;
67 return *this;
68}
69
Chris Lattner24943d22010-06-08 16:52:24 +000070//----------------------------------------------------------------------
71// Destructor
72//----------------------------------------------------------------------
73SBProcess::~SBProcess()
74{
75}
76
Jim Ingham5a15e692012-02-16 06:50:00 +000077const char *
78SBProcess::GetBroadcasterClassName ()
79{
80 return Process::GetStaticBroadcasterClass().AsCString();
81}
82
Greg Clayton334d33a2012-01-30 07:41:31 +000083lldb::ProcessSP
84SBProcess::GetSP() const
85{
86 return m_opaque_sp;
87}
88
Chris Lattner24943d22010-06-08 16:52:24 +000089void
Greg Clayton334d33a2012-01-30 07:41:31 +000090SBProcess::SetSP (const ProcessSP &process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000091{
Greg Clayton63094e02010-06-23 01:19:29 +000092 m_opaque_sp = process_sp;
Chris Lattner24943d22010-06-08 16:52:24 +000093}
94
95void
96SBProcess::Clear ()
97{
Greg Clayton63094e02010-06-23 01:19:29 +000098 m_opaque_sp.reset();
Chris Lattner24943d22010-06-08 16:52:24 +000099}
100
101
102bool
103SBProcess::IsValid() const
104{
Greg Clayton63094e02010-06-23 01:19:29 +0000105 return m_opaque_sp.get() != NULL;
Chris Lattner24943d22010-06-08 16:52:24 +0000106}
107
James McIlree38093402011-03-04 00:31:13 +0000108bool
109SBProcess::RemoteLaunch (char const **argv,
110 char const **envp,
111 const char *stdin_path,
112 const char *stdout_path,
113 const char *stderr_path,
114 const char *working_directory,
115 uint32_t launch_flags,
116 bool stop_at_entry,
117 lldb::SBError& error)
118{
119 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
120 if (log) {
121 log->Printf ("SBProcess(%p)::RemoteLaunch (argv=%p, envp=%p, stdin=%s, stdout=%s, stderr=%s, working-dir=%s, launch_flags=0x%x, stop_at_entry=%i, &error (%p))...",
122 m_opaque_sp.get(),
123 argv,
124 envp,
125 stdin_path ? stdin_path : "NULL",
126 stdout_path ? stdout_path : "NULL",
127 stderr_path ? stderr_path : "NULL",
128 working_directory ? working_directory : "NULL",
129 launch_flags,
130 stop_at_entry,
131 error.get());
132 }
133
Greg Clayton0416bdf2012-01-30 09:04:36 +0000134 ProcessSP process_sp(GetSP());
135 if (process_sp)
James McIlree38093402011-03-04 00:31:13 +0000136 {
Greg Claytona894fe72012-04-05 16:12:35 +0000137 Process::StopLocker stop_locker;
138
139 if (stop_locker.TryLock(&process_sp->GetRunLock()))
James McIlree38093402011-03-04 00:31:13 +0000140 {
Greg Claytona894fe72012-04-05 16:12:35 +0000141 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
142 if (process_sp->GetState() == eStateConnected)
143 {
144 if (stop_at_entry)
145 launch_flags |= eLaunchFlagStopAtEntry;
146 ProcessLaunchInfo launch_info (stdin_path,
147 stdout_path,
148 stderr_path,
149 working_directory,
150 launch_flags);
151 Module *exe_module = process_sp->GetTarget().GetExecutableModulePointer();
152 if (exe_module)
153 launch_info.SetExecutableFile(exe_module->GetFileSpec(), true);
154 if (argv)
155 launch_info.GetArguments().AppendArguments (argv);
156 if (envp)
157 launch_info.GetEnvironmentEntries ().SetArguments (envp);
158 error.SetError (process_sp->Launch (launch_info));
159 }
160 else
161 {
162 error.SetErrorString ("must be in eStateConnected to call RemoteLaunch");
163 }
James McIlree38093402011-03-04 00:31:13 +0000164 }
165 else
166 {
Greg Claytona894fe72012-04-05 16:12:35 +0000167 error.SetErrorString ("process is running");
James McIlree38093402011-03-04 00:31:13 +0000168 }
169 }
170 else
171 {
172 error.SetErrorString ("unable to attach pid");
173 }
174
175 if (log) {
176 SBStream sstr;
177 error.GetDescription (sstr);
Greg Clayton0416bdf2012-01-30 09:04:36 +0000178 log->Printf ("SBProcess(%p)::RemoteLaunch (...) => SBError (%p): %s", process_sp.get(), error.get(), sstr.GetData());
James McIlree38093402011-03-04 00:31:13 +0000179 }
180
181 return error.Success();
182}
183
184bool
185SBProcess::RemoteAttachToProcessWithID (lldb::pid_t pid, lldb::SBError& error)
186{
Greg Clayton0416bdf2012-01-30 09:04:36 +0000187 ProcessSP process_sp(GetSP());
188 if (process_sp)
James McIlree38093402011-03-04 00:31:13 +0000189 {
Greg Claytona894fe72012-04-05 16:12:35 +0000190 Process::StopLocker stop_locker;
191
192 if (stop_locker.TryLock(&process_sp->GetRunLock()))
James McIlree38093402011-03-04 00:31:13 +0000193 {
Greg Claytona894fe72012-04-05 16:12:35 +0000194 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
195 if (process_sp->GetState() == eStateConnected)
196 {
197 ProcessAttachInfo attach_info;
198 attach_info.SetProcessID (pid);
199 error.SetError (process_sp->Attach (attach_info));
200 }
201 else
202 {
203 error.SetErrorString ("must be in eStateConnected to call RemoteAttachToProcessWithID");
204 }
James McIlree38093402011-03-04 00:31:13 +0000205 }
206 else
207 {
Greg Claytona894fe72012-04-05 16:12:35 +0000208 error.SetErrorString ("process is running");
James McIlree38093402011-03-04 00:31:13 +0000209 }
210 }
211 else
212 {
213 error.SetErrorString ("unable to attach pid");
214 }
215
216 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
217 if (log) {
218 SBStream sstr;
219 error.GetDescription (sstr);
Greg Clayton0416bdf2012-01-30 09:04:36 +0000220 log->Printf ("SBProcess(%p)::RemoteAttachToProcessWithID (%llu) => SBError (%p): %s", process_sp.get(), pid, error.get(), sstr.GetData());
James McIlree38093402011-03-04 00:31:13 +0000221 }
222
223 return error.Success();
224}
225
Chris Lattner24943d22010-06-08 16:52:24 +0000226
227uint32_t
228SBProcess::GetNumThreads ()
229{
Greg Claytone005f2c2010-11-06 01:53:30 +0000230 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000231
Caroline Tice7826c882010-10-26 03:11:13 +0000232 uint32_t num_threads = 0;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000233 ProcessSP process_sp(GetSP());
234 if (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000235 {
Greg Claytona894fe72012-04-05 16:12:35 +0000236 Process::StopLocker stop_locker;
237
238 const bool can_update = stop_locker.TryLock(&process_sp->GetRunLock());
Greg Clayton0416bdf2012-01-30 09:04:36 +0000239 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
Greg Clayton0416bdf2012-01-30 09:04:36 +0000240 num_threads = process_sp->GetThreadList().GetSize(can_update);
Chris Lattner24943d22010-06-08 16:52:24 +0000241 }
Caroline Tice7826c882010-10-26 03:11:13 +0000242
243 if (log)
Greg Clayton0416bdf2012-01-30 09:04:36 +0000244 log->Printf ("SBProcess(%p)::GetNumThreads () => %d", process_sp.get(), num_threads);
Caroline Tice7826c882010-10-26 03:11:13 +0000245
246 return num_threads;
Chris Lattner24943d22010-06-08 16:52:24 +0000247}
248
249SBThread
Jim Inghamc8332952010-08-26 21:32:51 +0000250SBProcess::GetSelectedThread () const
Chris Lattner24943d22010-06-08 16:52:24 +0000251{
Greg Claytone005f2c2010-11-06 01:53:30 +0000252 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000253
Chris Lattner24943d22010-06-08 16:52:24 +0000254 SBThread sb_thread;
Greg Clayton90c52142012-01-30 02:53:15 +0000255 ThreadSP thread_sp;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000256 ProcessSP process_sp(GetSP());
257 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000258 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000259 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
260 thread_sp = process_sp->GetThreadList().GetSelectedThread();
Greg Clayton90c52142012-01-30 02:53:15 +0000261 sb_thread.SetThread (thread_sp);
Greg Claytonbdcda462010-12-20 20:49:23 +0000262 }
Caroline Tice7826c882010-10-26 03:11:13 +0000263
264 if (log)
265 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000266 log->Printf ("SBProcess(%p)::GetSelectedThread () => SBThread(%p)", process_sp.get(), thread_sp.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000267 }
268
Chris Lattner24943d22010-06-08 16:52:24 +0000269 return sb_thread;
270}
271
272SBTarget
273SBProcess::GetTarget() const
274{
Greg Claytone005f2c2010-11-06 01:53:30 +0000275 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000276
Chris Lattner24943d22010-06-08 16:52:24 +0000277 SBTarget sb_target;
Greg Clayton334d33a2012-01-30 07:41:31 +0000278 TargetSP target_sp;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000279 ProcessSP process_sp(GetSP());
280 if (process_sp)
Greg Clayton334d33a2012-01-30 07:41:31 +0000281 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000282 target_sp = process_sp->GetTarget().shared_from_this();
Greg Clayton334d33a2012-01-30 07:41:31 +0000283 sb_target.SetSP (target_sp);
284 }
Caroline Tice7826c882010-10-26 03:11:13 +0000285
286 if (log)
Greg Clayton0416bdf2012-01-30 09:04:36 +0000287 log->Printf ("SBProcess(%p)::GetTarget () => SBTarget(%p)", process_sp.get(), target_sp.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000288
Chris Lattner24943d22010-06-08 16:52:24 +0000289 return sb_target;
290}
291
292
293size_t
294SBProcess::PutSTDIN (const char *src, size_t src_len)
295{
Greg Claytone005f2c2010-11-06 01:53:30 +0000296 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000297
Caroline Tice7826c882010-10-26 03:11:13 +0000298 size_t ret_val = 0;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000299 ProcessSP process_sp(GetSP());
300 if (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000301 {
302 Error error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000303 ret_val = process_sp->PutSTDIN (src, src_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000304 }
Caroline Tice7826c882010-10-26 03:11:13 +0000305
306 if (log)
Jason Molenda7e5fa7f2011-09-20 21:44:10 +0000307 log->Printf ("SBProcess(%p)::PutSTDIN (src=\"%s\", src_len=%d) => %lu",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000308 process_sp.get(),
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000309 src,
310 (uint32_t) src_len,
311 ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000312
313 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000314}
315
316size_t
317SBProcess::GetSTDOUT (char *dst, size_t dst_len) const
318{
Greg Clayton49ce6822010-10-31 03:01:06 +0000319 size_t bytes_read = 0;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000320 ProcessSP process_sp(GetSP());
321 if (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000322 {
323 Error error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000324 bytes_read = process_sp->GetSTDOUT (dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000325 }
Caroline Tice7826c882010-10-26 03:11:13 +0000326
Greg Claytone005f2c2010-11-06 01:53:30 +0000327 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000328 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000329 log->Printf ("SBProcess(%p)::GetSTDOUT (dst=\"%.*s\", dst_len=%zu) => %zu",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000330 process_sp.get(), (int) bytes_read, dst, dst_len, bytes_read);
Caroline Tice7826c882010-10-26 03:11:13 +0000331
Greg Clayton49ce6822010-10-31 03:01:06 +0000332 return bytes_read;
Chris Lattner24943d22010-06-08 16:52:24 +0000333}
334
335size_t
336SBProcess::GetSTDERR (char *dst, size_t dst_len) const
337{
Greg Clayton49ce6822010-10-31 03:01:06 +0000338 size_t bytes_read = 0;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000339 ProcessSP process_sp(GetSP());
340 if (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000341 {
342 Error error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000343 bytes_read = process_sp->GetSTDERR (dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000344 }
Caroline Tice7826c882010-10-26 03:11:13 +0000345
Greg Claytone005f2c2010-11-06 01:53:30 +0000346 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000347 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000348 log->Printf ("SBProcess(%p)::GetSTDERR (dst=\"%.*s\", dst_len=%zu) => %zu",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000349 process_sp.get(), (int) bytes_read, dst, dst_len, bytes_read);
Caroline Tice7826c882010-10-26 03:11:13 +0000350
Greg Clayton49ce6822010-10-31 03:01:06 +0000351 return bytes_read;
Chris Lattner24943d22010-06-08 16:52:24 +0000352}
353
354void
Jim Inghamc8332952010-08-26 21:32:51 +0000355SBProcess::ReportEventState (const SBEvent &event, FILE *out) const
Chris Lattner24943d22010-06-08 16:52:24 +0000356{
357 if (out == NULL)
358 return;
359
Greg Clayton0416bdf2012-01-30 09:04:36 +0000360 ProcessSP process_sp(GetSP());
361 if (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000362 {
363 const StateType event_state = SBProcess::GetStateFromEvent (event);
364 char message[1024];
365 int message_len = ::snprintf (message,
366 sizeof (message),
Greg Clayton444e35b2011-10-19 18:09:39 +0000367 "Process %llu %s\n",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000368 process_sp->GetID(),
Chris Lattner24943d22010-06-08 16:52:24 +0000369 SBDebugger::StateAsCString (event_state));
370
371 if (message_len > 0)
372 ::fwrite (message, 1, message_len, out);
373 }
374}
375
376void
Jim Inghamc8332952010-08-26 21:32:51 +0000377SBProcess::AppendEventStateReport (const SBEvent &event, SBCommandReturnObject &result)
Chris Lattner24943d22010-06-08 16:52:24 +0000378{
Greg Clayton0416bdf2012-01-30 09:04:36 +0000379 ProcessSP process_sp(GetSP());
380 if (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000381 {
382 const StateType event_state = SBProcess::GetStateFromEvent (event);
383 char message[1024];
384 ::snprintf (message,
385 sizeof (message),
Greg Clayton444e35b2011-10-19 18:09:39 +0000386 "Process %llu %s\n",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000387 process_sp->GetID(),
Chris Lattner24943d22010-06-08 16:52:24 +0000388 SBDebugger::StateAsCString (event_state));
389
390 result.AppendMessage (message);
391 }
392}
393
394bool
Jim Inghamc8332952010-08-26 21:32:51 +0000395SBProcess::SetSelectedThread (const SBThread &thread)
Chris Lattner24943d22010-06-08 16:52:24 +0000396{
Greg Clayton0416bdf2012-01-30 09:04:36 +0000397 ProcessSP process_sp(GetSP());
398 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000399 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000400 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
401 return process_sp->GetThreadList().SetSelectedThreadByID (thread.GetThreadID());
Greg Claytonbdcda462010-12-20 20:49:23 +0000402 }
Chris Lattner24943d22010-06-08 16:52:24 +0000403 return false;
404}
405
406bool
Jim Inghamc8332952010-08-26 21:32:51 +0000407SBProcess::SetSelectedThreadByID (uint32_t tid)
Chris Lattner24943d22010-06-08 16:52:24 +0000408{
Greg Claytone005f2c2010-11-06 01:53:30 +0000409 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000410
Caroline Tice7826c882010-10-26 03:11:13 +0000411 bool ret_val = false;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000412 ProcessSP process_sp(GetSP());
413 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000414 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000415 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
416 ret_val = process_sp->GetThreadList().SetSelectedThreadByID (tid);
Greg Claytonbdcda462010-12-20 20:49:23 +0000417 }
Caroline Tice7826c882010-10-26 03:11:13 +0000418
419 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000420 log->Printf ("SBProcess(%p)::SetSelectedThreadByID (tid=0x%4.4x) => %s",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000421 process_sp.get(), tid, (ret_val ? "true" : "false"));
Caroline Tice7826c882010-10-26 03:11:13 +0000422
423 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000424}
425
426SBThread
427SBProcess::GetThreadAtIndex (size_t index)
428{
Greg Claytone005f2c2010-11-06 01:53:30 +0000429 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000430
Greg Clayton90c52142012-01-30 02:53:15 +0000431 SBThread sb_thread;
432 ThreadSP thread_sp;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000433 ProcessSP process_sp(GetSP());
434 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000435 {
Greg Claytona894fe72012-04-05 16:12:35 +0000436 Process::StopLocker stop_locker;
437 const bool can_update = stop_locker.TryLock(&process_sp->GetRunLock());
Greg Clayton0416bdf2012-01-30 09:04:36 +0000438 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
Greg Claytona894fe72012-04-05 16:12:35 +0000439 thread_sp = process_sp->GetThreadList().GetThreadAtIndex(index, can_update);
Greg Clayton90c52142012-01-30 02:53:15 +0000440 sb_thread.SetThread (thread_sp);
Greg Claytonbdcda462010-12-20 20:49:23 +0000441 }
Caroline Tice7826c882010-10-26 03:11:13 +0000442
443 if (log)
444 {
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000445 log->Printf ("SBProcess(%p)::GetThreadAtIndex (index=%d) => SBThread(%p)",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000446 process_sp.get(), (uint32_t) index, thread_sp.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000447 }
448
Greg Clayton90c52142012-01-30 02:53:15 +0000449 return sb_thread;
Chris Lattner24943d22010-06-08 16:52:24 +0000450}
451
452StateType
453SBProcess::GetState ()
454{
Caroline Tice7826c882010-10-26 03:11:13 +0000455
Caroline Tice7826c882010-10-26 03:11:13 +0000456 StateType ret_val = eStateInvalid;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000457 ProcessSP process_sp(GetSP());
458 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000459 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000460 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
461 ret_val = process_sp->GetState();
Greg Claytonbdcda462010-12-20 20:49:23 +0000462 }
Caroline Tice7826c882010-10-26 03:11:13 +0000463
Greg Claytone005f2c2010-11-06 01:53:30 +0000464 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000465 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000466 log->Printf ("SBProcess(%p)::GetState () => %s",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000467 process_sp.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000468 lldb_private::StateAsCString (ret_val));
Caroline Tice7826c882010-10-26 03:11:13 +0000469
470 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000471}
472
473
474int
475SBProcess::GetExitStatus ()
476{
Greg Claytona66ba462010-10-30 04:51:46 +0000477 int exit_status = 0;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000478 ProcessSP process_sp(GetSP());
479 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000480 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000481 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
482 exit_status = process_sp->GetExitStatus ();
Greg Claytonbdcda462010-12-20 20:49:23 +0000483 }
Greg Claytone005f2c2010-11-06 01:53:30 +0000484 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000485 if (log)
486 log->Printf ("SBProcess(%p)::GetExitStatus () => %i (0x%8.8x)",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000487 process_sp.get(), exit_status, exit_status);
Greg Claytona66ba462010-10-30 04:51:46 +0000488
489 return exit_status;
Chris Lattner24943d22010-06-08 16:52:24 +0000490}
491
492const char *
493SBProcess::GetExitDescription ()
494{
Greg Claytona66ba462010-10-30 04:51:46 +0000495 const char *exit_desc = NULL;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000496 ProcessSP process_sp(GetSP());
497 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000498 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000499 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
500 exit_desc = process_sp->GetExitDescription ();
Greg Claytonbdcda462010-12-20 20:49:23 +0000501 }
Greg Claytone005f2c2010-11-06 01:53:30 +0000502 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000503 if (log)
504 log->Printf ("SBProcess(%p)::GetExitDescription () => %s",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000505 process_sp.get(), exit_desc);
Greg Claytona66ba462010-10-30 04:51:46 +0000506 return exit_desc;
Chris Lattner24943d22010-06-08 16:52:24 +0000507}
508
509lldb::pid_t
510SBProcess::GetProcessID ()
511{
Caroline Tice7826c882010-10-26 03:11:13 +0000512 lldb::pid_t ret_val = LLDB_INVALID_PROCESS_ID;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000513 ProcessSP process_sp(GetSP());
514 if (process_sp)
515 ret_val = process_sp->GetID();
Caroline Tice7826c882010-10-26 03:11:13 +0000516
Greg Claytone005f2c2010-11-06 01:53:30 +0000517 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000518 if (log)
Greg Clayton0416bdf2012-01-30 09:04:36 +0000519 log->Printf ("SBProcess(%p)::GetProcessID () => %llu", process_sp.get(), ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000520
521 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000522}
523
Johnny Chen60a544f2011-03-01 22:56:31 +0000524ByteOrder
525SBProcess::GetByteOrder () const
526{
527 ByteOrder byteOrder = eByteOrderInvalid;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000528 ProcessSP process_sp(GetSP());
529 if (process_sp)
530 byteOrder = process_sp->GetTarget().GetArchitecture().GetByteOrder();
Johnny Chen60a544f2011-03-01 22:56:31 +0000531
532 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
533 if (log)
Greg Clayton0416bdf2012-01-30 09:04:36 +0000534 log->Printf ("SBProcess(%p)::GetByteOrder () => %d", process_sp.get(), byteOrder);
Johnny Chen60a544f2011-03-01 22:56:31 +0000535
536 return byteOrder;
537}
538
Chris Lattner24943d22010-06-08 16:52:24 +0000539uint32_t
540SBProcess::GetAddressByteSize () const
541{
Caroline Tice7826c882010-10-26 03:11:13 +0000542 uint32_t size = 0;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000543 ProcessSP process_sp(GetSP());
544 if (process_sp)
545 size = process_sp->GetTarget().GetArchitecture().GetAddressByteSize();
Caroline Tice7826c882010-10-26 03:11:13 +0000546
Greg Claytone005f2c2010-11-06 01:53:30 +0000547 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000548 if (log)
Greg Clayton0416bdf2012-01-30 09:04:36 +0000549 log->Printf ("SBProcess(%p)::GetAddressByteSize () => %d", process_sp.get(), size);
Caroline Tice7826c882010-10-26 03:11:13 +0000550
551 return size;
Chris Lattner24943d22010-06-08 16:52:24 +0000552}
553
Chris Lattner24943d22010-06-08 16:52:24 +0000554SBError
555SBProcess::Continue ()
556{
Greg Claytone005f2c2010-11-06 01:53:30 +0000557 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000558
Chris Lattner24943d22010-06-08 16:52:24 +0000559 SBError sb_error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000560 ProcessSP process_sp(GetSP());
561
562 if (log)
563 log->Printf ("SBProcess(%p)::Continue ()...", process_sp.get());
564
565 if (process_sp)
Greg Clayton1a3083a2010-10-06 03:53:16 +0000566 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000567 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
Greg Claytonde1dd812011-06-24 03:21:43 +0000568
Greg Clayton0416bdf2012-01-30 09:04:36 +0000569 Error error (process_sp->Resume());
Greg Clayton1a3083a2010-10-06 03:53:16 +0000570 if (error.Success())
571 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000572 if (process_sp->GetTarget().GetDebugger().GetAsyncExecution () == false)
Greg Claytona66ba462010-10-30 04:51:46 +0000573 {
574 if (log)
Greg Clayton0416bdf2012-01-30 09:04:36 +0000575 log->Printf ("SBProcess(%p)::Continue () waiting for process to stop...", process_sp.get());
576 process_sp->WaitForProcessToStop (NULL);
Greg Claytona66ba462010-10-30 04:51:46 +0000577 }
Greg Clayton1a3083a2010-10-06 03:53:16 +0000578 }
579 sb_error.SetError(error);
580 }
Chris Lattner24943d22010-06-08 16:52:24 +0000581 else
582 sb_error.SetErrorString ("SBProcess is invalid");
583
Caroline Tice7826c882010-10-26 03:11:13 +0000584 if (log)
585 {
586 SBStream sstr;
587 sb_error.GetDescription (sstr);
Greg Clayton0416bdf2012-01-30 09:04:36 +0000588 log->Printf ("SBProcess(%p)::Continue () => SBError (%p): %s", process_sp.get(), sb_error.get(), sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000589 }
590
Chris Lattner24943d22010-06-08 16:52:24 +0000591 return sb_error;
592}
593
594
595SBError
596SBProcess::Destroy ()
597{
598 SBError sb_error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000599 ProcessSP process_sp(GetSP());
600 if (process_sp)
Greg Clayton72e1c782011-01-22 23:43:18 +0000601 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000602 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
603 sb_error.SetError(process_sp->Destroy());
Greg Clayton72e1c782011-01-22 23:43:18 +0000604 }
Chris Lattner24943d22010-06-08 16:52:24 +0000605 else
606 sb_error.SetErrorString ("SBProcess is invalid");
607
Greg Claytone005f2c2010-11-06 01:53:30 +0000608 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000609 if (log)
610 {
611 SBStream sstr;
612 sb_error.GetDescription (sstr);
Greg Clayton72e1c782011-01-22 23:43:18 +0000613 log->Printf ("SBProcess(%p)::Destroy () => SBError (%p): %s",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000614 process_sp.get(),
Greg Clayton72e1c782011-01-22 23:43:18 +0000615 sb_error.get(),
616 sstr.GetData());
Greg Claytona66ba462010-10-30 04:51:46 +0000617 }
618
Chris Lattner24943d22010-06-08 16:52:24 +0000619 return sb_error;
620}
621
622
623SBError
624SBProcess::Stop ()
625{
626 SBError sb_error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000627 ProcessSP process_sp(GetSP());
628 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000629 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000630 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
631 sb_error.SetError (process_sp->Halt());
Greg Claytonbdcda462010-12-20 20:49:23 +0000632 }
Chris Lattner24943d22010-06-08 16:52:24 +0000633 else
634 sb_error.SetErrorString ("SBProcess is invalid");
Caroline Tice7826c882010-10-26 03:11:13 +0000635
Greg Claytone005f2c2010-11-06 01:53:30 +0000636 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000637 if (log)
638 {
639 SBStream sstr;
640 sb_error.GetDescription (sstr);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000641 log->Printf ("SBProcess(%p)::Stop () => SBError (%p): %s",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000642 process_sp.get(),
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000643 sb_error.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000644 sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000645 }
646
Chris Lattner24943d22010-06-08 16:52:24 +0000647 return sb_error;
648}
649
650SBError
651SBProcess::Kill ()
652{
653 SBError sb_error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000654 ProcessSP process_sp(GetSP());
655 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000656 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000657 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
658 sb_error.SetError (process_sp->Destroy());
Greg Claytonbdcda462010-12-20 20:49:23 +0000659 }
Chris Lattner24943d22010-06-08 16:52:24 +0000660 else
661 sb_error.SetErrorString ("SBProcess is invalid");
Caroline Tice7826c882010-10-26 03:11:13 +0000662
Greg Claytone005f2c2010-11-06 01:53:30 +0000663 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000664 if (log)
665 {
666 SBStream sstr;
667 sb_error.GetDescription (sstr);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000668 log->Printf ("SBProcess(%p)::Kill () => SBError (%p): %s",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000669 process_sp.get(),
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000670 sb_error.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000671 sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000672 }
673
Chris Lattner24943d22010-06-08 16:52:24 +0000674 return sb_error;
675}
676
Chris Lattner24943d22010-06-08 16:52:24 +0000677SBError
678SBProcess::Detach ()
679{
680 SBError sb_error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000681 ProcessSP process_sp(GetSP());
682 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000683 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000684 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
685 sb_error.SetError (process_sp->Detach());
Greg Claytonbdcda462010-12-20 20:49:23 +0000686 }
Chris Lattner24943d22010-06-08 16:52:24 +0000687 else
688 sb_error.SetErrorString ("SBProcess is invalid");
689
690 return sb_error;
691}
692
693SBError
Greg Claytona66ba462010-10-30 04:51:46 +0000694SBProcess::Signal (int signo)
Chris Lattner24943d22010-06-08 16:52:24 +0000695{
696 SBError sb_error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000697 ProcessSP process_sp(GetSP());
698 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000699 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000700 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
701 sb_error.SetError (process_sp->Signal (signo));
Greg Claytonbdcda462010-12-20 20:49:23 +0000702 }
Chris Lattner24943d22010-06-08 16:52:24 +0000703 else
704 sb_error.SetErrorString ("SBProcess is invalid");
Greg Claytone005f2c2010-11-06 01:53:30 +0000705 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000706 if (log)
707 {
708 SBStream sstr;
709 sb_error.GetDescription (sstr);
710 log->Printf ("SBProcess(%p)::Signal (signo=%i) => SBError (%p): %s",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000711 process_sp.get(),
Greg Claytona66ba462010-10-30 04:51:46 +0000712 signo,
713 sb_error.get(),
714 sstr.GetData());
715 }
Chris Lattner24943d22010-06-08 16:52:24 +0000716 return sb_error;
717}
718
Chris Lattner24943d22010-06-08 16:52:24 +0000719SBThread
Greg Claytona66ba462010-10-30 04:51:46 +0000720SBProcess::GetThreadByID (tid_t tid)
Chris Lattner24943d22010-06-08 16:52:24 +0000721{
Greg Claytona66ba462010-10-30 04:51:46 +0000722 SBThread sb_thread;
Greg Clayton90c52142012-01-30 02:53:15 +0000723 ThreadSP thread_sp;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000724 ProcessSP process_sp(GetSP());
725 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000726 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000727 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
Greg Claytona894fe72012-04-05 16:12:35 +0000728 Process::StopLocker stop_locker;
729 const bool can_update = stop_locker.TryLock(&process_sp->GetRunLock());
730 thread_sp = process_sp->GetThreadList().FindThreadByID (tid, can_update);
Greg Clayton90c52142012-01-30 02:53:15 +0000731 sb_thread.SetThread (thread_sp);
Greg Claytonbdcda462010-12-20 20:49:23 +0000732 }
Greg Claytona66ba462010-10-30 04:51:46 +0000733
Greg Claytone005f2c2010-11-06 01:53:30 +0000734 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000735 if (log)
736 {
Greg Claytond9919d32011-12-01 23:28:38 +0000737 log->Printf ("SBProcess(%p)::GetThreadByID (tid=0x%4.4llx) => SBThread (%p)",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000738 process_sp.get(),
Greg Claytona66ba462010-10-30 04:51:46 +0000739 tid,
Greg Clayton90c52142012-01-30 02:53:15 +0000740 thread_sp.get());
Greg Claytona66ba462010-10-30 04:51:46 +0000741 }
742
743 return sb_thread;
Chris Lattner24943d22010-06-08 16:52:24 +0000744}
745
Chris Lattner24943d22010-06-08 16:52:24 +0000746StateType
747SBProcess::GetStateFromEvent (const SBEvent &event)
748{
Greg Claytone005f2c2010-11-06 01:53:30 +0000749 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000750
Caroline Tice7826c882010-10-26 03:11:13 +0000751 StateType ret_val = Process::ProcessEventData::GetStateFromEvent (event.get());
752
753 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000754 log->Printf ("SBProcess::GetStateFromEvent (event.sp=%p) => %s", event.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000755 lldb_private::StateAsCString (ret_val));
Caroline Tice7826c882010-10-26 03:11:13 +0000756
757 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000758}
759
Chris Lattner24943d22010-06-08 16:52:24 +0000760bool
761SBProcess::GetRestartedFromEvent (const SBEvent &event)
762{
Greg Clayton63094e02010-06-23 01:19:29 +0000763 return Process::ProcessEventData::GetRestartedFromEvent (event.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000764}
765
766SBProcess
767SBProcess::GetProcessFromEvent (const SBEvent &event)
768{
Greg Clayton63094e02010-06-23 01:19:29 +0000769 SBProcess process(Process::ProcessEventData::GetProcessFromEvent (event.get()));
Chris Lattner24943d22010-06-08 16:52:24 +0000770 return process;
771}
772
Jim Ingham28e23862012-02-08 05:23:15 +0000773bool
774SBProcess::EventIsProcessEvent (const SBEvent &event)
775{
Jim Ingham5a15e692012-02-16 06:50:00 +0000776 return strcmp (event.GetBroadcasterClass(), SBProcess::GetBroadcasterClass()) == 0;
Jim Ingham28e23862012-02-08 05:23:15 +0000777}
Chris Lattner24943d22010-06-08 16:52:24 +0000778
779SBBroadcaster
780SBProcess::GetBroadcaster () const
781{
Greg Claytone005f2c2010-11-06 01:53:30 +0000782 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000783
Greg Clayton0416bdf2012-01-30 09:04:36 +0000784 ProcessSP process_sp(GetSP());
785
786 SBBroadcaster broadcaster(process_sp.get(), false);
Caroline Tice7826c882010-10-26 03:11:13 +0000787
788 if (log)
Greg Clayton0416bdf2012-01-30 09:04:36 +0000789 log->Printf ("SBProcess(%p)::GetBroadcaster () => SBBroadcaster (%p)", process_sp.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000790 broadcaster.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000791
Chris Lattner24943d22010-06-08 16:52:24 +0000792 return broadcaster;
793}
794
Jim Ingham5a15e692012-02-16 06:50:00 +0000795const char *
796SBProcess::GetBroadcasterClass ()
797{
798 return Process::GetStaticBroadcasterClass().AsCString();
799}
800
Chris Lattner24943d22010-06-08 16:52:24 +0000801size_t
802SBProcess::ReadMemory (addr_t addr, void *dst, size_t dst_len, SBError &sb_error)
803{
Greg Claytone005f2c2010-11-06 01:53:30 +0000804 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000805
Chris Lattner24943d22010-06-08 16:52:24 +0000806 size_t bytes_read = 0;
807
Greg Clayton0416bdf2012-01-30 09:04:36 +0000808 ProcessSP process_sp(GetSP());
809
Greg Claytona66ba462010-10-30 04:51:46 +0000810 if (log)
811 {
812 log->Printf ("SBProcess(%p)::ReadMemory (addr=0x%llx, dst=%p, dst_len=%zu, SBError (%p))...",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000813 process_sp.get(),
Greg Claytona66ba462010-10-30 04:51:46 +0000814 addr,
815 dst,
Greg Claytonbae39c52011-12-03 00:46:21 +0000816 dst_len,
Greg Claytona66ba462010-10-30 04:51:46 +0000817 sb_error.get());
818 }
Greg Clayton0416bdf2012-01-30 09:04:36 +0000819
820 if (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000821 {
Greg Claytona894fe72012-04-05 16:12:35 +0000822 Process::StopLocker stop_locker;
823 if (stop_locker.TryLock(&process_sp->GetRunLock()))
824 {
825 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
826 bytes_read = process_sp->ReadMemory (addr, dst, dst_len, sb_error.ref());
827 }
828 else
829 {
830 sb_error.SetErrorString("process is running");
831 }
Chris Lattner24943d22010-06-08 16:52:24 +0000832 }
833 else
834 {
835 sb_error.SetErrorString ("SBProcess is invalid");
836 }
837
Caroline Tice7826c882010-10-26 03:11:13 +0000838 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000839 {
840 SBStream sstr;
841 sb_error.GetDescription (sstr);
Greg Claytonbae39c52011-12-03 00:46:21 +0000842 log->Printf ("SBProcess(%p)::ReadMemory (addr=0x%llx, dst=%p, dst_len=%zu, SBError (%p): %s) => %zu",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000843 process_sp.get(),
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000844 addr,
845 dst,
Greg Claytonbae39c52011-12-03 00:46:21 +0000846 dst_len,
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000847 sb_error.get(),
848 sstr.GetData(),
Greg Claytonbae39c52011-12-03 00:46:21 +0000849 bytes_read);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000850 }
Caroline Tice7826c882010-10-26 03:11:13 +0000851
Chris Lattner24943d22010-06-08 16:52:24 +0000852 return bytes_read;
853}
854
855size_t
Greg Clayton4a2e3372011-12-15 03:14:23 +0000856SBProcess::ReadCStringFromMemory (addr_t addr, void *buf, size_t size, lldb::SBError &sb_error)
857{
858 size_t bytes_read = 0;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000859 ProcessSP process_sp(GetSP());
860 if (process_sp)
Greg Clayton4a2e3372011-12-15 03:14:23 +0000861 {
Greg Claytona894fe72012-04-05 16:12:35 +0000862 Process::StopLocker stop_locker;
863 if (stop_locker.TryLock(&process_sp->GetRunLock()))
864 {
865 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
866 bytes_read = process_sp->ReadCStringFromMemory (addr, (char *)buf, size, sb_error.ref());
867 }
868 else
869 {
870 sb_error.SetErrorString("process is running");
871 }
Greg Clayton4a2e3372011-12-15 03:14:23 +0000872 }
873 else
874 {
875 sb_error.SetErrorString ("SBProcess is invalid");
876 }
877 return bytes_read;
878}
879
880uint64_t
881SBProcess::ReadUnsignedFromMemory (addr_t addr, uint32_t byte_size, lldb::SBError &sb_error)
882{
Greg Claytona894fe72012-04-05 16:12:35 +0000883 uint64_t value = 0;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000884 ProcessSP process_sp(GetSP());
885 if (process_sp)
Greg Clayton4a2e3372011-12-15 03:14:23 +0000886 {
Greg Claytona894fe72012-04-05 16:12:35 +0000887 Process::StopLocker stop_locker;
888 if (stop_locker.TryLock(&process_sp->GetRunLock()))
889 {
890 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
891 value = process_sp->ReadUnsignedIntegerFromMemory (addr, byte_size, 0, sb_error.ref());
892 }
893 else
894 {
895 sb_error.SetErrorString("process is running");
896 }
Greg Clayton4a2e3372011-12-15 03:14:23 +0000897 }
898 else
899 {
900 sb_error.SetErrorString ("SBProcess is invalid");
901 }
Greg Claytona894fe72012-04-05 16:12:35 +0000902 return value;
Greg Clayton4a2e3372011-12-15 03:14:23 +0000903}
904
905lldb::addr_t
906SBProcess::ReadPointerFromMemory (addr_t addr, lldb::SBError &sb_error)
907{
908 lldb::addr_t ptr = LLDB_INVALID_ADDRESS;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000909 ProcessSP process_sp(GetSP());
910 if (process_sp)
Greg Clayton4a2e3372011-12-15 03:14:23 +0000911 {
Greg Claytona894fe72012-04-05 16:12:35 +0000912 Process::StopLocker stop_locker;
913 if (stop_locker.TryLock(&process_sp->GetRunLock()))
914 {
915 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
916 ptr = process_sp->ReadPointerFromMemory (addr, sb_error.ref());
917 }
918 else
919 {
920 sb_error.SetErrorString("process is running");
921 }
Greg Clayton4a2e3372011-12-15 03:14:23 +0000922 }
923 else
924 {
925 sb_error.SetErrorString ("SBProcess is invalid");
926 }
927 return ptr;
928}
929
930size_t
Chris Lattner24943d22010-06-08 16:52:24 +0000931SBProcess::WriteMemory (addr_t addr, const void *src, size_t src_len, SBError &sb_error)
932{
933 size_t bytes_written = 0;
934
Greg Claytone005f2c2010-11-06 01:53:30 +0000935 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Clayton0416bdf2012-01-30 09:04:36 +0000936
937 ProcessSP process_sp(GetSP());
938
Greg Claytona66ba462010-10-30 04:51:46 +0000939 if (log)
940 {
941 log->Printf ("SBProcess(%p)::WriteMemory (addr=0x%llx, src=%p, dst_len=%zu, SBError (%p))...",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000942 process_sp.get(),
Greg Claytona66ba462010-10-30 04:51:46 +0000943 addr,
944 src,
Greg Claytonbae39c52011-12-03 00:46:21 +0000945 src_len,
Greg Claytona66ba462010-10-30 04:51:46 +0000946 sb_error.get());
947 }
948
Greg Clayton0416bdf2012-01-30 09:04:36 +0000949 if (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000950 {
Greg Claytona894fe72012-04-05 16:12:35 +0000951 Process::StopLocker stop_locker;
952 if (stop_locker.TryLock(&process_sp->GetRunLock()))
953 {
954 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
955 bytes_written = process_sp->WriteMemory (addr, src, src_len, sb_error.ref());
956 }
957 else
958 {
959 sb_error.SetErrorString("process is running");
960 }
Chris Lattner24943d22010-06-08 16:52:24 +0000961 }
962
Greg Claytona66ba462010-10-30 04:51:46 +0000963 if (log)
964 {
965 SBStream sstr;
966 sb_error.GetDescription (sstr);
Greg Claytonbae39c52011-12-03 00:46:21 +0000967 log->Printf ("SBProcess(%p)::WriteMemory (addr=0x%llx, src=%p, dst_len=%zu, SBError (%p): %s) => %zu",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000968 process_sp.get(),
Greg Claytona66ba462010-10-30 04:51:46 +0000969 addr,
970 src,
Greg Claytonbae39c52011-12-03 00:46:21 +0000971 src_len,
Greg Claytona66ba462010-10-30 04:51:46 +0000972 sb_error.get(),
973 sstr.GetData(),
Greg Claytonbae39c52011-12-03 00:46:21 +0000974 bytes_written);
Greg Claytona66ba462010-10-30 04:51:46 +0000975 }
976
Chris Lattner24943d22010-06-08 16:52:24 +0000977 return bytes_written;
978}
979
Caroline Tice98f930f2010-09-20 05:20:02 +0000980bool
981SBProcess::GetDescription (SBStream &description)
982{
Greg Clayton96154be2011-11-13 06:57:31 +0000983 Stream &strm = description.ref();
984
Greg Clayton0416bdf2012-01-30 09:04:36 +0000985 ProcessSP process_sp(GetSP());
986 if (process_sp)
Caroline Tice98f930f2010-09-20 05:20:02 +0000987 {
988 char path[PATH_MAX];
989 GetTarget().GetExecutable().GetPath (path, sizeof(path));
Greg Clayton0416bdf2012-01-30 09:04:36 +0000990 Module *exe_module = process_sp->GetTarget().GetExecutableModulePointer();
Greg Clayton5c4c7462010-10-06 03:09:58 +0000991 const char *exe_name = NULL;
992 if (exe_module)
993 exe_name = exe_module->GetFileSpec().GetFilename().AsCString();
994
Greg Clayton96154be2011-11-13 06:57:31 +0000995 strm.Printf ("SBProcess: pid = %llu, state = %s, threads = %d%s%s",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000996 process_sp->GetID(),
Greg Clayton96154be2011-11-13 06:57:31 +0000997 lldb_private::StateAsCString (GetState()),
998 GetNumThreads(),
999 exe_name ? ", executable = " : "",
1000 exe_name ? exe_name : "");
Caroline Tice98f930f2010-09-20 05:20:02 +00001001 }
1002 else
Greg Clayton96154be2011-11-13 06:57:31 +00001003 strm.PutCString ("No value");
Caroline Tice98f930f2010-09-20 05:20:02 +00001004
1005 return true;
1006}
Greg Clayton0baa3942010-11-04 01:54:29 +00001007
1008uint32_t
1009SBProcess::LoadImage (lldb::SBFileSpec &sb_image_spec, lldb::SBError &sb_error)
1010{
Greg Clayton0416bdf2012-01-30 09:04:36 +00001011 ProcessSP process_sp(GetSP());
1012 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +00001013 {
Greg Claytona894fe72012-04-05 16:12:35 +00001014 Process::StopLocker stop_locker;
1015 if (stop_locker.TryLock(&process_sp->GetRunLock()))
1016 {
1017 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
1018 return process_sp->LoadImage (*sb_image_spec, sb_error.ref());
1019 }
1020 else
1021 {
1022 sb_error.SetErrorString("process is running");
1023 }
Greg Claytonbdcda462010-12-20 20:49:23 +00001024 }
Greg Clayton0baa3942010-11-04 01:54:29 +00001025 return LLDB_INVALID_IMAGE_TOKEN;
1026}
1027
1028lldb::SBError
1029SBProcess::UnloadImage (uint32_t image_token)
1030{
1031 lldb::SBError sb_error;
Greg Clayton0416bdf2012-01-30 09:04:36 +00001032 ProcessSP process_sp(GetSP());
1033 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +00001034 {
Greg Claytona894fe72012-04-05 16:12:35 +00001035 Process::StopLocker stop_locker;
1036 if (stop_locker.TryLock(&process_sp->GetRunLock()))
1037 {
1038 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
1039 sb_error.SetError (process_sp->UnloadImage (image_token));
1040 }
1041 else
1042 {
1043 sb_error.SetErrorString("process is running");
1044 }
Greg Claytonbdcda462010-12-20 20:49:23 +00001045 }
Greg Clayton0baa3942010-11-04 01:54:29 +00001046 else
1047 sb_error.SetErrorString("invalid process");
1048 return sb_error;
1049}