blob: 4b4e840e63d117832f143299a68dddf1c6435c9d [file] [log] [blame]
Chris Lattner24943d22010-06-08 16:52:24 +00001//===-- SBProcess.cpp -------------------------------------------*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
Eli Friedman7a62c8b2010-06-09 07:44:37 +000010#include "lldb/API/SBProcess.h"
Chris Lattner24943d22010-06-08 16:52:24 +000011
12#include "lldb/lldb-defines.h"
13#include "lldb/lldb-types.h"
14
Jim Ingham84cdc152010-06-15 19:49:27 +000015#include "lldb/Interpreter/Args.h"
Greg Clayton1a3083a2010-10-06 03:53:16 +000016#include "lldb/Core/Debugger.h"
Caroline Tice7826c882010-10-26 03:11:13 +000017#include "lldb/Core/Log.h"
Chris Lattner24943d22010-06-08 16:52:24 +000018#include "lldb/Core/State.h"
19#include "lldb/Core/Stream.h"
20#include "lldb/Core/StreamFile.h"
21#include "lldb/Target/Process.h"
Chris Lattner24943d22010-06-08 16:52:24 +000022#include "lldb/Target/RegisterContext.h"
Greg Clayton63094e02010-06-23 01:19:29 +000023#include "lldb/Target/Target.h"
24#include "lldb/Target/Thread.h"
Chris Lattner24943d22010-06-08 16:52:24 +000025
26// Project includes
27
Eli Friedman7a62c8b2010-06-09 07:44:37 +000028#include "lldb/API/SBBroadcaster.h"
29#include "lldb/API/SBDebugger.h"
30#include "lldb/API/SBCommandReturnObject.h"
31#include "lldb/API/SBEvent.h"
32#include "lldb/API/SBThread.h"
Caroline Tice98f930f2010-09-20 05:20:02 +000033#include "lldb/API/SBStream.h"
Eli Friedman7a62c8b2010-06-09 07:44:37 +000034#include "lldb/API/SBStringList.h"
Chris Lattner24943d22010-06-08 16:52:24 +000035
36using namespace lldb;
37using namespace lldb_private;
38
39
40
41SBProcess::SBProcess () :
Greg Clayton63094e02010-06-23 01:19:29 +000042 m_opaque_sp()
Chris Lattner24943d22010-06-08 16:52:24 +000043{
44}
45
46
47//----------------------------------------------------------------------
48// SBProcess constructor
49//----------------------------------------------------------------------
50
51SBProcess::SBProcess (const SBProcess& rhs) :
Greg Clayton63094e02010-06-23 01:19:29 +000052 m_opaque_sp (rhs.m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000053{
54}
55
56
57SBProcess::SBProcess (const lldb::ProcessSP &process_sp) :
Greg Clayton63094e02010-06-23 01:19:29 +000058 m_opaque_sp (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000059{
60}
61
Greg Clayton538eb822010-11-05 23:17:00 +000062const SBProcess&
63SBProcess::operator = (const SBProcess& rhs)
64{
65 if (this != &rhs)
66 m_opaque_sp = rhs.m_opaque_sp;
67 return *this;
68}
69
Chris Lattner24943d22010-06-08 16:52:24 +000070//----------------------------------------------------------------------
71// Destructor
72//----------------------------------------------------------------------
73SBProcess::~SBProcess()
74{
75}
76
Greg Clayton334d33a2012-01-30 07:41:31 +000077lldb::ProcessSP
78SBProcess::GetSP() const
79{
80 return m_opaque_sp;
81}
82
Chris Lattner24943d22010-06-08 16:52:24 +000083void
Greg Clayton334d33a2012-01-30 07:41:31 +000084SBProcess::SetSP (const ProcessSP &process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000085{
Greg Clayton63094e02010-06-23 01:19:29 +000086 m_opaque_sp = process_sp;
Chris Lattner24943d22010-06-08 16:52:24 +000087}
88
89void
90SBProcess::Clear ()
91{
Greg Clayton63094e02010-06-23 01:19:29 +000092 m_opaque_sp.reset();
Chris Lattner24943d22010-06-08 16:52:24 +000093}
94
95
96bool
97SBProcess::IsValid() const
98{
Greg Clayton63094e02010-06-23 01:19:29 +000099 return m_opaque_sp.get() != NULL;
Chris Lattner24943d22010-06-08 16:52:24 +0000100}
101
James McIlree38093402011-03-04 00:31:13 +0000102bool
103SBProcess::RemoteLaunch (char const **argv,
104 char const **envp,
105 const char *stdin_path,
106 const char *stdout_path,
107 const char *stderr_path,
108 const char *working_directory,
109 uint32_t launch_flags,
110 bool stop_at_entry,
111 lldb::SBError& error)
112{
113 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
114 if (log) {
115 log->Printf ("SBProcess(%p)::RemoteLaunch (argv=%p, envp=%p, stdin=%s, stdout=%s, stderr=%s, working-dir=%s, launch_flags=0x%x, stop_at_entry=%i, &error (%p))...",
116 m_opaque_sp.get(),
117 argv,
118 envp,
119 stdin_path ? stdin_path : "NULL",
120 stdout_path ? stdout_path : "NULL",
121 stderr_path ? stderr_path : "NULL",
122 working_directory ? working_directory : "NULL",
123 launch_flags,
124 stop_at_entry,
125 error.get());
126 }
127
Greg Clayton0416bdf2012-01-30 09:04:36 +0000128 ProcessSP process_sp(GetSP());
129 if (process_sp)
James McIlree38093402011-03-04 00:31:13 +0000130 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000131 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
132 if (process_sp->GetState() == eStateConnected)
James McIlree38093402011-03-04 00:31:13 +0000133 {
Greg Clayton36bc5ea2011-11-03 21:22:33 +0000134 if (stop_at_entry)
135 launch_flags |= eLaunchFlagStopAtEntry;
136 ProcessLaunchInfo launch_info (stdin_path,
137 stdout_path,
138 stderr_path,
139 working_directory,
140 launch_flags);
Greg Clayton0416bdf2012-01-30 09:04:36 +0000141 Module *exe_module = process_sp->GetTarget().GetExecutableModulePointer();
Greg Clayton36bc5ea2011-11-03 21:22:33 +0000142 if (exe_module)
143 launch_info.SetExecutableFile(exe_module->GetFileSpec(), true);
144 if (argv)
145 launch_info.GetArguments().AppendArguments (argv);
146 if (envp)
147 launch_info.GetEnvironmentEntries ().SetArguments (envp);
Greg Clayton0416bdf2012-01-30 09:04:36 +0000148 error.SetError (process_sp->Launch (launch_info));
James McIlree38093402011-03-04 00:31:13 +0000149 }
150 else
151 {
152 error.SetErrorString ("must be in eStateConnected to call RemoteLaunch");
153 }
154 }
155 else
156 {
157 error.SetErrorString ("unable to attach pid");
158 }
159
160 if (log) {
161 SBStream sstr;
162 error.GetDescription (sstr);
Greg Clayton0416bdf2012-01-30 09:04:36 +0000163 log->Printf ("SBProcess(%p)::RemoteLaunch (...) => SBError (%p): %s", process_sp.get(), error.get(), sstr.GetData());
James McIlree38093402011-03-04 00:31:13 +0000164 }
165
166 return error.Success();
167}
168
169bool
170SBProcess::RemoteAttachToProcessWithID (lldb::pid_t pid, lldb::SBError& error)
171{
Greg Clayton0416bdf2012-01-30 09:04:36 +0000172 ProcessSP process_sp(GetSP());
173 if (process_sp)
James McIlree38093402011-03-04 00:31:13 +0000174 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000175 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
176 if (process_sp->GetState() == eStateConnected)
James McIlree38093402011-03-04 00:31:13 +0000177 {
Greg Clayton527154d2011-11-15 03:53:30 +0000178 ProcessAttachInfo attach_info;
179 attach_info.SetProcessID (pid);
Greg Clayton0416bdf2012-01-30 09:04:36 +0000180 error.SetError (process_sp->Attach (attach_info));
James McIlree38093402011-03-04 00:31:13 +0000181 }
182 else
183 {
184 error.SetErrorString ("must be in eStateConnected to call RemoteAttachToProcessWithID");
185 }
186 }
187 else
188 {
189 error.SetErrorString ("unable to attach pid");
190 }
191
192 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
193 if (log) {
194 SBStream sstr;
195 error.GetDescription (sstr);
Greg Clayton0416bdf2012-01-30 09:04:36 +0000196 log->Printf ("SBProcess(%p)::RemoteAttachToProcessWithID (%llu) => SBError (%p): %s", process_sp.get(), pid, error.get(), sstr.GetData());
James McIlree38093402011-03-04 00:31:13 +0000197 }
198
199 return error.Success();
200}
201
Chris Lattner24943d22010-06-08 16:52:24 +0000202
203uint32_t
204SBProcess::GetNumThreads ()
205{
Greg Claytone005f2c2010-11-06 01:53:30 +0000206 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000207
Caroline Tice7826c882010-10-26 03:11:13 +0000208 uint32_t num_threads = 0;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000209 ProcessSP process_sp(GetSP());
210 if (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000211 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000212 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
Chris Lattner24943d22010-06-08 16:52:24 +0000213 const bool can_update = true;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000214 num_threads = process_sp->GetThreadList().GetSize(can_update);
Chris Lattner24943d22010-06-08 16:52:24 +0000215 }
Caroline Tice7826c882010-10-26 03:11:13 +0000216
217 if (log)
Greg Clayton0416bdf2012-01-30 09:04:36 +0000218 log->Printf ("SBProcess(%p)::GetNumThreads () => %d", process_sp.get(), num_threads);
Caroline Tice7826c882010-10-26 03:11:13 +0000219
220 return num_threads;
Chris Lattner24943d22010-06-08 16:52:24 +0000221}
222
223SBThread
Jim Inghamc8332952010-08-26 21:32:51 +0000224SBProcess::GetSelectedThread () const
Chris Lattner24943d22010-06-08 16:52:24 +0000225{
Greg Claytone005f2c2010-11-06 01:53:30 +0000226 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000227
Chris Lattner24943d22010-06-08 16:52:24 +0000228 SBThread sb_thread;
Greg Clayton90c52142012-01-30 02:53:15 +0000229 ThreadSP thread_sp;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000230 ProcessSP process_sp(GetSP());
231 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000232 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000233 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
234 thread_sp = process_sp->GetThreadList().GetSelectedThread();
Greg Clayton90c52142012-01-30 02:53:15 +0000235 sb_thread.SetThread (thread_sp);
Greg Claytonbdcda462010-12-20 20:49:23 +0000236 }
Caroline Tice7826c882010-10-26 03:11:13 +0000237
238 if (log)
239 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000240 log->Printf ("SBProcess(%p)::GetSelectedThread () => SBThread(%p)", process_sp.get(), thread_sp.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000241 }
242
Chris Lattner24943d22010-06-08 16:52:24 +0000243 return sb_thread;
244}
245
246SBTarget
247SBProcess::GetTarget() const
248{
Greg Claytone005f2c2010-11-06 01:53:30 +0000249 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000250
Chris Lattner24943d22010-06-08 16:52:24 +0000251 SBTarget sb_target;
Greg Clayton334d33a2012-01-30 07:41:31 +0000252 TargetSP target_sp;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000253 ProcessSP process_sp(GetSP());
254 if (process_sp)
Greg Clayton334d33a2012-01-30 07:41:31 +0000255 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000256 target_sp = process_sp->GetTarget().shared_from_this();
Greg Clayton334d33a2012-01-30 07:41:31 +0000257 sb_target.SetSP (target_sp);
258 }
Caroline Tice7826c882010-10-26 03:11:13 +0000259
260 if (log)
Greg Clayton0416bdf2012-01-30 09:04:36 +0000261 log->Printf ("SBProcess(%p)::GetTarget () => SBTarget(%p)", process_sp.get(), target_sp.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000262
Chris Lattner24943d22010-06-08 16:52:24 +0000263 return sb_target;
264}
265
266
267size_t
268SBProcess::PutSTDIN (const char *src, size_t src_len)
269{
Greg Claytone005f2c2010-11-06 01:53:30 +0000270 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000271
Caroline Tice7826c882010-10-26 03:11:13 +0000272 size_t ret_val = 0;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000273 ProcessSP process_sp(GetSP());
274 if (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000275 {
276 Error error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000277 ret_val = process_sp->PutSTDIN (src, src_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000278 }
Caroline Tice7826c882010-10-26 03:11:13 +0000279
280 if (log)
Jason Molenda7e5fa7f2011-09-20 21:44:10 +0000281 log->Printf ("SBProcess(%p)::PutSTDIN (src=\"%s\", src_len=%d) => %lu",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000282 process_sp.get(),
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000283 src,
284 (uint32_t) src_len,
285 ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000286
287 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000288}
289
290size_t
291SBProcess::GetSTDOUT (char *dst, size_t dst_len) const
292{
Greg Clayton49ce6822010-10-31 03:01:06 +0000293 size_t bytes_read = 0;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000294 ProcessSP process_sp(GetSP());
295 if (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000296 {
297 Error error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000298 bytes_read = process_sp->GetSTDOUT (dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000299 }
Caroline Tice7826c882010-10-26 03:11:13 +0000300
Greg Claytone005f2c2010-11-06 01:53:30 +0000301 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000302 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000303 log->Printf ("SBProcess(%p)::GetSTDOUT (dst=\"%.*s\", dst_len=%zu) => %zu",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000304 process_sp.get(), (int) bytes_read, dst, dst_len, bytes_read);
Caroline Tice7826c882010-10-26 03:11:13 +0000305
Greg Clayton49ce6822010-10-31 03:01:06 +0000306 return bytes_read;
Chris Lattner24943d22010-06-08 16:52:24 +0000307}
308
309size_t
310SBProcess::GetSTDERR (char *dst, size_t dst_len) const
311{
Greg Clayton49ce6822010-10-31 03:01:06 +0000312 size_t bytes_read = 0;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000313 ProcessSP process_sp(GetSP());
314 if (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000315 {
316 Error error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000317 bytes_read = process_sp->GetSTDERR (dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000318 }
Caroline Tice7826c882010-10-26 03:11:13 +0000319
Greg Claytone005f2c2010-11-06 01:53:30 +0000320 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000321 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000322 log->Printf ("SBProcess(%p)::GetSTDERR (dst=\"%.*s\", dst_len=%zu) => %zu",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000323 process_sp.get(), (int) bytes_read, dst, dst_len, bytes_read);
Caroline Tice7826c882010-10-26 03:11:13 +0000324
Greg Clayton49ce6822010-10-31 03:01:06 +0000325 return bytes_read;
Chris Lattner24943d22010-06-08 16:52:24 +0000326}
327
328void
Jim Inghamc8332952010-08-26 21:32:51 +0000329SBProcess::ReportEventState (const SBEvent &event, FILE *out) const
Chris Lattner24943d22010-06-08 16:52:24 +0000330{
331 if (out == NULL)
332 return;
333
Greg Clayton0416bdf2012-01-30 09:04:36 +0000334 ProcessSP process_sp(GetSP());
335 if (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000336 {
337 const StateType event_state = SBProcess::GetStateFromEvent (event);
338 char message[1024];
339 int message_len = ::snprintf (message,
340 sizeof (message),
Greg Clayton444e35b2011-10-19 18:09:39 +0000341 "Process %llu %s\n",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000342 process_sp->GetID(),
Chris Lattner24943d22010-06-08 16:52:24 +0000343 SBDebugger::StateAsCString (event_state));
344
345 if (message_len > 0)
346 ::fwrite (message, 1, message_len, out);
347 }
348}
349
350void
Jim Inghamc8332952010-08-26 21:32:51 +0000351SBProcess::AppendEventStateReport (const SBEvent &event, SBCommandReturnObject &result)
Chris Lattner24943d22010-06-08 16:52:24 +0000352{
Greg Clayton0416bdf2012-01-30 09:04:36 +0000353 ProcessSP process_sp(GetSP());
354 if (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000355 {
356 const StateType event_state = SBProcess::GetStateFromEvent (event);
357 char message[1024];
358 ::snprintf (message,
359 sizeof (message),
Greg Clayton444e35b2011-10-19 18:09:39 +0000360 "Process %llu %s\n",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000361 process_sp->GetID(),
Chris Lattner24943d22010-06-08 16:52:24 +0000362 SBDebugger::StateAsCString (event_state));
363
364 result.AppendMessage (message);
365 }
366}
367
368bool
Jim Inghamc8332952010-08-26 21:32:51 +0000369SBProcess::SetSelectedThread (const SBThread &thread)
Chris Lattner24943d22010-06-08 16:52:24 +0000370{
Greg Clayton0416bdf2012-01-30 09:04:36 +0000371 ProcessSP process_sp(GetSP());
372 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000373 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000374 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
375 return process_sp->GetThreadList().SetSelectedThreadByID (thread.GetThreadID());
Greg Claytonbdcda462010-12-20 20:49:23 +0000376 }
Chris Lattner24943d22010-06-08 16:52:24 +0000377 return false;
378}
379
380bool
Jim Inghamc8332952010-08-26 21:32:51 +0000381SBProcess::SetSelectedThreadByID (uint32_t tid)
Chris Lattner24943d22010-06-08 16:52:24 +0000382{
Greg Claytone005f2c2010-11-06 01:53:30 +0000383 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000384
Caroline Tice7826c882010-10-26 03:11:13 +0000385 bool ret_val = false;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000386 ProcessSP process_sp(GetSP());
387 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000388 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000389 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
390 ret_val = process_sp->GetThreadList().SetSelectedThreadByID (tid);
Greg Claytonbdcda462010-12-20 20:49:23 +0000391 }
Caroline Tice7826c882010-10-26 03:11:13 +0000392
393 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000394 log->Printf ("SBProcess(%p)::SetSelectedThreadByID (tid=0x%4.4x) => %s",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000395 process_sp.get(), tid, (ret_val ? "true" : "false"));
Caroline Tice7826c882010-10-26 03:11:13 +0000396
397 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000398}
399
400SBThread
401SBProcess::GetThreadAtIndex (size_t index)
402{
Greg Claytone005f2c2010-11-06 01:53:30 +0000403 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000404
Greg Clayton90c52142012-01-30 02:53:15 +0000405 SBThread sb_thread;
406 ThreadSP thread_sp;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000407 ProcessSP process_sp(GetSP());
408 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000409 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000410 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
411 thread_sp = process_sp->GetThreadList().GetThreadAtIndex(index);
Greg Clayton90c52142012-01-30 02:53:15 +0000412 sb_thread.SetThread (thread_sp);
Greg Claytonbdcda462010-12-20 20:49:23 +0000413 }
Caroline Tice7826c882010-10-26 03:11:13 +0000414
415 if (log)
416 {
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000417 log->Printf ("SBProcess(%p)::GetThreadAtIndex (index=%d) => SBThread(%p)",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000418 process_sp.get(), (uint32_t) index, thread_sp.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000419 }
420
Greg Clayton90c52142012-01-30 02:53:15 +0000421 return sb_thread;
Chris Lattner24943d22010-06-08 16:52:24 +0000422}
423
424StateType
425SBProcess::GetState ()
426{
Caroline Tice7826c882010-10-26 03:11:13 +0000427
Caroline Tice7826c882010-10-26 03:11:13 +0000428 StateType ret_val = eStateInvalid;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000429 ProcessSP process_sp(GetSP());
430 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000431 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000432 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
433 ret_val = process_sp->GetState();
Greg Claytonbdcda462010-12-20 20:49:23 +0000434 }
Caroline Tice7826c882010-10-26 03:11:13 +0000435
Greg Claytone005f2c2010-11-06 01:53:30 +0000436 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000437 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000438 log->Printf ("SBProcess(%p)::GetState () => %s",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000439 process_sp.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000440 lldb_private::StateAsCString (ret_val));
Caroline Tice7826c882010-10-26 03:11:13 +0000441
442 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000443}
444
445
446int
447SBProcess::GetExitStatus ()
448{
Greg Claytona66ba462010-10-30 04:51:46 +0000449 int exit_status = 0;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000450 ProcessSP process_sp(GetSP());
451 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000452 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000453 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
454 exit_status = process_sp->GetExitStatus ();
Greg Claytonbdcda462010-12-20 20:49:23 +0000455 }
Greg Claytone005f2c2010-11-06 01:53:30 +0000456 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000457 if (log)
458 log->Printf ("SBProcess(%p)::GetExitStatus () => %i (0x%8.8x)",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000459 process_sp.get(), exit_status, exit_status);
Greg Claytona66ba462010-10-30 04:51:46 +0000460
461 return exit_status;
Chris Lattner24943d22010-06-08 16:52:24 +0000462}
463
464const char *
465SBProcess::GetExitDescription ()
466{
Greg Claytona66ba462010-10-30 04:51:46 +0000467 const char *exit_desc = NULL;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000468 ProcessSP process_sp(GetSP());
469 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000470 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000471 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
472 exit_desc = process_sp->GetExitDescription ();
Greg Claytonbdcda462010-12-20 20:49:23 +0000473 }
Greg Claytone005f2c2010-11-06 01:53:30 +0000474 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000475 if (log)
476 log->Printf ("SBProcess(%p)::GetExitDescription () => %s",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000477 process_sp.get(), exit_desc);
Greg Claytona66ba462010-10-30 04:51:46 +0000478 return exit_desc;
Chris Lattner24943d22010-06-08 16:52:24 +0000479}
480
481lldb::pid_t
482SBProcess::GetProcessID ()
483{
Caroline Tice7826c882010-10-26 03:11:13 +0000484 lldb::pid_t ret_val = LLDB_INVALID_PROCESS_ID;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000485 ProcessSP process_sp(GetSP());
486 if (process_sp)
487 ret_val = process_sp->GetID();
Caroline Tice7826c882010-10-26 03:11:13 +0000488
Greg Claytone005f2c2010-11-06 01:53:30 +0000489 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000490 if (log)
Greg Clayton0416bdf2012-01-30 09:04:36 +0000491 log->Printf ("SBProcess(%p)::GetProcessID () => %llu", process_sp.get(), ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000492
493 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000494}
495
Johnny Chen60a544f2011-03-01 22:56:31 +0000496ByteOrder
497SBProcess::GetByteOrder () const
498{
499 ByteOrder byteOrder = eByteOrderInvalid;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000500 ProcessSP process_sp(GetSP());
501 if (process_sp)
502 byteOrder = process_sp->GetTarget().GetArchitecture().GetByteOrder();
Johnny Chen60a544f2011-03-01 22:56:31 +0000503
504 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
505 if (log)
Greg Clayton0416bdf2012-01-30 09:04:36 +0000506 log->Printf ("SBProcess(%p)::GetByteOrder () => %d", process_sp.get(), byteOrder);
Johnny Chen60a544f2011-03-01 22:56:31 +0000507
508 return byteOrder;
509}
510
Chris Lattner24943d22010-06-08 16:52:24 +0000511uint32_t
512SBProcess::GetAddressByteSize () const
513{
Caroline Tice7826c882010-10-26 03:11:13 +0000514 uint32_t size = 0;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000515 ProcessSP process_sp(GetSP());
516 if (process_sp)
517 size = process_sp->GetTarget().GetArchitecture().GetAddressByteSize();
Caroline Tice7826c882010-10-26 03:11:13 +0000518
Greg Claytone005f2c2010-11-06 01:53:30 +0000519 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000520 if (log)
Greg Clayton0416bdf2012-01-30 09:04:36 +0000521 log->Printf ("SBProcess(%p)::GetAddressByteSize () => %d", process_sp.get(), size);
Caroline Tice7826c882010-10-26 03:11:13 +0000522
523 return size;
Chris Lattner24943d22010-06-08 16:52:24 +0000524}
525
Chris Lattner24943d22010-06-08 16:52:24 +0000526SBError
527SBProcess::Continue ()
528{
Greg Claytone005f2c2010-11-06 01:53:30 +0000529 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000530
Chris Lattner24943d22010-06-08 16:52:24 +0000531 SBError sb_error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000532 ProcessSP process_sp(GetSP());
533
534 if (log)
535 log->Printf ("SBProcess(%p)::Continue ()...", process_sp.get());
536
537 if (process_sp)
Greg Clayton1a3083a2010-10-06 03:53:16 +0000538 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000539 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
Greg Claytonde1dd812011-06-24 03:21:43 +0000540
Greg Clayton0416bdf2012-01-30 09:04:36 +0000541 Error error (process_sp->Resume());
Greg Clayton1a3083a2010-10-06 03:53:16 +0000542 if (error.Success())
543 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000544 if (process_sp->GetTarget().GetDebugger().GetAsyncExecution () == false)
Greg Claytona66ba462010-10-30 04:51:46 +0000545 {
546 if (log)
Greg Clayton0416bdf2012-01-30 09:04:36 +0000547 log->Printf ("SBProcess(%p)::Continue () waiting for process to stop...", process_sp.get());
548 process_sp->WaitForProcessToStop (NULL);
Greg Claytona66ba462010-10-30 04:51:46 +0000549 }
Greg Clayton1a3083a2010-10-06 03:53:16 +0000550 }
551 sb_error.SetError(error);
552 }
Chris Lattner24943d22010-06-08 16:52:24 +0000553 else
554 sb_error.SetErrorString ("SBProcess is invalid");
555
Caroline Tice7826c882010-10-26 03:11:13 +0000556 if (log)
557 {
558 SBStream sstr;
559 sb_error.GetDescription (sstr);
Greg Clayton0416bdf2012-01-30 09:04:36 +0000560 log->Printf ("SBProcess(%p)::Continue () => SBError (%p): %s", process_sp.get(), sb_error.get(), sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000561 }
562
Chris Lattner24943d22010-06-08 16:52:24 +0000563 return sb_error;
564}
565
566
567SBError
568SBProcess::Destroy ()
569{
570 SBError sb_error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000571 ProcessSP process_sp(GetSP());
572 if (process_sp)
Greg Clayton72e1c782011-01-22 23:43:18 +0000573 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000574 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
575 sb_error.SetError(process_sp->Destroy());
Greg Clayton72e1c782011-01-22 23:43:18 +0000576 }
Chris Lattner24943d22010-06-08 16:52:24 +0000577 else
578 sb_error.SetErrorString ("SBProcess is invalid");
579
Greg Claytone005f2c2010-11-06 01:53:30 +0000580 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000581 if (log)
582 {
583 SBStream sstr;
584 sb_error.GetDescription (sstr);
Greg Clayton72e1c782011-01-22 23:43:18 +0000585 log->Printf ("SBProcess(%p)::Destroy () => SBError (%p): %s",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000586 process_sp.get(),
Greg Clayton72e1c782011-01-22 23:43:18 +0000587 sb_error.get(),
588 sstr.GetData());
Greg Claytona66ba462010-10-30 04:51:46 +0000589 }
590
Chris Lattner24943d22010-06-08 16:52:24 +0000591 return sb_error;
592}
593
594
595SBError
596SBProcess::Stop ()
597{
598 SBError sb_error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000599 ProcessSP process_sp(GetSP());
600 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000601 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000602 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
603 sb_error.SetError (process_sp->Halt());
Greg Claytonbdcda462010-12-20 20:49:23 +0000604 }
Chris Lattner24943d22010-06-08 16:52:24 +0000605 else
606 sb_error.SetErrorString ("SBProcess is invalid");
Caroline Tice7826c882010-10-26 03:11:13 +0000607
Greg Claytone005f2c2010-11-06 01:53:30 +0000608 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000609 if (log)
610 {
611 SBStream sstr;
612 sb_error.GetDescription (sstr);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000613 log->Printf ("SBProcess(%p)::Stop () => SBError (%p): %s",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000614 process_sp.get(),
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000615 sb_error.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000616 sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000617 }
618
Chris Lattner24943d22010-06-08 16:52:24 +0000619 return sb_error;
620}
621
622SBError
623SBProcess::Kill ()
624{
625 SBError sb_error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000626 ProcessSP process_sp(GetSP());
627 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000628 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000629 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
630 sb_error.SetError (process_sp->Destroy());
Greg Claytonbdcda462010-12-20 20:49:23 +0000631 }
Chris Lattner24943d22010-06-08 16:52:24 +0000632 else
633 sb_error.SetErrorString ("SBProcess is invalid");
Caroline Tice7826c882010-10-26 03:11:13 +0000634
Greg Claytone005f2c2010-11-06 01:53:30 +0000635 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000636 if (log)
637 {
638 SBStream sstr;
639 sb_error.GetDescription (sstr);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000640 log->Printf ("SBProcess(%p)::Kill () => SBError (%p): %s",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000641 process_sp.get(),
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000642 sb_error.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000643 sstr.GetData());
Caroline Tice7826c882010-10-26 03:11:13 +0000644 }
645
Chris Lattner24943d22010-06-08 16:52:24 +0000646 return sb_error;
647}
648
Chris Lattner24943d22010-06-08 16:52:24 +0000649SBError
650SBProcess::Detach ()
651{
652 SBError sb_error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000653 ProcessSP process_sp(GetSP());
654 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000655 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000656 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
657 sb_error.SetError (process_sp->Detach());
Greg Claytonbdcda462010-12-20 20:49:23 +0000658 }
Chris Lattner24943d22010-06-08 16:52:24 +0000659 else
660 sb_error.SetErrorString ("SBProcess is invalid");
661
662 return sb_error;
663}
664
665SBError
Greg Claytona66ba462010-10-30 04:51:46 +0000666SBProcess::Signal (int signo)
Chris Lattner24943d22010-06-08 16:52:24 +0000667{
668 SBError sb_error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000669 ProcessSP process_sp(GetSP());
670 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000671 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000672 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
673 sb_error.SetError (process_sp->Signal (signo));
Greg Claytonbdcda462010-12-20 20:49:23 +0000674 }
Chris Lattner24943d22010-06-08 16:52:24 +0000675 else
676 sb_error.SetErrorString ("SBProcess is invalid");
Greg Claytone005f2c2010-11-06 01:53:30 +0000677 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000678 if (log)
679 {
680 SBStream sstr;
681 sb_error.GetDescription (sstr);
682 log->Printf ("SBProcess(%p)::Signal (signo=%i) => SBError (%p): %s",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000683 process_sp.get(),
Greg Claytona66ba462010-10-30 04:51:46 +0000684 signo,
685 sb_error.get(),
686 sstr.GetData());
687 }
Chris Lattner24943d22010-06-08 16:52:24 +0000688 return sb_error;
689}
690
Chris Lattner24943d22010-06-08 16:52:24 +0000691SBThread
Greg Claytona66ba462010-10-30 04:51:46 +0000692SBProcess::GetThreadByID (tid_t tid)
Chris Lattner24943d22010-06-08 16:52:24 +0000693{
Greg Claytona66ba462010-10-30 04:51:46 +0000694 SBThread sb_thread;
Greg Clayton90c52142012-01-30 02:53:15 +0000695 ThreadSP thread_sp;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000696 ProcessSP process_sp(GetSP());
697 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000698 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000699 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
700 thread_sp = process_sp->GetThreadList().FindThreadByID (tid);
Greg Clayton90c52142012-01-30 02:53:15 +0000701 sb_thread.SetThread (thread_sp);
Greg Claytonbdcda462010-12-20 20:49:23 +0000702 }
Greg Claytona66ba462010-10-30 04:51:46 +0000703
Greg Claytone005f2c2010-11-06 01:53:30 +0000704 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000705 if (log)
706 {
Greg Claytond9919d32011-12-01 23:28:38 +0000707 log->Printf ("SBProcess(%p)::GetThreadByID (tid=0x%4.4llx) => SBThread (%p)",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000708 process_sp.get(),
Greg Claytona66ba462010-10-30 04:51:46 +0000709 tid,
Greg Clayton90c52142012-01-30 02:53:15 +0000710 thread_sp.get());
Greg Claytona66ba462010-10-30 04:51:46 +0000711 }
712
713 return sb_thread;
Chris Lattner24943d22010-06-08 16:52:24 +0000714}
715
Chris Lattner24943d22010-06-08 16:52:24 +0000716StateType
717SBProcess::GetStateFromEvent (const SBEvent &event)
718{
Greg Claytone005f2c2010-11-06 01:53:30 +0000719 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000720
Caroline Tice7826c882010-10-26 03:11:13 +0000721 StateType ret_val = Process::ProcessEventData::GetStateFromEvent (event.get());
722
723 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000724 log->Printf ("SBProcess::GetStateFromEvent (event.sp=%p) => %s", event.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000725 lldb_private::StateAsCString (ret_val));
Caroline Tice7826c882010-10-26 03:11:13 +0000726
727 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000728}
729
Chris Lattner24943d22010-06-08 16:52:24 +0000730bool
731SBProcess::GetRestartedFromEvent (const SBEvent &event)
732{
Greg Clayton63094e02010-06-23 01:19:29 +0000733 return Process::ProcessEventData::GetRestartedFromEvent (event.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000734}
735
736SBProcess
737SBProcess::GetProcessFromEvent (const SBEvent &event)
738{
Greg Clayton63094e02010-06-23 01:19:29 +0000739 SBProcess process(Process::ProcessEventData::GetProcessFromEvent (event.get()));
Chris Lattner24943d22010-06-08 16:52:24 +0000740 return process;
741}
742
743
744SBBroadcaster
745SBProcess::GetBroadcaster () const
746{
Greg Claytone005f2c2010-11-06 01:53:30 +0000747 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000748
Greg Clayton0416bdf2012-01-30 09:04:36 +0000749 ProcessSP process_sp(GetSP());
750
751 SBBroadcaster broadcaster(process_sp.get(), false);
Caroline Tice7826c882010-10-26 03:11:13 +0000752
753 if (log)
Greg Clayton0416bdf2012-01-30 09:04:36 +0000754 log->Printf ("SBProcess(%p)::GetBroadcaster () => SBBroadcaster (%p)", process_sp.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000755 broadcaster.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000756
Chris Lattner24943d22010-06-08 16:52:24 +0000757 return broadcaster;
758}
759
Chris Lattner24943d22010-06-08 16:52:24 +0000760size_t
761SBProcess::ReadMemory (addr_t addr, void *dst, size_t dst_len, SBError &sb_error)
762{
Greg Claytone005f2c2010-11-06 01:53:30 +0000763 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000764
Chris Lattner24943d22010-06-08 16:52:24 +0000765 size_t bytes_read = 0;
766
Greg Clayton0416bdf2012-01-30 09:04:36 +0000767 ProcessSP process_sp(GetSP());
768
Greg Claytona66ba462010-10-30 04:51:46 +0000769 if (log)
770 {
771 log->Printf ("SBProcess(%p)::ReadMemory (addr=0x%llx, dst=%p, dst_len=%zu, SBError (%p))...",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000772 process_sp.get(),
Greg Claytona66ba462010-10-30 04:51:46 +0000773 addr,
774 dst,
Greg Claytonbae39c52011-12-03 00:46:21 +0000775 dst_len,
Greg Claytona66ba462010-10-30 04:51:46 +0000776 sb_error.get());
777 }
Greg Clayton0416bdf2012-01-30 09:04:36 +0000778
779 if (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000780 {
781 Error error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000782 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
783 bytes_read = process_sp->ReadMemory (addr, dst, dst_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000784 sb_error.SetError (error);
785 }
786 else
787 {
788 sb_error.SetErrorString ("SBProcess is invalid");
789 }
790
Caroline Tice7826c882010-10-26 03:11:13 +0000791 if (log)
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000792 {
793 SBStream sstr;
794 sb_error.GetDescription (sstr);
Greg Claytonbae39c52011-12-03 00:46:21 +0000795 log->Printf ("SBProcess(%p)::ReadMemory (addr=0x%llx, dst=%p, dst_len=%zu, SBError (%p): %s) => %zu",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000796 process_sp.get(),
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000797 addr,
798 dst,
Greg Claytonbae39c52011-12-03 00:46:21 +0000799 dst_len,
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000800 sb_error.get(),
801 sstr.GetData(),
Greg Claytonbae39c52011-12-03 00:46:21 +0000802 bytes_read);
Greg Clayton3f5ee7f2010-10-29 04:59:35 +0000803 }
Caroline Tice7826c882010-10-26 03:11:13 +0000804
Chris Lattner24943d22010-06-08 16:52:24 +0000805 return bytes_read;
806}
807
808size_t
Greg Clayton4a2e3372011-12-15 03:14:23 +0000809SBProcess::ReadCStringFromMemory (addr_t addr, void *buf, size_t size, lldb::SBError &sb_error)
810{
811 size_t bytes_read = 0;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000812 ProcessSP process_sp(GetSP());
813 if (process_sp)
Greg Clayton4a2e3372011-12-15 03:14:23 +0000814 {
815 Error error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000816 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
817 bytes_read = process_sp->ReadCStringFromMemory (addr, (char *)buf, size, error);
Greg Clayton4a2e3372011-12-15 03:14:23 +0000818 sb_error.SetError (error);
819 }
820 else
821 {
822 sb_error.SetErrorString ("SBProcess is invalid");
823 }
824 return bytes_read;
825}
826
827uint64_t
828SBProcess::ReadUnsignedFromMemory (addr_t addr, uint32_t byte_size, lldb::SBError &sb_error)
829{
Greg Clayton0416bdf2012-01-30 09:04:36 +0000830 ProcessSP process_sp(GetSP());
831 if (process_sp)
Greg Clayton4a2e3372011-12-15 03:14:23 +0000832 {
833 Error error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000834 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
835 uint64_t value = process_sp->ReadUnsignedIntegerFromMemory (addr, byte_size, 0, error);
Greg Clayton4a2e3372011-12-15 03:14:23 +0000836 sb_error.SetError (error);
837 return value;
838 }
839 else
840 {
841 sb_error.SetErrorString ("SBProcess is invalid");
842 }
843 return 0;
844}
845
846lldb::addr_t
847SBProcess::ReadPointerFromMemory (addr_t addr, lldb::SBError &sb_error)
848{
849 lldb::addr_t ptr = LLDB_INVALID_ADDRESS;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000850 ProcessSP process_sp(GetSP());
851 if (process_sp)
Greg Clayton4a2e3372011-12-15 03:14:23 +0000852 {
853 Error error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000854 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
855 ptr = process_sp->ReadPointerFromMemory (addr, error);
Greg Clayton4a2e3372011-12-15 03:14:23 +0000856 sb_error.SetError (error);
857 }
858 else
859 {
860 sb_error.SetErrorString ("SBProcess is invalid");
861 }
862 return ptr;
863}
864
865size_t
Chris Lattner24943d22010-06-08 16:52:24 +0000866SBProcess::WriteMemory (addr_t addr, const void *src, size_t src_len, SBError &sb_error)
867{
868 size_t bytes_written = 0;
869
Greg Claytone005f2c2010-11-06 01:53:30 +0000870 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Clayton0416bdf2012-01-30 09:04:36 +0000871
872 ProcessSP process_sp(GetSP());
873
Greg Claytona66ba462010-10-30 04:51:46 +0000874 if (log)
875 {
876 log->Printf ("SBProcess(%p)::WriteMemory (addr=0x%llx, src=%p, dst_len=%zu, SBError (%p))...",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000877 process_sp.get(),
Greg Claytona66ba462010-10-30 04:51:46 +0000878 addr,
879 src,
Greg Claytonbae39c52011-12-03 00:46:21 +0000880 src_len,
Greg Claytona66ba462010-10-30 04:51:46 +0000881 sb_error.get());
882 }
883
Greg Clayton0416bdf2012-01-30 09:04:36 +0000884 if (process_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000885 {
886 Error error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000887 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
888 bytes_written = process_sp->WriteMemory (addr, src, src_len, error);
Chris Lattner24943d22010-06-08 16:52:24 +0000889 sb_error.SetError (error);
890 }
891
Greg Claytona66ba462010-10-30 04:51:46 +0000892 if (log)
893 {
894 SBStream sstr;
895 sb_error.GetDescription (sstr);
Greg Claytonbae39c52011-12-03 00:46:21 +0000896 log->Printf ("SBProcess(%p)::WriteMemory (addr=0x%llx, src=%p, dst_len=%zu, SBError (%p): %s) => %zu",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000897 process_sp.get(),
Greg Claytona66ba462010-10-30 04:51:46 +0000898 addr,
899 src,
Greg Claytonbae39c52011-12-03 00:46:21 +0000900 src_len,
Greg Claytona66ba462010-10-30 04:51:46 +0000901 sb_error.get(),
902 sstr.GetData(),
Greg Claytonbae39c52011-12-03 00:46:21 +0000903 bytes_written);
Greg Claytona66ba462010-10-30 04:51:46 +0000904 }
905
Chris Lattner24943d22010-06-08 16:52:24 +0000906 return bytes_written;
907}
908
Caroline Tice98f930f2010-09-20 05:20:02 +0000909bool
910SBProcess::GetDescription (SBStream &description)
911{
Greg Clayton96154be2011-11-13 06:57:31 +0000912 Stream &strm = description.ref();
913
Greg Clayton0416bdf2012-01-30 09:04:36 +0000914 ProcessSP process_sp(GetSP());
915 if (process_sp)
Caroline Tice98f930f2010-09-20 05:20:02 +0000916 {
917 char path[PATH_MAX];
918 GetTarget().GetExecutable().GetPath (path, sizeof(path));
Greg Clayton0416bdf2012-01-30 09:04:36 +0000919 Module *exe_module = process_sp->GetTarget().GetExecutableModulePointer();
Greg Clayton5c4c7462010-10-06 03:09:58 +0000920 const char *exe_name = NULL;
921 if (exe_module)
922 exe_name = exe_module->GetFileSpec().GetFilename().AsCString();
923
Greg Clayton96154be2011-11-13 06:57:31 +0000924 strm.Printf ("SBProcess: pid = %llu, state = %s, threads = %d%s%s",
Greg Clayton0416bdf2012-01-30 09:04:36 +0000925 process_sp->GetID(),
Greg Clayton96154be2011-11-13 06:57:31 +0000926 lldb_private::StateAsCString (GetState()),
927 GetNumThreads(),
928 exe_name ? ", executable = " : "",
929 exe_name ? exe_name : "");
Caroline Tice98f930f2010-09-20 05:20:02 +0000930 }
931 else
Greg Clayton96154be2011-11-13 06:57:31 +0000932 strm.PutCString ("No value");
Caroline Tice98f930f2010-09-20 05:20:02 +0000933
934 return true;
935}
Greg Clayton0baa3942010-11-04 01:54:29 +0000936
937uint32_t
938SBProcess::LoadImage (lldb::SBFileSpec &sb_image_spec, lldb::SBError &sb_error)
939{
Greg Clayton0416bdf2012-01-30 09:04:36 +0000940 ProcessSP process_sp(GetSP());
941 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000942 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000943 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
944 return process_sp->LoadImage (*sb_image_spec, sb_error.ref());
Greg Claytonbdcda462010-12-20 20:49:23 +0000945 }
Greg Clayton0baa3942010-11-04 01:54:29 +0000946 return LLDB_INVALID_IMAGE_TOKEN;
947}
948
949lldb::SBError
950SBProcess::UnloadImage (uint32_t image_token)
951{
952 lldb::SBError sb_error;
Greg Clayton0416bdf2012-01-30 09:04:36 +0000953 ProcessSP process_sp(GetSP());
954 if (process_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000955 {
Greg Clayton0416bdf2012-01-30 09:04:36 +0000956 Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
957 sb_error.SetError (process_sp->UnloadImage (image_token));
Greg Claytonbdcda462010-12-20 20:49:23 +0000958 }
Greg Clayton0baa3942010-11-04 01:54:29 +0000959 else
960 sb_error.SetErrorString("invalid process");
961 return sb_error;
962}