blob: 0c2eac500c7161ad0acdfff1c081925c82d14e38 [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 {
107 const bool can_update = true;
Caroline Tice7826c882010-10-26 03:11:13 +0000108 num_threads = m_opaque_sp->GetThreadList().GetSize(can_update);
Chris Lattner24943d22010-06-08 16:52:24 +0000109 }
Caroline Tice7826c882010-10-26 03:11:13 +0000110
111 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000112 log->Printf ("SBProcess(%p)::GetNumThreads () => %d", m_opaque_sp.get(), num_threads);
Caroline Tice7826c882010-10-26 03:11:13 +0000113
114 return num_threads;
Chris Lattner24943d22010-06-08 16:52:24 +0000115}
116
117SBThread
Jim Inghamc8332952010-08-26 21:32:51 +0000118SBProcess::GetSelectedThread () const
Chris Lattner24943d22010-06-08 16:52:24 +0000119{
Greg Claytone005f2c2010-11-06 01:53:30 +0000120 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000121
Chris Lattner24943d22010-06-08 16:52:24 +0000122 SBThread sb_thread;
Greg Clayton63094e02010-06-23 01:19:29 +0000123 if (m_opaque_sp)
Jim Inghamc8332952010-08-26 21:32:51 +0000124 sb_thread.SetThread (m_opaque_sp->GetThreadList().GetSelectedThread());
Caroline Tice7826c882010-10-26 03:11:13 +0000125
126 if (log)
127 {
Greg Claytona66ba462010-10-30 04:51:46 +0000128 log->Printf ("SBProcess(%p)::GetSelectedThread () => SBThread(%p)", m_opaque_sp.get(), sb_thread.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000129 }
130
Chris Lattner24943d22010-06-08 16:52:24 +0000131 return sb_thread;
132}
133
134SBTarget
135SBProcess::GetTarget() const
136{
Greg Claytone005f2c2010-11-06 01:53:30 +0000137 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000138
Chris Lattner24943d22010-06-08 16:52:24 +0000139 SBTarget sb_target;
Greg Clayton63094e02010-06-23 01:19:29 +0000140 if (m_opaque_sp)
141 sb_target = m_opaque_sp->GetTarget().GetSP();
Caroline Tice7826c882010-10-26 03:11:13 +0000142
143 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000144 log->Printf ("SBProcess(%p)::GetTarget () => SBTarget(%p)", m_opaque_sp.get(), sb_target.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000145
Chris Lattner24943d22010-06-08 16:52:24 +0000146 return sb_target;
147}
148
149
150size_t
151SBProcess::PutSTDIN (const char *src, size_t src_len)
152{
Greg Claytone005f2c2010-11-06 01:53:30 +0000153 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000154
Caroline Tice7826c882010-10-26 03:11:13 +0000155 size_t ret_val = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000156 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000157 {
158 Error error;
Caroline Tice7826c882010-10-26 03:11:13 +0000159 ret_val = m_opaque_sp->PutSTDIN (src, src_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000160 }
Caroline Tice7826c882010-10-26 03:11:13 +0000161
162 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000163 log->Printf ("SBProcess(%p)::PutSTDIN (src=\"%s\", src_len=%d) => %d",
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000164 m_opaque_sp.get(),
165 src,
166 (uint32_t) src_len,
167 ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000168
169 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000170}
171
172size_t
173SBProcess::GetSTDOUT (char *dst, size_t dst_len) const
174{
Greg Clayton49ce6822010-10-31 03:01:06 +0000175 size_t bytes_read = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000176 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000177 {
178 Error error;
Greg Clayton49ce6822010-10-31 03:01:06 +0000179 bytes_read = m_opaque_sp->GetSTDOUT (dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000180 }
Caroline Tice7826c882010-10-26 03:11:13 +0000181
Greg Claytone005f2c2010-11-06 01:53:30 +0000182 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000183 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000184 log->Printf ("SBProcess(%p)::GetSTDOUT (dst=\"%.*s\", dst_len=%zu) => %zu",
185 m_opaque_sp.get(), (int) bytes_read, dst, dst_len, bytes_read);
Caroline Tice7826c882010-10-26 03:11:13 +0000186
Greg Clayton49ce6822010-10-31 03:01:06 +0000187 return bytes_read;
Chris Lattner24943d22010-06-08 16:52:24 +0000188}
189
190size_t
191SBProcess::GetSTDERR (char *dst, size_t dst_len) const
192{
Greg Clayton49ce6822010-10-31 03:01:06 +0000193 size_t bytes_read = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000194 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000195 {
196 Error error;
Greg Clayton49ce6822010-10-31 03:01:06 +0000197 bytes_read = m_opaque_sp->GetSTDERR (dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000198 }
Caroline Tice7826c882010-10-26 03:11:13 +0000199
Greg Claytone005f2c2010-11-06 01:53:30 +0000200 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000201 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000202 log->Printf ("SBProcess(%p)::GetSTDERR (dst=\"%.*s\", dst_len=%zu) => %zu",
203 m_opaque_sp.get(), (int) bytes_read, dst, dst_len, bytes_read);
Caroline Tice7826c882010-10-26 03:11:13 +0000204
Greg Clayton49ce6822010-10-31 03:01:06 +0000205 return bytes_read;
Chris Lattner24943d22010-06-08 16:52:24 +0000206}
207
208void
Jim Inghamc8332952010-08-26 21:32:51 +0000209SBProcess::ReportEventState (const SBEvent &event, FILE *out) const
Chris Lattner24943d22010-06-08 16:52:24 +0000210{
211 if (out == NULL)
212 return;
213
Greg Clayton63094e02010-06-23 01:19:29 +0000214 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000215 {
216 const StateType event_state = SBProcess::GetStateFromEvent (event);
217 char message[1024];
218 int message_len = ::snprintf (message,
219 sizeof (message),
220 "Process %d %s\n",
Greg Clayton63094e02010-06-23 01:19:29 +0000221 m_opaque_sp->GetID(),
Chris Lattner24943d22010-06-08 16:52:24 +0000222 SBDebugger::StateAsCString (event_state));
223
224 if (message_len > 0)
225 ::fwrite (message, 1, message_len, out);
226 }
227}
228
229void
Jim Inghamc8332952010-08-26 21:32:51 +0000230SBProcess::AppendEventStateReport (const SBEvent &event, SBCommandReturnObject &result)
Chris Lattner24943d22010-06-08 16:52:24 +0000231{
Greg Clayton63094e02010-06-23 01:19:29 +0000232 if (m_opaque_sp != NULL)
Chris Lattner24943d22010-06-08 16:52:24 +0000233 {
234 const StateType event_state = SBProcess::GetStateFromEvent (event);
235 char message[1024];
236 ::snprintf (message,
237 sizeof (message),
238 "Process %d %s\n",
Greg Clayton63094e02010-06-23 01:19:29 +0000239 m_opaque_sp->GetID(),
Chris Lattner24943d22010-06-08 16:52:24 +0000240 SBDebugger::StateAsCString (event_state));
241
242 result.AppendMessage (message);
243 }
244}
245
246bool
Jim Inghamc8332952010-08-26 21:32:51 +0000247SBProcess::SetSelectedThread (const SBThread &thread)
Chris Lattner24943d22010-06-08 16:52:24 +0000248{
Greg Clayton63094e02010-06-23 01:19:29 +0000249 if (m_opaque_sp != NULL)
Jim Inghamc8332952010-08-26 21:32:51 +0000250 return m_opaque_sp->GetThreadList().SetSelectedThreadByID (thread.GetThreadID());
Chris Lattner24943d22010-06-08 16:52:24 +0000251 return false;
252}
253
254bool
Jim Inghamc8332952010-08-26 21:32:51 +0000255SBProcess::SetSelectedThreadByID (uint32_t tid)
Chris Lattner24943d22010-06-08 16:52:24 +0000256{
Greg Claytone005f2c2010-11-06 01:53:30 +0000257 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000258
Caroline Tice7826c882010-10-26 03:11:13 +0000259 bool ret_val = false;
Greg Clayton63094e02010-06-23 01:19:29 +0000260 if (m_opaque_sp != NULL)
Caroline Tice7826c882010-10-26 03:11:13 +0000261 ret_val = m_opaque_sp->GetThreadList().SetSelectedThreadByID (tid);
262
263 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000264 log->Printf ("SBProcess(%p)::SetSelectedThreadByID (tid=0x%4.4x) => %s",
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000265 m_opaque_sp.get(), tid, (ret_val ? "true" : "false"));
Caroline Tice7826c882010-10-26 03:11:13 +0000266
267 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000268}
269
270SBThread
271SBProcess::GetThreadAtIndex (size_t index)
272{
Greg Claytone005f2c2010-11-06 01:53:30 +0000273 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000274
Chris Lattner24943d22010-06-08 16:52:24 +0000275 SBThread thread;
Greg Clayton63094e02010-06-23 01:19:29 +0000276 if (m_opaque_sp)
277 thread.SetThread (m_opaque_sp->GetThreadList().GetThreadAtIndex(index));
Caroline Tice7826c882010-10-26 03:11:13 +0000278
279 if (log)
280 {
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000281 log->Printf ("SBProcess(%p)::GetThreadAtIndex (index=%d) => SBThread(%p)",
Greg Claytona66ba462010-10-30 04:51:46 +0000282 m_opaque_sp.get(), (uint32_t) index, thread.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000283 }
284
Chris Lattner24943d22010-06-08 16:52:24 +0000285 return thread;
286}
287
288StateType
289SBProcess::GetState ()
290{
Caroline Tice7826c882010-10-26 03:11:13 +0000291
Caroline Tice7826c882010-10-26 03:11:13 +0000292 StateType ret_val = eStateInvalid;
Greg Clayton63094e02010-06-23 01:19:29 +0000293 if (m_opaque_sp != NULL)
Caroline Tice7826c882010-10-26 03:11:13 +0000294 ret_val = m_opaque_sp->GetState();
295
Greg Claytone005f2c2010-11-06 01:53:30 +0000296 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000297 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000298 log->Printf ("SBProcess(%p)::GetState () => %s",
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000299 m_opaque_sp.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000300 lldb_private::StateAsCString (ret_val));
Caroline Tice7826c882010-10-26 03:11:13 +0000301
302 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000303}
304
305
306int
307SBProcess::GetExitStatus ()
308{
Greg Claytona66ba462010-10-30 04:51:46 +0000309 int exit_status = 0;
310 if (m_opaque_sp)
311 exit_status = m_opaque_sp->GetExitStatus ();
Greg Claytone005f2c2010-11-06 01:53:30 +0000312 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000313 if (log)
314 log->Printf ("SBProcess(%p)::GetExitStatus () => %i (0x%8.8x)",
315 m_opaque_sp.get(), exit_status, exit_status);
316
317 return exit_status;
Chris Lattner24943d22010-06-08 16:52:24 +0000318}
319
320const char *
321SBProcess::GetExitDescription ()
322{
Greg Claytona66ba462010-10-30 04:51:46 +0000323 const char *exit_desc = NULL;
Greg Clayton63094e02010-06-23 01:19:29 +0000324 if (m_opaque_sp != NULL)
Greg Claytona66ba462010-10-30 04:51:46 +0000325 exit_desc = m_opaque_sp->GetExitDescription ();
Greg Claytone005f2c2010-11-06 01:53:30 +0000326 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000327 if (log)
328 log->Printf ("SBProcess(%p)::GetExitDescription () => %s",
329 m_opaque_sp.get(), exit_desc);
330 return exit_desc;
Chris Lattner24943d22010-06-08 16:52:24 +0000331}
332
333lldb::pid_t
334SBProcess::GetProcessID ()
335{
Caroline Tice7826c882010-10-26 03:11:13 +0000336 lldb::pid_t ret_val = LLDB_INVALID_PROCESS_ID;
Greg Clayton63094e02010-06-23 01:19:29 +0000337 if (m_opaque_sp)
Caroline Tice7826c882010-10-26 03:11:13 +0000338 ret_val = m_opaque_sp->GetID();
339
Greg Claytone005f2c2010-11-06 01:53:30 +0000340 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000341 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000342 log->Printf ("SBProcess(%p)::GetProcessID () => %d", m_opaque_sp.get(), ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000343
344 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000345}
346
347uint32_t
348SBProcess::GetAddressByteSize () const
349{
Caroline Tice7826c882010-10-26 03:11:13 +0000350 uint32_t size = 0;
Greg Clayton63094e02010-06-23 01:19:29 +0000351 if (m_opaque_sp)
Caroline Tice7826c882010-10-26 03:11:13 +0000352 size = m_opaque_sp->GetAddressByteSize();
353
Greg Claytone005f2c2010-11-06 01:53:30 +0000354 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000355 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000356 log->Printf ("SBProcess(%p)::GetAddressByteSize () => %d", m_opaque_sp.get(), size);
Caroline Tice7826c882010-10-26 03:11:13 +0000357
358 return size;
Chris Lattner24943d22010-06-08 16:52:24 +0000359}
360
Chris Lattner24943d22010-06-08 16:52:24 +0000361SBError
362SBProcess::Continue ()
363{
Greg Claytone005f2c2010-11-06 01:53:30 +0000364 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000365 if (log)
366 log->Printf ("SBProcess(%p)::Continue ()...", m_opaque_sp.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000367
Chris Lattner24943d22010-06-08 16:52:24 +0000368 SBError sb_error;
369 if (IsValid())
Greg Clayton1a3083a2010-10-06 03:53:16 +0000370 {
371 Error error (m_opaque_sp->Resume());
372 if (error.Success())
373 {
374 if (m_opaque_sp->GetTarget().GetDebugger().GetAsyncExecution () == false)
Greg Claytona66ba462010-10-30 04:51:46 +0000375 {
376 if (log)
377 log->Printf ("SBProcess(%p)::Continue () waiting for process to stop...", m_opaque_sp.get());
Greg Clayton1a3083a2010-10-06 03:53:16 +0000378 m_opaque_sp->WaitForProcessToStop (NULL);
Greg Claytona66ba462010-10-30 04:51:46 +0000379 }
Greg Clayton1a3083a2010-10-06 03:53:16 +0000380 }
381 sb_error.SetError(error);
382 }
Chris Lattner24943d22010-06-08 16:52:24 +0000383 else
384 sb_error.SetErrorString ("SBProcess is invalid");
385
Caroline Tice7826c882010-10-26 03:11:13 +0000386 if (log)
387 {
388 SBStream sstr;
389 sb_error.GetDescription (sstr);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000390 log->Printf ("SBProcess(%p)::Continue () => SBError (%p): %s", m_opaque_sp.get(), sb_error.get(), sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000391 }
392
Chris Lattner24943d22010-06-08 16:52:24 +0000393 return sb_error;
394}
395
396
397SBError
398SBProcess::Destroy ()
399{
400 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000401 if (m_opaque_sp)
402 sb_error.SetError(m_opaque_sp->Destroy());
Chris Lattner24943d22010-06-08 16:52:24 +0000403 else
404 sb_error.SetErrorString ("SBProcess is invalid");
405
Greg Claytone005f2c2010-11-06 01:53:30 +0000406 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000407 if (log)
408 {
409 SBStream sstr;
410 sb_error.GetDescription (sstr);
411 log->Printf ("SBProcess(%p)::Destroy () => SBError (%p): %s", m_opaque_sp.get(), sb_error.get(), sstr.GetData());
412 }
413
Chris Lattner24943d22010-06-08 16:52:24 +0000414 return sb_error;
415}
416
417
418SBError
419SBProcess::Stop ()
420{
Caroline Tice7826c882010-10-26 03:11:13 +0000421
Chris Lattner24943d22010-06-08 16:52:24 +0000422 SBError sb_error;
423 if (IsValid())
Greg Clayton63094e02010-06-23 01:19:29 +0000424 sb_error.SetError (m_opaque_sp->Halt());
Chris Lattner24943d22010-06-08 16:52:24 +0000425 else
426 sb_error.SetErrorString ("SBProcess is invalid");
Caroline Tice7826c882010-10-26 03:11:13 +0000427
Greg Claytone005f2c2010-11-06 01:53:30 +0000428 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000429 if (log)
430 {
431 SBStream sstr;
432 sb_error.GetDescription (sstr);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000433 log->Printf ("SBProcess(%p)::Stop () => SBError (%p): %s",
434 m_opaque_sp.get(),
435 sb_error.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000436 sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000437 }
438
Chris Lattner24943d22010-06-08 16:52:24 +0000439 return sb_error;
440}
441
442SBError
443SBProcess::Kill ()
444{
Caroline Tice7826c882010-10-26 03:11:13 +0000445
Chris Lattner24943d22010-06-08 16:52:24 +0000446 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000447 if (m_opaque_sp)
448 sb_error.SetError (m_opaque_sp->Destroy());
Chris Lattner24943d22010-06-08 16:52:24 +0000449 else
450 sb_error.SetErrorString ("SBProcess is invalid");
Caroline Tice7826c882010-10-26 03:11:13 +0000451
Greg Claytone005f2c2010-11-06 01:53:30 +0000452 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000453 if (log)
454 {
455 SBStream sstr;
456 sb_error.GetDescription (sstr);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000457 log->Printf ("SBProcess(%p)::Kill () => SBError (%p): %s",
458 m_opaque_sp.get(),
459 sb_error.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000460 sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000461 }
462
Chris Lattner24943d22010-06-08 16:52:24 +0000463 return sb_error;
464}
465
466
467SBError
Greg Claytona66ba462010-10-30 04:51:46 +0000468SBProcess::AttachByName (const char *name, bool wait_for_launch) // DEPRECATED
Chris Lattner24943d22010-06-08 16:52:24 +0000469{
470 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000471 if (m_opaque_sp)
472 sb_error.SetError (m_opaque_sp->Attach (name, wait_for_launch));
Chris Lattner24943d22010-06-08 16:52:24 +0000473 else
474 sb_error.SetErrorString ("SBProcess is invalid");
475 return sb_error;
476}
477
478lldb::pid_t
Greg Claytona66ba462010-10-30 04:51:46 +0000479SBProcess::AttachByPID (lldb::pid_t attach_pid) // DEPRECATED
Chris Lattner24943d22010-06-08 16:52:24 +0000480{
481 Attach (attach_pid);
482 return GetProcessID();
483}
484
Caroline Ticedfc91c32010-09-15 18:29:06 +0000485
Chris Lattner24943d22010-06-08 16:52:24 +0000486SBError
Greg Claytona66ba462010-10-30 04:51:46 +0000487SBProcess::Attach (lldb::pid_t attach_pid) // DEPRECATED
Chris Lattner24943d22010-06-08 16:52:24 +0000488{
489 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000490 if (m_opaque_sp)
491 sb_error.SetError (m_opaque_sp->Attach (attach_pid));
Chris Lattner24943d22010-06-08 16:52:24 +0000492 else
493 sb_error.SetErrorString ("SBProcess is invalid");
494 return sb_error;
495}
496
497SBError
498SBProcess::Detach ()
499{
500 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000501 if (m_opaque_sp)
502 sb_error.SetError (m_opaque_sp->Detach());
Chris Lattner24943d22010-06-08 16:52:24 +0000503 else
504 sb_error.SetErrorString ("SBProcess is invalid");
505
506 return sb_error;
507}
508
509SBError
Greg Claytona66ba462010-10-30 04:51:46 +0000510SBProcess::Signal (int signo)
Chris Lattner24943d22010-06-08 16:52:24 +0000511{
512 SBError sb_error;
Greg Clayton63094e02010-06-23 01:19:29 +0000513 if (m_opaque_sp)
Greg Claytona66ba462010-10-30 04:51:46 +0000514 sb_error.SetError (m_opaque_sp->Signal (signo));
Chris Lattner24943d22010-06-08 16:52:24 +0000515 else
516 sb_error.SetErrorString ("SBProcess is invalid");
Greg Claytone005f2c2010-11-06 01:53:30 +0000517 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000518 if (log)
519 {
520 SBStream sstr;
521 sb_error.GetDescription (sstr);
522 log->Printf ("SBProcess(%p)::Signal (signo=%i) => SBError (%p): %s",
523 m_opaque_sp.get(),
524 signo,
525 sb_error.get(),
526 sstr.GetData());
527 }
Chris Lattner24943d22010-06-08 16:52:24 +0000528 return sb_error;
529}
530
Chris Lattner24943d22010-06-08 16:52:24 +0000531SBThread
Greg Claytona66ba462010-10-30 04:51:46 +0000532SBProcess::GetThreadByID (tid_t tid)
Chris Lattner24943d22010-06-08 16:52:24 +0000533{
Greg Claytona66ba462010-10-30 04:51:46 +0000534 SBThread sb_thread;
Greg Clayton63094e02010-06-23 01:19:29 +0000535 if (m_opaque_sp)
Greg Claytona66ba462010-10-30 04:51:46 +0000536 sb_thread.SetThread (m_opaque_sp->GetThreadList().FindThreadByID ((tid_t) tid));
537
Greg Claytone005f2c2010-11-06 01:53:30 +0000538 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000539 if (log)
540 {
541 log->Printf ("SBProcess(%p)::GetThreadByID (tid=0x%4.4x) => SBThread (%p)",
542 m_opaque_sp.get(),
543 tid,
544 sb_thread.get());
545 }
546
547 return sb_thread;
Chris Lattner24943d22010-06-08 16:52:24 +0000548}
549
Chris Lattner24943d22010-06-08 16:52:24 +0000550StateType
551SBProcess::GetStateFromEvent (const SBEvent &event)
552{
Greg Claytone005f2c2010-11-06 01:53:30 +0000553 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000554
Caroline Tice7826c882010-10-26 03:11:13 +0000555 StateType ret_val = Process::ProcessEventData::GetStateFromEvent (event.get());
556
557 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000558 log->Printf ("SBProcess::GetStateFromEvent (event.sp=%p) => %s", event.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000559 lldb_private::StateAsCString (ret_val));
Caroline Tice7826c882010-10-26 03:11:13 +0000560
561 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000562}
563
Chris Lattner24943d22010-06-08 16:52:24 +0000564bool
565SBProcess::GetRestartedFromEvent (const SBEvent &event)
566{
Greg Clayton63094e02010-06-23 01:19:29 +0000567 return Process::ProcessEventData::GetRestartedFromEvent (event.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000568}
569
570SBProcess
571SBProcess::GetProcessFromEvent (const SBEvent &event)
572{
Greg Clayton63094e02010-06-23 01:19:29 +0000573 SBProcess process(Process::ProcessEventData::GetProcessFromEvent (event.get()));
Chris Lattner24943d22010-06-08 16:52:24 +0000574 return process;
575}
576
577
578SBBroadcaster
579SBProcess::GetBroadcaster () const
580{
Greg Claytone005f2c2010-11-06 01:53:30 +0000581 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000582
Greg Clayton63094e02010-06-23 01:19:29 +0000583 SBBroadcaster broadcaster(m_opaque_sp.get(), false);
Caroline Tice7826c882010-10-26 03:11:13 +0000584
585 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000586 log->Printf ("SBProcess(%p)::GetBroadcaster () => SBBroadcaster (%p)", m_opaque_sp.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000587 broadcaster.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000588
Chris Lattner24943d22010-06-08 16:52:24 +0000589 return broadcaster;
590}
591
592lldb_private::Process *
593SBProcess::operator->() const
594{
Greg Clayton63094e02010-06-23 01:19:29 +0000595 return m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000596}
597
598size_t
599SBProcess::ReadMemory (addr_t addr, void *dst, size_t dst_len, SBError &sb_error)
600{
Greg Claytone005f2c2010-11-06 01:53:30 +0000601 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000602
Chris Lattner24943d22010-06-08 16:52:24 +0000603 size_t bytes_read = 0;
604
Greg Claytona66ba462010-10-30 04:51:46 +0000605 if (log)
606 {
607 log->Printf ("SBProcess(%p)::ReadMemory (addr=0x%llx, dst=%p, dst_len=%zu, SBError (%p))...",
608 m_opaque_sp.get(),
609 addr,
610 dst,
611 (uint32_t) dst_len,
612 sb_error.get());
613 }
614
Chris Lattner24943d22010-06-08 16:52:24 +0000615 if (IsValid())
616 {
617 Error error;
Greg Clayton63094e02010-06-23 01:19:29 +0000618 bytes_read = m_opaque_sp->ReadMemory (addr, dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000619 sb_error.SetError (error);
620 }
621 else
622 {
623 sb_error.SetErrorString ("SBProcess is invalid");
624 }
625
Caroline Tice7826c882010-10-26 03:11:13 +0000626 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000627 {
628 SBStream sstr;
629 sb_error.GetDescription (sstr);
Greg Claytona66ba462010-10-30 04:51:46 +0000630 log->Printf ("SBProcess(%p)::ReadMemory (addr=0x%llx, dst=%p, dst_len=%zu, SBError (%p): %s) => %d",
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000631 m_opaque_sp.get(),
632 addr,
633 dst,
634 (uint32_t) dst_len,
635 sb_error.get(),
636 sstr.GetData(),
637 (uint32_t) bytes_read);
638 }
Caroline Tice7826c882010-10-26 03:11:13 +0000639
Chris Lattner24943d22010-06-08 16:52:24 +0000640 return bytes_read;
641}
642
643size_t
644SBProcess::WriteMemory (addr_t addr, const void *src, size_t src_len, SBError &sb_error)
645{
646 size_t bytes_written = 0;
647
Greg Claytone005f2c2010-11-06 01:53:30 +0000648 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000649 if (log)
650 {
651 log->Printf ("SBProcess(%p)::WriteMemory (addr=0x%llx, src=%p, dst_len=%zu, SBError (%p))...",
652 m_opaque_sp.get(),
653 addr,
654 src,
655 (uint32_t) src_len,
656 sb_error.get());
657 }
658
Chris Lattner24943d22010-06-08 16:52:24 +0000659 if (IsValid())
660 {
661 Error error;
Greg Clayton63094e02010-06-23 01:19:29 +0000662 bytes_written = m_opaque_sp->WriteMemory (addr, src, src_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000663 sb_error.SetError (error);
664 }
665
Greg Claytona66ba462010-10-30 04:51:46 +0000666 if (log)
667 {
668 SBStream sstr;
669 sb_error.GetDescription (sstr);
670 log->Printf ("SBProcess(%p)::WriteMemory (addr=0x%llx, src=%p, dst_len=%zu, SBError (%p): %s) => %d",
671 m_opaque_sp.get(),
672 addr,
673 src,
674 (uint32_t) src_len,
675 sb_error.get(),
676 sstr.GetData(),
677 (uint32_t) bytes_written);
678 }
679
Chris Lattner24943d22010-06-08 16:52:24 +0000680 return bytes_written;
681}
682
683// Mimic shared pointer...
684lldb_private::Process *
685SBProcess::get() const
686{
Greg Clayton63094e02010-06-23 01:19:29 +0000687 return m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000688}
689
Caroline Tice98f930f2010-09-20 05:20:02 +0000690bool
691SBProcess::GetDescription (SBStream &description)
692{
693 if (m_opaque_sp)
694 {
695 char path[PATH_MAX];
696 GetTarget().GetExecutable().GetPath (path, sizeof(path));
Greg Clayton5c4c7462010-10-06 03:09:58 +0000697 Module *exe_module = m_opaque_sp->GetTarget().GetExecutableModule ().get();
698 const char *exe_name = NULL;
699 if (exe_module)
700 exe_name = exe_module->GetFileSpec().GetFilename().AsCString();
701
Greg Claytond8c62532010-10-07 04:19:01 +0000702 description.Printf ("SBProcess: pid = %d, state = %s, threads = %d%s%s",
Greg Clayton5c4c7462010-10-06 03:09:58 +0000703 m_opaque_sp->GetID(),
Caroline Tice7826c882010-10-26 03:11:13 +0000704 lldb_private::StateAsCString (GetState()),
Greg Clayton5c4c7462010-10-06 03:09:58 +0000705 GetNumThreads(),
Greg Claytond8c62532010-10-07 04:19:01 +0000706 exe_name ? ", executable = " : "",
Greg Clayton5c4c7462010-10-06 03:09:58 +0000707 exe_name ? exe_name : "");
Caroline Tice98f930f2010-09-20 05:20:02 +0000708 }
709 else
710 description.Printf ("No value");
711
712 return true;
713}
Greg Clayton0baa3942010-11-04 01:54:29 +0000714
715uint32_t
716SBProcess::LoadImage (lldb::SBFileSpec &sb_image_spec, lldb::SBError &sb_error)
717{
718 if (m_opaque_sp)
Greg Clayton0e0fd1c2010-12-05 20:38:01 +0000719 return m_opaque_sp->LoadImage (*sb_image_spec, sb_error.ref());
Greg Clayton0baa3942010-11-04 01:54:29 +0000720 return LLDB_INVALID_IMAGE_TOKEN;
721}
722
723lldb::SBError
724SBProcess::UnloadImage (uint32_t image_token)
725{
726 lldb::SBError sb_error;
727 if (m_opaque_sp)
728 sb_error.SetError (m_opaque_sp->UnloadImage (image_token));
729 else
730 sb_error.SetErrorString("invalid process");
731 return sb_error;
732}
733
734