blob: b56df41ac05f2eacb3c01a7b68d3c65dac9afffe [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"
Chris Lattner24943d22010-06-08 16:52:24 +000016#include "lldb/Core/DataBufferHeap.h"
17#include "lldb/Core/DataExtractor.h"
Greg Clayton1a3083a2010-10-06 03:53:16 +000018#include "lldb/Core/Debugger.h"
Caroline Tice7826c882010-10-26 03:11:13 +000019#include "lldb/Core/Log.h"
Chris Lattner24943d22010-06-08 16:52:24 +000020#include "lldb/Core/State.h"
21#include "lldb/Core/Stream.h"
22#include "lldb/Core/StreamFile.h"
23#include "lldb/Target/Process.h"
Chris Lattner24943d22010-06-08 16:52:24 +000024#include "lldb/Target/RegisterContext.h"
Greg Clayton63094e02010-06-23 01:19:29 +000025#include "lldb/Target/Target.h"
26#include "lldb/Target/Thread.h"
Chris Lattner24943d22010-06-08 16:52:24 +000027
28// Project includes
29
Eli Friedman7a62c8b2010-06-09 07:44:37 +000030#include "lldb/API/SBBroadcaster.h"
31#include "lldb/API/SBDebugger.h"
32#include "lldb/API/SBCommandReturnObject.h"
33#include "lldb/API/SBEvent.h"
34#include "lldb/API/SBThread.h"
Caroline Tice98f930f2010-09-20 05:20:02 +000035#include "lldb/API/SBStream.h"
Eli Friedman7a62c8b2010-06-09 07:44:37 +000036#include "lldb/API/SBStringList.h"
Chris Lattner24943d22010-06-08 16:52:24 +000037
38using namespace lldb;
39using namespace lldb_private;
40
41
42
43SBProcess::SBProcess () :
Greg Clayton63094e02010-06-23 01:19:29 +000044 m_opaque_sp()
Chris Lattner24943d22010-06-08 16:52:24 +000045{
46}
47
48
49//----------------------------------------------------------------------
50// SBProcess constructor
51//----------------------------------------------------------------------
52
53SBProcess::SBProcess (const SBProcess& rhs) :
Greg Clayton63094e02010-06-23 01:19:29 +000054 m_opaque_sp (rhs.m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000055{
56}
57
58
59SBProcess::SBProcess (const lldb::ProcessSP &process_sp) :
Greg Clayton63094e02010-06-23 01:19:29 +000060 m_opaque_sp (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000061{
62}
63
Greg Clayton538eb822010-11-05 23:17:00 +000064const SBProcess&
65SBProcess::operator = (const SBProcess& rhs)
66{
67 if (this != &rhs)
68 m_opaque_sp = rhs.m_opaque_sp;
69 return *this;
70}
71
Chris Lattner24943d22010-06-08 16:52:24 +000072//----------------------------------------------------------------------
73// Destructor
74//----------------------------------------------------------------------
75SBProcess::~SBProcess()
76{
77}
78
79void
80SBProcess::SetProcess (const ProcessSP &process_sp)
81{
Greg Clayton63094e02010-06-23 01:19:29 +000082 m_opaque_sp = process_sp;
Chris Lattner24943d22010-06-08 16:52:24 +000083}
84
85void
86SBProcess::Clear ()
87{
Greg Clayton63094e02010-06-23 01:19:29 +000088 m_opaque_sp.reset();
Chris Lattner24943d22010-06-08 16:52:24 +000089}
90
91
92bool
93SBProcess::IsValid() const
94{
Greg Clayton63094e02010-06-23 01:19:29 +000095 return m_opaque_sp.get() != NULL;
Chris Lattner24943d22010-06-08 16:52:24 +000096}
97
98
99uint32_t
100SBProcess::GetNumThreads ()
101{
Greg Claytone005f2c2010-11-06 01:53:30 +0000102 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000103
Caroline Tice7826c882010-10-26 03:11:13 +0000104 uint32_t num_threads = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000105 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000106 {
Greg Claytonbdcda462010-12-20 20:49:23 +0000107 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Chris Lattner24943d22010-06-08 16:52:24 +0000108 const bool can_update = true;
Caroline Tice7826c882010-10-26 03:11:13 +0000109 num_threads = m_opaque_sp->GetThreadList().GetSize(can_update);
Chris Lattner24943d22010-06-08 16:52:24 +0000110 }
Caroline Tice7826c882010-10-26 03:11:13 +0000111
112 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000113 log->Printf ("SBProcess(%p)::GetNumThreads () => %d", m_opaque_sp.get(), num_threads);
Caroline Tice7826c882010-10-26 03:11:13 +0000114
115 return num_threads;
Chris Lattner24943d22010-06-08 16:52:24 +0000116}
117
118SBThread
Jim Inghamc8332952010-08-26 21:32:51 +0000119SBProcess::GetSelectedThread () const
Chris Lattner24943d22010-06-08 16:52:24 +0000120{
Greg Claytone005f2c2010-11-06 01:53:30 +0000121 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000122
Chris Lattner24943d22010-06-08 16:52:24 +0000123 SBThread sb_thread;
Greg Clayton63094e02010-06-23 01:19:29 +0000124 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000125 {
126 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Jim Inghamc8332952010-08-26 21:32:51 +0000127 sb_thread.SetThread (m_opaque_sp->GetThreadList().GetSelectedThread());
Greg Claytonbdcda462010-12-20 20:49:23 +0000128 }
Caroline Tice7826c882010-10-26 03:11:13 +0000129
130 if (log)
131 {
Greg Claytona66ba462010-10-30 04:51:46 +0000132 log->Printf ("SBProcess(%p)::GetSelectedThread () => SBThread(%p)", m_opaque_sp.get(), sb_thread.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000133 }
134
Chris Lattner24943d22010-06-08 16:52:24 +0000135 return sb_thread;
136}
137
138SBTarget
139SBProcess::GetTarget() const
140{
Greg Claytone005f2c2010-11-06 01:53:30 +0000141 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000142
Chris Lattner24943d22010-06-08 16:52:24 +0000143 SBTarget sb_target;
Greg Clayton63094e02010-06-23 01:19:29 +0000144 if (m_opaque_sp)
145 sb_target = m_opaque_sp->GetTarget().GetSP();
Caroline Tice7826c882010-10-26 03:11:13 +0000146
147 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000148 log->Printf ("SBProcess(%p)::GetTarget () => SBTarget(%p)", m_opaque_sp.get(), sb_target.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000149
Chris Lattner24943d22010-06-08 16:52:24 +0000150 return sb_target;
151}
152
153
154size_t
155SBProcess::PutSTDIN (const char *src, size_t src_len)
156{
Greg Claytone005f2c2010-11-06 01:53:30 +0000157 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000158
Caroline Tice7826c882010-10-26 03:11:13 +0000159 size_t ret_val = 0;
Greg Claytonbdcda462010-12-20 20:49:23 +0000160 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000161 {
162 Error error;
Caroline Tice7826c882010-10-26 03:11:13 +0000163 ret_val = m_opaque_sp->PutSTDIN (src, src_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000164 }
Caroline Tice7826c882010-10-26 03:11:13 +0000165
166 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000167 log->Printf ("SBProcess(%p)::PutSTDIN (src=\"%s\", src_len=%d) => %d",
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000168 m_opaque_sp.get(),
169 src,
170 (uint32_t) src_len,
171 ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000172
173 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000174}
175
176size_t
177SBProcess::GetSTDOUT (char *dst, size_t dst_len) const
178{
Greg Clayton49ce6822010-10-31 03:01:06 +0000179 size_t bytes_read = 0;
Greg Claytonbdcda462010-12-20 20:49:23 +0000180 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000181 {
182 Error error;
Greg Clayton49ce6822010-10-31 03:01:06 +0000183 bytes_read = m_opaque_sp->GetSTDOUT (dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000184 }
Caroline Tice7826c882010-10-26 03:11:13 +0000185
Greg Claytone005f2c2010-11-06 01:53:30 +0000186 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000187 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000188 log->Printf ("SBProcess(%p)::GetSTDOUT (dst=\"%.*s\", dst_len=%zu) => %zu",
189 m_opaque_sp.get(), (int) bytes_read, dst, dst_len, bytes_read);
Caroline Tice7826c882010-10-26 03:11:13 +0000190
Greg Clayton49ce6822010-10-31 03:01:06 +0000191 return bytes_read;
Chris Lattner24943d22010-06-08 16:52:24 +0000192}
193
194size_t
195SBProcess::GetSTDERR (char *dst, size_t dst_len) const
196{
Greg Clayton49ce6822010-10-31 03:01:06 +0000197 size_t bytes_read = 0;
Greg Claytonbdcda462010-12-20 20:49:23 +0000198 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000199 {
200 Error error;
Greg Clayton49ce6822010-10-31 03:01:06 +0000201 bytes_read = m_opaque_sp->GetSTDERR (dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000202 }
Caroline Tice7826c882010-10-26 03:11:13 +0000203
Greg Claytone005f2c2010-11-06 01:53:30 +0000204 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000205 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000206 log->Printf ("SBProcess(%p)::GetSTDERR (dst=\"%.*s\", dst_len=%zu) => %zu",
207 m_opaque_sp.get(), (int) bytes_read, dst, dst_len, bytes_read);
Caroline Tice7826c882010-10-26 03:11:13 +0000208
Greg Clayton49ce6822010-10-31 03:01:06 +0000209 return bytes_read;
Chris Lattner24943d22010-06-08 16:52:24 +0000210}
211
212void
Jim Inghamc8332952010-08-26 21:32:51 +0000213SBProcess::ReportEventState (const SBEvent &event, FILE *out) const
Chris Lattner24943d22010-06-08 16:52:24 +0000214{
215 if (out == NULL)
216 return;
217
Greg Claytonbdcda462010-12-20 20:49:23 +0000218 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000219 {
220 const StateType event_state = SBProcess::GetStateFromEvent (event);
221 char message[1024];
222 int message_len = ::snprintf (message,
223 sizeof (message),
224 "Process %d %s\n",
Greg Clayton63094e02010-06-23 01:19:29 +0000225 m_opaque_sp->GetID(),
Chris Lattner24943d22010-06-08 16:52:24 +0000226 SBDebugger::StateAsCString (event_state));
227
228 if (message_len > 0)
229 ::fwrite (message, 1, message_len, out);
230 }
231}
232
233void
Jim Inghamc8332952010-08-26 21:32:51 +0000234SBProcess::AppendEventStateReport (const SBEvent &event, SBCommandReturnObject &result)
Chris Lattner24943d22010-06-08 16:52:24 +0000235{
Greg Claytonbdcda462010-12-20 20:49:23 +0000236 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000237 {
238 const StateType event_state = SBProcess::GetStateFromEvent (event);
239 char message[1024];
240 ::snprintf (message,
241 sizeof (message),
242 "Process %d %s\n",
Greg Clayton63094e02010-06-23 01:19:29 +0000243 m_opaque_sp->GetID(),
Chris Lattner24943d22010-06-08 16:52:24 +0000244 SBDebugger::StateAsCString (event_state));
245
246 result.AppendMessage (message);
247 }
248}
249
250bool
Jim Inghamc8332952010-08-26 21:32:51 +0000251SBProcess::SetSelectedThread (const SBThread &thread)
Chris Lattner24943d22010-06-08 16:52:24 +0000252{
Greg Claytonbdcda462010-12-20 20:49:23 +0000253 if (m_opaque_sp)
254 {
255 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Jim Inghamc8332952010-08-26 21:32:51 +0000256 return m_opaque_sp->GetThreadList().SetSelectedThreadByID (thread.GetThreadID());
Greg Claytonbdcda462010-12-20 20:49:23 +0000257 }
Chris Lattner24943d22010-06-08 16:52:24 +0000258 return false;
259}
260
261bool
Jim Inghamc8332952010-08-26 21:32:51 +0000262SBProcess::SetSelectedThreadByID (uint32_t tid)
Chris Lattner24943d22010-06-08 16:52:24 +0000263{
Greg Claytone005f2c2010-11-06 01:53:30 +0000264 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000265
Caroline Tice7826c882010-10-26 03:11:13 +0000266 bool ret_val = false;
Greg Claytonbdcda462010-12-20 20:49:23 +0000267 if (m_opaque_sp)
268 {
269 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Caroline Tice7826c882010-10-26 03:11:13 +0000270 ret_val = m_opaque_sp->GetThreadList().SetSelectedThreadByID (tid);
Greg Claytonbdcda462010-12-20 20:49:23 +0000271 }
Caroline Tice7826c882010-10-26 03:11:13 +0000272
273 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000274 log->Printf ("SBProcess(%p)::SetSelectedThreadByID (tid=0x%4.4x) => %s",
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000275 m_opaque_sp.get(), tid, (ret_val ? "true" : "false"));
Caroline Tice7826c882010-10-26 03:11:13 +0000276
277 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000278}
279
280SBThread
281SBProcess::GetThreadAtIndex (size_t index)
282{
Greg Claytone005f2c2010-11-06 01:53:30 +0000283 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000284
Chris Lattner24943d22010-06-08 16:52:24 +0000285 SBThread thread;
Greg Clayton63094e02010-06-23 01:19:29 +0000286 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000287 {
288 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton63094e02010-06-23 01:19:29 +0000289 thread.SetThread (m_opaque_sp->GetThreadList().GetThreadAtIndex(index));
Greg Claytonbdcda462010-12-20 20:49:23 +0000290 }
Caroline Tice7826c882010-10-26 03:11:13 +0000291
292 if (log)
293 {
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000294 log->Printf ("SBProcess(%p)::GetThreadAtIndex (index=%d) => SBThread(%p)",
Greg Claytona66ba462010-10-30 04:51:46 +0000295 m_opaque_sp.get(), (uint32_t) index, thread.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000296 }
297
Chris Lattner24943d22010-06-08 16:52:24 +0000298 return thread;
299}
300
301StateType
302SBProcess::GetState ()
303{
Caroline Tice7826c882010-10-26 03:11:13 +0000304
Caroline Tice7826c882010-10-26 03:11:13 +0000305 StateType ret_val = eStateInvalid;
Greg Claytonbdcda462010-12-20 20:49:23 +0000306 if (m_opaque_sp)
307 {
308 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Caroline Tice7826c882010-10-26 03:11:13 +0000309 ret_val = m_opaque_sp->GetState();
Greg Claytonbdcda462010-12-20 20:49:23 +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)::GetState () => %s",
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000315 m_opaque_sp.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000316 lldb_private::StateAsCString (ret_val));
Caroline Tice7826c882010-10-26 03:11:13 +0000317
318 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000319}
320
321
322int
323SBProcess::GetExitStatus ()
324{
Greg Claytona66ba462010-10-30 04:51:46 +0000325 int exit_status = 0;
326 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000327 {
328 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Claytona66ba462010-10-30 04:51:46 +0000329 exit_status = m_opaque_sp->GetExitStatus ();
Greg Claytonbdcda462010-12-20 20:49:23 +0000330 }
Greg Claytone005f2c2010-11-06 01:53:30 +0000331 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000332 if (log)
333 log->Printf ("SBProcess(%p)::GetExitStatus () => %i (0x%8.8x)",
334 m_opaque_sp.get(), exit_status, exit_status);
335
336 return exit_status;
Chris Lattner24943d22010-06-08 16:52:24 +0000337}
338
339const char *
340SBProcess::GetExitDescription ()
341{
Greg Claytona66ba462010-10-30 04:51:46 +0000342 const char *exit_desc = NULL;
Greg Claytonbdcda462010-12-20 20:49:23 +0000343 if (m_opaque_sp)
344 {
345 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Claytona66ba462010-10-30 04:51:46 +0000346 exit_desc = m_opaque_sp->GetExitDescription ();
Greg Claytonbdcda462010-12-20 20:49:23 +0000347 }
Greg Claytone005f2c2010-11-06 01:53:30 +0000348 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000349 if (log)
350 log->Printf ("SBProcess(%p)::GetExitDescription () => %s",
351 m_opaque_sp.get(), exit_desc);
352 return exit_desc;
Chris Lattner24943d22010-06-08 16:52:24 +0000353}
354
355lldb::pid_t
356SBProcess::GetProcessID ()
357{
Caroline Tice7826c882010-10-26 03:11:13 +0000358 lldb::pid_t ret_val = LLDB_INVALID_PROCESS_ID;
Greg Clayton63094e02010-06-23 01:19:29 +0000359 if (m_opaque_sp)
Caroline Tice7826c882010-10-26 03:11:13 +0000360 ret_val = m_opaque_sp->GetID();
361
Greg Claytone005f2c2010-11-06 01:53:30 +0000362 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000363 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000364 log->Printf ("SBProcess(%p)::GetProcessID () => %d", m_opaque_sp.get(), ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000365
366 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000367}
368
Johnny Chen60a544f2011-03-01 22:56:31 +0000369ByteOrder
370SBProcess::GetByteOrder () const
371{
372 ByteOrder byteOrder = eByteOrderInvalid;
373 if (m_opaque_sp)
374 byteOrder = m_opaque_sp->GetTarget().GetArchitecture().GetByteOrder();
375
376 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
377 if (log)
378 log->Printf ("SBProcess(%p)::GetByteOrder () => %d", m_opaque_sp.get(), byteOrder);
379
380 return byteOrder;
381}
382
Chris Lattner24943d22010-06-08 16:52:24 +0000383uint32_t
384SBProcess::GetAddressByteSize () const
385{
Caroline Tice7826c882010-10-26 03:11:13 +0000386 uint32_t size = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000387 if (m_opaque_sp)
Greg Clayton395fc332011-02-15 21:59:32 +0000388 size = m_opaque_sp->GetTarget().GetArchitecture().GetAddressByteSize();
Caroline Tice7826c882010-10-26 03:11:13 +0000389
Greg Claytone005f2c2010-11-06 01:53:30 +0000390 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000391 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000392 log->Printf ("SBProcess(%p)::GetAddressByteSize () => %d", m_opaque_sp.get(), size);
Caroline Tice7826c882010-10-26 03:11:13 +0000393
394 return size;
Chris Lattner24943d22010-06-08 16:52:24 +0000395}
396
Chris Lattner24943d22010-06-08 16:52:24 +0000397SBError
398SBProcess::Continue ()
399{
Greg Claytonbdcda462010-12-20 20:49:23 +0000400 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
401
Greg Claytone005f2c2010-11-06 01:53:30 +0000402 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000403 if (log)
404 log->Printf ("SBProcess(%p)::Continue ()...", m_opaque_sp.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000405
Chris Lattner24943d22010-06-08 16:52:24 +0000406 SBError sb_error;
407 if (IsValid())
Greg Clayton1a3083a2010-10-06 03:53:16 +0000408 {
409 Error error (m_opaque_sp->Resume());
410 if (error.Success())
411 {
412 if (m_opaque_sp->GetTarget().GetDebugger().GetAsyncExecution () == false)
Greg Claytona66ba462010-10-30 04:51:46 +0000413 {
414 if (log)
415 log->Printf ("SBProcess(%p)::Continue () waiting for process to stop...", m_opaque_sp.get());
Greg Clayton1a3083a2010-10-06 03:53:16 +0000416 m_opaque_sp->WaitForProcessToStop (NULL);
Greg Claytona66ba462010-10-30 04:51:46 +0000417 }
Greg Clayton1a3083a2010-10-06 03:53:16 +0000418 }
419 sb_error.SetError(error);
420 }
Chris Lattner24943d22010-06-08 16:52:24 +0000421 else
422 sb_error.SetErrorString ("SBProcess is invalid");
423
Caroline Tice7826c882010-10-26 03:11:13 +0000424 if (log)
425 {
426 SBStream sstr;
427 sb_error.GetDescription (sstr);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000428 log->Printf ("SBProcess(%p)::Continue () => SBError (%p): %s", m_opaque_sp.get(), sb_error.get(), sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000429 }
430
Chris Lattner24943d22010-06-08 16:52:24 +0000431 return sb_error;
432}
433
434
435SBError
436SBProcess::Destroy ()
437{
438 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000439 if (m_opaque_sp)
Greg Clayton72e1c782011-01-22 23:43:18 +0000440 {
441 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton63094e02010-06-23 01:19:29 +0000442 sb_error.SetError(m_opaque_sp->Destroy());
Greg Clayton72e1c782011-01-22 23:43:18 +0000443 }
Chris Lattner24943d22010-06-08 16:52:24 +0000444 else
445 sb_error.SetErrorString ("SBProcess is invalid");
446
Greg Claytone005f2c2010-11-06 01:53:30 +0000447 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000448 if (log)
449 {
450 SBStream sstr;
451 sb_error.GetDescription (sstr);
Greg Clayton72e1c782011-01-22 23:43:18 +0000452 log->Printf ("SBProcess(%p)::Destroy () => SBError (%p): %s",
453 m_opaque_sp.get(),
454 sb_error.get(),
455 sstr.GetData());
Greg Claytona66ba462010-10-30 04:51:46 +0000456 }
457
Chris Lattner24943d22010-06-08 16:52:24 +0000458 return sb_error;
459}
460
461
462SBError
463SBProcess::Stop ()
464{
465 SBError sb_error;
466 if (IsValid())
Greg Claytonbdcda462010-12-20 20:49:23 +0000467 {
468 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton63094e02010-06-23 01:19:29 +0000469 sb_error.SetError (m_opaque_sp->Halt());
Greg Claytonbdcda462010-12-20 20:49:23 +0000470 }
Chris Lattner24943d22010-06-08 16:52:24 +0000471 else
472 sb_error.SetErrorString ("SBProcess is invalid");
Caroline Tice7826c882010-10-26 03:11:13 +0000473
Greg Claytone005f2c2010-11-06 01:53:30 +0000474 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000475 if (log)
476 {
477 SBStream sstr;
478 sb_error.GetDescription (sstr);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000479 log->Printf ("SBProcess(%p)::Stop () => SBError (%p): %s",
480 m_opaque_sp.get(),
481 sb_error.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000482 sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000483 }
484
Chris Lattner24943d22010-06-08 16:52:24 +0000485 return sb_error;
486}
487
488SBError
489SBProcess::Kill ()
490{
491 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000492 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000493 {
494 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton63094e02010-06-23 01:19:29 +0000495 sb_error.SetError (m_opaque_sp->Destroy());
Greg Claytonbdcda462010-12-20 20:49:23 +0000496 }
Chris Lattner24943d22010-06-08 16:52:24 +0000497 else
498 sb_error.SetErrorString ("SBProcess is invalid");
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)
502 {
503 SBStream sstr;
504 sb_error.GetDescription (sstr);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000505 log->Printf ("SBProcess(%p)::Kill () => SBError (%p): %s",
506 m_opaque_sp.get(),
507 sb_error.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000508 sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000509 }
510
Chris Lattner24943d22010-06-08 16:52:24 +0000511 return sb_error;
512}
513
Chris Lattner24943d22010-06-08 16:52:24 +0000514SBError
515SBProcess::Detach ()
516{
517 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000518 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000519 {
520 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton63094e02010-06-23 01:19:29 +0000521 sb_error.SetError (m_opaque_sp->Detach());
Greg Claytonbdcda462010-12-20 20:49:23 +0000522 }
Chris Lattner24943d22010-06-08 16:52:24 +0000523 else
524 sb_error.SetErrorString ("SBProcess is invalid");
525
526 return sb_error;
527}
528
529SBError
Greg Claytona66ba462010-10-30 04:51:46 +0000530SBProcess::Signal (int signo)
Chris Lattner24943d22010-06-08 16:52:24 +0000531{
532 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000533 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000534 {
535 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Claytona66ba462010-10-30 04:51:46 +0000536 sb_error.SetError (m_opaque_sp->Signal (signo));
Greg Claytonbdcda462010-12-20 20:49:23 +0000537 }
Chris Lattner24943d22010-06-08 16:52:24 +0000538 else
539 sb_error.SetErrorString ("SBProcess is invalid");
Greg Claytone005f2c2010-11-06 01:53:30 +0000540 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000541 if (log)
542 {
543 SBStream sstr;
544 sb_error.GetDescription (sstr);
545 log->Printf ("SBProcess(%p)::Signal (signo=%i) => SBError (%p): %s",
546 m_opaque_sp.get(),
547 signo,
548 sb_error.get(),
549 sstr.GetData());
550 }
Chris Lattner24943d22010-06-08 16:52:24 +0000551 return sb_error;
552}
553
Chris Lattner24943d22010-06-08 16:52:24 +0000554SBThread
Greg Claytona66ba462010-10-30 04:51:46 +0000555SBProcess::GetThreadByID (tid_t tid)
Chris Lattner24943d22010-06-08 16:52:24 +0000556{
Greg Claytona66ba462010-10-30 04:51:46 +0000557 SBThread sb_thread;
Greg Clayton63094e02010-06-23 01:19:29 +0000558 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000559 {
560 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Claytona66ba462010-10-30 04:51:46 +0000561 sb_thread.SetThread (m_opaque_sp->GetThreadList().FindThreadByID ((tid_t) tid));
Greg Claytonbdcda462010-12-20 20:49:23 +0000562 }
Greg Claytona66ba462010-10-30 04:51:46 +0000563
Greg Claytone005f2c2010-11-06 01:53:30 +0000564 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000565 if (log)
566 {
567 log->Printf ("SBProcess(%p)::GetThreadByID (tid=0x%4.4x) => SBThread (%p)",
568 m_opaque_sp.get(),
569 tid,
570 sb_thread.get());
571 }
572
573 return sb_thread;
Chris Lattner24943d22010-06-08 16:52:24 +0000574}
575
Chris Lattner24943d22010-06-08 16:52:24 +0000576StateType
577SBProcess::GetStateFromEvent (const SBEvent &event)
578{
Greg Claytone005f2c2010-11-06 01:53:30 +0000579 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000580
Caroline Tice7826c882010-10-26 03:11:13 +0000581 StateType ret_val = Process::ProcessEventData::GetStateFromEvent (event.get());
582
583 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000584 log->Printf ("SBProcess::GetStateFromEvent (event.sp=%p) => %s", event.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000585 lldb_private::StateAsCString (ret_val));
Caroline Tice7826c882010-10-26 03:11:13 +0000586
587 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000588}
589
Chris Lattner24943d22010-06-08 16:52:24 +0000590bool
591SBProcess::GetRestartedFromEvent (const SBEvent &event)
592{
Greg Clayton63094e02010-06-23 01:19:29 +0000593 return Process::ProcessEventData::GetRestartedFromEvent (event.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000594}
595
596SBProcess
597SBProcess::GetProcessFromEvent (const SBEvent &event)
598{
Greg Clayton63094e02010-06-23 01:19:29 +0000599 SBProcess process(Process::ProcessEventData::GetProcessFromEvent (event.get()));
Chris Lattner24943d22010-06-08 16:52:24 +0000600 return process;
601}
602
603
604SBBroadcaster
605SBProcess::GetBroadcaster () const
606{
Greg Claytone005f2c2010-11-06 01:53:30 +0000607 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000608
Greg Clayton63094e02010-06-23 01:19:29 +0000609 SBBroadcaster broadcaster(m_opaque_sp.get(), false);
Caroline Tice7826c882010-10-26 03:11:13 +0000610
611 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000612 log->Printf ("SBProcess(%p)::GetBroadcaster () => SBBroadcaster (%p)", m_opaque_sp.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000613 broadcaster.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000614
Chris Lattner24943d22010-06-08 16:52:24 +0000615 return broadcaster;
616}
617
618lldb_private::Process *
619SBProcess::operator->() const
620{
Greg Clayton63094e02010-06-23 01:19:29 +0000621 return m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000622}
623
624size_t
625SBProcess::ReadMemory (addr_t addr, void *dst, size_t dst_len, SBError &sb_error)
626{
Greg Claytone005f2c2010-11-06 01:53:30 +0000627 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000628
Chris Lattner24943d22010-06-08 16:52:24 +0000629 size_t bytes_read = 0;
630
Greg Claytona66ba462010-10-30 04:51:46 +0000631 if (log)
632 {
633 log->Printf ("SBProcess(%p)::ReadMemory (addr=0x%llx, dst=%p, dst_len=%zu, SBError (%p))...",
634 m_opaque_sp.get(),
635 addr,
636 dst,
637 (uint32_t) dst_len,
638 sb_error.get());
639 }
640
Greg Claytonbdcda462010-12-20 20:49:23 +0000641 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000642 {
643 Error error;
Greg Claytonbdcda462010-12-20 20:49:23 +0000644 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton63094e02010-06-23 01:19:29 +0000645 bytes_read = m_opaque_sp->ReadMemory (addr, dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000646 sb_error.SetError (error);
647 }
648 else
649 {
650 sb_error.SetErrorString ("SBProcess is invalid");
651 }
652
Caroline Tice7826c882010-10-26 03:11:13 +0000653 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000654 {
655 SBStream sstr;
656 sb_error.GetDescription (sstr);
Greg Claytona66ba462010-10-30 04:51:46 +0000657 log->Printf ("SBProcess(%p)::ReadMemory (addr=0x%llx, dst=%p, dst_len=%zu, SBError (%p): %s) => %d",
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000658 m_opaque_sp.get(),
659 addr,
660 dst,
661 (uint32_t) dst_len,
662 sb_error.get(),
663 sstr.GetData(),
664 (uint32_t) bytes_read);
665 }
Caroline Tice7826c882010-10-26 03:11:13 +0000666
Chris Lattner24943d22010-06-08 16:52:24 +0000667 return bytes_read;
668}
669
670size_t
671SBProcess::WriteMemory (addr_t addr, const void *src, size_t src_len, SBError &sb_error)
672{
673 size_t bytes_written = 0;
674
Greg Claytone005f2c2010-11-06 01:53:30 +0000675 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000676 if (log)
677 {
678 log->Printf ("SBProcess(%p)::WriteMemory (addr=0x%llx, src=%p, dst_len=%zu, SBError (%p))...",
679 m_opaque_sp.get(),
680 addr,
681 src,
682 (uint32_t) src_len,
683 sb_error.get());
684 }
685
Greg Claytonbdcda462010-12-20 20:49:23 +0000686 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000687 {
688 Error error;
Greg Claytonbdcda462010-12-20 20:49:23 +0000689 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton63094e02010-06-23 01:19:29 +0000690 bytes_written = m_opaque_sp->WriteMemory (addr, src, src_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000691 sb_error.SetError (error);
692 }
693
Greg Claytona66ba462010-10-30 04:51:46 +0000694 if (log)
695 {
696 SBStream sstr;
697 sb_error.GetDescription (sstr);
698 log->Printf ("SBProcess(%p)::WriteMemory (addr=0x%llx, src=%p, dst_len=%zu, SBError (%p): %s) => %d",
699 m_opaque_sp.get(),
700 addr,
701 src,
702 (uint32_t) src_len,
703 sb_error.get(),
704 sstr.GetData(),
705 (uint32_t) bytes_written);
706 }
707
Chris Lattner24943d22010-06-08 16:52:24 +0000708 return bytes_written;
709}
710
711// Mimic shared pointer...
712lldb_private::Process *
713SBProcess::get() const
714{
Greg Clayton63094e02010-06-23 01:19:29 +0000715 return m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000716}
717
Caroline Tice98f930f2010-09-20 05:20:02 +0000718bool
719SBProcess::GetDescription (SBStream &description)
720{
721 if (m_opaque_sp)
722 {
723 char path[PATH_MAX];
724 GetTarget().GetExecutable().GetPath (path, sizeof(path));
Greg Clayton5c4c7462010-10-06 03:09:58 +0000725 Module *exe_module = m_opaque_sp->GetTarget().GetExecutableModule ().get();
726 const char *exe_name = NULL;
727 if (exe_module)
728 exe_name = exe_module->GetFileSpec().GetFilename().AsCString();
729
Greg Claytond8c62532010-10-07 04:19:01 +0000730 description.Printf ("SBProcess: pid = %d, state = %s, threads = %d%s%s",
Greg Clayton5c4c7462010-10-06 03:09:58 +0000731 m_opaque_sp->GetID(),
Caroline Tice7826c882010-10-26 03:11:13 +0000732 lldb_private::StateAsCString (GetState()),
Greg Clayton5c4c7462010-10-06 03:09:58 +0000733 GetNumThreads(),
Greg Claytond8c62532010-10-07 04:19:01 +0000734 exe_name ? ", executable = " : "",
Greg Clayton5c4c7462010-10-06 03:09:58 +0000735 exe_name ? exe_name : "");
Caroline Tice98f930f2010-09-20 05:20:02 +0000736 }
737 else
738 description.Printf ("No value");
739
740 return true;
741}
Greg Clayton0baa3942010-11-04 01:54:29 +0000742
743uint32_t
744SBProcess::LoadImage (lldb::SBFileSpec &sb_image_spec, lldb::SBError &sb_error)
745{
746 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000747 {
748 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton0e0fd1c2010-12-05 20:38:01 +0000749 return m_opaque_sp->LoadImage (*sb_image_spec, sb_error.ref());
Greg Claytonbdcda462010-12-20 20:49:23 +0000750 }
Greg Clayton0baa3942010-11-04 01:54:29 +0000751 return LLDB_INVALID_IMAGE_TOKEN;
752}
753
754lldb::SBError
755SBProcess::UnloadImage (uint32_t image_token)
756{
757 lldb::SBError sb_error;
758 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000759 {
760 Mutex::Locker api_locker (m_opaque_sp->GetTarget().GetAPIMutex());
Greg Clayton0baa3942010-11-04 01:54:29 +0000761 sb_error.SetError (m_opaque_sp->UnloadImage (image_token));
Greg Claytonbdcda462010-12-20 20:49:23 +0000762 }
Greg Clayton0baa3942010-11-04 01:54:29 +0000763 else
764 sb_error.SetErrorString("invalid process");
765 return sb_error;
766}
767
768