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 
104c5de699SEli Friedman #include "lldb/API/SBProcess.h"
1130fdc8d8SChris Lattner 
1230fdc8d8SChris Lattner #include "lldb/lldb-defines.h"
1330fdc8d8SChris Lattner #include "lldb/lldb-types.h"
1430fdc8d8SChris Lattner 
1540af72e1SJim Ingham #include "lldb/Interpreter/Args.h"
165d5028b5SGreg Clayton #include "lldb/Core/Debugger.h"
17ceb6b139SCaroline Tice #include "lldb/Core/Log.h"
1830fdc8d8SChris Lattner #include "lldb/Core/State.h"
1930fdc8d8SChris Lattner #include "lldb/Core/Stream.h"
2030fdc8d8SChris Lattner #include "lldb/Core/StreamFile.h"
2130fdc8d8SChris Lattner #include "lldb/Target/Process.h"
2230fdc8d8SChris Lattner #include "lldb/Target/RegisterContext.h"
236611103cSGreg Clayton #include "lldb/Target/Target.h"
246611103cSGreg Clayton #include "lldb/Target/Thread.h"
2530fdc8d8SChris Lattner 
2630fdc8d8SChris Lattner // Project includes
2730fdc8d8SChris Lattner 
284c5de699SEli Friedman #include "lldb/API/SBBroadcaster.h"
294c5de699SEli Friedman #include "lldb/API/SBCommandReturnObject.h"
300e615684SGreg Clayton #include "lldb/API/SBDebugger.h"
314c5de699SEli Friedman #include "lldb/API/SBEvent.h"
320e615684SGreg Clayton #include "lldb/API/SBFileSpec.h"
334c5de699SEli Friedman #include "lldb/API/SBThread.h"
34dde9cff3SCaroline Tice #include "lldb/API/SBStream.h"
354c5de699SEli Friedman #include "lldb/API/SBStringList.h"
3630fdc8d8SChris Lattner 
3730fdc8d8SChris Lattner using namespace lldb;
3830fdc8d8SChris Lattner using namespace lldb_private;
3930fdc8d8SChris Lattner 
4030fdc8d8SChris Lattner 
4130fdc8d8SChris Lattner SBProcess::SBProcess () :
424e0fe8abSGreg Clayton     m_opaque_wp()
4330fdc8d8SChris Lattner {
4430fdc8d8SChris Lattner }
4530fdc8d8SChris Lattner 
4630fdc8d8SChris Lattner 
4730fdc8d8SChris Lattner //----------------------------------------------------------------------
4830fdc8d8SChris Lattner // SBProcess constructor
4930fdc8d8SChris Lattner //----------------------------------------------------------------------
5030fdc8d8SChris Lattner 
5130fdc8d8SChris Lattner SBProcess::SBProcess (const SBProcess& rhs) :
524e0fe8abSGreg Clayton     m_opaque_wp (rhs.m_opaque_wp)
5330fdc8d8SChris Lattner {
5430fdc8d8SChris Lattner }
5530fdc8d8SChris Lattner 
5630fdc8d8SChris Lattner 
5730fdc8d8SChris Lattner SBProcess::SBProcess (const lldb::ProcessSP &process_sp) :
584e0fe8abSGreg Clayton     m_opaque_wp (process_sp)
5930fdc8d8SChris Lattner {
6030fdc8d8SChris Lattner }
6130fdc8d8SChris Lattner 
62efabb123SGreg Clayton const SBProcess&
63efabb123SGreg Clayton SBProcess::operator = (const SBProcess& rhs)
64efabb123SGreg Clayton {
65efabb123SGreg Clayton     if (this != &rhs)
664e0fe8abSGreg Clayton         m_opaque_wp = rhs.m_opaque_wp;
67efabb123SGreg Clayton     return *this;
68efabb123SGreg Clayton }
69efabb123SGreg Clayton 
7030fdc8d8SChris Lattner //----------------------------------------------------------------------
7130fdc8d8SChris Lattner // Destructor
7230fdc8d8SChris Lattner //----------------------------------------------------------------------
7330fdc8d8SChris Lattner SBProcess::~SBProcess()
7430fdc8d8SChris Lattner {
7530fdc8d8SChris Lattner }
7630fdc8d8SChris Lattner 
774bddaeb5SJim Ingham const char *
784bddaeb5SJim Ingham SBProcess::GetBroadcasterClassName ()
794bddaeb5SJim Ingham {
804bddaeb5SJim Ingham     return Process::GetStaticBroadcasterClass().AsCString();
814bddaeb5SJim Ingham }
824bddaeb5SJim Ingham 
83b9556accSGreg Clayton lldb::ProcessSP
84b9556accSGreg Clayton SBProcess::GetSP() const
85b9556accSGreg Clayton {
864e0fe8abSGreg Clayton     return m_opaque_wp.lock();
87b9556accSGreg Clayton }
88b9556accSGreg Clayton 
8930fdc8d8SChris Lattner void
90b9556accSGreg Clayton SBProcess::SetSP (const ProcessSP &process_sp)
9130fdc8d8SChris Lattner {
924e0fe8abSGreg Clayton     m_opaque_wp = process_sp;
9330fdc8d8SChris Lattner }
9430fdc8d8SChris Lattner 
9530fdc8d8SChris Lattner void
9630fdc8d8SChris Lattner SBProcess::Clear ()
9730fdc8d8SChris Lattner {
984e0fe8abSGreg Clayton     m_opaque_wp.reset();
9930fdc8d8SChris Lattner }
10030fdc8d8SChris Lattner 
10130fdc8d8SChris Lattner 
10230fdc8d8SChris Lattner bool
10330fdc8d8SChris Lattner SBProcess::IsValid() const
10430fdc8d8SChris Lattner {
105*4fc6cb9cSJim Ingham     ProcessSP process_sp(m_opaque_wp.lock());
106*4fc6cb9cSJim Ingham     return ((bool) process_sp && process_sp->IsValid());
10730fdc8d8SChris Lattner }
10830fdc8d8SChris Lattner 
1099631aae2SJames McIlree bool
1109631aae2SJames McIlree SBProcess::RemoteLaunch (char const **argv,
1119631aae2SJames McIlree                          char const **envp,
1129631aae2SJames McIlree                          const char *stdin_path,
1139631aae2SJames McIlree                          const char *stdout_path,
1149631aae2SJames McIlree                          const char *stderr_path,
1159631aae2SJames McIlree                          const char *working_directory,
1169631aae2SJames McIlree                          uint32_t launch_flags,
1179631aae2SJames McIlree                          bool stop_at_entry,
1189631aae2SJames McIlree                          lldb::SBError& error)
1199631aae2SJames McIlree {
1209631aae2SJames McIlree     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1219631aae2SJames McIlree     if (log) {
1229631aae2SJames 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))...",
1234e0fe8abSGreg Clayton                      m_opaque_wp.lock().get(),
1249631aae2SJames McIlree                      argv,
1259631aae2SJames McIlree                      envp,
1269631aae2SJames McIlree                      stdin_path ? stdin_path : "NULL",
1279631aae2SJames McIlree                      stdout_path ? stdout_path : "NULL",
1289631aae2SJames McIlree                      stderr_path ? stderr_path : "NULL",
1299631aae2SJames McIlree                      working_directory ? working_directory : "NULL",
1309631aae2SJames McIlree                      launch_flags,
1319631aae2SJames McIlree                      stop_at_entry,
1329631aae2SJames McIlree                      error.get());
1339631aae2SJames McIlree     }
1349631aae2SJames McIlree 
135acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
136acdbe816SGreg Clayton     if (process_sp)
1379631aae2SJames McIlree     {
138acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
139acdbe816SGreg Clayton         if (process_sp->GetState() == eStateConnected)
1409631aae2SJames McIlree         {
141982c9762SGreg Clayton             if (stop_at_entry)
142982c9762SGreg Clayton                 launch_flags |= eLaunchFlagStopAtEntry;
143982c9762SGreg Clayton             ProcessLaunchInfo launch_info (stdin_path,
144982c9762SGreg Clayton                                            stdout_path,
145982c9762SGreg Clayton                                            stderr_path,
146982c9762SGreg Clayton                                            working_directory,
147982c9762SGreg Clayton                                            launch_flags);
148acdbe816SGreg Clayton             Module *exe_module = process_sp->GetTarget().GetExecutableModulePointer();
149982c9762SGreg Clayton             if (exe_module)
150982c9762SGreg Clayton                 launch_info.SetExecutableFile(exe_module->GetFileSpec(), true);
151982c9762SGreg Clayton             if (argv)
152982c9762SGreg Clayton                 launch_info.GetArguments().AppendArguments (argv);
153982c9762SGreg Clayton             if (envp)
154982c9762SGreg Clayton                 launch_info.GetEnvironmentEntries ().SetArguments (envp);
155acdbe816SGreg Clayton             error.SetError (process_sp->Launch (launch_info));
1569631aae2SJames McIlree         }
1579631aae2SJames McIlree         else
1589631aae2SJames McIlree         {
1599631aae2SJames McIlree             error.SetErrorString ("must be in eStateConnected to call RemoteLaunch");
1609631aae2SJames McIlree         }
1619631aae2SJames McIlree     }
1629631aae2SJames McIlree     else
1639631aae2SJames McIlree     {
1649631aae2SJames McIlree         error.SetErrorString ("unable to attach pid");
1659631aae2SJames McIlree     }
1669631aae2SJames McIlree 
1679631aae2SJames McIlree     if (log) {
1689631aae2SJames McIlree         SBStream sstr;
1699631aae2SJames McIlree         error.GetDescription (sstr);
170acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::RemoteLaunch (...) => SBError (%p): %s", process_sp.get(), error.get(), sstr.GetData());
1719631aae2SJames McIlree     }
1729631aae2SJames McIlree 
1739631aae2SJames McIlree     return error.Success();
1749631aae2SJames McIlree }
1759631aae2SJames McIlree 
1769631aae2SJames McIlree bool
1779631aae2SJames McIlree SBProcess::RemoteAttachToProcessWithID (lldb::pid_t pid, lldb::SBError& error)
1789631aae2SJames McIlree {
179acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
180acdbe816SGreg Clayton     if (process_sp)
1819631aae2SJames McIlree     {
182acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
183acdbe816SGreg Clayton         if (process_sp->GetState() == eStateConnected)
1849631aae2SJames McIlree         {
185144f3a9cSGreg Clayton             ProcessAttachInfo attach_info;
186144f3a9cSGreg Clayton             attach_info.SetProcessID (pid);
187acdbe816SGreg Clayton             error.SetError (process_sp->Attach (attach_info));
1889631aae2SJames McIlree         }
1899631aae2SJames McIlree         else
1909631aae2SJames McIlree         {
1919631aae2SJames McIlree             error.SetErrorString ("must be in eStateConnected to call RemoteAttachToProcessWithID");
1929631aae2SJames McIlree         }
1939631aae2SJames McIlree     }
1949631aae2SJames McIlree     else
1959631aae2SJames McIlree     {
1969631aae2SJames McIlree         error.SetErrorString ("unable to attach pid");
1979631aae2SJames McIlree     }
1989631aae2SJames McIlree 
1999631aae2SJames McIlree     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
2009631aae2SJames McIlree     if (log) {
2019631aae2SJames McIlree         SBStream sstr;
2029631aae2SJames McIlree         error.GetDescription (sstr);
203acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::RemoteAttachToProcessWithID (%llu) => SBError (%p): %s", process_sp.get(), pid, error.get(), sstr.GetData());
2049631aae2SJames McIlree     }
2059631aae2SJames McIlree 
2069631aae2SJames McIlree     return error.Success();
2079631aae2SJames McIlree }
2089631aae2SJames McIlree 
20930fdc8d8SChris Lattner 
21030fdc8d8SChris Lattner uint32_t
21130fdc8d8SChris Lattner SBProcess::GetNumThreads ()
21230fdc8d8SChris Lattner {
2132d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
214ceb6b139SCaroline Tice 
215ceb6b139SCaroline Tice     uint32_t num_threads = 0;
216acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
217acdbe816SGreg Clayton     if (process_sp)
21830fdc8d8SChris Lattner     {
2197fdf9ef1SGreg Clayton         Process::StopLocker stop_locker;
2207fdf9ef1SGreg Clayton 
2217fdf9ef1SGreg Clayton         const bool can_update = stop_locker.TryLock(&process_sp->GetRunLock());
222acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
223acdbe816SGreg Clayton         num_threads = process_sp->GetThreadList().GetSize(can_update);
22430fdc8d8SChris Lattner     }
225ceb6b139SCaroline Tice 
226ceb6b139SCaroline Tice     if (log)
227acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::GetNumThreads () => %d", process_sp.get(), num_threads);
228ceb6b139SCaroline Tice 
229ceb6b139SCaroline Tice     return num_threads;
23030fdc8d8SChris Lattner }
23130fdc8d8SChris Lattner 
23230fdc8d8SChris Lattner SBThread
2332976d00aSJim Ingham SBProcess::GetSelectedThread () const
23430fdc8d8SChris Lattner {
2352d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
236ceb6b139SCaroline Tice 
23730fdc8d8SChris Lattner     SBThread sb_thread;
23817a6ad05SGreg Clayton     ThreadSP thread_sp;
239acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
240acdbe816SGreg Clayton     if (process_sp)
241af67cecdSGreg Clayton     {
242acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
243acdbe816SGreg Clayton         thread_sp = process_sp->GetThreadList().GetSelectedThread();
24417a6ad05SGreg Clayton         sb_thread.SetThread (thread_sp);
245af67cecdSGreg Clayton     }
246ceb6b139SCaroline Tice 
247ceb6b139SCaroline Tice     if (log)
248ceb6b139SCaroline Tice     {
249acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::GetSelectedThread () => SBThread(%p)", process_sp.get(), thread_sp.get());
250ceb6b139SCaroline Tice     }
251ceb6b139SCaroline Tice 
25230fdc8d8SChris Lattner     return sb_thread;
25330fdc8d8SChris Lattner }
25430fdc8d8SChris Lattner 
25530fdc8d8SChris Lattner SBTarget
25630fdc8d8SChris Lattner SBProcess::GetTarget() const
25730fdc8d8SChris Lattner {
2582d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
259ceb6b139SCaroline Tice 
26030fdc8d8SChris Lattner     SBTarget sb_target;
261b9556accSGreg Clayton     TargetSP target_sp;
262acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
263acdbe816SGreg Clayton     if (process_sp)
264b9556accSGreg Clayton     {
265acdbe816SGreg Clayton         target_sp = process_sp->GetTarget().shared_from_this();
266b9556accSGreg Clayton         sb_target.SetSP (target_sp);
267b9556accSGreg Clayton     }
268ceb6b139SCaroline Tice 
269ceb6b139SCaroline Tice     if (log)
270acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::GetTarget () => SBTarget(%p)", process_sp.get(), target_sp.get());
271ceb6b139SCaroline Tice 
27230fdc8d8SChris Lattner     return sb_target;
27330fdc8d8SChris Lattner }
27430fdc8d8SChris Lattner 
27530fdc8d8SChris Lattner 
27630fdc8d8SChris Lattner size_t
27730fdc8d8SChris Lattner SBProcess::PutSTDIN (const char *src, size_t src_len)
27830fdc8d8SChris Lattner {
2792d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
280ceb6b139SCaroline Tice 
281ceb6b139SCaroline Tice     size_t ret_val = 0;
282acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
283acdbe816SGreg Clayton     if (process_sp)
28430fdc8d8SChris Lattner     {
28530fdc8d8SChris Lattner         Error error;
286acdbe816SGreg Clayton         ret_val =  process_sp->PutSTDIN (src, src_len, error);
28730fdc8d8SChris Lattner     }
288ceb6b139SCaroline Tice 
289ceb6b139SCaroline Tice     if (log)
290fd54b368SJason Molenda         log->Printf ("SBProcess(%p)::PutSTDIN (src=\"%s\", src_len=%d) => %lu",
291acdbe816SGreg Clayton                      process_sp.get(),
29293aa84e8SGreg Clayton                      src,
29393aa84e8SGreg Clayton                      (uint32_t) src_len,
29493aa84e8SGreg Clayton                      ret_val);
295ceb6b139SCaroline Tice 
296ceb6b139SCaroline Tice     return ret_val;
29730fdc8d8SChris Lattner }
29830fdc8d8SChris Lattner 
29930fdc8d8SChris Lattner size_t
30030fdc8d8SChris Lattner SBProcess::GetSTDOUT (char *dst, size_t dst_len) const
30130fdc8d8SChris Lattner {
302cfd1acedSGreg Clayton     size_t bytes_read = 0;
303acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
304acdbe816SGreg Clayton     if (process_sp)
30530fdc8d8SChris Lattner     {
30630fdc8d8SChris Lattner         Error error;
307acdbe816SGreg Clayton         bytes_read = process_sp->GetSTDOUT (dst, dst_len, error);
30830fdc8d8SChris Lattner     }
309ceb6b139SCaroline Tice 
3102d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
311ceb6b139SCaroline Tice     if (log)
312cfd1acedSGreg Clayton         log->Printf ("SBProcess(%p)::GetSTDOUT (dst=\"%.*s\", dst_len=%zu) => %zu",
313acdbe816SGreg Clayton                      process_sp.get(), (int) bytes_read, dst, dst_len, bytes_read);
314ceb6b139SCaroline Tice 
315cfd1acedSGreg Clayton     return bytes_read;
31630fdc8d8SChris Lattner }
31730fdc8d8SChris Lattner 
31830fdc8d8SChris Lattner size_t
31930fdc8d8SChris Lattner SBProcess::GetSTDERR (char *dst, size_t dst_len) const
32030fdc8d8SChris Lattner {
321cfd1acedSGreg Clayton     size_t bytes_read = 0;
322acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
323acdbe816SGreg Clayton     if (process_sp)
32430fdc8d8SChris Lattner     {
32530fdc8d8SChris Lattner         Error error;
326acdbe816SGreg Clayton         bytes_read = process_sp->GetSTDERR (dst, dst_len, error);
32730fdc8d8SChris Lattner     }
328ceb6b139SCaroline Tice 
3292d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
330ceb6b139SCaroline Tice     if (log)
331cfd1acedSGreg Clayton         log->Printf ("SBProcess(%p)::GetSTDERR (dst=\"%.*s\", dst_len=%zu) => %zu",
332acdbe816SGreg Clayton                      process_sp.get(), (int) bytes_read, dst, dst_len, bytes_read);
333ceb6b139SCaroline Tice 
334cfd1acedSGreg Clayton     return bytes_read;
33530fdc8d8SChris Lattner }
33630fdc8d8SChris Lattner 
33730fdc8d8SChris Lattner void
3382976d00aSJim Ingham SBProcess::ReportEventState (const SBEvent &event, FILE *out) const
33930fdc8d8SChris Lattner {
34030fdc8d8SChris Lattner     if (out == NULL)
34130fdc8d8SChris Lattner         return;
34230fdc8d8SChris Lattner 
343acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
344acdbe816SGreg Clayton     if (process_sp)
34530fdc8d8SChris Lattner     {
34630fdc8d8SChris Lattner         const StateType event_state = SBProcess::GetStateFromEvent (event);
34730fdc8d8SChris Lattner         char message[1024];
34830fdc8d8SChris Lattner         int message_len = ::snprintf (message,
34930fdc8d8SChris Lattner                                       sizeof (message),
35081c22f61SGreg Clayton                                       "Process %llu %s\n",
351acdbe816SGreg Clayton                                       process_sp->GetID(),
35230fdc8d8SChris Lattner                                       SBDebugger::StateAsCString (event_state));
35330fdc8d8SChris Lattner 
35430fdc8d8SChris Lattner         if (message_len > 0)
35530fdc8d8SChris Lattner             ::fwrite (message, 1, message_len, out);
35630fdc8d8SChris Lattner     }
35730fdc8d8SChris Lattner }
35830fdc8d8SChris Lattner 
35930fdc8d8SChris Lattner void
3602976d00aSJim Ingham SBProcess::AppendEventStateReport (const SBEvent &event, SBCommandReturnObject &result)
36130fdc8d8SChris Lattner {
362acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
363acdbe816SGreg Clayton     if (process_sp)
36430fdc8d8SChris Lattner     {
36530fdc8d8SChris Lattner         const StateType event_state = SBProcess::GetStateFromEvent (event);
36630fdc8d8SChris Lattner         char message[1024];
36730fdc8d8SChris Lattner         ::snprintf (message,
36830fdc8d8SChris Lattner                     sizeof (message),
36981c22f61SGreg Clayton                     "Process %llu %s\n",
370acdbe816SGreg Clayton                     process_sp->GetID(),
37130fdc8d8SChris Lattner                     SBDebugger::StateAsCString (event_state));
37230fdc8d8SChris Lattner 
37330fdc8d8SChris Lattner         result.AppendMessage (message);
37430fdc8d8SChris Lattner     }
37530fdc8d8SChris Lattner }
37630fdc8d8SChris Lattner 
37730fdc8d8SChris Lattner bool
3782976d00aSJim Ingham SBProcess::SetSelectedThread (const SBThread &thread)
37930fdc8d8SChris Lattner {
380acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
381acdbe816SGreg Clayton     if (process_sp)
382af67cecdSGreg Clayton     {
383acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
384acdbe816SGreg Clayton         return process_sp->GetThreadList().SetSelectedThreadByID (thread.GetThreadID());
385af67cecdSGreg Clayton     }
38630fdc8d8SChris Lattner     return false;
38730fdc8d8SChris Lattner }
38830fdc8d8SChris Lattner 
38930fdc8d8SChris Lattner bool
3902976d00aSJim Ingham SBProcess::SetSelectedThreadByID (uint32_t tid)
39130fdc8d8SChris Lattner {
3922d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
393ceb6b139SCaroline Tice 
394ceb6b139SCaroline Tice     bool ret_val = false;
395acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
396acdbe816SGreg Clayton     if (process_sp)
397af67cecdSGreg Clayton     {
398acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
399acdbe816SGreg Clayton         ret_val = process_sp->GetThreadList().SetSelectedThreadByID (tid);
400af67cecdSGreg Clayton     }
401ceb6b139SCaroline Tice 
402ceb6b139SCaroline Tice     if (log)
403cfd1acedSGreg Clayton         log->Printf ("SBProcess(%p)::SetSelectedThreadByID (tid=0x%4.4x) => %s",
404acdbe816SGreg Clayton                      process_sp.get(), tid, (ret_val ? "true" : "false"));
405ceb6b139SCaroline Tice 
406ceb6b139SCaroline Tice     return ret_val;
40730fdc8d8SChris Lattner }
40830fdc8d8SChris Lattner 
40918b46896SJim Ingham bool
41018b46896SJim Ingham SBProcess::SetSelectedThreadByIndexID (uint32_t index_id)
41118b46896SJim Ingham {
41218b46896SJim Ingham     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
41318b46896SJim Ingham 
41418b46896SJim Ingham     bool ret_val = false;
41518b46896SJim Ingham     ProcessSP process_sp(GetSP());
41618b46896SJim Ingham     if (process_sp)
41718b46896SJim Ingham     {
41818b46896SJim Ingham         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
41918b46896SJim Ingham         ret_val = process_sp->GetThreadList().SetSelectedThreadByIndexID (index_id);
42018b46896SJim Ingham     }
42118b46896SJim Ingham 
42218b46896SJim Ingham     if (log)
42318b46896SJim Ingham         log->Printf ("SBProcess(%p)::SetSelectedThreadByID (tid=0x%x) => %s",
42418b46896SJim Ingham                      process_sp.get(), index_id, (ret_val ? "true" : "false"));
42518b46896SJim Ingham 
42618b46896SJim Ingham     return ret_val;
42718b46896SJim Ingham }
42818b46896SJim Ingham 
42930fdc8d8SChris Lattner SBThread
43030fdc8d8SChris Lattner SBProcess::GetThreadAtIndex (size_t index)
43130fdc8d8SChris Lattner {
4322d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
433ceb6b139SCaroline Tice 
43417a6ad05SGreg Clayton     SBThread sb_thread;
43517a6ad05SGreg Clayton     ThreadSP thread_sp;
436acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
437acdbe816SGreg Clayton     if (process_sp)
438af67cecdSGreg Clayton     {
4397fdf9ef1SGreg Clayton         Process::StopLocker stop_locker;
4407fdf9ef1SGreg Clayton         const bool can_update = stop_locker.TryLock(&process_sp->GetRunLock());
441acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
4427fdf9ef1SGreg Clayton         thread_sp = process_sp->GetThreadList().GetThreadAtIndex(index, can_update);
44317a6ad05SGreg Clayton         sb_thread.SetThread (thread_sp);
444af67cecdSGreg Clayton     }
445ceb6b139SCaroline Tice 
446ceb6b139SCaroline Tice     if (log)
447ceb6b139SCaroline Tice     {
44893aa84e8SGreg Clayton         log->Printf ("SBProcess(%p)::GetThreadAtIndex (index=%d) => SBThread(%p)",
449acdbe816SGreg Clayton                      process_sp.get(), (uint32_t) index, thread_sp.get());
450ceb6b139SCaroline Tice     }
451ceb6b139SCaroline Tice 
45217a6ad05SGreg Clayton     return sb_thread;
45330fdc8d8SChris Lattner }
45430fdc8d8SChris Lattner 
45530fdc8d8SChris Lattner StateType
45630fdc8d8SChris Lattner SBProcess::GetState ()
45730fdc8d8SChris Lattner {
458ceb6b139SCaroline Tice 
459ceb6b139SCaroline Tice     StateType ret_val = eStateInvalid;
460acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
461acdbe816SGreg Clayton     if (process_sp)
462af67cecdSGreg Clayton     {
463acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
464acdbe816SGreg Clayton         ret_val = process_sp->GetState();
465af67cecdSGreg Clayton     }
466ceb6b139SCaroline Tice 
4672d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
468ceb6b139SCaroline Tice     if (log)
469cfd1acedSGreg Clayton         log->Printf ("SBProcess(%p)::GetState () => %s",
470acdbe816SGreg Clayton                      process_sp.get(),
471750cd175SCaroline Tice                      lldb_private::StateAsCString (ret_val));
472ceb6b139SCaroline Tice 
473ceb6b139SCaroline Tice     return ret_val;
47430fdc8d8SChris Lattner }
47530fdc8d8SChris Lattner 
47630fdc8d8SChris Lattner 
47730fdc8d8SChris Lattner int
47830fdc8d8SChris Lattner SBProcess::GetExitStatus ()
47930fdc8d8SChris Lattner {
4804838131bSGreg Clayton     int exit_status = 0;
481acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
482acdbe816SGreg Clayton     if (process_sp)
483af67cecdSGreg Clayton     {
484acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
485acdbe816SGreg Clayton         exit_status = process_sp->GetExitStatus ();
486af67cecdSGreg Clayton     }
4872d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
4884838131bSGreg Clayton     if (log)
4894838131bSGreg Clayton         log->Printf ("SBProcess(%p)::GetExitStatus () => %i (0x%8.8x)",
490acdbe816SGreg Clayton                      process_sp.get(), exit_status, exit_status);
4914838131bSGreg Clayton 
4924838131bSGreg Clayton     return exit_status;
49330fdc8d8SChris Lattner }
49430fdc8d8SChris Lattner 
49530fdc8d8SChris Lattner const char *
49630fdc8d8SChris Lattner SBProcess::GetExitDescription ()
49730fdc8d8SChris Lattner {
4984838131bSGreg Clayton     const char *exit_desc = NULL;
499acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
500acdbe816SGreg Clayton     if (process_sp)
501af67cecdSGreg Clayton     {
502acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
503acdbe816SGreg Clayton         exit_desc = process_sp->GetExitDescription ();
504af67cecdSGreg Clayton     }
5052d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
5064838131bSGreg Clayton     if (log)
5074838131bSGreg Clayton         log->Printf ("SBProcess(%p)::GetExitDescription () => %s",
508acdbe816SGreg Clayton                      process_sp.get(), exit_desc);
5094838131bSGreg Clayton     return exit_desc;
51030fdc8d8SChris Lattner }
51130fdc8d8SChris Lattner 
51230fdc8d8SChris Lattner lldb::pid_t
51330fdc8d8SChris Lattner SBProcess::GetProcessID ()
51430fdc8d8SChris Lattner {
515ceb6b139SCaroline Tice     lldb::pid_t ret_val = LLDB_INVALID_PROCESS_ID;
516acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
517acdbe816SGreg Clayton     if (process_sp)
518acdbe816SGreg Clayton         ret_val = process_sp->GetID();
519ceb6b139SCaroline Tice 
5202d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
521ceb6b139SCaroline Tice     if (log)
522acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::GetProcessID () => %llu", process_sp.get(), ret_val);
523ceb6b139SCaroline Tice 
524ceb6b139SCaroline Tice     return ret_val;
52530fdc8d8SChris Lattner }
52630fdc8d8SChris Lattner 
527cf386e24SJohnny Chen ByteOrder
528cf386e24SJohnny Chen SBProcess::GetByteOrder () const
529cf386e24SJohnny Chen {
530cf386e24SJohnny Chen     ByteOrder byteOrder = eByteOrderInvalid;
531acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
532acdbe816SGreg Clayton     if (process_sp)
533acdbe816SGreg Clayton         byteOrder = process_sp->GetTarget().GetArchitecture().GetByteOrder();
534cf386e24SJohnny Chen 
535cf386e24SJohnny Chen     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
536cf386e24SJohnny Chen     if (log)
537acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::GetByteOrder () => %d", process_sp.get(), byteOrder);
538cf386e24SJohnny Chen 
539cf386e24SJohnny Chen     return byteOrder;
540cf386e24SJohnny Chen }
541cf386e24SJohnny Chen 
54230fdc8d8SChris Lattner uint32_t
54330fdc8d8SChris Lattner SBProcess::GetAddressByteSize () const
54430fdc8d8SChris Lattner {
545ceb6b139SCaroline Tice     uint32_t size = 0;
546acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
547acdbe816SGreg Clayton     if (process_sp)
548acdbe816SGreg Clayton         size =  process_sp->GetTarget().GetArchitecture().GetAddressByteSize();
549ceb6b139SCaroline Tice 
5502d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
551ceb6b139SCaroline Tice     if (log)
552acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::GetAddressByteSize () => %d", process_sp.get(), size);
553ceb6b139SCaroline Tice 
554ceb6b139SCaroline Tice     return size;
55530fdc8d8SChris Lattner }
55630fdc8d8SChris Lattner 
55730fdc8d8SChris Lattner SBError
55830fdc8d8SChris Lattner SBProcess::Continue ()
55930fdc8d8SChris Lattner {
5602d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
561ceb6b139SCaroline Tice 
56230fdc8d8SChris Lattner     SBError sb_error;
563acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
5640c74e78dSGreg Clayton 
565acdbe816SGreg Clayton     if (log)
566acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::Continue ()...", process_sp.get());
567acdbe816SGreg Clayton 
568acdbe816SGreg Clayton     if (process_sp)
569acdbe816SGreg Clayton     {
570acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
571acdbe816SGreg Clayton 
572acdbe816SGreg Clayton         Error error (process_sp->Resume());
5735d5028b5SGreg Clayton         if (error.Success())
5745d5028b5SGreg Clayton         {
575acdbe816SGreg Clayton             if (process_sp->GetTarget().GetDebugger().GetAsyncExecution () == false)
5764838131bSGreg Clayton             {
5774838131bSGreg Clayton                 if (log)
578acdbe816SGreg Clayton                     log->Printf ("SBProcess(%p)::Continue () waiting for process to stop...", process_sp.get());
579acdbe816SGreg Clayton                 process_sp->WaitForProcessToStop (NULL);
5805d5028b5SGreg Clayton             }
5814838131bSGreg Clayton         }
5825d5028b5SGreg Clayton         sb_error.SetError(error);
5835d5028b5SGreg Clayton     }
58430fdc8d8SChris Lattner     else
58530fdc8d8SChris Lattner         sb_error.SetErrorString ("SBProcess is invalid");
58630fdc8d8SChris Lattner 
587ceb6b139SCaroline Tice     if (log)
588ceb6b139SCaroline Tice     {
589ceb6b139SCaroline Tice         SBStream sstr;
590ceb6b139SCaroline Tice         sb_error.GetDescription (sstr);
591acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::Continue () => SBError (%p): %s", process_sp.get(), sb_error.get(), sstr.GetData());
592ceb6b139SCaroline Tice     }
593ceb6b139SCaroline Tice 
59430fdc8d8SChris Lattner     return sb_error;
59530fdc8d8SChris Lattner }
59630fdc8d8SChris Lattner 
59730fdc8d8SChris Lattner 
59830fdc8d8SChris Lattner SBError
59930fdc8d8SChris Lattner SBProcess::Destroy ()
60030fdc8d8SChris Lattner {
60130fdc8d8SChris Lattner     SBError sb_error;
602acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
603acdbe816SGreg Clayton     if (process_sp)
6046779606aSGreg Clayton     {
605acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
606acdbe816SGreg Clayton         sb_error.SetError(process_sp->Destroy());
6076779606aSGreg Clayton     }
60830fdc8d8SChris Lattner     else
60930fdc8d8SChris Lattner         sb_error.SetErrorString ("SBProcess is invalid");
61030fdc8d8SChris Lattner 
6112d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
6124838131bSGreg Clayton     if (log)
6134838131bSGreg Clayton     {
6144838131bSGreg Clayton         SBStream sstr;
6154838131bSGreg Clayton         sb_error.GetDescription (sstr);
6166779606aSGreg Clayton         log->Printf ("SBProcess(%p)::Destroy () => SBError (%p): %s",
617acdbe816SGreg Clayton                      process_sp.get(),
6186779606aSGreg Clayton                      sb_error.get(),
6196779606aSGreg Clayton                      sstr.GetData());
6204838131bSGreg Clayton     }
6214838131bSGreg Clayton 
62230fdc8d8SChris Lattner     return sb_error;
62330fdc8d8SChris Lattner }
62430fdc8d8SChris Lattner 
62530fdc8d8SChris Lattner 
62630fdc8d8SChris Lattner SBError
62730fdc8d8SChris Lattner SBProcess::Stop ()
62830fdc8d8SChris Lattner {
62930fdc8d8SChris Lattner     SBError sb_error;
630acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
631acdbe816SGreg Clayton     if (process_sp)
632af67cecdSGreg Clayton     {
633acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
634acdbe816SGreg Clayton         sb_error.SetError (process_sp->Halt());
635af67cecdSGreg Clayton     }
63630fdc8d8SChris Lattner     else
63730fdc8d8SChris Lattner         sb_error.SetErrorString ("SBProcess is invalid");
638ceb6b139SCaroline Tice 
6392d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
640ceb6b139SCaroline Tice     if (log)
641ceb6b139SCaroline Tice     {
642ceb6b139SCaroline Tice         SBStream sstr;
643ceb6b139SCaroline Tice         sb_error.GetDescription (sstr);
64493aa84e8SGreg Clayton         log->Printf ("SBProcess(%p)::Stop () => SBError (%p): %s",
645acdbe816SGreg Clayton                      process_sp.get(),
64693aa84e8SGreg Clayton                      sb_error.get(),
647750cd175SCaroline Tice                      sstr.GetData());
648ceb6b139SCaroline Tice     }
649ceb6b139SCaroline Tice 
65030fdc8d8SChris Lattner     return sb_error;
65130fdc8d8SChris Lattner }
65230fdc8d8SChris Lattner 
65330fdc8d8SChris Lattner SBError
65430fdc8d8SChris Lattner SBProcess::Kill ()
65530fdc8d8SChris Lattner {
65630fdc8d8SChris Lattner     SBError sb_error;
657acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
658acdbe816SGreg Clayton     if (process_sp)
659af67cecdSGreg Clayton     {
660acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
661acdbe816SGreg Clayton         sb_error.SetError (process_sp->Destroy());
662af67cecdSGreg Clayton     }
66330fdc8d8SChris Lattner     else
66430fdc8d8SChris Lattner         sb_error.SetErrorString ("SBProcess is invalid");
665ceb6b139SCaroline Tice 
6662d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
667ceb6b139SCaroline Tice     if (log)
668ceb6b139SCaroline Tice     {
669ceb6b139SCaroline Tice         SBStream sstr;
670ceb6b139SCaroline Tice         sb_error.GetDescription (sstr);
67193aa84e8SGreg Clayton         log->Printf ("SBProcess(%p)::Kill () => SBError (%p): %s",
672acdbe816SGreg Clayton                      process_sp.get(),
67393aa84e8SGreg Clayton                      sb_error.get(),
674750cd175SCaroline Tice                      sstr.GetData());
675ceb6b139SCaroline Tice     }
676ceb6b139SCaroline Tice 
67730fdc8d8SChris Lattner     return sb_error;
67830fdc8d8SChris Lattner }
67930fdc8d8SChris Lattner 
68030fdc8d8SChris Lattner SBError
68130fdc8d8SChris Lattner SBProcess::Detach ()
68230fdc8d8SChris Lattner {
68330fdc8d8SChris Lattner     SBError sb_error;
684acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
685acdbe816SGreg Clayton     if (process_sp)
686af67cecdSGreg Clayton     {
687acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
688acdbe816SGreg Clayton         sb_error.SetError (process_sp->Detach());
689af67cecdSGreg Clayton     }
69030fdc8d8SChris Lattner     else
69130fdc8d8SChris Lattner         sb_error.SetErrorString ("SBProcess is invalid");
69230fdc8d8SChris Lattner 
69330fdc8d8SChris Lattner     return sb_error;
69430fdc8d8SChris Lattner }
69530fdc8d8SChris Lattner 
69630fdc8d8SChris Lattner SBError
6974838131bSGreg Clayton SBProcess::Signal (int signo)
69830fdc8d8SChris Lattner {
69930fdc8d8SChris Lattner     SBError sb_error;
700acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
701acdbe816SGreg Clayton     if (process_sp)
702af67cecdSGreg Clayton     {
703acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
704acdbe816SGreg Clayton         sb_error.SetError (process_sp->Signal (signo));
705af67cecdSGreg Clayton     }
70630fdc8d8SChris Lattner     else
70730fdc8d8SChris Lattner         sb_error.SetErrorString ("SBProcess is invalid");
7082d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
7094838131bSGreg Clayton     if (log)
7104838131bSGreg Clayton     {
7114838131bSGreg Clayton         SBStream sstr;
7124838131bSGreg Clayton         sb_error.GetDescription (sstr);
7134838131bSGreg Clayton         log->Printf ("SBProcess(%p)::Signal (signo=%i) => SBError (%p): %s",
714acdbe816SGreg Clayton                      process_sp.get(),
7154838131bSGreg Clayton                      signo,
7164838131bSGreg Clayton                      sb_error.get(),
7174838131bSGreg Clayton                      sstr.GetData());
7184838131bSGreg Clayton     }
71930fdc8d8SChris Lattner     return sb_error;
72030fdc8d8SChris Lattner }
72130fdc8d8SChris Lattner 
722cfc0935eSJim Ingham void
723cfc0935eSJim Ingham SBProcess::SendAsyncInterrupt ()
724cfc0935eSJim Ingham {
725cfc0935eSJim Ingham     ProcessSP process_sp(GetSP());
726cfc0935eSJim Ingham     if (process_sp)
727cfc0935eSJim Ingham     {
728cfc0935eSJim Ingham         process_sp->SendAsyncInterrupt ();
729cfc0935eSJim Ingham     }
730cfc0935eSJim Ingham }
731cfc0935eSJim Ingham 
73230fdc8d8SChris Lattner SBThread
7334838131bSGreg Clayton SBProcess::GetThreadByID (tid_t tid)
73430fdc8d8SChris Lattner {
7354838131bSGreg Clayton     SBThread sb_thread;
73617a6ad05SGreg Clayton     ThreadSP thread_sp;
737acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
738acdbe816SGreg Clayton     if (process_sp)
739af67cecdSGreg Clayton     {
740acdbe816SGreg Clayton         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
7417fdf9ef1SGreg Clayton         Process::StopLocker stop_locker;
7427fdf9ef1SGreg Clayton         const bool can_update = stop_locker.TryLock(&process_sp->GetRunLock());
7437fdf9ef1SGreg Clayton         thread_sp = process_sp->GetThreadList().FindThreadByID (tid, can_update);
74417a6ad05SGreg Clayton         sb_thread.SetThread (thread_sp);
745af67cecdSGreg Clayton     }
7464838131bSGreg Clayton 
7472d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
7484838131bSGreg Clayton     if (log)
7494838131bSGreg Clayton     {
75061e7a58cSGreg Clayton         log->Printf ("SBProcess(%p)::GetThreadByID (tid=0x%4.4llx) => SBThread (%p)",
751acdbe816SGreg Clayton                      process_sp.get(),
7524838131bSGreg Clayton                      tid,
75317a6ad05SGreg Clayton                      thread_sp.get());
7544838131bSGreg Clayton     }
7554838131bSGreg Clayton 
7564838131bSGreg Clayton     return sb_thread;
75730fdc8d8SChris Lattner }
75830fdc8d8SChris Lattner 
75918b46896SJim Ingham SBThread
76018b46896SJim Ingham SBProcess::GetThreadByIndexID (uint32_t index_id)
76118b46896SJim Ingham {
76218b46896SJim Ingham     SBThread sb_thread;
76318b46896SJim Ingham     ThreadSP thread_sp;
76418b46896SJim Ingham     ProcessSP process_sp(GetSP());
76518b46896SJim Ingham     if (process_sp)
76618b46896SJim Ingham     {
76718b46896SJim Ingham         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
76818b46896SJim Ingham         Process::StopLocker stop_locker;
76918b46896SJim Ingham         const bool can_update = stop_locker.TryLock(&process_sp->GetRunLock());
77018b46896SJim Ingham         thread_sp = process_sp->GetThreadList().FindThreadByIndexID (index_id, can_update);
77118b46896SJim Ingham         sb_thread.SetThread (thread_sp);
77218b46896SJim Ingham     }
77318b46896SJim Ingham 
77418b46896SJim Ingham     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
77518b46896SJim Ingham     if (log)
77618b46896SJim Ingham     {
77718b46896SJim Ingham         log->Printf ("SBProcess(%p)::GetThreadByID (tid=0x%x) => SBThread (%p)",
77818b46896SJim Ingham                      process_sp.get(),
77918b46896SJim Ingham                      index_id,
78018b46896SJim Ingham                      thread_sp.get());
78118b46896SJim Ingham     }
78218b46896SJim Ingham 
78318b46896SJim Ingham     return sb_thread;
78418b46896SJim Ingham }
78518b46896SJim Ingham 
78630fdc8d8SChris Lattner StateType
78730fdc8d8SChris Lattner SBProcess::GetStateFromEvent (const SBEvent &event)
78830fdc8d8SChris Lattner {
7892d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
790ceb6b139SCaroline Tice 
791ceb6b139SCaroline Tice     StateType ret_val = Process::ProcessEventData::GetStateFromEvent (event.get());
792ceb6b139SCaroline Tice 
793ceb6b139SCaroline Tice     if (log)
794cfd1acedSGreg Clayton         log->Printf ("SBProcess::GetStateFromEvent (event.sp=%p) => %s", event.get(),
795750cd175SCaroline Tice                      lldb_private::StateAsCString (ret_val));
796ceb6b139SCaroline Tice 
797ceb6b139SCaroline Tice     return ret_val;
79830fdc8d8SChris Lattner }
79930fdc8d8SChris Lattner 
80030fdc8d8SChris Lattner bool
80130fdc8d8SChris Lattner SBProcess::GetRestartedFromEvent (const SBEvent &event)
80230fdc8d8SChris Lattner {
8036611103cSGreg Clayton     return Process::ProcessEventData::GetRestartedFromEvent (event.get());
80430fdc8d8SChris Lattner }
80530fdc8d8SChris Lattner 
80630fdc8d8SChris Lattner SBProcess
80730fdc8d8SChris Lattner SBProcess::GetProcessFromEvent (const SBEvent &event)
80830fdc8d8SChris Lattner {
8096611103cSGreg Clayton     SBProcess process(Process::ProcessEventData::GetProcessFromEvent (event.get()));
81030fdc8d8SChris Lattner     return process;
81130fdc8d8SChris Lattner }
81230fdc8d8SChris Lattner 
813e6bc6cb9SJim Ingham bool
814e6bc6cb9SJim Ingham SBProcess::EventIsProcessEvent (const SBEvent &event)
815e6bc6cb9SJim Ingham {
8164bddaeb5SJim Ingham     return strcmp (event.GetBroadcasterClass(), SBProcess::GetBroadcasterClass()) == 0;
817e6bc6cb9SJim Ingham }
81830fdc8d8SChris Lattner 
81930fdc8d8SChris Lattner SBBroadcaster
82030fdc8d8SChris Lattner SBProcess::GetBroadcaster () const
82130fdc8d8SChris Lattner {
8222d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
823ceb6b139SCaroline Tice 
824acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
825acdbe816SGreg Clayton 
826acdbe816SGreg Clayton     SBBroadcaster broadcaster(process_sp.get(), false);
827ceb6b139SCaroline Tice 
828ceb6b139SCaroline Tice     if (log)
829acdbe816SGreg Clayton         log->Printf ("SBProcess(%p)::GetBroadcaster () => SBBroadcaster (%p)",  process_sp.get(),
830750cd175SCaroline Tice                      broadcaster.get());
831ceb6b139SCaroline Tice 
83230fdc8d8SChris Lattner     return broadcaster;
83330fdc8d8SChris Lattner }
83430fdc8d8SChris Lattner 
8354bddaeb5SJim Ingham const char *
8364bddaeb5SJim Ingham SBProcess::GetBroadcasterClass ()
8374bddaeb5SJim Ingham {
8384bddaeb5SJim Ingham     return Process::GetStaticBroadcasterClass().AsCString();
8394bddaeb5SJim Ingham }
8404bddaeb5SJim Ingham 
84130fdc8d8SChris Lattner size_t
84230fdc8d8SChris Lattner SBProcess::ReadMemory (addr_t addr, void *dst, size_t dst_len, SBError &sb_error)
84330fdc8d8SChris Lattner {
8442d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
845ceb6b139SCaroline Tice 
84630fdc8d8SChris Lattner     size_t bytes_read = 0;
84730fdc8d8SChris Lattner 
848acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
849acdbe816SGreg Clayton 
8504838131bSGreg Clayton     if (log)
8514838131bSGreg Clayton     {
8524838131bSGreg Clayton         log->Printf ("SBProcess(%p)::ReadMemory (addr=0x%llx, dst=%p, dst_len=%zu, SBError (%p))...",
853acdbe816SGreg Clayton                      process_sp.get(),
8544838131bSGreg Clayton                      addr,
8554838131bSGreg Clayton                      dst,
856c91d804aSGreg Clayton                      dst_len,
8574838131bSGreg Clayton                      sb_error.get());
8584838131bSGreg Clayton     }
8594838131bSGreg Clayton 
860acdbe816SGreg Clayton     if (process_sp)
86130fdc8d8SChris Lattner     {
8627fdf9ef1SGreg Clayton         Process::StopLocker stop_locker;
8637fdf9ef1SGreg Clayton         if (stop_locker.TryLock(&process_sp->GetRunLock()))
8647fdf9ef1SGreg Clayton         {
865acdbe816SGreg Clayton             Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
8667fdf9ef1SGreg Clayton             bytes_read = process_sp->ReadMemory (addr, dst, dst_len, sb_error.ref());
8677fdf9ef1SGreg Clayton         }
8687fdf9ef1SGreg Clayton         else
8697fdf9ef1SGreg Clayton         {
870c9858e4dSGreg Clayton             if (log)
871c9858e4dSGreg Clayton                 log->Printf ("SBProcess(%p)::ReadMemory() => error: process is running", process_sp.get());
8727fdf9ef1SGreg Clayton             sb_error.SetErrorString("process is running");
8737fdf9ef1SGreg Clayton         }
87430fdc8d8SChris Lattner     }
87530fdc8d8SChris Lattner     else
87630fdc8d8SChris Lattner     {
87730fdc8d8SChris Lattner         sb_error.SetErrorString ("SBProcess is invalid");
87830fdc8d8SChris Lattner     }
87930fdc8d8SChris Lattner 
880ceb6b139SCaroline Tice     if (log)
88193aa84e8SGreg Clayton     {
88293aa84e8SGreg Clayton         SBStream sstr;
88393aa84e8SGreg Clayton         sb_error.GetDescription (sstr);
884c91d804aSGreg Clayton         log->Printf ("SBProcess(%p)::ReadMemory (addr=0x%llx, dst=%p, dst_len=%zu, SBError (%p): %s) => %zu",
885acdbe816SGreg Clayton                      process_sp.get(),
88693aa84e8SGreg Clayton                      addr,
88793aa84e8SGreg Clayton                      dst,
888c91d804aSGreg Clayton                      dst_len,
88993aa84e8SGreg Clayton                      sb_error.get(),
89093aa84e8SGreg Clayton                      sstr.GetData(),
891c91d804aSGreg Clayton                      bytes_read);
89293aa84e8SGreg Clayton     }
893ceb6b139SCaroline Tice 
89430fdc8d8SChris Lattner     return bytes_read;
89530fdc8d8SChris Lattner }
89630fdc8d8SChris Lattner 
89730fdc8d8SChris Lattner size_t
898e91b7957SGreg Clayton SBProcess::ReadCStringFromMemory (addr_t addr, void *buf, size_t size, lldb::SBError &sb_error)
899e91b7957SGreg Clayton {
900e91b7957SGreg Clayton     size_t bytes_read = 0;
901acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
902acdbe816SGreg Clayton     if (process_sp)
903e91b7957SGreg Clayton     {
9047fdf9ef1SGreg Clayton         Process::StopLocker stop_locker;
9057fdf9ef1SGreg Clayton         if (stop_locker.TryLock(&process_sp->GetRunLock()))
9067fdf9ef1SGreg Clayton         {
907acdbe816SGreg Clayton             Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
9087fdf9ef1SGreg Clayton             bytes_read = process_sp->ReadCStringFromMemory (addr, (char *)buf, size, sb_error.ref());
9097fdf9ef1SGreg Clayton         }
9107fdf9ef1SGreg Clayton         else
9117fdf9ef1SGreg Clayton         {
912c9858e4dSGreg Clayton             LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
913c9858e4dSGreg Clayton             if (log)
914c9858e4dSGreg Clayton                 log->Printf ("SBProcess(%p)::ReadCStringFromMemory() => error: process is running", process_sp.get());
9157fdf9ef1SGreg Clayton             sb_error.SetErrorString("process is running");
9167fdf9ef1SGreg Clayton         }
917e91b7957SGreg Clayton     }
918e91b7957SGreg Clayton     else
919e91b7957SGreg Clayton     {
920e91b7957SGreg Clayton         sb_error.SetErrorString ("SBProcess is invalid");
921e91b7957SGreg Clayton     }
922e91b7957SGreg Clayton     return bytes_read;
923e91b7957SGreg Clayton }
924e91b7957SGreg Clayton 
925e91b7957SGreg Clayton uint64_t
926e91b7957SGreg Clayton SBProcess::ReadUnsignedFromMemory (addr_t addr, uint32_t byte_size, lldb::SBError &sb_error)
927e91b7957SGreg Clayton {
9287fdf9ef1SGreg Clayton     uint64_t value = 0;
929acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
930acdbe816SGreg Clayton     if (process_sp)
931e91b7957SGreg Clayton     {
9327fdf9ef1SGreg Clayton         Process::StopLocker stop_locker;
9337fdf9ef1SGreg Clayton         if (stop_locker.TryLock(&process_sp->GetRunLock()))
9347fdf9ef1SGreg Clayton         {
935acdbe816SGreg Clayton             Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
9367fdf9ef1SGreg Clayton             value = process_sp->ReadUnsignedIntegerFromMemory (addr, byte_size, 0, sb_error.ref());
9377fdf9ef1SGreg Clayton         }
9387fdf9ef1SGreg Clayton         else
9397fdf9ef1SGreg Clayton         {
940c9858e4dSGreg Clayton             LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
941c9858e4dSGreg Clayton             if (log)
942c9858e4dSGreg Clayton                 log->Printf ("SBProcess(%p)::ReadUnsignedFromMemory() => error: process is running", process_sp.get());
9437fdf9ef1SGreg Clayton             sb_error.SetErrorString("process is running");
9447fdf9ef1SGreg Clayton         }
945e91b7957SGreg Clayton     }
946e91b7957SGreg Clayton     else
947e91b7957SGreg Clayton     {
948e91b7957SGreg Clayton         sb_error.SetErrorString ("SBProcess is invalid");
949e91b7957SGreg Clayton     }
9507fdf9ef1SGreg Clayton     return value;
951e91b7957SGreg Clayton }
952e91b7957SGreg Clayton 
953e91b7957SGreg Clayton lldb::addr_t
954e91b7957SGreg Clayton SBProcess::ReadPointerFromMemory (addr_t addr, lldb::SBError &sb_error)
955e91b7957SGreg Clayton {
956e91b7957SGreg Clayton     lldb::addr_t ptr = LLDB_INVALID_ADDRESS;
957acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
958acdbe816SGreg Clayton     if (process_sp)
959e91b7957SGreg Clayton     {
9607fdf9ef1SGreg Clayton         Process::StopLocker stop_locker;
9617fdf9ef1SGreg Clayton         if (stop_locker.TryLock(&process_sp->GetRunLock()))
9627fdf9ef1SGreg Clayton         {
963acdbe816SGreg Clayton             Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
9647fdf9ef1SGreg Clayton             ptr = process_sp->ReadPointerFromMemory (addr, sb_error.ref());
9657fdf9ef1SGreg Clayton         }
9667fdf9ef1SGreg Clayton         else
9677fdf9ef1SGreg Clayton         {
968c9858e4dSGreg Clayton             LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
969c9858e4dSGreg Clayton             if (log)
970c9858e4dSGreg Clayton                 log->Printf ("SBProcess(%p)::ReadPointerFromMemory() => error: process is running", process_sp.get());
9717fdf9ef1SGreg Clayton             sb_error.SetErrorString("process is running");
9727fdf9ef1SGreg Clayton         }
973e91b7957SGreg Clayton     }
974e91b7957SGreg Clayton     else
975e91b7957SGreg Clayton     {
976e91b7957SGreg Clayton         sb_error.SetErrorString ("SBProcess is invalid");
977e91b7957SGreg Clayton     }
978e91b7957SGreg Clayton     return ptr;
979e91b7957SGreg Clayton }
980e91b7957SGreg Clayton 
981e91b7957SGreg Clayton size_t
98230fdc8d8SChris Lattner SBProcess::WriteMemory (addr_t addr, const void *src, size_t src_len, SBError &sb_error)
98330fdc8d8SChris Lattner {
98430fdc8d8SChris Lattner     size_t bytes_written = 0;
98530fdc8d8SChris Lattner 
9862d4edfbcSGreg Clayton     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
987acdbe816SGreg Clayton 
988acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
989acdbe816SGreg Clayton 
9904838131bSGreg Clayton     if (log)
9914838131bSGreg Clayton     {
9924838131bSGreg Clayton         log->Printf ("SBProcess(%p)::WriteMemory (addr=0x%llx, src=%p, dst_len=%zu, SBError (%p))...",
993acdbe816SGreg Clayton                      process_sp.get(),
9944838131bSGreg Clayton                      addr,
9954838131bSGreg Clayton                      src,
996c91d804aSGreg Clayton                      src_len,
9974838131bSGreg Clayton                      sb_error.get());
9984838131bSGreg Clayton     }
9994838131bSGreg Clayton 
1000acdbe816SGreg Clayton     if (process_sp)
100130fdc8d8SChris Lattner     {
10027fdf9ef1SGreg Clayton         Process::StopLocker stop_locker;
10037fdf9ef1SGreg Clayton         if (stop_locker.TryLock(&process_sp->GetRunLock()))
10047fdf9ef1SGreg Clayton         {
1005acdbe816SGreg Clayton             Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
10067fdf9ef1SGreg Clayton             bytes_written = process_sp->WriteMemory (addr, src, src_len, sb_error.ref());
10077fdf9ef1SGreg Clayton         }
10087fdf9ef1SGreg Clayton         else
10097fdf9ef1SGreg Clayton         {
1010c9858e4dSGreg Clayton             if (log)
1011c9858e4dSGreg Clayton                 log->Printf ("SBProcess(%p)::WriteMemory() => error: process is running", process_sp.get());
10127fdf9ef1SGreg Clayton             sb_error.SetErrorString("process is running");
10137fdf9ef1SGreg Clayton         }
101430fdc8d8SChris Lattner     }
101530fdc8d8SChris Lattner 
10164838131bSGreg Clayton     if (log)
10174838131bSGreg Clayton     {
10184838131bSGreg Clayton         SBStream sstr;
10194838131bSGreg Clayton         sb_error.GetDescription (sstr);
1020c91d804aSGreg Clayton         log->Printf ("SBProcess(%p)::WriteMemory (addr=0x%llx, src=%p, dst_len=%zu, SBError (%p): %s) => %zu",
1021acdbe816SGreg Clayton                      process_sp.get(),
10224838131bSGreg Clayton                      addr,
10234838131bSGreg Clayton                      src,
1024c91d804aSGreg Clayton                      src_len,
10254838131bSGreg Clayton                      sb_error.get(),
10264838131bSGreg Clayton                      sstr.GetData(),
1027c91d804aSGreg Clayton                      bytes_written);
10284838131bSGreg Clayton     }
10294838131bSGreg Clayton 
103030fdc8d8SChris Lattner     return bytes_written;
103130fdc8d8SChris Lattner }
103230fdc8d8SChris Lattner 
1033dde9cff3SCaroline Tice bool
1034dde9cff3SCaroline Tice SBProcess::GetDescription (SBStream &description)
1035dde9cff3SCaroline Tice {
1036da7bc7d0SGreg Clayton     Stream &strm = description.ref();
1037da7bc7d0SGreg Clayton 
1038acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
1039acdbe816SGreg Clayton     if (process_sp)
1040dde9cff3SCaroline Tice     {
1041dde9cff3SCaroline Tice         char path[PATH_MAX];
1042dde9cff3SCaroline Tice         GetTarget().GetExecutable().GetPath (path, sizeof(path));
1043acdbe816SGreg Clayton         Module *exe_module = process_sp->GetTarget().GetExecutableModulePointer();
10441d273166SGreg Clayton         const char *exe_name = NULL;
10451d273166SGreg Clayton         if (exe_module)
10461d273166SGreg Clayton             exe_name = exe_module->GetFileSpec().GetFilename().AsCString();
10471d273166SGreg Clayton 
1048da7bc7d0SGreg Clayton         strm.Printf ("SBProcess: pid = %llu, state = %s, threads = %d%s%s",
1049acdbe816SGreg Clayton                      process_sp->GetID(),
1050ceb6b139SCaroline Tice                      lldb_private::StateAsCString (GetState()),
10511d273166SGreg Clayton                      GetNumThreads(),
105205faeb71SGreg Clayton                      exe_name ? ", executable = " : "",
10531d273166SGreg Clayton                      exe_name ? exe_name : "");
1054dde9cff3SCaroline Tice     }
1055dde9cff3SCaroline Tice     else
1056da7bc7d0SGreg Clayton         strm.PutCString ("No value");
1057dde9cff3SCaroline Tice 
1058dde9cff3SCaroline Tice     return true;
1059dde9cff3SCaroline Tice }
10608f343b09SGreg Clayton 
10618f343b09SGreg Clayton uint32_t
1062f9ef60d2SJohnny Chen SBProcess::GetNumSupportedHardwareWatchpoints (lldb::SBError &sb_error) const
1063f9ef60d2SJohnny Chen {
1064f9ef60d2SJohnny Chen     LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1065f9ef60d2SJohnny Chen 
1066f9ef60d2SJohnny Chen     uint32_t num = 0;
1067f9ef60d2SJohnny Chen     ProcessSP process_sp(GetSP());
1068f9ef60d2SJohnny Chen     if (process_sp)
1069f9ef60d2SJohnny Chen     {
1070f9ef60d2SJohnny Chen         Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
1071f9ef60d2SJohnny Chen         sb_error.SetError(process_sp->GetWatchpointSupportInfo (num));
1072f9ef60d2SJohnny Chen         LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1073f9ef60d2SJohnny Chen         if (log)
1074f9ef60d2SJohnny Chen             log->Printf ("SBProcess(%p)::GetNumSupportedHardwareWatchpoints () => %u",
1075f9ef60d2SJohnny Chen                          process_sp.get(), num);
1076f9ef60d2SJohnny Chen     }
1077f9ef60d2SJohnny Chen     else
1078f9ef60d2SJohnny Chen     {
1079f9ef60d2SJohnny Chen         sb_error.SetErrorString ("SBProcess is invalid");
1080f9ef60d2SJohnny Chen     }
1081f9ef60d2SJohnny Chen     return num;
1082f9ef60d2SJohnny Chen }
1083f9ef60d2SJohnny Chen 
1084f9ef60d2SJohnny Chen uint32_t
10858f343b09SGreg Clayton SBProcess::LoadImage (lldb::SBFileSpec &sb_image_spec, lldb::SBError &sb_error)
10868f343b09SGreg Clayton {
1087acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
1088acdbe816SGreg Clayton     if (process_sp)
1089af67cecdSGreg 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());
1094acdbe816SGreg Clayton             return process_sp->LoadImage (*sb_image_spec, sb_error.ref());
1095af67cecdSGreg Clayton         }
10967fdf9ef1SGreg Clayton         else
10977fdf9ef1SGreg Clayton         {
1098c9858e4dSGreg Clayton             LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1099c9858e4dSGreg Clayton             if (log)
1100c9858e4dSGreg Clayton                 log->Printf ("SBProcess(%p)::LoadImage() => error: process is running", process_sp.get());
11017fdf9ef1SGreg Clayton             sb_error.SetErrorString("process is running");
11027fdf9ef1SGreg Clayton         }
11037fdf9ef1SGreg Clayton     }
11048f343b09SGreg Clayton     return LLDB_INVALID_IMAGE_TOKEN;
11058f343b09SGreg Clayton }
11068f343b09SGreg Clayton 
11078f343b09SGreg Clayton lldb::SBError
11088f343b09SGreg Clayton SBProcess::UnloadImage (uint32_t image_token)
11098f343b09SGreg Clayton {
11108f343b09SGreg Clayton     lldb::SBError sb_error;
1111acdbe816SGreg Clayton     ProcessSP process_sp(GetSP());
1112acdbe816SGreg Clayton     if (process_sp)
1113af67cecdSGreg Clayton     {
11147fdf9ef1SGreg Clayton         Process::StopLocker stop_locker;
11157fdf9ef1SGreg Clayton         if (stop_locker.TryLock(&process_sp->GetRunLock()))
11167fdf9ef1SGreg Clayton         {
1117acdbe816SGreg Clayton             Mutex::Locker api_locker (process_sp->GetTarget().GetAPIMutex());
1118acdbe816SGreg Clayton             sb_error.SetError (process_sp->UnloadImage (image_token));
1119af67cecdSGreg Clayton         }
11208f343b09SGreg Clayton         else
11217fdf9ef1SGreg Clayton         {
1122c9858e4dSGreg Clayton             LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
1123c9858e4dSGreg Clayton             if (log)
1124c9858e4dSGreg Clayton                 log->Printf ("SBProcess(%p)::UnloadImage() => error: process is running", process_sp.get());
11257fdf9ef1SGreg Clayton             sb_error.SetErrorString("process is running");
11267fdf9ef1SGreg Clayton         }
11277fdf9ef1SGreg Clayton     }
11287fdf9ef1SGreg Clayton     else
11298f343b09SGreg Clayton         sb_error.SetErrorString("invalid process");
11308f343b09SGreg Clayton     return sb_error;
11318f343b09SGreg Clayton }
1132