blob: 0c52b6b15d1858b308326d64697087c9735de4e6 [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
64//----------------------------------------------------------------------
65// Destructor
66//----------------------------------------------------------------------
67SBProcess::~SBProcess()
68{
69}
70
71void
72SBProcess::SetProcess (const ProcessSP &process_sp)
73{
Greg Clayton63094e02010-06-23 01:19:29 +000074 m_opaque_sp = process_sp;
Chris Lattner24943d22010-06-08 16:52:24 +000075}
76
77void
78SBProcess::Clear ()
79{
Greg Clayton63094e02010-06-23 01:19:29 +000080 m_opaque_sp.reset();
Chris Lattner24943d22010-06-08 16:52:24 +000081}
82
83
84bool
85SBProcess::IsValid() const
86{
Greg Clayton63094e02010-06-23 01:19:29 +000087 return m_opaque_sp.get() != NULL;
Chris Lattner24943d22010-06-08 16:52:24 +000088}
89
90
91uint32_t
92SBProcess::GetNumThreads ()
93{
Caroline Tice7826c882010-10-26 03:11:13 +000094 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
95
Caroline Tice7826c882010-10-26 03:11:13 +000096 uint32_t num_threads = 0;
Greg Clayton63094e02010-06-23 01:19:29 +000097 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000098 {
99 const bool can_update = true;
Caroline Tice7826c882010-10-26 03:11:13 +0000100 num_threads = m_opaque_sp->GetThreadList().GetSize(can_update);
Chris Lattner24943d22010-06-08 16:52:24 +0000101 }
Caroline Tice7826c882010-10-26 03:11:13 +0000102
103 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000104 log->Printf ("SBProcess(%p)::GetNumThreads () => %d", m_opaque_sp.get(), num_threads);
Caroline Tice7826c882010-10-26 03:11:13 +0000105
106 return num_threads;
Chris Lattner24943d22010-06-08 16:52:24 +0000107}
108
109SBThread
Jim Inghamc8332952010-08-26 21:32:51 +0000110SBProcess::GetSelectedThread () const
Chris Lattner24943d22010-06-08 16:52:24 +0000111{
Caroline Tice7826c882010-10-26 03:11:13 +0000112 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
113
Chris Lattner24943d22010-06-08 16:52:24 +0000114 SBThread sb_thread;
Greg Clayton63094e02010-06-23 01:19:29 +0000115 if (m_opaque_sp)
Jim Inghamc8332952010-08-26 21:32:51 +0000116 sb_thread.SetThread (m_opaque_sp->GetThreadList().GetSelectedThread());
Caroline Tice7826c882010-10-26 03:11:13 +0000117
118 if (log)
119 {
Greg Claytona66ba462010-10-30 04:51:46 +0000120 log->Printf ("SBProcess(%p)::GetSelectedThread () => SBThread(%p)", m_opaque_sp.get(), sb_thread.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000121 }
122
Chris Lattner24943d22010-06-08 16:52:24 +0000123 return sb_thread;
124}
125
126SBTarget
127SBProcess::GetTarget() const
128{
Caroline Tice7826c882010-10-26 03:11:13 +0000129 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
130
Chris Lattner24943d22010-06-08 16:52:24 +0000131 SBTarget sb_target;
Greg Clayton63094e02010-06-23 01:19:29 +0000132 if (m_opaque_sp)
133 sb_target = m_opaque_sp->GetTarget().GetSP();
Caroline Tice7826c882010-10-26 03:11:13 +0000134
135 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000136 log->Printf ("SBProcess(%p)::GetTarget () => SBTarget(%p)", m_opaque_sp.get(), sb_target.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000137
Chris Lattner24943d22010-06-08 16:52:24 +0000138 return sb_target;
139}
140
141
142size_t
143SBProcess::PutSTDIN (const char *src, size_t src_len)
144{
Caroline Tice7826c882010-10-26 03:11:13 +0000145 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
146
Caroline Tice7826c882010-10-26 03:11:13 +0000147 size_t ret_val = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000148 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000149 {
150 Error error;
Caroline Tice7826c882010-10-26 03:11:13 +0000151 ret_val = m_opaque_sp->PutSTDIN (src, src_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000152 }
Caroline Tice7826c882010-10-26 03:11:13 +0000153
154 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000155 log->Printf ("SBProcess(%p)::PutSTDIN (src=\"%s\", src_len=%d) => %d",
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000156 m_opaque_sp.get(),
157 src,
158 (uint32_t) src_len,
159 ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000160
161 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000162}
163
164size_t
165SBProcess::GetSTDOUT (char *dst, size_t dst_len) const
166{
Greg Clayton49ce6822010-10-31 03:01:06 +0000167 size_t bytes_read = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000168 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000169 {
170 Error error;
Greg Clayton49ce6822010-10-31 03:01:06 +0000171 bytes_read = m_opaque_sp->GetSTDOUT (dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000172 }
Caroline Tice7826c882010-10-26 03:11:13 +0000173
Greg Clayton49ce6822010-10-31 03:01:06 +0000174 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
Caroline Tice7826c882010-10-26 03:11:13 +0000175 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000176 log->Printf ("SBProcess(%p)::GetSTDOUT (dst=\"%.*s\", dst_len=%zu) => %zu",
177 m_opaque_sp.get(), (int) bytes_read, dst, dst_len, bytes_read);
Caroline Tice7826c882010-10-26 03:11:13 +0000178
Greg Clayton49ce6822010-10-31 03:01:06 +0000179 return bytes_read;
Chris Lattner24943d22010-06-08 16:52:24 +0000180}
181
182size_t
183SBProcess::GetSTDERR (char *dst, size_t dst_len) const
184{
Greg Clayton49ce6822010-10-31 03:01:06 +0000185 size_t bytes_read = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000186 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000187 {
188 Error error;
Greg Clayton49ce6822010-10-31 03:01:06 +0000189 bytes_read = m_opaque_sp->GetSTDERR (dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000190 }
Caroline Tice7826c882010-10-26 03:11:13 +0000191
Greg Clayton49ce6822010-10-31 03:01:06 +0000192 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
Caroline Tice7826c882010-10-26 03:11:13 +0000193 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000194 log->Printf ("SBProcess(%p)::GetSTDERR (dst=\"%.*s\", dst_len=%zu) => %zu",
195 m_opaque_sp.get(), (int) bytes_read, dst, dst_len, bytes_read);
Caroline Tice7826c882010-10-26 03:11:13 +0000196
Greg Clayton49ce6822010-10-31 03:01:06 +0000197 return bytes_read;
Chris Lattner24943d22010-06-08 16:52:24 +0000198}
199
200void
Jim Inghamc8332952010-08-26 21:32:51 +0000201SBProcess::ReportEventState (const SBEvent &event, FILE *out) const
Chris Lattner24943d22010-06-08 16:52:24 +0000202{
203 if (out == NULL)
204 return;
205
Greg Clayton63094e02010-06-23 01:19:29 +0000206 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000207 {
208 const StateType event_state = SBProcess::GetStateFromEvent (event);
209 char message[1024];
210 int message_len = ::snprintf (message,
211 sizeof (message),
212 "Process %d %s\n",
Greg Clayton63094e02010-06-23 01:19:29 +0000213 m_opaque_sp->GetID(),
Chris Lattner24943d22010-06-08 16:52:24 +0000214 SBDebugger::StateAsCString (event_state));
215
216 if (message_len > 0)
217 ::fwrite (message, 1, message_len, out);
218 }
219}
220
221void
Jim Inghamc8332952010-08-26 21:32:51 +0000222SBProcess::AppendEventStateReport (const SBEvent &event, SBCommandReturnObject &result)
Chris Lattner24943d22010-06-08 16:52:24 +0000223{
Greg Clayton63094e02010-06-23 01:19:29 +0000224 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000225 {
226 const StateType event_state = SBProcess::GetStateFromEvent (event);
227 char message[1024];
228 ::snprintf (message,
229 sizeof (message),
230 "Process %d %s\n",
Greg Clayton63094e02010-06-23 01:19:29 +0000231 m_opaque_sp->GetID(),
Chris Lattner24943d22010-06-08 16:52:24 +0000232 SBDebugger::StateAsCString (event_state));
233
234 result.AppendMessage (message);
235 }
236}
237
238bool
Jim Inghamc8332952010-08-26 21:32:51 +0000239SBProcess::SetSelectedThread (const SBThread &thread)
Chris Lattner24943d22010-06-08 16:52:24 +0000240{
Greg Clayton63094e02010-06-23 01:19:29 +0000241 if (m_opaque_sp != NULL)
Jim Inghamc8332952010-08-26 21:32:51 +0000242 return m_opaque_sp->GetThreadList().SetSelectedThreadByID (thread.GetThreadID());
Chris Lattner24943d22010-06-08 16:52:24 +0000243 return false;
244}
245
246bool
Jim Inghamc8332952010-08-26 21:32:51 +0000247SBProcess::SetSelectedThreadByID (uint32_t tid)
Chris Lattner24943d22010-06-08 16:52:24 +0000248{
Caroline Tice7826c882010-10-26 03:11:13 +0000249 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
250
Caroline Tice7826c882010-10-26 03:11:13 +0000251 bool ret_val = false;
Greg Clayton63094e02010-06-23 01:19:29 +0000252 if (m_opaque_sp != NULL)
Caroline Tice7826c882010-10-26 03:11:13 +0000253 ret_val = m_opaque_sp->GetThreadList().SetSelectedThreadByID (tid);
254
255 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000256 log->Printf ("SBProcess(%p)::SetSelectedThreadByID (tid=0x%4.4x) => %s",
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000257 m_opaque_sp.get(), tid, (ret_val ? "true" : "false"));
Caroline Tice7826c882010-10-26 03:11:13 +0000258
259 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000260}
261
262SBThread
263SBProcess::GetThreadAtIndex (size_t index)
264{
Caroline Tice7826c882010-10-26 03:11:13 +0000265 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
266
Chris Lattner24943d22010-06-08 16:52:24 +0000267 SBThread thread;
Greg Clayton63094e02010-06-23 01:19:29 +0000268 if (m_opaque_sp)
269 thread.SetThread (m_opaque_sp->GetThreadList().GetThreadAtIndex(index));
Caroline Tice7826c882010-10-26 03:11:13 +0000270
271 if (log)
272 {
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000273 log->Printf ("SBProcess(%p)::GetThreadAtIndex (index=%d) => SBThread(%p)",
Greg Claytona66ba462010-10-30 04:51:46 +0000274 m_opaque_sp.get(), (uint32_t) index, thread.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000275 }
276
Chris Lattner24943d22010-06-08 16:52:24 +0000277 return thread;
278}
279
280StateType
281SBProcess::GetState ()
282{
Caroline Tice7826c882010-10-26 03:11:13 +0000283
Caroline Tice7826c882010-10-26 03:11:13 +0000284 StateType ret_val = eStateInvalid;
Greg Clayton63094e02010-06-23 01:19:29 +0000285 if (m_opaque_sp != NULL)
Caroline Tice7826c882010-10-26 03:11:13 +0000286 ret_val = m_opaque_sp->GetState();
287
Greg Claytona66ba462010-10-30 04:51:46 +0000288 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
Caroline Tice7826c882010-10-26 03:11:13 +0000289 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000290 log->Printf ("SBProcess(%p)::GetState () => %s",
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000291 m_opaque_sp.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000292 lldb_private::StateAsCString (ret_val));
Caroline Tice7826c882010-10-26 03:11:13 +0000293
294 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000295}
296
297
298int
299SBProcess::GetExitStatus ()
300{
Greg Claytona66ba462010-10-30 04:51:46 +0000301 int exit_status = 0;
302 if (m_opaque_sp)
303 exit_status = m_opaque_sp->GetExitStatus ();
304 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
305 if (log)
306 log->Printf ("SBProcess(%p)::GetExitStatus () => %i (0x%8.8x)",
307 m_opaque_sp.get(), exit_status, exit_status);
308
309 return exit_status;
Chris Lattner24943d22010-06-08 16:52:24 +0000310}
311
312const char *
313SBProcess::GetExitDescription ()
314{
Greg Claytona66ba462010-10-30 04:51:46 +0000315 const char *exit_desc = NULL;
Greg Clayton63094e02010-06-23 01:19:29 +0000316 if (m_opaque_sp != NULL)
Greg Claytona66ba462010-10-30 04:51:46 +0000317 exit_desc = m_opaque_sp->GetExitDescription ();
318 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
319 if (log)
320 log->Printf ("SBProcess(%p)::GetExitDescription () => %s",
321 m_opaque_sp.get(), exit_desc);
322 return exit_desc;
Chris Lattner24943d22010-06-08 16:52:24 +0000323}
324
325lldb::pid_t
326SBProcess::GetProcessID ()
327{
Caroline Tice7826c882010-10-26 03:11:13 +0000328 lldb::pid_t ret_val = LLDB_INVALID_PROCESS_ID;
Greg Clayton63094e02010-06-23 01:19:29 +0000329 if (m_opaque_sp)
Caroline Tice7826c882010-10-26 03:11:13 +0000330 ret_val = m_opaque_sp->GetID();
331
Greg Claytona66ba462010-10-30 04:51:46 +0000332 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
Caroline Tice7826c882010-10-26 03:11:13 +0000333 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000334 log->Printf ("SBProcess(%p)::GetProcessID () => %d", m_opaque_sp.get(), ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000335
336 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000337}
338
339uint32_t
340SBProcess::GetAddressByteSize () const
341{
Caroline Tice7826c882010-10-26 03:11:13 +0000342 uint32_t size = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000343 if (m_opaque_sp)
Caroline Tice7826c882010-10-26 03:11:13 +0000344 size = m_opaque_sp->GetAddressByteSize();
345
Greg Claytona66ba462010-10-30 04:51:46 +0000346 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
Caroline Tice7826c882010-10-26 03:11:13 +0000347 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000348 log->Printf ("SBProcess(%p)::GetAddressByteSize () => %d", m_opaque_sp.get(), size);
Caroline Tice7826c882010-10-26 03:11:13 +0000349
350 return size;
Chris Lattner24943d22010-06-08 16:52:24 +0000351}
352
Chris Lattner24943d22010-06-08 16:52:24 +0000353SBError
354SBProcess::Continue ()
355{
Greg Claytona66ba462010-10-30 04:51:46 +0000356 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
357 if (log)
358 log->Printf ("SBProcess(%p)::Continue ()...", m_opaque_sp.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000359
Chris Lattner24943d22010-06-08 16:52:24 +0000360 SBError sb_error;
361 if (IsValid())
Greg Clayton1a3083a2010-10-06 03:53:16 +0000362 {
363 Error error (m_opaque_sp->Resume());
364 if (error.Success())
365 {
366 if (m_opaque_sp->GetTarget().GetDebugger().GetAsyncExecution () == false)
Greg Claytona66ba462010-10-30 04:51:46 +0000367 {
368 if (log)
369 log->Printf ("SBProcess(%p)::Continue () waiting for process to stop...", m_opaque_sp.get());
Greg Clayton1a3083a2010-10-06 03:53:16 +0000370 m_opaque_sp->WaitForProcessToStop (NULL);
Greg Claytona66ba462010-10-30 04:51:46 +0000371 }
Greg Clayton1a3083a2010-10-06 03:53:16 +0000372 }
373 sb_error.SetError(error);
374 }
Chris Lattner24943d22010-06-08 16:52:24 +0000375 else
376 sb_error.SetErrorString ("SBProcess is invalid");
377
Caroline Tice7826c882010-10-26 03:11:13 +0000378 if (log)
379 {
380 SBStream sstr;
381 sb_error.GetDescription (sstr);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000382 log->Printf ("SBProcess(%p)::Continue () => SBError (%p): %s", m_opaque_sp.get(), sb_error.get(), sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000383 }
384
Chris Lattner24943d22010-06-08 16:52:24 +0000385 return sb_error;
386}
387
388
389SBError
390SBProcess::Destroy ()
391{
392 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000393 if (m_opaque_sp)
394 sb_error.SetError(m_opaque_sp->Destroy());
Chris Lattner24943d22010-06-08 16:52:24 +0000395 else
396 sb_error.SetErrorString ("SBProcess is invalid");
397
Greg Claytona66ba462010-10-30 04:51:46 +0000398 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
399 if (log)
400 {
401 SBStream sstr;
402 sb_error.GetDescription (sstr);
403 log->Printf ("SBProcess(%p)::Destroy () => SBError (%p): %s", m_opaque_sp.get(), sb_error.get(), sstr.GetData());
404 }
405
Chris Lattner24943d22010-06-08 16:52:24 +0000406 return sb_error;
407}
408
409
410SBError
411SBProcess::Stop ()
412{
Caroline Tice7826c882010-10-26 03:11:13 +0000413
Chris Lattner24943d22010-06-08 16:52:24 +0000414 SBError sb_error;
415 if (IsValid())
Greg Clayton63094e02010-06-23 01:19:29 +0000416 sb_error.SetError (m_opaque_sp->Halt());
Chris Lattner24943d22010-06-08 16:52:24 +0000417 else
418 sb_error.SetErrorString ("SBProcess is invalid");
Caroline Tice7826c882010-10-26 03:11:13 +0000419
Caroline Tice926060e2010-10-29 21:48:37 +0000420 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
Caroline Tice7826c882010-10-26 03:11:13 +0000421 if (log)
422 {
423 SBStream sstr;
424 sb_error.GetDescription (sstr);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000425 log->Printf ("SBProcess(%p)::Stop () => SBError (%p): %s",
426 m_opaque_sp.get(),
427 sb_error.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000428 sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000429 }
430
Chris Lattner24943d22010-06-08 16:52:24 +0000431 return sb_error;
432}
433
434SBError
435SBProcess::Kill ()
436{
Caroline Tice7826c882010-10-26 03:11:13 +0000437
Chris Lattner24943d22010-06-08 16:52:24 +0000438 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000439 if (m_opaque_sp)
440 sb_error.SetError (m_opaque_sp->Destroy());
Chris Lattner24943d22010-06-08 16:52:24 +0000441 else
442 sb_error.SetErrorString ("SBProcess is invalid");
Caroline Tice7826c882010-10-26 03:11:13 +0000443
Caroline Tice926060e2010-10-29 21:48:37 +0000444 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
Caroline Tice7826c882010-10-26 03:11:13 +0000445 if (log)
446 {
447 SBStream sstr;
448 sb_error.GetDescription (sstr);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000449 log->Printf ("SBProcess(%p)::Kill () => SBError (%p): %s",
450 m_opaque_sp.get(),
451 sb_error.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000452 sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000453 }
454
Chris Lattner24943d22010-06-08 16:52:24 +0000455 return sb_error;
456}
457
458
459SBError
Greg Claytona66ba462010-10-30 04:51:46 +0000460SBProcess::AttachByName (const char *name, bool wait_for_launch) // DEPRECATED
Chris Lattner24943d22010-06-08 16:52:24 +0000461{
462 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000463 if (m_opaque_sp)
464 sb_error.SetError (m_opaque_sp->Attach (name, wait_for_launch));
Chris Lattner24943d22010-06-08 16:52:24 +0000465 else
466 sb_error.SetErrorString ("SBProcess is invalid");
467 return sb_error;
468}
469
470lldb::pid_t
Greg Claytona66ba462010-10-30 04:51:46 +0000471SBProcess::AttachByPID (lldb::pid_t attach_pid) // DEPRECATED
Chris Lattner24943d22010-06-08 16:52:24 +0000472{
473 Attach (attach_pid);
474 return GetProcessID();
475}
476
Caroline Ticedfc91c32010-09-15 18:29:06 +0000477
Chris Lattner24943d22010-06-08 16:52:24 +0000478SBError
Greg Claytona66ba462010-10-30 04:51:46 +0000479SBProcess::Attach (lldb::pid_t attach_pid) // DEPRECATED
Chris Lattner24943d22010-06-08 16:52:24 +0000480{
481 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000482 if (m_opaque_sp)
483 sb_error.SetError (m_opaque_sp->Attach (attach_pid));
Chris Lattner24943d22010-06-08 16:52:24 +0000484 else
485 sb_error.SetErrorString ("SBProcess is invalid");
486 return sb_error;
487}
488
489SBError
490SBProcess::Detach ()
491{
492 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000493 if (m_opaque_sp)
494 sb_error.SetError (m_opaque_sp->Detach());
Chris Lattner24943d22010-06-08 16:52:24 +0000495 else
496 sb_error.SetErrorString ("SBProcess is invalid");
497
498 return sb_error;
499}
500
501SBError
Greg Claytona66ba462010-10-30 04:51:46 +0000502SBProcess::Signal (int signo)
Chris Lattner24943d22010-06-08 16:52:24 +0000503{
504 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000505 if (m_opaque_sp)
Greg Claytona66ba462010-10-30 04:51:46 +0000506 sb_error.SetError (m_opaque_sp->Signal (signo));
Chris Lattner24943d22010-06-08 16:52:24 +0000507 else
508 sb_error.SetErrorString ("SBProcess is invalid");
Greg Claytona66ba462010-10-30 04:51:46 +0000509 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
510 if (log)
511 {
512 SBStream sstr;
513 sb_error.GetDescription (sstr);
514 log->Printf ("SBProcess(%p)::Signal (signo=%i) => SBError (%p): %s",
515 m_opaque_sp.get(),
516 signo,
517 sb_error.get(),
518 sstr.GetData());
519 }
Chris Lattner24943d22010-06-08 16:52:24 +0000520 return sb_error;
521}
522
Chris Lattner24943d22010-06-08 16:52:24 +0000523SBThread
Greg Claytona66ba462010-10-30 04:51:46 +0000524SBProcess::GetThreadByID (tid_t tid)
Chris Lattner24943d22010-06-08 16:52:24 +0000525{
Greg Claytona66ba462010-10-30 04:51:46 +0000526 SBThread sb_thread;
Greg Clayton63094e02010-06-23 01:19:29 +0000527 if (m_opaque_sp)
Greg Claytona66ba462010-10-30 04:51:46 +0000528 sb_thread.SetThread (m_opaque_sp->GetThreadList().FindThreadByID ((tid_t) tid));
529
530 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
531 if (log)
532 {
533 log->Printf ("SBProcess(%p)::GetThreadByID (tid=0x%4.4x) => SBThread (%p)",
534 m_opaque_sp.get(),
535 tid,
536 sb_thread.get());
537 }
538
539 return sb_thread;
Chris Lattner24943d22010-06-08 16:52:24 +0000540}
541
Chris Lattner24943d22010-06-08 16:52:24 +0000542StateType
543SBProcess::GetStateFromEvent (const SBEvent &event)
544{
Caroline Tice7826c882010-10-26 03:11:13 +0000545 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
546
Caroline Tice7826c882010-10-26 03:11:13 +0000547 StateType ret_val = Process::ProcessEventData::GetStateFromEvent (event.get());
548
549 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000550 log->Printf ("SBProcess::GetStateFromEvent (event.sp=%p) => %s", event.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000551 lldb_private::StateAsCString (ret_val));
Caroline Tice7826c882010-10-26 03:11:13 +0000552
553 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000554}
555
Chris Lattner24943d22010-06-08 16:52:24 +0000556bool
557SBProcess::GetRestartedFromEvent (const SBEvent &event)
558{
Greg Clayton63094e02010-06-23 01:19:29 +0000559 return Process::ProcessEventData::GetRestartedFromEvent (event.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000560}
561
562SBProcess
563SBProcess::GetProcessFromEvent (const SBEvent &event)
564{
Greg Clayton63094e02010-06-23 01:19:29 +0000565 SBProcess process(Process::ProcessEventData::GetProcessFromEvent (event.get()));
Chris Lattner24943d22010-06-08 16:52:24 +0000566 return process;
567}
568
569
570SBBroadcaster
571SBProcess::GetBroadcaster () const
572{
Caroline Tice7826c882010-10-26 03:11:13 +0000573 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
574
Greg Clayton63094e02010-06-23 01:19:29 +0000575 SBBroadcaster broadcaster(m_opaque_sp.get(), false);
Caroline Tice7826c882010-10-26 03:11:13 +0000576
577 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000578 log->Printf ("SBProcess(%p)::GetBroadcaster () => SBBroadcaster (%p)", m_opaque_sp.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000579 broadcaster.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000580
Chris Lattner24943d22010-06-08 16:52:24 +0000581 return broadcaster;
582}
583
584lldb_private::Process *
585SBProcess::operator->() const
586{
Greg Clayton63094e02010-06-23 01:19:29 +0000587 return m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000588}
589
590size_t
591SBProcess::ReadMemory (addr_t addr, void *dst, size_t dst_len, SBError &sb_error)
592{
Caroline Tice7826c882010-10-26 03:11:13 +0000593 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
594
Chris Lattner24943d22010-06-08 16:52:24 +0000595 size_t bytes_read = 0;
596
Greg Claytona66ba462010-10-30 04:51:46 +0000597 if (log)
598 {
599 log->Printf ("SBProcess(%p)::ReadMemory (addr=0x%llx, dst=%p, dst_len=%zu, SBError (%p))...",
600 m_opaque_sp.get(),
601 addr,
602 dst,
603 (uint32_t) dst_len,
604 sb_error.get());
605 }
606
Chris Lattner24943d22010-06-08 16:52:24 +0000607 if (IsValid())
608 {
609 Error error;
Greg Clayton63094e02010-06-23 01:19:29 +0000610 bytes_read = m_opaque_sp->ReadMemory (addr, dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000611 sb_error.SetError (error);
612 }
613 else
614 {
615 sb_error.SetErrorString ("SBProcess is invalid");
616 }
617
Caroline Tice7826c882010-10-26 03:11:13 +0000618 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000619 {
620 SBStream sstr;
621 sb_error.GetDescription (sstr);
Greg Claytona66ba462010-10-30 04:51:46 +0000622 log->Printf ("SBProcess(%p)::ReadMemory (addr=0x%llx, dst=%p, dst_len=%zu, SBError (%p): %s) => %d",
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000623 m_opaque_sp.get(),
624 addr,
625 dst,
626 (uint32_t) dst_len,
627 sb_error.get(),
628 sstr.GetData(),
629 (uint32_t) bytes_read);
630 }
Caroline Tice7826c882010-10-26 03:11:13 +0000631
Chris Lattner24943d22010-06-08 16:52:24 +0000632 return bytes_read;
633}
634
635size_t
636SBProcess::WriteMemory (addr_t addr, const void *src, size_t src_len, SBError &sb_error)
637{
638 size_t bytes_written = 0;
639
Greg Claytona66ba462010-10-30 04:51:46 +0000640 Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API);
641 if (log)
642 {
643 log->Printf ("SBProcess(%p)::WriteMemory (addr=0x%llx, src=%p, dst_len=%zu, SBError (%p))...",
644 m_opaque_sp.get(),
645 addr,
646 src,
647 (uint32_t) src_len,
648 sb_error.get());
649 }
650
Chris Lattner24943d22010-06-08 16:52:24 +0000651 if (IsValid())
652 {
653 Error error;
Greg Clayton63094e02010-06-23 01:19:29 +0000654 bytes_written = m_opaque_sp->WriteMemory (addr, src, src_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000655 sb_error.SetError (error);
656 }
657
Greg Claytona66ba462010-10-30 04:51:46 +0000658 if (log)
659 {
660 SBStream sstr;
661 sb_error.GetDescription (sstr);
662 log->Printf ("SBProcess(%p)::WriteMemory (addr=0x%llx, src=%p, dst_len=%zu, SBError (%p): %s) => %d",
663 m_opaque_sp.get(),
664 addr,
665 src,
666 (uint32_t) src_len,
667 sb_error.get(),
668 sstr.GetData(),
669 (uint32_t) bytes_written);
670 }
671
Chris Lattner24943d22010-06-08 16:52:24 +0000672 return bytes_written;
673}
674
675// Mimic shared pointer...
676lldb_private::Process *
677SBProcess::get() const
678{
Greg Clayton63094e02010-06-23 01:19:29 +0000679 return m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000680}
681
Caroline Tice98f930f2010-09-20 05:20:02 +0000682bool
683SBProcess::GetDescription (SBStream &description)
684{
685 if (m_opaque_sp)
686 {
687 char path[PATH_MAX];
688 GetTarget().GetExecutable().GetPath (path, sizeof(path));
Greg Clayton5c4c7462010-10-06 03:09:58 +0000689 Module *exe_module = m_opaque_sp->GetTarget().GetExecutableModule ().get();
690 const char *exe_name = NULL;
691 if (exe_module)
692 exe_name = exe_module->GetFileSpec().GetFilename().AsCString();
693
Greg Claytond8c62532010-10-07 04:19:01 +0000694 description.Printf ("SBProcess: pid = %d, state = %s, threads = %d%s%s",
Greg Clayton5c4c7462010-10-06 03:09:58 +0000695 m_opaque_sp->GetID(),
Caroline Tice7826c882010-10-26 03:11:13 +0000696 lldb_private::StateAsCString (GetState()),
Greg Clayton5c4c7462010-10-06 03:09:58 +0000697 GetNumThreads(),
Greg Claytond8c62532010-10-07 04:19:01 +0000698 exe_name ? ", executable = " : "",
Greg Clayton5c4c7462010-10-06 03:09:58 +0000699 exe_name ? exe_name : "");
Caroline Tice98f930f2010-09-20 05:20:02 +0000700 }
701 else
702 description.Printf ("No value");
703
704 return true;
705}
Greg Clayton0baa3942010-11-04 01:54:29 +0000706
707uint32_t
708SBProcess::LoadImage (lldb::SBFileSpec &sb_image_spec, lldb::SBError &sb_error)
709{
710 if (m_opaque_sp)
711 m_opaque_sp->LoadImage (*sb_image_spec, sb_error.ref());
712 return LLDB_INVALID_IMAGE_TOKEN;
713}
714
715lldb::SBError
716SBProcess::UnloadImage (uint32_t image_token)
717{
718 lldb::SBError sb_error;
719 if (m_opaque_sp)
720 sb_error.SetError (m_opaque_sp->UnloadImage (image_token));
721 else
722 sb_error.SetErrorString("invalid process");
723 return sb_error;
724}
725
726