blob: 3422efbdb94d26a324d76c5c9a23c0caa32d8a8d [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"
29#include "lldb/API/SBDebugger.h"
30#include "lldb/API/SBCommandReturnObject.h"
31#include "lldb/API/SBEvent.h"
32#include "lldb/API/SBThread.h"
Caroline Tice98f930f2010-09-20 05:20:02 +000033#include "lldb/API/SBStream.h"
Eli Friedman7a62c8b2010-06-09 07:44:37 +000034#include "lldb/API/SBStringList.h"
Chris Lattner24943d22010-06-08 16:52:24 +000035
36using namespace lldb;
37using namespace lldb_private;
38
39
40
41SBProcess::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
Greg Clayton334d33a2012-01-30 07:41:31 +000077lldb::ProcessSP
78SBProcess::GetSP() const
79{
80 return m_opaque_sp;
81}
82
Chris Lattner24943d22010-06-08 16:52:24 +000083void
Greg Clayton334d33a2012-01-30 07:41:31 +000084SBProcess::SetSP (const ProcessSP &process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000085{
Greg Clayton63094e02010-06-23 01:19:29 +000086 m_opaque_sp = process_sp;
Chris Lattner24943d22010-06-08 16:52:24 +000087}
88
89void
90SBProcess::Clear ()
91{
Greg Clayton63094e02010-06-23 01:19:29 +000092 m_opaque_sp.reset();
Chris Lattner24943d22010-06-08 16:52:24 +000093}
94
95
96bool
97SBProcess::IsValid() const
98{
Greg Clayton63094e02010-06-23 01:19:29 +000099 return m_opaque_sp.get() != NULL;
Chris Lattner24943d22010-06-08 16:52:24 +0000100}
101
James McIlree38093402011-03-04 00:31:13 +0000102bool
103SBProcess::RemoteLaunch (char const **argv,
104 char const **envp,
105 const char *stdin_path,
106 const char *stdout_path,
107 const char *stderr_path,
108 const char *working_directory,
109 uint32_t launch_flags,
110 bool stop_at_entry,
111 lldb::SBError& error)
112{
113 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
114 if (log) {
115 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))...",
116 m_opaque_sp.get(),
117 argv,
118 envp,
119 stdin_path ? stdin_path : "NULL",
120 stdout_path ? stdout_path : "NULL",
121 stderr_path ? stderr_path : "NULL",
122 working_directory ? working_directory : "NULL",
123 launch_flags,
124 stop_at_entry,
125 error.get());
126 }
127
128 if (m_opaque_sp)
129 {
130 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
131 if (m_opaque_sp->GetState() == eStateConnected)
132 {
Greg Clayton36bc5ea2011-11-03 21:22:33 +0000133 if (stop_at_entry)
134 launch_flags |= eLaunchFlagStopAtEntry;
135 ProcessLaunchInfo launch_info (stdin_path,
136 stdout_path,
137 stderr_path,
138 working_directory,
139 launch_flags);
140 Module *exe_module = m_opaque_sp->GetTarget().GetExecutableModulePointer();
141 if (exe_module)
142 launch_info.SetExecutableFile(exe_module->GetFileSpec(), true);
143 if (argv)
144 launch_info.GetArguments().AppendArguments (argv);
145 if (envp)
146 launch_info.GetEnvironmentEntries ().SetArguments (envp);
147 error.SetError (m_opaque_sp->Launch (launch_info));
James McIlree38093402011-03-04 00:31:13 +0000148 }
149 else
150 {
151 error.SetErrorString ("must be in eStateConnected to call RemoteLaunch");
152 }
153 }
154 else
155 {
156 error.SetErrorString ("unable to attach pid");
157 }
158
159 if (log) {
160 SBStream sstr;
161 error.GetDescription (sstr);
Johnny Chen42da4da2011-03-05 01:20:11 +0000162 log->Printf ("SBProcess(%p)::RemoteLaunch (...) => SBError (%p): %s", m_opaque_sp.get(), error.get(), sstr.GetData());
James McIlree38093402011-03-04 00:31:13 +0000163 }
164
165 return error.Success();
166}
167
168bool
169SBProcess::RemoteAttachToProcessWithID (lldb::pid_t pid, lldb::SBError& error)
170{
171 if (m_opaque_sp)
172 {
173 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
174 if (m_opaque_sp->GetState() == eStateConnected)
175 {
Greg Clayton527154d2011-11-15 03:53:30 +0000176 ProcessAttachInfo attach_info;
177 attach_info.SetProcessID (pid);
178 error.SetError (m_opaque_sp->Attach (attach_info));
James McIlree38093402011-03-04 00:31:13 +0000179 }
180 else
181 {
182 error.SetErrorString ("must be in eStateConnected to call RemoteAttachToProcessWithID");
183 }
184 }
185 else
186 {
187 error.SetErrorString ("unable to attach pid");
188 }
189
190 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
191 if (log) {
192 SBStream sstr;
193 error.GetDescription (sstr);
Greg Claytond9919d32011-12-01 23:28:38 +0000194 log->Printf ("SBProcess(%p)::RemoteAttachToProcessWithID (%llu) => SBError (%p): %s", m_opaque_sp.get(), pid, error.get(), sstr.GetData());
James McIlree38093402011-03-04 00:31:13 +0000195 }
196
197 return error.Success();
198}
199
Chris Lattner24943d22010-06-08 16:52:24 +0000200
201uint32_t
202SBProcess::GetNumThreads ()
203{
Greg Claytone005f2c2010-11-06 01:53:30 +0000204 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000205
Caroline Tice7826c882010-10-26 03:11:13 +0000206 uint32_t num_threads = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000207 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000208 {
Greg Claytonbdcda462010-12-20 20:49:23 +0000209 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Chris Lattner24943d22010-06-08 16:52:24 +0000210 const bool can_update = true;
Caroline Tice7826c882010-10-26 03:11:13 +0000211 num_threads = m_opaque_sp->GetThreadList().GetSize(can_update);
Chris Lattner24943d22010-06-08 16:52:24 +0000212 }
Caroline Tice7826c882010-10-26 03:11:13 +0000213
214 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000215 log->Printf ("SBProcess(%p)::GetNumThreads () => %d", m_opaque_sp.get(), num_threads);
Caroline Tice7826c882010-10-26 03:11:13 +0000216
217 return num_threads;
Chris Lattner24943d22010-06-08 16:52:24 +0000218}
219
220SBThread
Jim Inghamc8332952010-08-26 21:32:51 +0000221SBProcess::GetSelectedThread () const
Chris Lattner24943d22010-06-08 16:52:24 +0000222{
Greg Claytone005f2c2010-11-06 01:53:30 +0000223 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000224
Chris Lattner24943d22010-06-08 16:52:24 +0000225 SBThread sb_thread;
Greg Clayton90c52142012-01-30 02:53:15 +0000226 ThreadSP thread_sp;
Greg Clayton63094e02010-06-23 01:19:29 +0000227 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000228 {
229 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton90c52142012-01-30 02:53:15 +0000230 thread_sp = m_opaque_sp->GetThreadList().GetSelectedThread();
231 sb_thread.SetThread (thread_sp);
Greg Claytonbdcda462010-12-20 20:49:23 +0000232 }
Caroline Tice7826c882010-10-26 03:11:13 +0000233
234 if (log)
235 {
Greg Clayton90c52142012-01-30 02:53:15 +0000236 log->Printf ("SBProcess(%p)::GetSelectedThread () => SBThread(%p)", m_opaque_sp.get(), thread_sp.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000237 }
238
Chris Lattner24943d22010-06-08 16:52:24 +0000239 return sb_thread;
240}
241
242SBTarget
243SBProcess::GetTarget() const
244{
Greg Claytone005f2c2010-11-06 01:53:30 +0000245 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000246
Chris Lattner24943d22010-06-08 16:52:24 +0000247 SBTarget sb_target;
Greg Clayton334d33a2012-01-30 07:41:31 +0000248 TargetSP target_sp;
Greg Clayton63094e02010-06-23 01:19:29 +0000249 if (m_opaque_sp)
Greg Clayton334d33a2012-01-30 07:41:31 +0000250 {
251 target_sp = m_opaque_sp->GetTarget().shared_from_this();
252 sb_target.SetSP (target_sp);
253 }
Caroline Tice7826c882010-10-26 03:11:13 +0000254
255 if (log)
Greg Clayton334d33a2012-01-30 07:41:31 +0000256 log->Printf ("SBProcess(%p)::GetTarget () => SBTarget(%p)", m_opaque_sp.get(), target_sp.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000257
Chris Lattner24943d22010-06-08 16:52:24 +0000258 return sb_target;
259}
260
261
262size_t
263SBProcess::PutSTDIN (const char *src, size_t src_len)
264{
Greg Claytone005f2c2010-11-06 01:53:30 +0000265 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000266
Caroline Tice7826c882010-10-26 03:11:13 +0000267 size_t ret_val = 0;
Greg Claytonbdcda462010-12-20 20:49:23 +0000268 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000269 {
270 Error error;
Caroline Tice7826c882010-10-26 03:11:13 +0000271 ret_val = m_opaque_sp->PutSTDIN (src, src_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000272 }
Caroline Tice7826c882010-10-26 03:11:13 +0000273
274 if (log)
Jason Molenda7e5fa7f2011-09-20 21:44:10 +0000275 log->Printf ("SBProcess(%p)::PutSTDIN (src=\"%s\", src_len=%d) => %lu",
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000276 m_opaque_sp.get(),
277 src,
278 (uint32_t) src_len,
279 ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000280
281 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000282}
283
284size_t
285SBProcess::GetSTDOUT (char *dst, size_t dst_len) const
286{
Greg Clayton49ce6822010-10-31 03:01:06 +0000287 size_t bytes_read = 0;
Greg Claytonbdcda462010-12-20 20:49:23 +0000288 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000289 {
290 Error error;
Greg Clayton49ce6822010-10-31 03:01:06 +0000291 bytes_read = m_opaque_sp->GetSTDOUT (dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000292 }
Caroline Tice7826c882010-10-26 03:11:13 +0000293
Greg Claytone005f2c2010-11-06 01:53:30 +0000294 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000295 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000296 log->Printf ("SBProcess(%p)::GetSTDOUT (dst=\"%.*s\", dst_len=%zu) => %zu",
297 m_opaque_sp.get(), (int) bytes_read, dst, dst_len, bytes_read);
Caroline Tice7826c882010-10-26 03:11:13 +0000298
Greg Clayton49ce6822010-10-31 03:01:06 +0000299 return bytes_read;
Chris Lattner24943d22010-06-08 16:52:24 +0000300}
301
302size_t
303SBProcess::GetSTDERR (char *dst, size_t dst_len) const
304{
Greg Clayton49ce6822010-10-31 03:01:06 +0000305 size_t bytes_read = 0;
Greg Claytonbdcda462010-12-20 20:49:23 +0000306 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000307 {
308 Error error;
Greg Clayton49ce6822010-10-31 03:01:06 +0000309 bytes_read = m_opaque_sp->GetSTDERR (dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000310 }
Caroline Tice7826c882010-10-26 03:11:13 +0000311
Greg Claytone005f2c2010-11-06 01:53:30 +0000312 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000313 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000314 log->Printf ("SBProcess(%p)::GetSTDERR (dst=\"%.*s\", dst_len=%zu) => %zu",
315 m_opaque_sp.get(), (int) bytes_read, dst, dst_len, bytes_read);
Caroline Tice7826c882010-10-26 03:11:13 +0000316
Greg Clayton49ce6822010-10-31 03:01:06 +0000317 return bytes_read;
Chris Lattner24943d22010-06-08 16:52:24 +0000318}
319
320void
Jim Inghamc8332952010-08-26 21:32:51 +0000321SBProcess::ReportEventState (const SBEvent &event, FILE *out) const
Chris Lattner24943d22010-06-08 16:52:24 +0000322{
323 if (out == NULL)
324 return;
325
Greg Claytonbdcda462010-12-20 20:49:23 +0000326 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000327 {
328 const StateType event_state = SBProcess::GetStateFromEvent (event);
329 char message[1024];
330 int message_len = ::snprintf (message,
331 sizeof (message),
Greg Clayton444e35b2011-10-19 18:09:39 +0000332 "Process %llu %s\n",
Greg Clayton63094e02010-06-23 01:19:29 +0000333 m_opaque_sp->GetID(),
Chris Lattner24943d22010-06-08 16:52:24 +0000334 SBDebugger::StateAsCString (event_state));
335
336 if (message_len > 0)
337 ::fwrite (message, 1, message_len, out);
338 }
339}
340
341void
Jim Inghamc8332952010-08-26 21:32:51 +0000342SBProcess::AppendEventStateReport (const SBEvent &event, SBCommandReturnObject &result)
Chris Lattner24943d22010-06-08 16:52:24 +0000343{
Greg Claytonbdcda462010-12-20 20:49:23 +0000344 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000345 {
346 const StateType event_state = SBProcess::GetStateFromEvent (event);
347 char message[1024];
348 ::snprintf (message,
349 sizeof (message),
Greg Clayton444e35b2011-10-19 18:09:39 +0000350 "Process %llu %s\n",
Greg Clayton63094e02010-06-23 01:19:29 +0000351 m_opaque_sp->GetID(),
Chris Lattner24943d22010-06-08 16:52:24 +0000352 SBDebugger::StateAsCString (event_state));
353
354 result.AppendMessage (message);
355 }
356}
357
358bool
Jim Inghamc8332952010-08-26 21:32:51 +0000359SBProcess::SetSelectedThread (const SBThread &thread)
Chris Lattner24943d22010-06-08 16:52:24 +0000360{
Greg Claytonbdcda462010-12-20 20:49:23 +0000361 if (m_opaque_sp)
362 {
363 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Jim Inghamc8332952010-08-26 21:32:51 +0000364 return m_opaque_sp->GetThreadList().SetSelectedThreadByID (thread.GetThreadID());
Greg Claytonbdcda462010-12-20 20:49:23 +0000365 }
Chris Lattner24943d22010-06-08 16:52:24 +0000366 return false;
367}
368
369bool
Jim Inghamc8332952010-08-26 21:32:51 +0000370SBProcess::SetSelectedThreadByID (uint32_t tid)
Chris Lattner24943d22010-06-08 16:52:24 +0000371{
Greg Claytone005f2c2010-11-06 01:53:30 +0000372 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000373
Caroline Tice7826c882010-10-26 03:11:13 +0000374 bool ret_val = false;
Greg Claytonbdcda462010-12-20 20:49:23 +0000375 if (m_opaque_sp)
376 {
377 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Caroline Tice7826c882010-10-26 03:11:13 +0000378 ret_val = m_opaque_sp->GetThreadList().SetSelectedThreadByID (tid);
Greg Claytonbdcda462010-12-20 20:49:23 +0000379 }
Caroline Tice7826c882010-10-26 03:11:13 +0000380
381 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000382 log->Printf ("SBProcess(%p)::SetSelectedThreadByID (tid=0x%4.4x) => %s",
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000383 m_opaque_sp.get(), tid, (ret_val ? "true" : "false"));
Caroline Tice7826c882010-10-26 03:11:13 +0000384
385 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000386}
387
388SBThread
389SBProcess::GetThreadAtIndex (size_t index)
390{
Greg Claytone005f2c2010-11-06 01:53:30 +0000391 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000392
Greg Clayton90c52142012-01-30 02:53:15 +0000393 SBThread sb_thread;
394 ThreadSP thread_sp;
Greg Clayton63094e02010-06-23 01:19:29 +0000395 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000396 {
397 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton90c52142012-01-30 02:53:15 +0000398 thread_sp = m_opaque_sp->GetThreadList().GetThreadAtIndex(index);
399 sb_thread.SetThread (thread_sp);
Greg Claytonbdcda462010-12-20 20:49:23 +0000400 }
Caroline Tice7826c882010-10-26 03:11:13 +0000401
402 if (log)
403 {
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000404 log->Printf ("SBProcess(%p)::GetThreadAtIndex (index=%d) => SBThread(%p)",
Greg Clayton90c52142012-01-30 02:53:15 +0000405 m_opaque_sp.get(), (uint32_t) index, thread_sp.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000406 }
407
Greg Clayton90c52142012-01-30 02:53:15 +0000408 return sb_thread;
Chris Lattner24943d22010-06-08 16:52:24 +0000409}
410
411StateType
412SBProcess::GetState ()
413{
Caroline Tice7826c882010-10-26 03:11:13 +0000414
Caroline Tice7826c882010-10-26 03:11:13 +0000415 StateType ret_val = eStateInvalid;
Greg Claytonbdcda462010-12-20 20:49:23 +0000416 if (m_opaque_sp)
417 {
418 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Caroline Tice7826c882010-10-26 03:11:13 +0000419 ret_val = m_opaque_sp->GetState();
Greg Claytonbdcda462010-12-20 20:49:23 +0000420 }
Caroline Tice7826c882010-10-26 03:11:13 +0000421
Greg Claytone005f2c2010-11-06 01:53:30 +0000422 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000423 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000424 log->Printf ("SBProcess(%p)::GetState () => %s",
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000425 m_opaque_sp.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000426 lldb_private::StateAsCString (ret_val));
Caroline Tice7826c882010-10-26 03:11:13 +0000427
428 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000429}
430
431
432int
433SBProcess::GetExitStatus ()
434{
Greg Claytona66ba462010-10-30 04:51:46 +0000435 int exit_status = 0;
436 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000437 {
438 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Claytona66ba462010-10-30 04:51:46 +0000439 exit_status = m_opaque_sp->GetExitStatus ();
Greg Claytonbdcda462010-12-20 20:49:23 +0000440 }
Greg Claytone005f2c2010-11-06 01:53:30 +0000441 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000442 if (log)
443 log->Printf ("SBProcess(%p)::GetExitStatus () => %i (0x%8.8x)",
444 m_opaque_sp.get(), exit_status, exit_status);
445
446 return exit_status;
Chris Lattner24943d22010-06-08 16:52:24 +0000447}
448
449const char *
450SBProcess::GetExitDescription ()
451{
Greg Claytona66ba462010-10-30 04:51:46 +0000452 const char *exit_desc = NULL;
Greg Claytonbdcda462010-12-20 20:49:23 +0000453 if (m_opaque_sp)
454 {
455 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Claytona66ba462010-10-30 04:51:46 +0000456 exit_desc = m_opaque_sp->GetExitDescription ();
Greg Claytonbdcda462010-12-20 20:49:23 +0000457 }
Greg Claytone005f2c2010-11-06 01:53:30 +0000458 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000459 if (log)
460 log->Printf ("SBProcess(%p)::GetExitDescription () => %s",
461 m_opaque_sp.get(), exit_desc);
462 return exit_desc;
Chris Lattner24943d22010-06-08 16:52:24 +0000463}
464
465lldb::pid_t
466SBProcess::GetProcessID ()
467{
Caroline Tice7826c882010-10-26 03:11:13 +0000468 lldb::pid_t ret_val = LLDB_INVALID_PROCESS_ID;
Greg Clayton63094e02010-06-23 01:19:29 +0000469 if (m_opaque_sp)
Caroline Tice7826c882010-10-26 03:11:13 +0000470 ret_val = m_opaque_sp->GetID();
471
Greg Claytone005f2c2010-11-06 01:53:30 +0000472 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000473 if (log)
Greg Claytond9919d32011-12-01 23:28:38 +0000474 log->Printf ("SBProcess(%p)::GetProcessID () => %llu", m_opaque_sp.get(), ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000475
476 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000477}
478
Johnny Chen60a544f2011-03-01 22:56:31 +0000479ByteOrder
480SBProcess::GetByteOrder () const
481{
482 ByteOrder byteOrder = eByteOrderInvalid;
483 if (m_opaque_sp)
484 byteOrder = m_opaque_sp->GetTarget().GetArchitecture().GetByteOrder();
485
486 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
487 if (log)
488 log->Printf ("SBProcess(%p)::GetByteOrder () => %d", m_opaque_sp.get(), byteOrder);
489
490 return byteOrder;
491}
492
Chris Lattner24943d22010-06-08 16:52:24 +0000493uint32_t
494SBProcess::GetAddressByteSize () const
495{
Caroline Tice7826c882010-10-26 03:11:13 +0000496 uint32_t size = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000497 if (m_opaque_sp)
Greg Clayton395fc332011-02-15 21:59:32 +0000498 size = m_opaque_sp->GetTarget().GetArchitecture().GetAddressByteSize();
Caroline Tice7826c882010-10-26 03:11:13 +0000499
Greg Claytone005f2c2010-11-06 01:53:30 +0000500 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000501 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000502 log->Printf ("SBProcess(%p)::GetAddressByteSize () => %d", m_opaque_sp.get(), size);
Caroline Tice7826c882010-10-26 03:11:13 +0000503
504 return size;
Chris Lattner24943d22010-06-08 16:52:24 +0000505}
506
Chris Lattner24943d22010-06-08 16:52:24 +0000507SBError
508SBProcess::Continue ()
509{
Greg Claytone005f2c2010-11-06 01:53:30 +0000510 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000511 if (log)
512 log->Printf ("SBProcess(%p)::Continue ()...", m_opaque_sp.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000513
Chris Lattner24943d22010-06-08 16:52:24 +0000514 SBError sb_error;
Greg Claytonde1dd812011-06-24 03:21:43 +0000515 if (m_opaque_sp)
Greg Clayton1a3083a2010-10-06 03:53:16 +0000516 {
Greg Claytonde1dd812011-06-24 03:21:43 +0000517 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
518
Greg Clayton1a3083a2010-10-06 03:53:16 +0000519 Error error (m_opaque_sp->Resume());
520 if (error.Success())
521 {
522 if (m_opaque_sp->GetTarget().GetDebugger().GetAsyncExecution () == false)
Greg Claytona66ba462010-10-30 04:51:46 +0000523 {
524 if (log)
525 log->Printf ("SBProcess(%p)::Continue () waiting for process to stop...", m_opaque_sp.get());
Greg Clayton1a3083a2010-10-06 03:53:16 +0000526 m_opaque_sp->WaitForProcessToStop (NULL);
Greg Claytona66ba462010-10-30 04:51:46 +0000527 }
Greg Clayton1a3083a2010-10-06 03:53:16 +0000528 }
529 sb_error.SetError(error);
530 }
Chris Lattner24943d22010-06-08 16:52:24 +0000531 else
532 sb_error.SetErrorString ("SBProcess is invalid");
533
Caroline Tice7826c882010-10-26 03:11:13 +0000534 if (log)
535 {
536 SBStream sstr;
537 sb_error.GetDescription (sstr);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000538 log->Printf ("SBProcess(%p)::Continue () => SBError (%p): %s", m_opaque_sp.get(), sb_error.get(), sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000539 }
540
Chris Lattner24943d22010-06-08 16:52:24 +0000541 return sb_error;
542}
543
544
545SBError
546SBProcess::Destroy ()
547{
548 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000549 if (m_opaque_sp)
Greg Clayton72e1c782011-01-22 23:43:18 +0000550 {
551 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton63094e02010-06-23 01:19:29 +0000552 sb_error.SetError(m_opaque_sp->Destroy());
Greg Clayton72e1c782011-01-22 23:43:18 +0000553 }
Chris Lattner24943d22010-06-08 16:52:24 +0000554 else
555 sb_error.SetErrorString ("SBProcess is invalid");
556
Greg Claytone005f2c2010-11-06 01:53:30 +0000557 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000558 if (log)
559 {
560 SBStream sstr;
561 sb_error.GetDescription (sstr);
Greg Clayton72e1c782011-01-22 23:43:18 +0000562 log->Printf ("SBProcess(%p)::Destroy () => SBError (%p): %s",
563 m_opaque_sp.get(),
564 sb_error.get(),
565 sstr.GetData());
Greg Claytona66ba462010-10-30 04:51:46 +0000566 }
567
Chris Lattner24943d22010-06-08 16:52:24 +0000568 return sb_error;
569}
570
571
572SBError
573SBProcess::Stop ()
574{
575 SBError sb_error;
Greg Claytonde1dd812011-06-24 03:21:43 +0000576 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000577 {
578 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton63094e02010-06-23 01:19:29 +0000579 sb_error.SetError (m_opaque_sp->Halt());
Greg Claytonbdcda462010-12-20 20:49:23 +0000580 }
Chris Lattner24943d22010-06-08 16:52:24 +0000581 else
582 sb_error.SetErrorString ("SBProcess is invalid");
Caroline Tice7826c882010-10-26 03:11:13 +0000583
Greg Claytone005f2c2010-11-06 01:53:30 +0000584 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000585 if (log)
586 {
587 SBStream sstr;
588 sb_error.GetDescription (sstr);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000589 log->Printf ("SBProcess(%p)::Stop () => SBError (%p): %s",
590 m_opaque_sp.get(),
591 sb_error.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000592 sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000593 }
594
Chris Lattner24943d22010-06-08 16:52:24 +0000595 return sb_error;
596}
597
598SBError
599SBProcess::Kill ()
600{
601 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000602 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000603 {
604 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton63094e02010-06-23 01:19:29 +0000605 sb_error.SetError (m_opaque_sp->Destroy());
Greg Claytonbdcda462010-12-20 20:49:23 +0000606 }
Chris Lattner24943d22010-06-08 16:52:24 +0000607 else
608 sb_error.SetErrorString ("SBProcess is invalid");
Caroline Tice7826c882010-10-26 03:11:13 +0000609
Greg Claytone005f2c2010-11-06 01:53:30 +0000610 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000611 if (log)
612 {
613 SBStream sstr;
614 sb_error.GetDescription (sstr);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000615 log->Printf ("SBProcess(%p)::Kill () => SBError (%p): %s",
616 m_opaque_sp.get(),
617 sb_error.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000618 sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000619 }
620
Chris Lattner24943d22010-06-08 16:52:24 +0000621 return sb_error;
622}
623
Chris Lattner24943d22010-06-08 16:52:24 +0000624SBError
625SBProcess::Detach ()
626{
627 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000628 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000629 {
630 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton63094e02010-06-23 01:19:29 +0000631 sb_error.SetError (m_opaque_sp->Detach());
Greg Claytonbdcda462010-12-20 20:49:23 +0000632 }
Chris Lattner24943d22010-06-08 16:52:24 +0000633 else
634 sb_error.SetErrorString ("SBProcess is invalid");
635
636 return sb_error;
637}
638
639SBError
Greg Claytona66ba462010-10-30 04:51:46 +0000640SBProcess::Signal (int signo)
Chris Lattner24943d22010-06-08 16:52:24 +0000641{
642 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000643 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000644 {
645 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Claytona66ba462010-10-30 04:51:46 +0000646 sb_error.SetError (m_opaque_sp->Signal (signo));
Greg Claytonbdcda462010-12-20 20:49:23 +0000647 }
Chris Lattner24943d22010-06-08 16:52:24 +0000648 else
649 sb_error.SetErrorString ("SBProcess is invalid");
Greg Claytone005f2c2010-11-06 01:53:30 +0000650 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000651 if (log)
652 {
653 SBStream sstr;
654 sb_error.GetDescription (sstr);
655 log->Printf ("SBProcess(%p)::Signal (signo=%i) => SBError (%p): %s",
656 m_opaque_sp.get(),
657 signo,
658 sb_error.get(),
659 sstr.GetData());
660 }
Chris Lattner24943d22010-06-08 16:52:24 +0000661 return sb_error;
662}
663
Chris Lattner24943d22010-06-08 16:52:24 +0000664SBThread
Greg Claytona66ba462010-10-30 04:51:46 +0000665SBProcess::GetThreadByID (tid_t tid)
Chris Lattner24943d22010-06-08 16:52:24 +0000666{
Greg Claytona66ba462010-10-30 04:51:46 +0000667 SBThread sb_thread;
Greg Clayton90c52142012-01-30 02:53:15 +0000668 ThreadSP thread_sp;
Greg Clayton63094e02010-06-23 01:19:29 +0000669 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000670 {
671 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton90c52142012-01-30 02:53:15 +0000672 thread_sp = m_opaque_sp->GetThreadList().FindThreadByID (tid);
673 sb_thread.SetThread (thread_sp);
Greg Claytonbdcda462010-12-20 20:49:23 +0000674 }
Greg Claytona66ba462010-10-30 04:51:46 +0000675
Greg Claytone005f2c2010-11-06 01:53:30 +0000676 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000677 if (log)
678 {
Greg Claytond9919d32011-12-01 23:28:38 +0000679 log->Printf ("SBProcess(%p)::GetThreadByID (tid=0x%4.4llx) => SBThread (%p)",
Greg Claytona66ba462010-10-30 04:51:46 +0000680 m_opaque_sp.get(),
681 tid,
Greg Clayton90c52142012-01-30 02:53:15 +0000682 thread_sp.get());
Greg Claytona66ba462010-10-30 04:51:46 +0000683 }
684
685 return sb_thread;
Chris Lattner24943d22010-06-08 16:52:24 +0000686}
687
Chris Lattner24943d22010-06-08 16:52:24 +0000688StateType
689SBProcess::GetStateFromEvent (const SBEvent &event)
690{
Greg Claytone005f2c2010-11-06 01:53:30 +0000691 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000692
Caroline Tice7826c882010-10-26 03:11:13 +0000693 StateType ret_val = Process::ProcessEventData::GetStateFromEvent (event.get());
694
695 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000696 log->Printf ("SBProcess::GetStateFromEvent (event.sp=%p) => %s", event.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000697 lldb_private::StateAsCString (ret_val));
Caroline Tice7826c882010-10-26 03:11:13 +0000698
699 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000700}
701
Chris Lattner24943d22010-06-08 16:52:24 +0000702bool
703SBProcess::GetRestartedFromEvent (const SBEvent &event)
704{
Greg Clayton63094e02010-06-23 01:19:29 +0000705 return Process::ProcessEventData::GetRestartedFromEvent (event.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000706}
707
708SBProcess
709SBProcess::GetProcessFromEvent (const SBEvent &event)
710{
Greg Clayton63094e02010-06-23 01:19:29 +0000711 SBProcess process(Process::ProcessEventData::GetProcessFromEvent (event.get()));
Chris Lattner24943d22010-06-08 16:52:24 +0000712 return process;
713}
714
715
716SBBroadcaster
717SBProcess::GetBroadcaster () const
718{
Greg Claytone005f2c2010-11-06 01:53:30 +0000719 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000720
Greg Clayton63094e02010-06-23 01:19:29 +0000721 SBBroadcaster broadcaster(m_opaque_sp.get(), false);
Caroline Tice7826c882010-10-26 03:11:13 +0000722
723 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000724 log->Printf ("SBProcess(%p)::GetBroadcaster () => SBBroadcaster (%p)", m_opaque_sp.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000725 broadcaster.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000726
Chris Lattner24943d22010-06-08 16:52:24 +0000727 return broadcaster;
728}
729
Chris Lattner24943d22010-06-08 16:52:24 +0000730size_t
731SBProcess::ReadMemory (addr_t addr, void *dst, size_t dst_len, SBError &sb_error)
732{
Greg Claytone005f2c2010-11-06 01:53:30 +0000733 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000734
Chris Lattner24943d22010-06-08 16:52:24 +0000735 size_t bytes_read = 0;
736
Greg Claytona66ba462010-10-30 04:51:46 +0000737 if (log)
738 {
739 log->Printf ("SBProcess(%p)::ReadMemory (addr=0x%llx, dst=%p, dst_len=%zu, SBError (%p))...",
740 m_opaque_sp.get(),
741 addr,
742 dst,
Greg Claytonbae39c52011-12-03 00:46:21 +0000743 dst_len,
Greg Claytona66ba462010-10-30 04:51:46 +0000744 sb_error.get());
745 }
746
Greg Claytonbdcda462010-12-20 20:49:23 +0000747 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000748 {
749 Error error;
Greg Claytonbdcda462010-12-20 20:49:23 +0000750 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton63094e02010-06-23 01:19:29 +0000751 bytes_read = m_opaque_sp->ReadMemory (addr, dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000752 sb_error.SetError (error);
753 }
754 else
755 {
756 sb_error.SetErrorString ("SBProcess is invalid");
757 }
758
Caroline Tice7826c882010-10-26 03:11:13 +0000759 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000760 {
761 SBStream sstr;
762 sb_error.GetDescription (sstr);
Greg Claytonbae39c52011-12-03 00:46:21 +0000763 log->Printf ("SBProcess(%p)::ReadMemory (addr=0x%llx, dst=%p, dst_len=%zu, SBError (%p): %s) => %zu",
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000764 m_opaque_sp.get(),
765 addr,
766 dst,
Greg Claytonbae39c52011-12-03 00:46:21 +0000767 dst_len,
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000768 sb_error.get(),
769 sstr.GetData(),
Greg Claytonbae39c52011-12-03 00:46:21 +0000770 bytes_read);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000771 }
Caroline Tice7826c882010-10-26 03:11:13 +0000772
Chris Lattner24943d22010-06-08 16:52:24 +0000773 return bytes_read;
774}
775
776size_t
Greg Clayton4a2e3372011-12-15 03:14:23 +0000777SBProcess::ReadCStringFromMemory (addr_t addr, void *buf, size_t size, lldb::SBError &sb_error)
778{
779 size_t bytes_read = 0;
780 if (m_opaque_sp)
781 {
782 Error error;
783 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
784 bytes_read = m_opaque_sp->ReadCStringFromMemory (addr, (char *)buf, size, error);
785 sb_error.SetError (error);
786 }
787 else
788 {
789 sb_error.SetErrorString ("SBProcess is invalid");
790 }
791 return bytes_read;
792}
793
794uint64_t
795SBProcess::ReadUnsignedFromMemory (addr_t addr, uint32_t byte_size, lldb::SBError &sb_error)
796{
797 if (m_opaque_sp)
798 {
799 Error error;
800 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
801 uint64_t value = m_opaque_sp->ReadUnsignedIntegerFromMemory (addr, byte_size, 0, error);
802 sb_error.SetError (error);
803 return value;
804 }
805 else
806 {
807 sb_error.SetErrorString ("SBProcess is invalid");
808 }
809 return 0;
810}
811
812lldb::addr_t
813SBProcess::ReadPointerFromMemory (addr_t addr, lldb::SBError &sb_error)
814{
815 lldb::addr_t ptr = LLDB_INVALID_ADDRESS;
816 if (m_opaque_sp)
817 {
818 Error error;
819 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
820 ptr = m_opaque_sp->ReadPointerFromMemory (addr, error);
821 sb_error.SetError (error);
822 }
823 else
824 {
825 sb_error.SetErrorString ("SBProcess is invalid");
826 }
827 return ptr;
828}
829
830size_t
Chris Lattner24943d22010-06-08 16:52:24 +0000831SBProcess::WriteMemory (addr_t addr, const void *src, size_t src_len, SBError &sb_error)
832{
833 size_t bytes_written = 0;
834
Greg Claytone005f2c2010-11-06 01:53:30 +0000835 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000836 if (log)
837 {
838 log->Printf ("SBProcess(%p)::WriteMemory (addr=0x%llx, src=%p, dst_len=%zu, SBError (%p))...",
839 m_opaque_sp.get(),
840 addr,
841 src,
Greg Claytonbae39c52011-12-03 00:46:21 +0000842 src_len,
Greg Claytona66ba462010-10-30 04:51:46 +0000843 sb_error.get());
844 }
845
Greg Claytonbdcda462010-12-20 20:49:23 +0000846 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000847 {
848 Error error;
Greg Claytonbdcda462010-12-20 20:49:23 +0000849 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton63094e02010-06-23 01:19:29 +0000850 bytes_written = m_opaque_sp->WriteMemory (addr, src, src_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000851 sb_error.SetError (error);
852 }
853
Greg Claytona66ba462010-10-30 04:51:46 +0000854 if (log)
855 {
856 SBStream sstr;
857 sb_error.GetDescription (sstr);
Greg Claytonbae39c52011-12-03 00:46:21 +0000858 log->Printf ("SBProcess(%p)::WriteMemory (addr=0x%llx, src=%p, dst_len=%zu, SBError (%p): %s) => %zu",
Greg Claytona66ba462010-10-30 04:51:46 +0000859 m_opaque_sp.get(),
860 addr,
861 src,
Greg Claytonbae39c52011-12-03 00:46:21 +0000862 src_len,
Greg Claytona66ba462010-10-30 04:51:46 +0000863 sb_error.get(),
864 sstr.GetData(),
Greg Claytonbae39c52011-12-03 00:46:21 +0000865 bytes_written);
Greg Claytona66ba462010-10-30 04:51:46 +0000866 }
867
Chris Lattner24943d22010-06-08 16:52:24 +0000868 return bytes_written;
869}
870
Caroline Tice98f930f2010-09-20 05:20:02 +0000871bool
872SBProcess::GetDescription (SBStream &description)
873{
Greg Clayton96154be2011-11-13 06:57:31 +0000874 Stream &strm = description.ref();
875
Caroline Tice98f930f2010-09-20 05:20:02 +0000876 if (m_opaque_sp)
877 {
878 char path[PATH_MAX];
879 GetTarget().GetExecutable().GetPath (path, sizeof(path));
Greg Clayton5beb99d2011-08-11 02:48:45 +0000880 Module *exe_module = m_opaque_sp->GetTarget().GetExecutableModulePointer();
Greg Clayton5c4c7462010-10-06 03:09:58 +0000881 const char *exe_name = NULL;
882 if (exe_module)
883 exe_name = exe_module->GetFileSpec().GetFilename().AsCString();
884
Greg Clayton96154be2011-11-13 06:57:31 +0000885 strm.Printf ("SBProcess: pid = %llu, state = %s, threads = %d%s%s",
886 m_opaque_sp->GetID(),
887 lldb_private::StateAsCString (GetState()),
888 GetNumThreads(),
889 exe_name ? ", executable = " : "",
890 exe_name ? exe_name : "");
Caroline Tice98f930f2010-09-20 05:20:02 +0000891 }
892 else
Greg Clayton96154be2011-11-13 06:57:31 +0000893 strm.PutCString ("No value");
Caroline Tice98f930f2010-09-20 05:20:02 +0000894
895 return true;
896}
Greg Clayton0baa3942010-11-04 01:54:29 +0000897
898uint32_t
899SBProcess::LoadImage (lldb::SBFileSpec &sb_image_spec, lldb::SBError &sb_error)
900{
901 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000902 {
903 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton0e0fd1c2010-12-05 20:38:01 +0000904 return m_opaque_sp->LoadImage (*sb_image_spec, sb_error.ref());
Greg Claytonbdcda462010-12-20 20:49:23 +0000905 }
Greg Clayton0baa3942010-11-04 01:54:29 +0000906 return LLDB_INVALID_IMAGE_TOKEN;
907}
908
909lldb::SBError
910SBProcess::UnloadImage (uint32_t image_token)
911{
912 lldb::SBError sb_error;
913 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000914 {
915 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton0baa3942010-11-04 01:54:29 +0000916 sb_error.SetError (m_opaque_sp->UnloadImage (image_token));
Greg Claytonbdcda462010-12-20 20:49:23 +0000917 }
Greg Clayton0baa3942010-11-04 01:54:29 +0000918 else
919 sb_error.SetErrorString("invalid process");
920 return sb_error;
921}