130fdc8d8SChris Lattner //===-- SBProcess.cpp -------------------------------------------*- C++ -*-===//
230fdc8d8SChris Lattner //
330fdc8d8SChris Lattner //                     The LLVM Compiler Infrastructure
430fdc8d8SChris Lattner //
530fdc8d8SChris Lattner // This file is distributed under the University of Illinois Open Source
630fdc8d8SChris Lattner // License. See LICENSE.TXT for details.
730fdc8d8SChris Lattner //
830fdc8d8SChris Lattner //===----------------------------------------------------------------------===//
930fdc8d8SChris Lattner 
1093a64300SDaniel Malea #include "lldb/lldb-python.h"
1193a64300SDaniel Malea 
124c5de699SEli Friedman #include "lldb/API/SBProcess.h"
1330fdc8d8SChris Lattner 
14bdae3787SVirgile Bello // C Includes
15bdae3787SVirgile Bello #include <inttypes.h>
16bdae3787SVirgile Bello 
1730fdc8d8SChris Lattner #include "lldb/lldb-defines.h"
1830fdc8d8SChris Lattner #include "lldb/lldb-types.h"
1930fdc8d8SChris Lattner 
2040af72e1SJim Ingham #include "lldb/Interpreter/Args.h"
215d5028b5SGreg Clayton #include "lldb/Core/Debugger.h"
22ceb6b139SCaroline Tice #include "lldb/Core/Log.h"
231f746071SGreg Clayton #include "lldb/Core/Module.h"
2430fdc8d8SChris Lattner #include "lldb/Core/State.h"
2530fdc8d8SChris Lattner #include "lldb/Core/Stream.h"
2630fdc8d8SChris Lattner #include "lldb/Core/StreamFile.h"
2730fdc8d8SChris Lattner #include "lldb/Target/Process.h"
2830fdc8d8SChris Lattner #include "lldb/Target/RegisterContext.h"
298c71337aSJason Molenda #include "lldb/Target/SystemRuntime.h"
306611103cSGreg Clayton #include "lldb/Target/Target.h"
316611103cSGreg Clayton #include "lldb/Target/Thread.h"
3230fdc8d8SChris Lattner 
3330fdc8d8SChris Lattner // Project includes
3430fdc8d8SChris Lattner 
354c5de699SEli Friedman #include "lldb/API/SBBroadcaster.h"
364c5de699SEli Friedman #include "lldb/API/SBCommandReturnObject.h"
370e615684SGreg Clayton #include "lldb/API/SBDebugger.h"
384c5de699SEli Friedman #include "lldb/API/SBEvent.h"
390e615684SGreg Clayton #include "lldb/API/SBFileSpec.h"
404c5de699SEli Friedman #include "lldb/API/SBThread.h"
41dde9cff3SCaroline Tice #include "lldb/API/SBStream.h"
424c5de699SEli Friedman #include "lldb/API/SBStringList.h"
4330fdc8d8SChris Lattner 
4430fdc8d8SChris Lattner using namespace lldb;
4530fdc8d8SChris Lattner using namespace lldb_private;
4630fdc8d8SChris Lattner 
4730fdc8d8SChris Lattner 
4830fdc8d8SChris Lattner SBProcess::SBProcess () :
494e0fe8abSGreg Clayton     m_opaque_wp()
5030fdc8d8SChris Lattner {
5130fdc8d8SChris Lattner }
5230fdc8d8SChris Lattner 
5330fdc8d8SChris Lattner 
5430fdc8d8SChris Lattner //----------------------------------------------------------------------
5530fdc8d8SChris Lattner // SBProcess constructor
5630fdc8d8SChris Lattner //----------------------------------------------------------------------
5730fdc8d8SChris Lattner 
5830fdc8d8SChris Lattner SBProcess::SBProcess (const SBProcess& rhs) :
594e0fe8abSGreg Clayton     m_opaque_wp (rhs.m_opaque_wp)
6030fdc8d8SChris Lattner {
6130fdc8d8SChris Lattner }
6230fdc8d8SChris Lattner 
6330fdc8d8SChris Lattner 
6430fdc8d8SChris Lattner SBProcess::SBProcess (const lldb::ProcessSP &process_sp) :
654e0fe8abSGreg Clayton     m_opaque_wp (process_sp)
6630fdc8d8SChris Lattner {
6730fdc8d8SChris Lattner }
6830fdc8d8SChris Lattner 
69efabb123SGreg Clayton const SBProcess&
70efabb123SGreg Clayton SBProcess::operator = (const SBProcess& rhs)
71efabb123SGreg Clayton {
72efabb123SGreg Clayton     if (this != &rhs)
734e0fe8abSGreg Clayton         m_opaque_wp = rhs.m_opaque_wp;
74efabb123SGreg Clayton     return *this;
75efabb123SGreg Clayton }
76efabb123SGreg Clayton 
7730fdc8d8SChris Lattner //----------------------------------------------------------------------
7830fdc8d8SChris Lattner // Destructor
7930fdc8d8SChris Lattner //----------------------------------------------------------------------
8030fdc8d8SChris Lattner SBProcess::~SBProcess()
8130fdc8d8SChris Lattner {
8230fdc8d8SChris Lattner }
8330fdc8d8SChris Lattner 
844bddaeb5SJim Ingham const char *
854bddaeb5SJim Ingham SBProcess::GetBroadcasterClassName ()
864bddaeb5SJim Ingham {
874bddaeb5SJim Ingham     return Process::GetStaticBroadcasterClass().AsCString();
884bddaeb5SJim Ingham }
894bddaeb5SJim Ingham 
90d7b30ef9SJim Ingham const char *
91d7b30ef9SJim Ingham SBProcess::GetPluginName ()
92d7b30ef9SJim Ingham {
93d7b30ef9SJim Ingham     ProcessSP process_sp(GetSP());
94d7b30ef9SJim Ingham     if (process_sp)
95d7b30ef9SJim Ingham     {
9657abc5d6SGreg Clayton         return process_sp->GetPluginName().GetCString();
97d7b30ef9SJim Ingham     }
98d7b30ef9SJim Ingham     return "<Unknown>";
99d7b30ef9SJim Ingham }
100d7b30ef9SJim Ingham 
101d7b30ef9SJim Ingham const char *
102d7b30ef9SJim Ingham SBProcess::GetShortPluginName ()
103d7b30ef9SJim Ingham {
104d7b30ef9SJim Ingham     ProcessSP process_sp(GetSP());
105d7b30ef9SJim Ingham     if (process_sp)
106d7b30ef9SJim Ingham     {
10757abc5d6SGreg Clayton         return process_sp->GetPluginName().GetCString();
108d7b30ef9SJim Ingham     }
109d7b30ef9SJim Ingham     return "<Unknown>";
110d7b30ef9SJim Ingham }
111d7b30ef9SJim Ingham 
112d7b30ef9SJim Ingham 
113b9556accSGreg Clayton lldb::ProcessSP
114b9556accSGreg Clayton SBProcess::GetSP() const
115b9556accSGreg Clayton {
1164e0fe8abSGreg Clayton     return m_opaque_wp.lock();
117b9556accSGreg Clayton }
118b9556accSGreg Clayton 
11930fdc8d8SChris Lattner void
120b9556accSGreg Clayton SBProcess::SetSP (const ProcessSP &process_sp)
12130fdc8d8SChris Lattner {
1224e0fe8abSGreg Clayton     m_opaque_wp = process_sp;
12330fdc8d8SChris Lattner }
12430fdc8d8SChris Lattner 
12530fdc8d8SChris Lattner void
12630fdc8d8SChris Lattner SBProcess::Clear ()
12730fdc8d8SChris Lattner {
1284e0fe8abSGreg Clayton     m_opaque_wp.reset();
12930fdc8d8SChris Lattner }
13030fdc8d8SChris Lattner 
13130fdc8d8SChris Lattner 
13230fdc8d8SChris Lattner bool
13330fdc8d8SChris Lattner SBProcess::IsValid() const
13430fdc8d8SChris Lattner {
1354fc6cb9cSJim Ingham     ProcessSP process_sp(m_opaque_wp.lock());
1364fc6cb9cSJim Ingham     return ((bool) process_sp && process_sp->IsValid());
13730fdc8d8SChris Lattner }
13830fdc8d8SChris Lattner 
1399631aae2SJames McIlree bool
1409631aae2SJames McIlree SBProcess::RemoteLaunch (char const **argv,
1419631aae2SJames McIlree                          char const **envp,
1429631aae2SJames McIlree                          const char *stdin_path,
1439631aae2SJames McIlree                          const char *stdout_path,
1449631aae2SJames McIlree                          const char *stderr_path,
1459631aae2SJames McIlree                          const char *working_directory,
1469631aae2SJames McIlree                          uint32_t launch_flags,
1479631aae2SJames McIlree                          bool stop_at_entry,
1489631aae2SJames McIlree                          lldb::SBError& error)
1499631aae2SJames McIlree {
1505160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1519631aae2SJames McIlree     if (log) {
1529631aae2SJames McIlree         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))...",
1534e0fe8abSGreg Clayton                      m_opaque_wp.lock().get(),
1549631aae2SJames McIlree                      argv,
1559631aae2SJames McIlree                      envp,
1569631aae2SJames McIlree                      stdin_path ? stdin_path : "NULL",
1579631aae2SJames McIlree                      stdout_path ? stdout_path : "NULL",
1589631aae2SJames McIlree                      stderr_path ? stderr_path : "NULL",
1599631aae2SJames McIlree                      working_directory ? working_directory : "NULL",
1609631aae2SJames McIlree                      launch_flags,
1619631aae2SJames McIlree                      stop_at_entry,
1629631aae2SJames McIlree                      error.get());
1639631aae2SJames McIlree     }
1649631aae2SJames McIlree 
165acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
166acdbe816SGreg Clayton     if (process_sp)
1679631aae2SJames McIlree     {
168acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
169acdbe816SGreg Clayton         if (process_sp->GetState() == eStateConnected)
1709631aae2SJames McIlree         {
171982c9762SGreg Clayton             if (stop_at_entry)
172982c9762SGreg Clayton                 launch_flags |= eLaunchFlagStopAtEntry;
173982c9762SGreg Clayton             ProcessLaunchInfo launch_info (stdin_path,
174982c9762SGreg Clayton                                            stdout_path,
175982c9762SGreg Clayton                                            stderr_path,
176982c9762SGreg Clayton                                            working_directory,
177982c9762SGreg Clayton                                            launch_flags);
178acdbe816SGreg Clayton             Module *exe_module = process_sp->GetTarget().GetExecutableModulePointer();
179982c9762SGreg Clayton             if (exe_module)
18014715c68SGreg Clayton                 launch_info.SetExecutableFile(exe_module->GetPlatformFileSpec(), true);
181982c9762SGreg Clayton             if (argv)
182982c9762SGreg Clayton                 launch_info.GetArguments().AppendArguments (argv);
183982c9762SGreg Clayton             if (envp)
184982c9762SGreg Clayton                 launch_info.GetEnvironmentEntries ().SetArguments (envp);
185acdbe816SGreg Clayton             error.SetError (process_sp->Launch (launch_info));
1869631aae2SJames McIlree         }
1879631aae2SJames McIlree         else
1889631aae2SJames McIlree         {
1899631aae2SJames McIlree             error.SetErrorString ("must be in eStateConnected to call RemoteLaunch");
1909631aae2SJames McIlree         }
1919631aae2SJames McIlree     }
1929631aae2SJames McIlree     else
1939631aae2SJames McIlree     {
1949631aae2SJames McIlree         error.SetErrorString ("unable to attach pid");
1959631aae2SJames McIlree     }
1969631aae2SJames McIlree 
1979631aae2SJames McIlree     if (log) {
1989631aae2SJames McIlree         SBStream sstr;
1999631aae2SJames McIlree         error.GetDescription (sstr);
200acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::RemoteLaunch (...) => SBError (%p): %s", process_sp.get(), error.get(), sstr.GetData());
2019631aae2SJames McIlree     }
2029631aae2SJames McIlree 
2039631aae2SJames McIlree     return error.Success();
2049631aae2SJames McIlree }
2059631aae2SJames McIlree 
2069631aae2SJames McIlree bool
2079631aae2SJames McIlree SBProcess::RemoteAttachToProcessWithID (lldb::pid_t pid, lldb::SBError& error)
2089631aae2SJames McIlree {
209acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
210acdbe816SGreg Clayton     if (process_sp)
2119631aae2SJames McIlree     {
212acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
213acdbe816SGreg Clayton         if (process_sp->GetState() == eStateConnected)
2149631aae2SJames McIlree         {
215144f3a9cSGreg Clayton             ProcessAttachInfo attach_info;
216144f3a9cSGreg Clayton             attach_info.SetProcessID (pid);
217acdbe816SGreg Clayton             error.SetError (process_sp->Attach (attach_info));
2189631aae2SJames McIlree         }
2199631aae2SJames McIlree         else
2209631aae2SJames McIlree         {
2219631aae2SJames McIlree             error.SetErrorString ("must be in eStateConnected to call RemoteAttachToProcessWithID");
2229631aae2SJames McIlree         }
2239631aae2SJames McIlree     }
2249631aae2SJames McIlree     else
2259631aae2SJames McIlree     {
2269631aae2SJames McIlree         error.SetErrorString ("unable to attach pid");
2279631aae2SJames McIlree     }
2289631aae2SJames McIlree 
2295160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
2309631aae2SJames McIlree     if (log) {
2319631aae2SJames McIlree         SBStream sstr;
2329631aae2SJames McIlree         error.GetDescription (sstr);
233d01b2953SDaniel Malea         log->Printf ("SBProcess(%p)::RemoteAttachToProcessWithID (%" PRIu64 ") => SBError (%p): %s", process_sp.get(), pid, error.get(), sstr.GetData());
2349631aae2SJames McIlree     }
2359631aae2SJames McIlree 
2369631aae2SJames McIlree     return error.Success();
2379631aae2SJames McIlree }
2389631aae2SJames McIlree 
23930fdc8d8SChris Lattner 
24030fdc8d8SChris Lattner uint32_t
24130fdc8d8SChris Lattner SBProcess::GetNumThreads ()
24230fdc8d8SChris Lattner {
2435160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
244ceb6b139SCaroline Tice 
245ceb6b139SCaroline Tice     uint32_t num_threads = 0;
246acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
247acdbe816SGreg Clayton     if (process_sp)
24830fdc8d8SChris Lattner     {
2497fdf9ef1SGreg Clayton         Process::StopLocker stop_locker;
2507fdf9ef1SGreg Clayton 
2517fdf9ef1SGreg Clayton         const bool can_update = stop_locker.TryLock(&process_sp->GetRunLock());
252acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
253acdbe816SGreg Clayton         num_threads = process_sp->GetThreadList().GetSize(can_update);
25430fdc8d8SChris Lattner     }
255ceb6b139SCaroline Tice 
256ceb6b139SCaroline Tice     if (log)
257acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::GetNumThreads () => %d", process_sp.get(), num_threads);
258ceb6b139SCaroline Tice 
259ceb6b139SCaroline Tice     return num_threads;
26030fdc8d8SChris Lattner }
26130fdc8d8SChris Lattner 
26230fdc8d8SChris Lattner SBThread
2632976d00aSJim Ingham SBProcess::GetSelectedThread () const
26430fdc8d8SChris Lattner {
2655160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
266ceb6b139SCaroline Tice 
26730fdc8d8SChris Lattner     SBThread sb_thread;
26817a6ad05SGreg Clayton     ThreadSP thread_sp;
269acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
270acdbe816SGreg Clayton     if (process_sp)
271af67cecdSGreg Clayton     {
272acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
273acdbe816SGreg Clayton         thread_sp = process_sp->GetThreadList().GetSelectedThread();
27417a6ad05SGreg Clayton         sb_thread.SetThread (thread_sp);
275af67cecdSGreg Clayton     }
276ceb6b139SCaroline Tice 
277ceb6b139SCaroline Tice     if (log)
278ceb6b139SCaroline Tice     {
279acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::GetSelectedThread () => SBThread(%p)", process_sp.get(), thread_sp.get());
280ceb6b139SCaroline Tice     }
281ceb6b139SCaroline Tice 
28230fdc8d8SChris Lattner     return sb_thread;
28330fdc8d8SChris Lattner }
28430fdc8d8SChris Lattner 
285a4d8747dSGreg Clayton SBThread
286a4d8747dSGreg Clayton SBProcess::CreateOSPluginThread (lldb::tid_t tid, lldb::addr_t context)
287a4d8747dSGreg Clayton {
2885160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
289a4d8747dSGreg Clayton 
290a4d8747dSGreg Clayton     SBThread sb_thread;
291a4d8747dSGreg Clayton     ThreadSP thread_sp;
292a4d8747dSGreg Clayton     ProcessSP process_sp(GetSP());
293a4d8747dSGreg Clayton     if (process_sp)
294a4d8747dSGreg Clayton     {
295a4d8747dSGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
296a4d8747dSGreg Clayton         thread_sp = process_sp->CreateOSPluginThread(tid, context);
297a4d8747dSGreg Clayton         sb_thread.SetThread (thread_sp);
298a4d8747dSGreg Clayton     }
299a4d8747dSGreg Clayton 
300a4d8747dSGreg Clayton     if (log)
301a4d8747dSGreg Clayton         log->Printf ("SBProcess(%p)::CreateOSPluginThread (tid=0x%" PRIx64 ", context=0x%" PRIx64 ") => SBThread(%p)", process_sp.get(), tid, context, thread_sp.get());
302a4d8747dSGreg Clayton 
303a4d8747dSGreg Clayton     return sb_thread;
304a4d8747dSGreg Clayton }
305a4d8747dSGreg Clayton 
30630fdc8d8SChris Lattner SBTarget
30730fdc8d8SChris Lattner SBProcess::GetTarget() const
30830fdc8d8SChris Lattner {
3095160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
310ceb6b139SCaroline Tice 
31130fdc8d8SChris Lattner     SBTarget sb_target;
312b9556accSGreg Clayton     TargetSP target_sp;
313acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
314acdbe816SGreg Clayton     if (process_sp)
315b9556accSGreg Clayton     {
316acdbe816SGreg Clayton         target_sp = process_sp->GetTarget().shared_from_this();
317b9556accSGreg Clayton         sb_target.SetSP (target_sp);
318b9556accSGreg Clayton     }
319ceb6b139SCaroline Tice 
320ceb6b139SCaroline Tice     if (log)
321acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::GetTarget () => SBTarget(%p)", process_sp.get(), target_sp.get());
322ceb6b139SCaroline Tice 
32330fdc8d8SChris Lattner     return sb_target;
32430fdc8d8SChris Lattner }
32530fdc8d8SChris Lattner 
32630fdc8d8SChris Lattner 
32730fdc8d8SChris Lattner size_t
32830fdc8d8SChris Lattner SBProcess::PutSTDIN (const char *src, size_t src_len)
32930fdc8d8SChris Lattner {
3305160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
331ceb6b139SCaroline Tice 
332ceb6b139SCaroline Tice     size_t ret_val = 0;
333acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
334acdbe816SGreg Clayton     if (process_sp)
33530fdc8d8SChris Lattner     {
33630fdc8d8SChris Lattner         Error error;
337acdbe816SGreg Clayton         ret_val =  process_sp->PutSTDIN (src, src_len, error);
33830fdc8d8SChris Lattner     }
339ceb6b139SCaroline Tice 
340ceb6b139SCaroline Tice     if (log)
341779f9213SSylvestre Ledru         log->Printf ("SBProcess(%p)::PutSTDIN (src=\"%s\", src_len=%d) => %zu",
342acdbe816SGreg Clayton                      process_sp.get(),
34393aa84e8SGreg Clayton                      src,
34493aa84e8SGreg Clayton                      (uint32_t) src_len,
34593aa84e8SGreg Clayton                      ret_val);
346ceb6b139SCaroline Tice 
347ceb6b139SCaroline Tice     return ret_val;
34830fdc8d8SChris Lattner }
34930fdc8d8SChris Lattner 
35030fdc8d8SChris Lattner size_t
35130fdc8d8SChris Lattner SBProcess::GetSTDOUT (char *dst, size_t dst_len) const
35230fdc8d8SChris Lattner {
353cfd1acedSGreg Clayton     size_t bytes_read = 0;
354acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
355acdbe816SGreg Clayton     if (process_sp)
35630fdc8d8SChris Lattner     {
35730fdc8d8SChris Lattner         Error error;
358acdbe816SGreg Clayton         bytes_read = process_sp->GetSTDOUT (dst, dst_len, error);
35930fdc8d8SChris Lattner     }
360ceb6b139SCaroline Tice 
3615160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
362ceb6b139SCaroline Tice     if (log)
363d01b2953SDaniel Malea         log->Printf ("SBProcess(%p)::GetSTDOUT (dst=\"%.*s\", dst_len=%" PRIu64 ") => %" PRIu64,
36443e0af06SGreg Clayton                      process_sp.get(),
36543e0af06SGreg Clayton                      (int) bytes_read,
36643e0af06SGreg Clayton                      dst,
36743e0af06SGreg Clayton                      (uint64_t)dst_len,
36843e0af06SGreg Clayton                      (uint64_t)bytes_read);
369ceb6b139SCaroline Tice 
370cfd1acedSGreg Clayton     return bytes_read;
37130fdc8d8SChris Lattner }
37230fdc8d8SChris Lattner 
37330fdc8d8SChris Lattner size_t
37430fdc8d8SChris Lattner SBProcess::GetSTDERR (char *dst, size_t dst_len) const
37530fdc8d8SChris Lattner {
376cfd1acedSGreg Clayton     size_t bytes_read = 0;
377acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
378acdbe816SGreg Clayton     if (process_sp)
37930fdc8d8SChris Lattner     {
38030fdc8d8SChris Lattner         Error error;
381acdbe816SGreg Clayton         bytes_read = process_sp->GetSTDERR (dst, dst_len, error);
38230fdc8d8SChris Lattner     }
383ceb6b139SCaroline Tice 
3845160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
385ceb6b139SCaroline Tice     if (log)
386d01b2953SDaniel Malea         log->Printf ("SBProcess(%p)::GetSTDERR (dst=\"%.*s\", dst_len=%" PRIu64 ") => %" PRIu64,
38743e0af06SGreg Clayton                      process_sp.get(),
38843e0af06SGreg Clayton                      (int) bytes_read,
38943e0af06SGreg Clayton                      dst,
39043e0af06SGreg Clayton                      (uint64_t)dst_len,
39143e0af06SGreg Clayton                      (uint64_t)bytes_read);
392ceb6b139SCaroline Tice 
393cfd1acedSGreg Clayton     return bytes_read;
39430fdc8d8SChris Lattner }
39530fdc8d8SChris Lattner 
396ab3b8b22SHan Ming Ong size_t
397ab3b8b22SHan Ming Ong SBProcess::GetAsyncProfileData(char *dst, size_t dst_len) const
398ab3b8b22SHan Ming Ong {
399ab3b8b22SHan Ming Ong     size_t bytes_read = 0;
400ab3b8b22SHan Ming Ong     ProcessSP process_sp(GetSP());
401ab3b8b22SHan Ming Ong     if (process_sp)
402ab3b8b22SHan Ming Ong     {
403ab3b8b22SHan Ming Ong         Error error;
404ab3b8b22SHan Ming Ong         bytes_read = process_sp->GetAsyncProfileData (dst, dst_len, error);
405ab3b8b22SHan Ming Ong     }
406ab3b8b22SHan Ming Ong 
4075160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
408ab3b8b22SHan Ming Ong     if (log)
409d01b2953SDaniel Malea         log->Printf ("SBProcess(%p)::GetProfileData (dst=\"%.*s\", dst_len=%" PRIu64 ") => %" PRIu64,
410ab3b8b22SHan Ming Ong                      process_sp.get(),
411ab3b8b22SHan Ming Ong                      (int) bytes_read,
412ab3b8b22SHan Ming Ong                      dst,
413ab3b8b22SHan Ming Ong                      (uint64_t)dst_len,
414ab3b8b22SHan Ming Ong                      (uint64_t)bytes_read);
415ab3b8b22SHan Ming Ong 
416ab3b8b22SHan Ming Ong     return bytes_read;
417ab3b8b22SHan Ming Ong }
418ab3b8b22SHan Ming Ong 
41930fdc8d8SChris Lattner void
4202976d00aSJim Ingham SBProcess::ReportEventState (const SBEvent &event, FILE *out) const
42130fdc8d8SChris Lattner {
42230fdc8d8SChris Lattner     if (out == NULL)
42330fdc8d8SChris Lattner         return;
42430fdc8d8SChris Lattner 
425acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
426acdbe816SGreg Clayton     if (process_sp)
42730fdc8d8SChris Lattner     {
42830fdc8d8SChris Lattner         const StateType event_state = SBProcess::GetStateFromEvent (event);
42930fdc8d8SChris Lattner         char message[1024];
43030fdc8d8SChris Lattner         int message_len = ::snprintf (message,
43130fdc8d8SChris Lattner                                       sizeof (message),
432d01b2953SDaniel Malea                                       "Process %" PRIu64 " %s\n",
433acdbe816SGreg Clayton                                       process_sp->GetID(),
43430fdc8d8SChris Lattner                                       SBDebugger::StateAsCString (event_state));
43530fdc8d8SChris Lattner 
43630fdc8d8SChris Lattner         if (message_len > 0)
43730fdc8d8SChris Lattner             ::fwrite (message, 1, message_len, out);
43830fdc8d8SChris Lattner     }
43930fdc8d8SChris Lattner }
44030fdc8d8SChris Lattner 
44130fdc8d8SChris Lattner void
4422976d00aSJim Ingham SBProcess::AppendEventStateReport (const SBEvent &event, SBCommandReturnObject &result)
44330fdc8d8SChris Lattner {
444acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
445acdbe816SGreg Clayton     if (process_sp)
44630fdc8d8SChris Lattner     {
44730fdc8d8SChris Lattner         const StateType event_state = SBProcess::GetStateFromEvent (event);
44830fdc8d8SChris Lattner         char message[1024];
44930fdc8d8SChris Lattner         ::snprintf (message,
45030fdc8d8SChris Lattner                     sizeof (message),
451d01b2953SDaniel Malea                     "Process %" PRIu64 " %s\n",
452acdbe816SGreg Clayton                     process_sp->GetID(),
45330fdc8d8SChris Lattner                     SBDebugger::StateAsCString (event_state));
45430fdc8d8SChris Lattner 
45530fdc8d8SChris Lattner         result.AppendMessage (message);
45630fdc8d8SChris Lattner     }
45730fdc8d8SChris Lattner }
45830fdc8d8SChris Lattner 
45930fdc8d8SChris Lattner bool
4602976d00aSJim Ingham SBProcess::SetSelectedThread (const SBThread &thread)
46130fdc8d8SChris Lattner {
462acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
463acdbe816SGreg Clayton     if (process_sp)
464af67cecdSGreg Clayton     {
465acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
466acdbe816SGreg Clayton         return process_sp->GetThreadList().SetSelectedThreadByID (thread.GetThreadID());
467af67cecdSGreg Clayton     }
46830fdc8d8SChris Lattner     return false;
46930fdc8d8SChris Lattner }
47030fdc8d8SChris Lattner 
47130fdc8d8SChris Lattner bool
472ea561dcfSGreg Clayton SBProcess::SetSelectedThreadByID (lldb::tid_t tid)
473ea561dcfSGreg Clayton {
4745160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
475ceb6b139SCaroline Tice 
476ceb6b139SCaroline Tice     bool ret_val = false;
477acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
478acdbe816SGreg Clayton     if (process_sp)
479af67cecdSGreg Clayton     {
480acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
481acdbe816SGreg Clayton         ret_val = process_sp->GetThreadList().SetSelectedThreadByID (tid);
482af67cecdSGreg Clayton     }
483ceb6b139SCaroline Tice 
484ceb6b139SCaroline Tice     if (log)
485d01b2953SDaniel Malea         log->Printf ("SBProcess(%p)::SetSelectedThreadByID (tid=0x%4.4" PRIx64 ") => %s",
486acdbe816SGreg Clayton                      process_sp.get(), tid, (ret_val ? "true" : "false"));
487ceb6b139SCaroline Tice 
488ceb6b139SCaroline Tice     return ret_val;
48930fdc8d8SChris Lattner }
49030fdc8d8SChris Lattner 
49118b46896SJim Ingham bool
49218b46896SJim Ingham SBProcess::SetSelectedThreadByIndexID (uint32_t index_id)
49318b46896SJim Ingham {
4945160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
49518b46896SJim Ingham 
49618b46896SJim Ingham     bool ret_val = false;
49718b46896SJim Ingham     ProcessSP process_sp(GetSP());
49818b46896SJim Ingham     if (process_sp)
49918b46896SJim Ingham     {
50018b46896SJim Ingham         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
50118b46896SJim Ingham         ret_val = process_sp->GetThreadList().SetSelectedThreadByIndexID (index_id);
50218b46896SJim Ingham     }
50318b46896SJim Ingham 
50418b46896SJim Ingham     if (log)
50518b46896SJim Ingham         log->Printf ("SBProcess(%p)::SetSelectedThreadByID (tid=0x%x) => %s",
50618b46896SJim Ingham                      process_sp.get(), index_id, (ret_val ? "true" : "false"));
50718b46896SJim Ingham 
50818b46896SJim Ingham     return ret_val;
50918b46896SJim Ingham }
51018b46896SJim Ingham 
51130fdc8d8SChris Lattner SBThread
51230fdc8d8SChris Lattner SBProcess::GetThreadAtIndex (size_t index)
51330fdc8d8SChris Lattner {
5145160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
515ceb6b139SCaroline Tice 
51617a6ad05SGreg Clayton     SBThread sb_thread;
51717a6ad05SGreg Clayton     ThreadSP thread_sp;
518acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
519acdbe816SGreg Clayton     if (process_sp)
520af67cecdSGreg Clayton     {
5217fdf9ef1SGreg Clayton         Process::StopLocker stop_locker;
5227fdf9ef1SGreg Clayton         const bool can_update = stop_locker.TryLock(&process_sp->GetRunLock());
523acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
5247fdf9ef1SGreg Clayton         thread_sp = process_sp->GetThreadList().GetThreadAtIndex(index, can_update);
52517a6ad05SGreg Clayton         sb_thread.SetThread (thread_sp);
526af67cecdSGreg Clayton     }
527ceb6b139SCaroline Tice 
528ceb6b139SCaroline Tice     if (log)
529ceb6b139SCaroline Tice     {
53093aa84e8SGreg Clayton         log->Printf ("SBProcess(%p)::GetThreadAtIndex (index=%d) => SBThread(%p)",
531acdbe816SGreg Clayton                      process_sp.get(), (uint32_t) index, thread_sp.get());
532ceb6b139SCaroline Tice     }
533ceb6b139SCaroline Tice 
53417a6ad05SGreg Clayton     return sb_thread;
53530fdc8d8SChris Lattner }
53630fdc8d8SChris Lattner 
537bf2956a2SJim Ingham uint32_t
538bf2956a2SJim Ingham SBProcess::GetStopID(bool include_expression_stops)
539bf2956a2SJim Ingham {
540bf2956a2SJim Ingham     ProcessSP process_sp(GetSP());
541bf2956a2SJim Ingham     if (process_sp)
542bf2956a2SJim Ingham     {
543bf2956a2SJim Ingham         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
544bf2956a2SJim Ingham         if (include_expression_stops)
545bf2956a2SJim Ingham             return process_sp->GetStopID();
546bf2956a2SJim Ingham         else
547bf2956a2SJim Ingham             return process_sp->GetLastNaturalStopID();
548bf2956a2SJim Ingham     }
549bf2956a2SJim Ingham     return 0;
550bf2956a2SJim Ingham }
551bf2956a2SJim Ingham 
55230fdc8d8SChris Lattner StateType
55330fdc8d8SChris Lattner SBProcess::GetState ()
55430fdc8d8SChris Lattner {
555ceb6b139SCaroline Tice 
556ceb6b139SCaroline Tice     StateType ret_val = eStateInvalid;
557acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
558acdbe816SGreg Clayton     if (process_sp)
559af67cecdSGreg Clayton     {
560acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
561acdbe816SGreg Clayton         ret_val = process_sp->GetState();
562af67cecdSGreg Clayton     }
563ceb6b139SCaroline Tice 
5645160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
565ceb6b139SCaroline Tice     if (log)
566cfd1acedSGreg Clayton         log->Printf ("SBProcess(%p)::GetState () => %s",
567acdbe816SGreg Clayton                      process_sp.get(),
568750cd175SCaroline Tice                      lldb_private::StateAsCString (ret_val));
569ceb6b139SCaroline Tice 
570ceb6b139SCaroline Tice     return ret_val;
57130fdc8d8SChris Lattner }
57230fdc8d8SChris Lattner 
57330fdc8d8SChris Lattner 
57430fdc8d8SChris Lattner int
57530fdc8d8SChris Lattner SBProcess::GetExitStatus ()
57630fdc8d8SChris Lattner {
5774838131bSGreg Clayton     int exit_status = 0;
578acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
579acdbe816SGreg Clayton     if (process_sp)
580af67cecdSGreg Clayton     {
581acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
582acdbe816SGreg Clayton         exit_status = process_sp->GetExitStatus ();
583af67cecdSGreg Clayton     }
5845160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
5854838131bSGreg Clayton     if (log)
5864838131bSGreg Clayton         log->Printf ("SBProcess(%p)::GetExitStatus () => %i (0x%8.8x)",
587acdbe816SGreg Clayton                      process_sp.get(), exit_status, exit_status);
5884838131bSGreg Clayton 
5894838131bSGreg Clayton     return exit_status;
59030fdc8d8SChris Lattner }
59130fdc8d8SChris Lattner 
59230fdc8d8SChris Lattner const char *
59330fdc8d8SChris Lattner SBProcess::GetExitDescription ()
59430fdc8d8SChris Lattner {
5954838131bSGreg Clayton     const char *exit_desc = NULL;
596acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
597acdbe816SGreg Clayton     if (process_sp)
598af67cecdSGreg Clayton     {
599acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
600acdbe816SGreg Clayton         exit_desc = process_sp->GetExitDescription ();
601af67cecdSGreg Clayton     }
6025160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
6034838131bSGreg Clayton     if (log)
6044838131bSGreg Clayton         log->Printf ("SBProcess(%p)::GetExitDescription () => %s",
605acdbe816SGreg Clayton                      process_sp.get(), exit_desc);
6064838131bSGreg Clayton     return exit_desc;
60730fdc8d8SChris Lattner }
60830fdc8d8SChris Lattner 
60930fdc8d8SChris Lattner lldb::pid_t
61030fdc8d8SChris Lattner SBProcess::GetProcessID ()
61130fdc8d8SChris Lattner {
612ceb6b139SCaroline Tice     lldb::pid_t ret_val = LLDB_INVALID_PROCESS_ID;
613acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
614acdbe816SGreg Clayton     if (process_sp)
615acdbe816SGreg Clayton         ret_val = process_sp->GetID();
616ceb6b139SCaroline Tice 
6175160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
618ceb6b139SCaroline Tice     if (log)
619d01b2953SDaniel Malea         log->Printf ("SBProcess(%p)::GetProcessID () => %" PRIu64, process_sp.get(), ret_val);
620ceb6b139SCaroline Tice 
621ceb6b139SCaroline Tice     return ret_val;
62230fdc8d8SChris Lattner }
62330fdc8d8SChris Lattner 
624949e8221SGreg Clayton uint32_t
625949e8221SGreg Clayton SBProcess::GetUniqueID()
626949e8221SGreg Clayton {
627949e8221SGreg Clayton     uint32_t ret_val = 0;
628949e8221SGreg Clayton     ProcessSP process_sp(GetSP());
629949e8221SGreg Clayton     if (process_sp)
630949e8221SGreg Clayton         ret_val = process_sp->GetUniqueID();
6315160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
632949e8221SGreg Clayton     if (log)
633949e8221SGreg Clayton         log->Printf ("SBProcess(%p)::GetUniqueID () => %" PRIu32, process_sp.get(), ret_val);
634949e8221SGreg Clayton     return ret_val;
635949e8221SGreg Clayton }
636949e8221SGreg Clayton 
637cf386e24SJohnny Chen ByteOrder
638cf386e24SJohnny Chen SBProcess::GetByteOrder () const
639cf386e24SJohnny Chen {
640cf386e24SJohnny Chen     ByteOrder byteOrder = eByteOrderInvalid;
641acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
642acdbe816SGreg Clayton     if (process_sp)
643acdbe816SGreg Clayton         byteOrder = process_sp->GetTarget().GetArchitecture().GetByteOrder();
644cf386e24SJohnny Chen 
6455160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
646cf386e24SJohnny Chen     if (log)
647acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::GetByteOrder () => %d", process_sp.get(), byteOrder);
648cf386e24SJohnny Chen 
649cf386e24SJohnny Chen     return byteOrder;
650cf386e24SJohnny Chen }
651cf386e24SJohnny Chen 
65230fdc8d8SChris Lattner uint32_t
65330fdc8d8SChris Lattner SBProcess::GetAddressByteSize () const
65430fdc8d8SChris Lattner {
655ceb6b139SCaroline Tice     uint32_t size = 0;
656acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
657acdbe816SGreg Clayton     if (process_sp)
658acdbe816SGreg Clayton         size =  process_sp->GetTarget().GetArchitecture().GetAddressByteSize();
659ceb6b139SCaroline Tice 
6605160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
661ceb6b139SCaroline Tice     if (log)
662acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::GetAddressByteSize () => %d", process_sp.get(), size);
663ceb6b139SCaroline Tice 
664ceb6b139SCaroline Tice     return size;
66530fdc8d8SChris Lattner }
66630fdc8d8SChris Lattner 
66730fdc8d8SChris Lattner SBError
66830fdc8d8SChris Lattner SBProcess::Continue ()
66930fdc8d8SChris Lattner {
6705160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
671ceb6b139SCaroline Tice 
67230fdc8d8SChris Lattner     SBError sb_error;
673acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
6740c74e78dSGreg Clayton 
675acdbe816SGreg Clayton     if (log)
676acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::Continue ()...", process_sp.get());
677acdbe816SGreg Clayton 
678acdbe816SGreg Clayton     if (process_sp)
679acdbe816SGreg Clayton     {
680acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
681acdbe816SGreg Clayton 
682acdbe816SGreg Clayton         Error error (process_sp->Resume());
6835d5028b5SGreg Clayton         if (error.Success())
6845d5028b5SGreg Clayton         {
685acdbe816SGreg Clayton             if (process_sp->GetTarget().GetDebugger().GetAsyncExecution () == false)
6864838131bSGreg Clayton             {
6874838131bSGreg Clayton                 if (log)
688acdbe816SGreg Clayton                     log->Printf ("SBProcess(%p)::Continue () waiting for process to stop...", process_sp.get());
689acdbe816SGreg Clayton                 process_sp->WaitForProcessToStop (NULL);
6905d5028b5SGreg Clayton             }
6914838131bSGreg Clayton         }
6925d5028b5SGreg Clayton         sb_error.SetError(error);
6935d5028b5SGreg Clayton     }
69430fdc8d8SChris Lattner     else
69530fdc8d8SChris Lattner         sb_error.SetErrorString ("SBProcess is invalid");
69630fdc8d8SChris Lattner 
697ceb6b139SCaroline Tice     if (log)
698ceb6b139SCaroline Tice     {
699ceb6b139SCaroline Tice         SBStream sstr;
700ceb6b139SCaroline Tice         sb_error.GetDescription (sstr);
701acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::Continue () => SBError (%p): %s", process_sp.get(), sb_error.get(), sstr.GetData());
702ceb6b139SCaroline Tice     }
703ceb6b139SCaroline Tice 
70430fdc8d8SChris Lattner     return sb_error;
70530fdc8d8SChris Lattner }
70630fdc8d8SChris Lattner 
70730fdc8d8SChris Lattner 
70830fdc8d8SChris Lattner SBError
70930fdc8d8SChris Lattner SBProcess::Destroy ()
71030fdc8d8SChris Lattner {
71130fdc8d8SChris Lattner     SBError sb_error;
712acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
713acdbe816SGreg Clayton     if (process_sp)
7146779606aSGreg Clayton     {
715acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
716acdbe816SGreg Clayton         sb_error.SetError(process_sp->Destroy());
7176779606aSGreg Clayton     }
71830fdc8d8SChris Lattner     else
71930fdc8d8SChris Lattner         sb_error.SetErrorString ("SBProcess is invalid");
72030fdc8d8SChris Lattner 
7215160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
7224838131bSGreg Clayton     if (log)
7234838131bSGreg Clayton     {
7244838131bSGreg Clayton         SBStream sstr;
7254838131bSGreg Clayton         sb_error.GetDescription (sstr);
7266779606aSGreg Clayton         log->Printf ("SBProcess(%p)::Destroy () => SBError (%p): %s",
727acdbe816SGreg Clayton                      process_sp.get(),
7286779606aSGreg Clayton                      sb_error.get(),
7296779606aSGreg Clayton                      sstr.GetData());
7304838131bSGreg Clayton     }
7314838131bSGreg Clayton 
73230fdc8d8SChris Lattner     return sb_error;
73330fdc8d8SChris Lattner }
73430fdc8d8SChris Lattner 
73530fdc8d8SChris Lattner 
73630fdc8d8SChris Lattner SBError
73730fdc8d8SChris Lattner SBProcess::Stop ()
73830fdc8d8SChris Lattner {
73930fdc8d8SChris Lattner     SBError sb_error;
740acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
741acdbe816SGreg Clayton     if (process_sp)
742af67cecdSGreg Clayton     {
743acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
744acdbe816SGreg Clayton         sb_error.SetError (process_sp->Halt());
745af67cecdSGreg Clayton     }
74630fdc8d8SChris Lattner     else
74730fdc8d8SChris Lattner         sb_error.SetErrorString ("SBProcess is invalid");
748ceb6b139SCaroline Tice 
7495160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
750ceb6b139SCaroline Tice     if (log)
751ceb6b139SCaroline Tice     {
752ceb6b139SCaroline Tice         SBStream sstr;
753ceb6b139SCaroline Tice         sb_error.GetDescription (sstr);
75493aa84e8SGreg Clayton         log->Printf ("SBProcess(%p)::Stop () => SBError (%p): %s",
755acdbe816SGreg Clayton                      process_sp.get(),
75693aa84e8SGreg Clayton                      sb_error.get(),
757750cd175SCaroline Tice                      sstr.GetData());
758ceb6b139SCaroline Tice     }
759ceb6b139SCaroline Tice 
76030fdc8d8SChris Lattner     return sb_error;
76130fdc8d8SChris Lattner }
76230fdc8d8SChris Lattner 
76330fdc8d8SChris Lattner SBError
76430fdc8d8SChris Lattner SBProcess::Kill ()
76530fdc8d8SChris Lattner {
76630fdc8d8SChris Lattner     SBError sb_error;
767acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
768acdbe816SGreg Clayton     if (process_sp)
769af67cecdSGreg Clayton     {
770acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
771acdbe816SGreg Clayton         sb_error.SetError (process_sp->Destroy());
772af67cecdSGreg Clayton     }
77330fdc8d8SChris Lattner     else
77430fdc8d8SChris Lattner         sb_error.SetErrorString ("SBProcess is invalid");
775ceb6b139SCaroline Tice 
7765160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
777ceb6b139SCaroline Tice     if (log)
778ceb6b139SCaroline Tice     {
779ceb6b139SCaroline Tice         SBStream sstr;
780ceb6b139SCaroline Tice         sb_error.GetDescription (sstr);
78193aa84e8SGreg Clayton         log->Printf ("SBProcess(%p)::Kill () => SBError (%p): %s",
782acdbe816SGreg Clayton                      process_sp.get(),
78393aa84e8SGreg Clayton                      sb_error.get(),
784750cd175SCaroline Tice                      sstr.GetData());
785ceb6b139SCaroline Tice     }
786ceb6b139SCaroline Tice 
78730fdc8d8SChris Lattner     return sb_error;
78830fdc8d8SChris Lattner }
78930fdc8d8SChris Lattner 
79030fdc8d8SChris Lattner SBError
79130fdc8d8SChris Lattner SBProcess::Detach ()
79230fdc8d8SChris Lattner {
793acff8950SJim Ingham     // FIXME: This should come from a process default.
794acff8950SJim Ingham     bool keep_stopped = false;
795acff8950SJim Ingham     return Detach (keep_stopped);
796acff8950SJim Ingham }
797acff8950SJim Ingham 
798acff8950SJim Ingham SBError
799acff8950SJim Ingham SBProcess::Detach (bool keep_stopped)
800acff8950SJim Ingham {
80130fdc8d8SChris Lattner     SBError sb_error;
802acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
803acdbe816SGreg Clayton     if (process_sp)
804af67cecdSGreg Clayton     {
805acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
806acff8950SJim Ingham         sb_error.SetError (process_sp->Detach(keep_stopped));
807af67cecdSGreg Clayton     }
80830fdc8d8SChris Lattner     else
80930fdc8d8SChris Lattner         sb_error.SetErrorString ("SBProcess is invalid");
81030fdc8d8SChris Lattner 
81130fdc8d8SChris Lattner     return sb_error;
81230fdc8d8SChris Lattner }
81330fdc8d8SChris Lattner 
81430fdc8d8SChris Lattner SBError
8154838131bSGreg Clayton SBProcess::Signal (int signo)
81630fdc8d8SChris Lattner {
81730fdc8d8SChris Lattner     SBError sb_error;
818acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
819acdbe816SGreg Clayton     if (process_sp)
820af67cecdSGreg Clayton     {
821acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
822acdbe816SGreg Clayton         sb_error.SetError (process_sp->Signal (signo));
823af67cecdSGreg Clayton     }
82430fdc8d8SChris Lattner     else
82530fdc8d8SChris Lattner         sb_error.SetErrorString ("SBProcess is invalid");
8265160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
8274838131bSGreg Clayton     if (log)
8284838131bSGreg Clayton     {
8294838131bSGreg Clayton         SBStream sstr;
8304838131bSGreg Clayton         sb_error.GetDescription (sstr);
8314838131bSGreg Clayton         log->Printf ("SBProcess(%p)::Signal (signo=%i) => SBError (%p): %s",
832acdbe816SGreg Clayton                      process_sp.get(),
8334838131bSGreg Clayton                      signo,
8344838131bSGreg Clayton                      sb_error.get(),
8354838131bSGreg Clayton                      sstr.GetData());
8364838131bSGreg Clayton     }
83730fdc8d8SChris Lattner     return sb_error;
83830fdc8d8SChris Lattner }
83930fdc8d8SChris Lattner 
840cfc0935eSJim Ingham void
841cfc0935eSJim Ingham SBProcess::SendAsyncInterrupt ()
842cfc0935eSJim Ingham {
843cfc0935eSJim Ingham     ProcessSP process_sp(GetSP());
844cfc0935eSJim Ingham     if (process_sp)
845cfc0935eSJim Ingham     {
846cfc0935eSJim Ingham         process_sp->SendAsyncInterrupt ();
847cfc0935eSJim Ingham     }
848cfc0935eSJim Ingham }
849cfc0935eSJim Ingham 
85030fdc8d8SChris Lattner SBThread
8514838131bSGreg Clayton SBProcess::GetThreadByID (tid_t tid)
85230fdc8d8SChris Lattner {
8534838131bSGreg Clayton     SBThread sb_thread;
85417a6ad05SGreg Clayton     ThreadSP thread_sp;
855acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
856acdbe816SGreg Clayton     if (process_sp)
857af67cecdSGreg Clayton     {
858acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
8597fdf9ef1SGreg Clayton         Process::StopLocker stop_locker;
8607fdf9ef1SGreg Clayton         const bool can_update = stop_locker.TryLock(&process_sp->GetRunLock());
8617fdf9ef1SGreg Clayton         thread_sp = process_sp->GetThreadList().FindThreadByID (tid, can_update);
86217a6ad05SGreg Clayton         sb_thread.SetThread (thread_sp);
863af67cecdSGreg Clayton     }
8644838131bSGreg Clayton 
8655160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
8664838131bSGreg Clayton     if (log)
8674838131bSGreg Clayton     {
868d01b2953SDaniel Malea         log->Printf ("SBProcess(%p)::GetThreadByID (tid=0x%4.4" PRIx64 ") => SBThread (%p)",
869acdbe816SGreg Clayton                      process_sp.get(),
8704838131bSGreg Clayton                      tid,
87117a6ad05SGreg Clayton                      thread_sp.get());
8724838131bSGreg Clayton     }
8734838131bSGreg Clayton 
8744838131bSGreg Clayton     return sb_thread;
87530fdc8d8SChris Lattner }
87630fdc8d8SChris Lattner 
87718b46896SJim Ingham SBThread
87818b46896SJim Ingham SBProcess::GetThreadByIndexID (uint32_t index_id)
87918b46896SJim Ingham {
88018b46896SJim Ingham     SBThread sb_thread;
88118b46896SJim Ingham     ThreadSP thread_sp;
88218b46896SJim Ingham     ProcessSP process_sp(GetSP());
88318b46896SJim Ingham     if (process_sp)
88418b46896SJim Ingham     {
88518b46896SJim Ingham         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
88618b46896SJim Ingham         Process::StopLocker stop_locker;
88718b46896SJim Ingham         const bool can_update = stop_locker.TryLock(&process_sp->GetRunLock());
88818b46896SJim Ingham         thread_sp = process_sp->GetThreadList().FindThreadByIndexID (index_id, can_update);
88918b46896SJim Ingham         sb_thread.SetThread (thread_sp);
89018b46896SJim Ingham     }
89118b46896SJim Ingham 
8925160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
89318b46896SJim Ingham     if (log)
89418b46896SJim Ingham     {
89518b46896SJim Ingham         log->Printf ("SBProcess(%p)::GetThreadByID (tid=0x%x) => SBThread (%p)",
89618b46896SJim Ingham                      process_sp.get(),
89718b46896SJim Ingham                      index_id,
89818b46896SJim Ingham                      thread_sp.get());
89918b46896SJim Ingham     }
90018b46896SJim Ingham 
90118b46896SJim Ingham     return sb_thread;
90218b46896SJim Ingham }
90318b46896SJim Ingham 
90430fdc8d8SChris Lattner StateType
90530fdc8d8SChris Lattner SBProcess::GetStateFromEvent (const SBEvent &event)
90630fdc8d8SChris Lattner {
9075160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
908ceb6b139SCaroline Tice 
909ceb6b139SCaroline Tice     StateType ret_val = Process::ProcessEventData::GetStateFromEvent (event.get());
910ceb6b139SCaroline Tice 
911ceb6b139SCaroline Tice     if (log)
912cfd1acedSGreg Clayton         log->Printf ("SBProcess::GetStateFromEvent (event.sp=%p) => %s", event.get(),
913750cd175SCaroline Tice                      lldb_private::StateAsCString (ret_val));
914ceb6b139SCaroline Tice 
915ceb6b139SCaroline Tice     return ret_val;
91630fdc8d8SChris Lattner }
91730fdc8d8SChris Lattner 
91830fdc8d8SChris Lattner bool
91930fdc8d8SChris Lattner SBProcess::GetRestartedFromEvent (const SBEvent &event)
92030fdc8d8SChris Lattner {
9216611103cSGreg Clayton     return Process::ProcessEventData::GetRestartedFromEvent (event.get());
92230fdc8d8SChris Lattner }
92330fdc8d8SChris Lattner 
9240161b49cSJim Ingham size_t
9250161b49cSJim Ingham SBProcess::GetNumRestartedReasonsFromEvent (const lldb::SBEvent &event)
9260161b49cSJim Ingham {
9270161b49cSJim Ingham     return Process::ProcessEventData::GetNumRestartedReasons(event.get());
9280161b49cSJim Ingham }
9290161b49cSJim Ingham 
9300161b49cSJim Ingham const char *
9310161b49cSJim Ingham SBProcess::GetRestartedReasonAtIndexFromEvent (const lldb::SBEvent &event, size_t idx)
9320161b49cSJim Ingham {
9330161b49cSJim Ingham     return Process::ProcessEventData::GetRestartedReasonAtIndex(event.get(), idx);
9340161b49cSJim Ingham }
9350161b49cSJim Ingham 
93630fdc8d8SChris Lattner SBProcess
93730fdc8d8SChris Lattner SBProcess::GetProcessFromEvent (const SBEvent &event)
93830fdc8d8SChris Lattner {
9396611103cSGreg Clayton     SBProcess process(Process::ProcessEventData::GetProcessFromEvent (event.get()));
94030fdc8d8SChris Lattner     return process;
94130fdc8d8SChris Lattner }
94230fdc8d8SChris Lattner 
943e6bc6cb9SJim Ingham bool
944e6bc6cb9SJim Ingham SBProcess::EventIsProcessEvent (const SBEvent &event)
945e6bc6cb9SJim Ingham {
9464bddaeb5SJim Ingham     return strcmp (event.GetBroadcasterClass(), SBProcess::GetBroadcasterClass()) == 0;
947e6bc6cb9SJim Ingham }
94830fdc8d8SChris Lattner 
94930fdc8d8SChris Lattner SBBroadcaster
95030fdc8d8SChris Lattner SBProcess::GetBroadcaster () const
95130fdc8d8SChris Lattner {
9525160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
953ceb6b139SCaroline Tice 
954acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
955acdbe816SGreg Clayton 
956acdbe816SGreg Clayton     SBBroadcaster broadcaster(process_sp.get(), false);
957ceb6b139SCaroline Tice 
958ceb6b139SCaroline Tice     if (log)
959acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::GetBroadcaster () => SBBroadcaster (%p)",  process_sp.get(),
960750cd175SCaroline Tice                      broadcaster.get());
961ceb6b139SCaroline Tice 
96230fdc8d8SChris Lattner     return broadcaster;
96330fdc8d8SChris Lattner }
96430fdc8d8SChris Lattner 
9654bddaeb5SJim Ingham const char *
9664bddaeb5SJim Ingham SBProcess::GetBroadcasterClass ()
9674bddaeb5SJim Ingham {
9684bddaeb5SJim Ingham     return Process::GetStaticBroadcasterClass().AsCString();
9694bddaeb5SJim Ingham }
9704bddaeb5SJim Ingham 
97130fdc8d8SChris Lattner size_t
97230fdc8d8SChris Lattner SBProcess::ReadMemory (addr_t addr, void *dst, size_t dst_len, SBError &sb_error)
97330fdc8d8SChris Lattner {
9745160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
975ceb6b139SCaroline Tice 
97630fdc8d8SChris Lattner     size_t bytes_read = 0;
97730fdc8d8SChris Lattner 
978acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
979acdbe816SGreg Clayton 
9804838131bSGreg Clayton     if (log)
9814838131bSGreg Clayton     {
982d01b2953SDaniel Malea         log->Printf ("SBProcess(%p)::ReadMemory (addr=0x%" PRIx64 ", dst=%p, dst_len=%" PRIu64 ", SBError (%p))...",
983acdbe816SGreg Clayton                      process_sp.get(),
9844838131bSGreg Clayton                      addr,
9854838131bSGreg Clayton                      dst,
98643e0af06SGreg Clayton                      (uint64_t)dst_len,
9874838131bSGreg Clayton                      sb_error.get());
9884838131bSGreg Clayton     }
9894838131bSGreg Clayton 
990acdbe816SGreg Clayton     if (process_sp)
99130fdc8d8SChris Lattner     {
9927fdf9ef1SGreg Clayton         Process::StopLocker stop_locker;
9937fdf9ef1SGreg Clayton         if (stop_locker.TryLock(&process_sp->GetRunLock()))
9947fdf9ef1SGreg Clayton         {
995acdbe816SGreg Clayton             Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
9967fdf9ef1SGreg Clayton             bytes_read = process_sp->ReadMemory (addr, dst, dst_len, sb_error.ref());
9977fdf9ef1SGreg Clayton         }
9987fdf9ef1SGreg Clayton         else
9997fdf9ef1SGreg Clayton         {
1000c9858e4dSGreg Clayton             if (log)
1001c9858e4dSGreg Clayton                 log->Printf ("SBProcess(%p)::ReadMemory() => error: process is running", process_sp.get());
10027fdf9ef1SGreg Clayton             sb_error.SetErrorString("process is running");
10037fdf9ef1SGreg Clayton         }
100430fdc8d8SChris Lattner     }
100530fdc8d8SChris Lattner     else
100630fdc8d8SChris Lattner     {
100730fdc8d8SChris Lattner         sb_error.SetErrorString ("SBProcess is invalid");
100830fdc8d8SChris Lattner     }
100930fdc8d8SChris Lattner 
1010ceb6b139SCaroline Tice     if (log)
101193aa84e8SGreg Clayton     {
101293aa84e8SGreg Clayton         SBStream sstr;
101393aa84e8SGreg Clayton         sb_error.GetDescription (sstr);
1014d01b2953SDaniel Malea         log->Printf ("SBProcess(%p)::ReadMemory (addr=0x%" PRIx64 ", dst=%p, dst_len=%" PRIu64 ", SBError (%p): %s) => %" PRIu64,
1015acdbe816SGreg Clayton                      process_sp.get(),
101693aa84e8SGreg Clayton                      addr,
101793aa84e8SGreg Clayton                      dst,
101843e0af06SGreg Clayton                      (uint64_t)dst_len,
101993aa84e8SGreg Clayton                      sb_error.get(),
102093aa84e8SGreg Clayton                      sstr.GetData(),
102143e0af06SGreg Clayton                      (uint64_t)bytes_read);
102293aa84e8SGreg Clayton     }
1023ceb6b139SCaroline Tice 
102430fdc8d8SChris Lattner     return bytes_read;
102530fdc8d8SChris Lattner }
102630fdc8d8SChris Lattner 
102730fdc8d8SChris Lattner size_t
1028e91b7957SGreg Clayton SBProcess::ReadCStringFromMemory (addr_t addr, void *buf, size_t size, lldb::SBError &sb_error)
1029e91b7957SGreg Clayton {
1030e91b7957SGreg Clayton     size_t bytes_read = 0;
1031acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
1032acdbe816SGreg Clayton     if (process_sp)
1033e91b7957SGreg Clayton     {
10347fdf9ef1SGreg Clayton         Process::StopLocker stop_locker;
10357fdf9ef1SGreg Clayton         if (stop_locker.TryLock(&process_sp->GetRunLock()))
10367fdf9ef1SGreg Clayton         {
1037acdbe816SGreg Clayton             Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
10387fdf9ef1SGreg Clayton             bytes_read = process_sp->ReadCStringFromMemory (addr, (char *)buf, size, sb_error.ref());
10397fdf9ef1SGreg Clayton         }
10407fdf9ef1SGreg Clayton         else
10417fdf9ef1SGreg Clayton         {
10425160ce5cSGreg Clayton             Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1043c9858e4dSGreg Clayton             if (log)
1044c9858e4dSGreg Clayton                 log->Printf ("SBProcess(%p)::ReadCStringFromMemory() => error: process is running", process_sp.get());
10457fdf9ef1SGreg Clayton             sb_error.SetErrorString("process is running");
10467fdf9ef1SGreg Clayton         }
1047e91b7957SGreg Clayton     }
1048e91b7957SGreg Clayton     else
1049e91b7957SGreg Clayton     {
1050e91b7957SGreg Clayton         sb_error.SetErrorString ("SBProcess is invalid");
1051e91b7957SGreg Clayton     }
1052e91b7957SGreg Clayton     return bytes_read;
1053e91b7957SGreg Clayton }
1054e91b7957SGreg Clayton 
1055e91b7957SGreg Clayton uint64_t
1056e91b7957SGreg Clayton SBProcess::ReadUnsignedFromMemory (addr_t addr, uint32_t byte_size, lldb::SBError &sb_error)
1057e91b7957SGreg Clayton {
10587fdf9ef1SGreg Clayton     uint64_t value = 0;
1059acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
1060acdbe816SGreg Clayton     if (process_sp)
1061e91b7957SGreg Clayton     {
10627fdf9ef1SGreg Clayton         Process::StopLocker stop_locker;
10637fdf9ef1SGreg Clayton         if (stop_locker.TryLock(&process_sp->GetRunLock()))
10647fdf9ef1SGreg Clayton         {
1065acdbe816SGreg Clayton             Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
10667fdf9ef1SGreg Clayton             value = process_sp->ReadUnsignedIntegerFromMemory (addr, byte_size, 0, sb_error.ref());
10677fdf9ef1SGreg Clayton         }
10687fdf9ef1SGreg Clayton         else
10697fdf9ef1SGreg Clayton         {
10705160ce5cSGreg Clayton             Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1071c9858e4dSGreg Clayton             if (log)
1072c9858e4dSGreg Clayton                 log->Printf ("SBProcess(%p)::ReadUnsignedFromMemory() => error: process is running", process_sp.get());
10737fdf9ef1SGreg Clayton             sb_error.SetErrorString("process is running");
10747fdf9ef1SGreg Clayton         }
1075e91b7957SGreg Clayton     }
1076e91b7957SGreg Clayton     else
1077e91b7957SGreg Clayton     {
1078e91b7957SGreg Clayton         sb_error.SetErrorString ("SBProcess is invalid");
1079e91b7957SGreg Clayton     }
10807fdf9ef1SGreg Clayton     return value;
1081e91b7957SGreg Clayton }
1082e91b7957SGreg Clayton 
1083e91b7957SGreg Clayton lldb::addr_t
1084e91b7957SGreg Clayton SBProcess::ReadPointerFromMemory (addr_t addr, lldb::SBError &sb_error)
1085e91b7957SGreg Clayton {
1086e91b7957SGreg Clayton     lldb::addr_t ptr = LLDB_INVALID_ADDRESS;
1087acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
1088acdbe816SGreg Clayton     if (process_sp)
1089e91b7957SGreg Clayton     {
10907fdf9ef1SGreg Clayton         Process::StopLocker stop_locker;
10917fdf9ef1SGreg Clayton         if (stop_locker.TryLock(&process_sp->GetRunLock()))
10927fdf9ef1SGreg Clayton         {
1093acdbe816SGreg Clayton             Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
10947fdf9ef1SGreg Clayton             ptr = process_sp->ReadPointerFromMemory (addr, sb_error.ref());
10957fdf9ef1SGreg Clayton         }
10967fdf9ef1SGreg Clayton         else
10977fdf9ef1SGreg Clayton         {
10985160ce5cSGreg Clayton             Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1099c9858e4dSGreg Clayton             if (log)
1100c9858e4dSGreg Clayton                 log->Printf ("SBProcess(%p)::ReadPointerFromMemory() => error: process is running", process_sp.get());
11017fdf9ef1SGreg Clayton             sb_error.SetErrorString("process is running");
11027fdf9ef1SGreg Clayton         }
1103e91b7957SGreg Clayton     }
1104e91b7957SGreg Clayton     else
1105e91b7957SGreg Clayton     {
1106e91b7957SGreg Clayton         sb_error.SetErrorString ("SBProcess is invalid");
1107e91b7957SGreg Clayton     }
1108e91b7957SGreg Clayton     return ptr;
1109e91b7957SGreg Clayton }
1110e91b7957SGreg Clayton 
1111e91b7957SGreg Clayton size_t
111230fdc8d8SChris Lattner SBProcess::WriteMemory (addr_t addr, const void *src, size_t src_len, SBError &sb_error)
111330fdc8d8SChris Lattner {
111430fdc8d8SChris Lattner     size_t bytes_written = 0;
111530fdc8d8SChris Lattner 
11165160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1117acdbe816SGreg Clayton 
1118acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
1119acdbe816SGreg Clayton 
11204838131bSGreg Clayton     if (log)
11214838131bSGreg Clayton     {
1122d01b2953SDaniel Malea         log->Printf ("SBProcess(%p)::WriteMemory (addr=0x%" PRIx64 ", src=%p, src_len=%" PRIu64 ", SBError (%p))...",
1123acdbe816SGreg Clayton                      process_sp.get(),
11244838131bSGreg Clayton                      addr,
11254838131bSGreg Clayton                      src,
112643e0af06SGreg Clayton                      (uint64_t)src_len,
11274838131bSGreg Clayton                      sb_error.get());
11284838131bSGreg Clayton     }
11294838131bSGreg Clayton 
1130acdbe816SGreg Clayton     if (process_sp)
113130fdc8d8SChris Lattner     {
11327fdf9ef1SGreg Clayton         Process::StopLocker stop_locker;
11337fdf9ef1SGreg Clayton         if (stop_locker.TryLock(&process_sp->GetRunLock()))
11347fdf9ef1SGreg Clayton         {
1135acdbe816SGreg Clayton             Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
11367fdf9ef1SGreg Clayton             bytes_written = process_sp->WriteMemory (addr, src, src_len, sb_error.ref());
11377fdf9ef1SGreg Clayton         }
11387fdf9ef1SGreg Clayton         else
11397fdf9ef1SGreg Clayton         {
1140c9858e4dSGreg Clayton             if (log)
1141c9858e4dSGreg Clayton                 log->Printf ("SBProcess(%p)::WriteMemory() => error: process is running", process_sp.get());
11427fdf9ef1SGreg Clayton             sb_error.SetErrorString("process is running");
11437fdf9ef1SGreg Clayton         }
114430fdc8d8SChris Lattner     }
114530fdc8d8SChris Lattner 
11464838131bSGreg Clayton     if (log)
11474838131bSGreg Clayton     {
11484838131bSGreg Clayton         SBStream sstr;
11494838131bSGreg Clayton         sb_error.GetDescription (sstr);
1150d01b2953SDaniel Malea         log->Printf ("SBProcess(%p)::WriteMemory (addr=0x%" PRIx64 ", src=%p, src_len=%" PRIu64 ", SBError (%p): %s) => %" PRIu64,
1151acdbe816SGreg Clayton                      process_sp.get(),
11524838131bSGreg Clayton                      addr,
11534838131bSGreg Clayton                      src,
115443e0af06SGreg Clayton                      (uint64_t)src_len,
11554838131bSGreg Clayton                      sb_error.get(),
11564838131bSGreg Clayton                      sstr.GetData(),
115743e0af06SGreg Clayton                      (uint64_t)bytes_written);
11584838131bSGreg Clayton     }
11594838131bSGreg Clayton 
116030fdc8d8SChris Lattner     return bytes_written;
116130fdc8d8SChris Lattner }
116230fdc8d8SChris Lattner 
1163dde9cff3SCaroline Tice bool
1164dde9cff3SCaroline Tice SBProcess::GetDescription (SBStream &description)
1165dde9cff3SCaroline Tice {
1166da7bc7d0SGreg Clayton     Stream &strm = description.ref();
1167da7bc7d0SGreg Clayton 
1168acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
1169acdbe816SGreg Clayton     if (process_sp)
1170dde9cff3SCaroline Tice     {
1171dde9cff3SCaroline Tice         char path[PATH_MAX];
1172dde9cff3SCaroline Tice         GetTarget().GetExecutable().GetPath (path, sizeof(path));
1173acdbe816SGreg Clayton         Module *exe_module = process_sp->GetTarget().GetExecutableModulePointer();
11741d273166SGreg Clayton         const char *exe_name = NULL;
11751d273166SGreg Clayton         if (exe_module)
11761d273166SGreg Clayton             exe_name = exe_module->GetFileSpec().GetFilename().AsCString();
11771d273166SGreg Clayton 
1178d01b2953SDaniel Malea         strm.Printf ("SBProcess: pid = %" PRIu64 ", state = %s, threads = %d%s%s",
1179acdbe816SGreg Clayton                      process_sp->GetID(),
1180ceb6b139SCaroline Tice                      lldb_private::StateAsCString (GetState()),
11811d273166SGreg Clayton                      GetNumThreads(),
118205faeb71SGreg Clayton                      exe_name ? ", executable = " : "",
11831d273166SGreg Clayton                      exe_name ? exe_name : "");
1184dde9cff3SCaroline Tice     }
1185dde9cff3SCaroline Tice     else
1186da7bc7d0SGreg Clayton         strm.PutCString ("No value");
1187dde9cff3SCaroline Tice 
1188dde9cff3SCaroline Tice     return true;
1189dde9cff3SCaroline Tice }
11908f343b09SGreg Clayton 
11918f343b09SGreg Clayton uint32_t
1192f9ef60d2SJohnny Chen SBProcess::GetNumSupportedHardwareWatchpoints (lldb::SBError &sb_error) const
1193f9ef60d2SJohnny Chen {
11945160ce5cSGreg Clayton     Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1195f9ef60d2SJohnny Chen 
1196f9ef60d2SJohnny Chen     uint32_t num = 0;
1197f9ef60d2SJohnny Chen     ProcessSP process_sp(GetSP());
1198f9ef60d2SJohnny Chen     if (process_sp)
1199f9ef60d2SJohnny Chen     {
1200f9ef60d2SJohnny Chen         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
1201f9ef60d2SJohnny Chen         sb_error.SetError(process_sp->GetWatchpointSupportInfo (num));
1202f9ef60d2SJohnny Chen         if (log)
1203f9ef60d2SJohnny Chen             log->Printf ("SBProcess(%p)::GetNumSupportedHardwareWatchpoints () => %u",
1204f9ef60d2SJohnny Chen                          process_sp.get(), num);
1205f9ef60d2SJohnny Chen     }
1206f9ef60d2SJohnny Chen     else
1207f9ef60d2SJohnny Chen     {
1208f9ef60d2SJohnny Chen         sb_error.SetErrorString ("SBProcess is invalid");
1209f9ef60d2SJohnny Chen     }
1210f9ef60d2SJohnny Chen     return num;
1211f9ef60d2SJohnny Chen }
1212f9ef60d2SJohnny Chen 
1213f9ef60d2SJohnny Chen uint32_t
12148f343b09SGreg Clayton SBProcess::LoadImage (lldb::SBFileSpec &sb_image_spec, lldb::SBError &sb_error)
12158f343b09SGreg Clayton {
1216acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
1217acdbe816SGreg Clayton     if (process_sp)
1218af67cecdSGreg Clayton     {
12197fdf9ef1SGreg Clayton         Process::StopLocker stop_locker;
12207fdf9ef1SGreg Clayton         if (stop_locker.TryLock(&process_sp->GetRunLock()))
12217fdf9ef1SGreg Clayton         {
1222acdbe816SGreg Clayton             Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
1223acdbe816SGreg Clayton             return process_sp->LoadImage (*sb_image_spec, sb_error.ref());
1224af67cecdSGreg Clayton         }
12257fdf9ef1SGreg Clayton         else
12267fdf9ef1SGreg Clayton         {
12275160ce5cSGreg Clayton             Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1228c9858e4dSGreg Clayton             if (log)
1229c9858e4dSGreg Clayton                 log->Printf ("SBProcess(%p)::LoadImage() => error: process is running", process_sp.get());
12307fdf9ef1SGreg Clayton             sb_error.SetErrorString("process is running");
12317fdf9ef1SGreg Clayton         }
12327fdf9ef1SGreg Clayton     }
12338f343b09SGreg Clayton     return LLDB_INVALID_IMAGE_TOKEN;
12348f343b09SGreg Clayton }
12358f343b09SGreg Clayton 
12368f343b09SGreg Clayton lldb::SBError
12378f343b09SGreg Clayton SBProcess::UnloadImage (uint32_t image_token)
12388f343b09SGreg Clayton {
12398f343b09SGreg Clayton     lldb::SBError sb_error;
1240acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
1241acdbe816SGreg Clayton     if (process_sp)
1242af67cecdSGreg Clayton     {
12437fdf9ef1SGreg Clayton         Process::StopLocker stop_locker;
12447fdf9ef1SGreg Clayton         if (stop_locker.TryLock(&process_sp->GetRunLock()))
12457fdf9ef1SGreg Clayton         {
1246acdbe816SGreg Clayton             Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
1247acdbe816SGreg Clayton             sb_error.SetError (process_sp->UnloadImage (image_token));
1248af67cecdSGreg Clayton         }
12498f343b09SGreg Clayton         else
12507fdf9ef1SGreg Clayton         {
12515160ce5cSGreg Clayton             Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1252c9858e4dSGreg Clayton             if (log)
1253c9858e4dSGreg Clayton                 log->Printf ("SBProcess(%p)::UnloadImage() => error: process is running", process_sp.get());
12547fdf9ef1SGreg Clayton             sb_error.SetErrorString("process is running");
12557fdf9ef1SGreg Clayton         }
12567fdf9ef1SGreg Clayton     }
12577fdf9ef1SGreg Clayton     else
12588f343b09SGreg Clayton         sb_error.SetErrorString("invalid process");
12598f343b09SGreg Clayton     return sb_error;
12608f343b09SGreg Clayton }
12618c71337aSJason Molenda 
12628c71337aSJason Molenda uint32_t
1263*95d005c7SJason Molenda SBProcess::GetNumExtendedBacktraceTypes ()
12648c71337aSJason Molenda {
12658c71337aSJason Molenda     ProcessSP process_sp(GetSP());
12668c71337aSJason Molenda     if (process_sp && process_sp->GetSystemRuntime())
12678c71337aSJason Molenda     {
12688c71337aSJason Molenda         SystemRuntime *runtime = process_sp->GetSystemRuntime();
1269*95d005c7SJason Molenda         return runtime->GetExtendedBacktraceTypes().size();
12708c71337aSJason Molenda     }
12718c71337aSJason Molenda     return 0;
12728c71337aSJason Molenda }
12738c71337aSJason Molenda 
12748c71337aSJason Molenda const char *
1275*95d005c7SJason Molenda SBProcess::GetExtendedBacktraceTypeAtIndex (uint32_t idx)
12768c71337aSJason Molenda {
12778c71337aSJason Molenda     ProcessSP process_sp(GetSP());
12788c71337aSJason Molenda     if (process_sp && process_sp->GetSystemRuntime())
12798c71337aSJason Molenda     {
12808c71337aSJason Molenda         SystemRuntime *runtime = process_sp->GetSystemRuntime();
1281*95d005c7SJason Molenda         std::vector<ConstString> names = runtime->GetExtendedBacktraceTypes();
12828c71337aSJason Molenda         if (idx < names.size())
12838c71337aSJason Molenda         {
12848c71337aSJason Molenda             return names[idx].AsCString();
12858c71337aSJason Molenda         }
12868c71337aSJason Molenda         else
12878c71337aSJason Molenda         {
12888c71337aSJason Molenda             Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
12898c71337aSJason Molenda             if (log)
1290*95d005c7SJason Molenda                 log->Printf("SBProcess(%p)::GetExtendedBacktraceTypeAtIndex() => error: requested extended backtrace name out of bounds", process_sp.get());
12918c71337aSJason Molenda         }
12928c71337aSJason Molenda     }
12938c71337aSJason Molenda     return NULL;
12948c71337aSJason Molenda }
1295