130fdc8d8SChris Lattner //===-- SBProcess.cpp -------------------------------------------*- C++ -*-===//
230fdc8d8SChris Lattner //
32946cd70SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
42946cd70SChandler Carruth // See https://llvm.org/LICENSE.txt for license information.
52946cd70SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
630fdc8d8SChris Lattner //
730fdc8d8SChris Lattner //===----------------------------------------------------------------------===//
830fdc8d8SChris Lattner 
94c5de699SEli Friedman #include "lldb/API/SBProcess.h"
10baf5664fSJonas Devlieghere #include "SBReproducerPrivate.h"
1130fdc8d8SChris Lattner 
12bdae3787SVirgile Bello #include <inttypes.h>
13bdae3787SVirgile Bello 
1430fdc8d8SChris Lattner #include "lldb/lldb-defines.h"
1530fdc8d8SChris Lattner #include "lldb/lldb-types.h"
1630fdc8d8SChris Lattner 
175d5028b5SGreg Clayton #include "lldb/Core/Debugger.h"
181f746071SGreg Clayton #include "lldb/Core/Module.h"
19f7d1893fSAdrian McCarthy #include "lldb/Core/PluginManager.h"
2030fdc8d8SChris Lattner #include "lldb/Core/StreamFile.h"
2126036843SHoward Hellyer #include "lldb/Target/MemoryRegionInfo.h"
2230fdc8d8SChris Lattner #include "lldb/Target/Process.h"
2330fdc8d8SChris Lattner #include "lldb/Target/RegisterContext.h"
248c71337aSJason Molenda #include "lldb/Target/SystemRuntime.h"
256611103cSGreg Clayton #include "lldb/Target/Target.h"
266611103cSGreg Clayton #include "lldb/Target/Thread.h"
27145d95c9SPavel Labath #include "lldb/Utility/Args.h"
28805e7106SZachary Turner #include "lldb/Utility/ProcessInfo.h"
29d821c997SPavel Labath #include "lldb/Utility/State.h"
30bf9a7730SZachary Turner #include "lldb/Utility/Stream.h"
3130fdc8d8SChris Lattner 
3230fdc8d8SChris Lattner 
334c5de699SEli Friedman #include "lldb/API/SBBroadcaster.h"
344c5de699SEli Friedman #include "lldb/API/SBCommandReturnObject.h"
350e615684SGreg Clayton #include "lldb/API/SBDebugger.h"
364c5de699SEli Friedman #include "lldb/API/SBEvent.h"
370e615684SGreg Clayton #include "lldb/API/SBFileSpec.h"
3826036843SHoward Hellyer #include "lldb/API/SBMemoryRegionInfo.h"
3926036843SHoward Hellyer #include "lldb/API/SBMemoryRegionInfoList.h"
40b9c1b51eSKate Stone #include "lldb/API/SBStream.h"
41b9c1b51eSKate Stone #include "lldb/API/SBStringList.h"
4275930019STodd Fiala #include "lldb/API/SBStructuredData.h"
434c5de699SEli Friedman #include "lldb/API/SBThread.h"
44a51ea382SKuba Brecka #include "lldb/API/SBThreadCollection.h"
45d5d8d91cSRavitheja Addepally #include "lldb/API/SBTrace.h"
46d5d8d91cSRavitheja Addepally #include "lldb/API/SBTraceOptions.h"
47802dc402STodd Fiala #include "lldb/API/SBUnixSignals.h"
4830fdc8d8SChris Lattner 
4930fdc8d8SChris Lattner using namespace lldb;
5030fdc8d8SChris Lattner using namespace lldb_private;
5130fdc8d8SChris Lattner 
52baf5664fSJonas Devlieghere SBProcess::SBProcess() : m_opaque_wp() {
53baf5664fSJonas Devlieghere   LLDB_RECORD_CONSTRUCTOR_NO_ARGS(SBProcess);
54baf5664fSJonas Devlieghere }
5530fdc8d8SChris Lattner 
5630fdc8d8SChris Lattner //----------------------------------------------------------------------
5730fdc8d8SChris Lattner // SBProcess constructor
5830fdc8d8SChris Lattner //----------------------------------------------------------------------
5930fdc8d8SChris Lattner 
60baf5664fSJonas Devlieghere SBProcess::SBProcess(const SBProcess &rhs) : m_opaque_wp(rhs.m_opaque_wp) {
61baf5664fSJonas Devlieghere   LLDB_RECORD_CONSTRUCTOR(SBProcess, (const lldb::SBProcess &), rhs);
62baf5664fSJonas Devlieghere }
6330fdc8d8SChris Lattner 
64b9c1b51eSKate Stone SBProcess::SBProcess(const lldb::ProcessSP &process_sp)
65baf5664fSJonas Devlieghere     : m_opaque_wp(process_sp) {
66baf5664fSJonas Devlieghere   LLDB_RECORD_CONSTRUCTOR(SBProcess, (const lldb::ProcessSP &), process_sp);
67baf5664fSJonas Devlieghere }
6830fdc8d8SChris Lattner 
69b9c1b51eSKate Stone const SBProcess &SBProcess::operator=(const SBProcess &rhs) {
70baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(const lldb::SBProcess &,
71baf5664fSJonas Devlieghere                      SBProcess, operator=,(const lldb::SBProcess &), rhs);
72baf5664fSJonas Devlieghere 
73efabb123SGreg Clayton   if (this != &rhs)
744e0fe8abSGreg Clayton     m_opaque_wp = rhs.m_opaque_wp;
75efabb123SGreg Clayton   return *this;
76efabb123SGreg Clayton }
77efabb123SGreg Clayton 
7830fdc8d8SChris Lattner //----------------------------------------------------------------------
7930fdc8d8SChris Lattner // Destructor
8030fdc8d8SChris Lattner //----------------------------------------------------------------------
81b9c1b51eSKate Stone SBProcess::~SBProcess() {}
8230fdc8d8SChris Lattner 
83b9c1b51eSKate Stone const char *SBProcess::GetBroadcasterClassName() {
84baf5664fSJonas Devlieghere   LLDB_RECORD_STATIC_METHOD_NO_ARGS(const char *, SBProcess,
85baf5664fSJonas Devlieghere                                     GetBroadcasterClassName);
86baf5664fSJonas Devlieghere 
874bddaeb5SJim Ingham   return Process::GetStaticBroadcasterClass().AsCString();
884bddaeb5SJim Ingham }
894bddaeb5SJim Ingham 
90b9c1b51eSKate Stone const char *SBProcess::GetPluginName() {
91baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(const char *, SBProcess, GetPluginName);
92baf5664fSJonas Devlieghere 
93d7b30ef9SJim Ingham   ProcessSP process_sp(GetSP());
94b9c1b51eSKate Stone   if (process_sp) {
9557abc5d6SGreg Clayton     return process_sp->GetPluginName().GetCString();
96d7b30ef9SJim Ingham   }
97d7b30ef9SJim Ingham   return "<Unknown>";
98d7b30ef9SJim Ingham }
99d7b30ef9SJim Ingham 
100b9c1b51eSKate Stone const char *SBProcess::GetShortPluginName() {
101baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(const char *, SBProcess, GetShortPluginName);
102baf5664fSJonas Devlieghere 
103d7b30ef9SJim Ingham   ProcessSP process_sp(GetSP());
104b9c1b51eSKate Stone   if (process_sp) {
10557abc5d6SGreg Clayton     return process_sp->GetPluginName().GetCString();
106d7b30ef9SJim Ingham   }
107d7b30ef9SJim Ingham   return "<Unknown>";
108d7b30ef9SJim Ingham }
109d7b30ef9SJim Ingham 
110b9c1b51eSKate Stone lldb::ProcessSP SBProcess::GetSP() const { return m_opaque_wp.lock(); }
111d7b30ef9SJim Ingham 
112b9c1b51eSKate Stone void SBProcess::SetSP(const ProcessSP &process_sp) { m_opaque_wp = process_sp; }
113b9556accSGreg Clayton 
114baf5664fSJonas Devlieghere void SBProcess::Clear() {
115baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(void, SBProcess, Clear);
116baf5664fSJonas Devlieghere 
117baf5664fSJonas Devlieghere   m_opaque_wp.reset();
118baf5664fSJonas Devlieghere }
11930fdc8d8SChris Lattner 
120b9c1b51eSKate Stone bool SBProcess::IsValid() const {
121baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_CONST_NO_ARGS(bool, SBProcess, IsValid);
122baf5664fSJonas Devlieghere 
1234fc6cb9cSJim Ingham   ProcessSP process_sp(m_opaque_wp.lock());
1244fc6cb9cSJim Ingham   return ((bool)process_sp && process_sp->IsValid());
12530fdc8d8SChris Lattner }
12630fdc8d8SChris Lattner 
127b9c1b51eSKate Stone bool SBProcess::RemoteLaunch(char const **argv, char const **envp,
128b9c1b51eSKate Stone                              const char *stdin_path, const char *stdout_path,
1299631aae2SJames McIlree                              const char *stderr_path,
1309631aae2SJames McIlree                              const char *working_directory,
131b9c1b51eSKate Stone                              uint32_t launch_flags, bool stop_at_entry,
132b9c1b51eSKate Stone                              lldb::SBError &error) {
133baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(bool, SBProcess, RemoteLaunch,
134baf5664fSJonas Devlieghere                      (const char **, const char **, const char *, const char *,
135baf5664fSJonas Devlieghere                       const char *, const char *, uint32_t, bool,
136baf5664fSJonas Devlieghere                       lldb::SBError &),
137baf5664fSJonas Devlieghere                      argv, envp, stdin_path, stdout_path, stderr_path,
138baf5664fSJonas Devlieghere                      working_directory, launch_flags, stop_at_entry, error);
139baf5664fSJonas Devlieghere 
140acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
141b9c1b51eSKate Stone   if (process_sp) {
142b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
143b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
144b9c1b51eSKate Stone     if (process_sp->GetState() == eStateConnected) {
145982c9762SGreg Clayton       if (stop_at_entry)
146982c9762SGreg Clayton         launch_flags |= eLaunchFlagStopAtEntry;
1478f3be7a3SJonas Devlieghere       ProcessLaunchInfo launch_info(FileSpec(stdin_path), FileSpec(stdout_path),
1488f3be7a3SJonas Devlieghere                                     FileSpec(stderr_path),
1498f3be7a3SJonas Devlieghere                                     FileSpec(working_directory), launch_flags);
150acdbe816SGreg Clayton       Module *exe_module = process_sp->GetTarget().GetExecutableModulePointer();
151982c9762SGreg Clayton       if (exe_module)
15214715c68SGreg Clayton         launch_info.SetExecutableFile(exe_module->GetPlatformFileSpec(), true);
153982c9762SGreg Clayton       if (argv)
154982c9762SGreg Clayton         launch_info.GetArguments().AppendArguments(argv);
155982c9762SGreg Clayton       if (envp)
15662930e57SPavel Labath         launch_info.GetEnvironment() = Environment(envp);
157acdbe816SGreg Clayton       error.SetError(process_sp->Launch(launch_info));
158b9c1b51eSKate Stone     } else {
1599631aae2SJames McIlree       error.SetErrorString("must be in eStateConnected to call RemoteLaunch");
1609631aae2SJames McIlree     }
161b9c1b51eSKate Stone   } else {
1629631aae2SJames McIlree     error.SetErrorString("unable to attach pid");
1639631aae2SJames McIlree   }
1649631aae2SJames McIlree 
1659631aae2SJames McIlree   return error.Success();
1669631aae2SJames McIlree }
1679631aae2SJames McIlree 
168b9c1b51eSKate Stone bool SBProcess::RemoteAttachToProcessWithID(lldb::pid_t pid,
169b9c1b51eSKate Stone                                             lldb::SBError &error) {
170baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(bool, SBProcess, RemoteAttachToProcessWithID,
171baf5664fSJonas Devlieghere                      (lldb::pid_t, lldb::SBError &), pid, error);
172baf5664fSJonas Devlieghere 
173acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
174b9c1b51eSKate Stone   if (process_sp) {
175b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
176b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
177b9c1b51eSKate Stone     if (process_sp->GetState() == eStateConnected) {
178144f3a9cSGreg Clayton       ProcessAttachInfo attach_info;
179144f3a9cSGreg Clayton       attach_info.SetProcessID(pid);
180acdbe816SGreg Clayton       error.SetError(process_sp->Attach(attach_info));
181b9c1b51eSKate Stone     } else {
182b9c1b51eSKate Stone       error.SetErrorString(
183b9c1b51eSKate Stone           "must be in eStateConnected to call RemoteAttachToProcessWithID");
1849631aae2SJames McIlree     }
185b9c1b51eSKate Stone   } else {
1869631aae2SJames McIlree     error.SetErrorString("unable to attach pid");
1879631aae2SJames McIlree   }
1889631aae2SJames McIlree 
1899631aae2SJames McIlree   return error.Success();
1909631aae2SJames McIlree }
1919631aae2SJames McIlree 
192b9c1b51eSKate Stone uint32_t SBProcess::GetNumThreads() {
193baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(uint32_t, SBProcess, GetNumThreads);
194baf5664fSJonas Devlieghere 
195ceb6b139SCaroline Tice   uint32_t num_threads = 0;
196acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
197b9c1b51eSKate Stone   if (process_sp) {
1987fdf9ef1SGreg Clayton     Process::StopLocker stop_locker;
1997fdf9ef1SGreg Clayton 
2007fdf9ef1SGreg Clayton     const bool can_update = stop_locker.TryLock(&process_sp->GetRunLock());
201b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
202b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
203acdbe816SGreg Clayton     num_threads = process_sp->GetThreadList().GetSize(can_update);
20430fdc8d8SChris Lattner   }
205ceb6b139SCaroline Tice 
206ceb6b139SCaroline Tice   return num_threads;
20730fdc8d8SChris Lattner }
20830fdc8d8SChris Lattner 
209b9c1b51eSKate Stone SBThread SBProcess::GetSelectedThread() const {
210baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_CONST_NO_ARGS(lldb::SBThread, SBProcess,
211baf5664fSJonas Devlieghere                                    GetSelectedThread);
212baf5664fSJonas Devlieghere 
21330fdc8d8SChris Lattner   SBThread sb_thread;
21417a6ad05SGreg Clayton   ThreadSP thread_sp;
215acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
216b9c1b51eSKate Stone   if (process_sp) {
217b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
218b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
219acdbe816SGreg Clayton     thread_sp = process_sp->GetThreadList().GetSelectedThread();
22017a6ad05SGreg Clayton     sb_thread.SetThread(thread_sp);
221af67cecdSGreg Clayton   }
222ceb6b139SCaroline Tice 
223baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(sb_thread);
22430fdc8d8SChris Lattner }
22530fdc8d8SChris Lattner 
226b9c1b51eSKate Stone SBThread SBProcess::CreateOSPluginThread(lldb::tid_t tid,
227b9c1b51eSKate Stone                                          lldb::addr_t context) {
228baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(lldb::SBThread, SBProcess, CreateOSPluginThread,
229baf5664fSJonas Devlieghere                      (lldb::tid_t, lldb::addr_t), tid, context);
230baf5664fSJonas Devlieghere 
231a4d8747dSGreg Clayton   SBThread sb_thread;
232a4d8747dSGreg Clayton   ThreadSP thread_sp;
233a4d8747dSGreg Clayton   ProcessSP process_sp(GetSP());
234b9c1b51eSKate Stone   if (process_sp) {
235b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
236b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
237a4d8747dSGreg Clayton     thread_sp = process_sp->CreateOSPluginThread(tid, context);
238a4d8747dSGreg Clayton     sb_thread.SetThread(thread_sp);
239a4d8747dSGreg Clayton   }
240a4d8747dSGreg Clayton 
241baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(sb_thread);
242a4d8747dSGreg Clayton }
243a4d8747dSGreg Clayton 
244b9c1b51eSKate Stone SBTarget SBProcess::GetTarget() const {
245baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_CONST_NO_ARGS(lldb::SBTarget, SBProcess, GetTarget);
246baf5664fSJonas Devlieghere 
24730fdc8d8SChris Lattner   SBTarget sb_target;
248b9556accSGreg Clayton   TargetSP target_sp;
249acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
250b9c1b51eSKate Stone   if (process_sp) {
251acdbe816SGreg Clayton     target_sp = process_sp->GetTarget().shared_from_this();
252b9556accSGreg Clayton     sb_target.SetSP(target_sp);
253b9556accSGreg Clayton   }
254ceb6b139SCaroline Tice 
255baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(sb_target);
25630fdc8d8SChris Lattner }
25730fdc8d8SChris Lattner 
258b9c1b51eSKate Stone size_t SBProcess::PutSTDIN(const char *src, size_t src_len) {
259baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(size_t, SBProcess, PutSTDIN, (const char *, size_t), src,
260baf5664fSJonas Devlieghere                      src_len);
261baf5664fSJonas Devlieghere 
262ceb6b139SCaroline Tice   size_t ret_val = 0;
263acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
264b9c1b51eSKate Stone   if (process_sp) {
26597206d57SZachary Turner     Status error;
266acdbe816SGreg Clayton     ret_val = process_sp->PutSTDIN(src, src_len, error);
26730fdc8d8SChris Lattner   }
268ceb6b139SCaroline Tice 
269ceb6b139SCaroline Tice   return ret_val;
27030fdc8d8SChris Lattner }
27130fdc8d8SChris Lattner 
272b9c1b51eSKate Stone size_t SBProcess::GetSTDOUT(char *dst, size_t dst_len) const {
273baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_CONST(size_t, SBProcess, GetSTDOUT, (char *, size_t), dst,
274baf5664fSJonas Devlieghere                            dst_len);
275baf5664fSJonas Devlieghere 
276cfd1acedSGreg Clayton   size_t bytes_read = 0;
277acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
278b9c1b51eSKate Stone   if (process_sp) {
27997206d57SZachary Turner     Status error;
280acdbe816SGreg Clayton     bytes_read = process_sp->GetSTDOUT(dst, dst_len, error);
28130fdc8d8SChris Lattner   }
282ceb6b139SCaroline Tice 
283cfd1acedSGreg Clayton   return bytes_read;
28430fdc8d8SChris Lattner }
28530fdc8d8SChris Lattner 
286b9c1b51eSKate Stone size_t SBProcess::GetSTDERR(char *dst, size_t dst_len) const {
287baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_CONST(size_t, SBProcess, GetSTDERR, (char *, size_t), dst,
288baf5664fSJonas Devlieghere                            dst_len);
289baf5664fSJonas Devlieghere 
290cfd1acedSGreg Clayton   size_t bytes_read = 0;
291acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
292b9c1b51eSKate Stone   if (process_sp) {
29397206d57SZachary Turner     Status error;
294acdbe816SGreg Clayton     bytes_read = process_sp->GetSTDERR(dst, dst_len, error);
29530fdc8d8SChris Lattner   }
296ceb6b139SCaroline Tice 
297cfd1acedSGreg Clayton   return bytes_read;
29830fdc8d8SChris Lattner }
29930fdc8d8SChris Lattner 
300b9c1b51eSKate Stone size_t SBProcess::GetAsyncProfileData(char *dst, size_t dst_len) const {
301baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_CONST(size_t, SBProcess, GetAsyncProfileData,
302baf5664fSJonas Devlieghere                            (char *, size_t), dst, dst_len);
303baf5664fSJonas Devlieghere 
304ab3b8b22SHan Ming Ong   size_t bytes_read = 0;
305ab3b8b22SHan Ming Ong   ProcessSP process_sp(GetSP());
306b9c1b51eSKate Stone   if (process_sp) {
30797206d57SZachary Turner     Status error;
308ab3b8b22SHan Ming Ong     bytes_read = process_sp->GetAsyncProfileData(dst, dst_len, error);
309ab3b8b22SHan Ming Ong   }
310ab3b8b22SHan Ming Ong 
311ab3b8b22SHan Ming Ong   return bytes_read;
312ab3b8b22SHan Ming Ong }
313ab3b8b22SHan Ming Ong 
314d5d8d91cSRavitheja Addepally lldb::SBTrace SBProcess::StartTrace(SBTraceOptions &options,
315d5d8d91cSRavitheja Addepally                                     lldb::SBError &error) {
316baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(lldb::SBTrace, SBProcess, StartTrace,
317baf5664fSJonas Devlieghere                      (lldb::SBTraceOptions &, lldb::SBError &), options, error);
318baf5664fSJonas Devlieghere 
319d5d8d91cSRavitheja Addepally   ProcessSP process_sp(GetSP());
320d5d8d91cSRavitheja Addepally   error.Clear();
321d5d8d91cSRavitheja Addepally   SBTrace trace_instance;
322d5d8d91cSRavitheja Addepally   trace_instance.SetSP(process_sp);
323d5d8d91cSRavitheja Addepally   lldb::user_id_t uid = LLDB_INVALID_UID;
324d5d8d91cSRavitheja Addepally 
325d5d8d91cSRavitheja Addepally   if (!process_sp) {
326d5d8d91cSRavitheja Addepally     error.SetErrorString("invalid process");
327d5d8d91cSRavitheja Addepally   } else {
328e714c4f5SRavitheja Addepally     uid = process_sp->StartTrace(*(options.m_traceoptions_sp), error.ref());
329d5d8d91cSRavitheja Addepally     trace_instance.SetTraceUID(uid);
330d5d8d91cSRavitheja Addepally   }
331baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(trace_instance);
332d5d8d91cSRavitheja Addepally }
333d5d8d91cSRavitheja Addepally 
334b9c1b51eSKate Stone void SBProcess::ReportEventState(const SBEvent &event, FILE *out) const {
335baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_CONST(void, SBProcess, ReportEventState,
336baf5664fSJonas Devlieghere                            (const lldb::SBEvent &, FILE *), event, out);
337baf5664fSJonas Devlieghere 
33830fdc8d8SChris Lattner   if (out == NULL)
33930fdc8d8SChris Lattner     return;
34030fdc8d8SChris Lattner 
341acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
342b9c1b51eSKate Stone   if (process_sp) {
34330fdc8d8SChris Lattner     const StateType event_state = SBProcess::GetStateFromEvent(event);
34430fdc8d8SChris Lattner     char message[1024];
345b9c1b51eSKate Stone     int message_len = ::snprintf(
346b9c1b51eSKate Stone         message, sizeof(message), "Process %" PRIu64 " %s\n",
347b9c1b51eSKate Stone         process_sp->GetID(), SBDebugger::StateAsCString(event_state));
34830fdc8d8SChris Lattner 
34930fdc8d8SChris Lattner     if (message_len > 0)
35030fdc8d8SChris Lattner       ::fwrite(message, 1, message_len, out);
35130fdc8d8SChris Lattner   }
35230fdc8d8SChris Lattner }
35330fdc8d8SChris Lattner 
354b9c1b51eSKate Stone void SBProcess::AppendEventStateReport(const SBEvent &event,
355b9c1b51eSKate Stone                                        SBCommandReturnObject &result) {
356baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(void, SBProcess, AppendEventStateReport,
357baf5664fSJonas Devlieghere                      (const lldb::SBEvent &, lldb::SBCommandReturnObject &),
358baf5664fSJonas Devlieghere                      event, result);
359baf5664fSJonas Devlieghere 
360acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
361b9c1b51eSKate Stone   if (process_sp) {
36230fdc8d8SChris Lattner     const StateType event_state = SBProcess::GetStateFromEvent(event);
36330fdc8d8SChris Lattner     char message[1024];
364b9c1b51eSKate Stone     ::snprintf(message, sizeof(message), "Process %" PRIu64 " %s\n",
365b9c1b51eSKate Stone                process_sp->GetID(), SBDebugger::StateAsCString(event_state));
36630fdc8d8SChris Lattner 
36730fdc8d8SChris Lattner     result.AppendMessage(message);
36830fdc8d8SChris Lattner   }
36930fdc8d8SChris Lattner }
37030fdc8d8SChris Lattner 
371b9c1b51eSKate Stone bool SBProcess::SetSelectedThread(const SBThread &thread) {
372baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(bool, SBProcess, SetSelectedThread,
373baf5664fSJonas Devlieghere                      (const lldb::SBThread &), thread);
374baf5664fSJonas Devlieghere 
375acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
376b9c1b51eSKate Stone   if (process_sp) {
377b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
378b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
379b9c1b51eSKate Stone     return process_sp->GetThreadList().SetSelectedThreadByID(
380b9c1b51eSKate Stone         thread.GetThreadID());
381af67cecdSGreg Clayton   }
38230fdc8d8SChris Lattner   return false;
38330fdc8d8SChris Lattner }
38430fdc8d8SChris Lattner 
385b9c1b51eSKate Stone bool SBProcess::SetSelectedThreadByID(lldb::tid_t tid) {
386baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(bool, SBProcess, SetSelectedThreadByID, (lldb::tid_t),
387baf5664fSJonas Devlieghere                      tid);
388baf5664fSJonas Devlieghere 
389ceb6b139SCaroline Tice 
390ceb6b139SCaroline Tice   bool ret_val = false;
391acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
392b9c1b51eSKate Stone   if (process_sp) {
393b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
394b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
395acdbe816SGreg Clayton     ret_val = process_sp->GetThreadList().SetSelectedThreadByID(tid);
396af67cecdSGreg Clayton   }
397ceb6b139SCaroline Tice 
398ceb6b139SCaroline Tice   return ret_val;
39930fdc8d8SChris Lattner }
40030fdc8d8SChris Lattner 
401b9c1b51eSKate Stone bool SBProcess::SetSelectedThreadByIndexID(uint32_t index_id) {
402baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(bool, SBProcess, SetSelectedThreadByIndexID, (uint32_t),
403baf5664fSJonas Devlieghere                      index_id);
404baf5664fSJonas Devlieghere 
40518b46896SJim Ingham   bool ret_val = false;
40618b46896SJim Ingham   ProcessSP process_sp(GetSP());
407b9c1b51eSKate Stone   if (process_sp) {
408b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
409b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
41018b46896SJim Ingham     ret_val = process_sp->GetThreadList().SetSelectedThreadByIndexID(index_id);
41118b46896SJim Ingham   }
41218b46896SJim Ingham 
41318b46896SJim Ingham 
41418b46896SJim Ingham   return ret_val;
41518b46896SJim Ingham }
41618b46896SJim Ingham 
417b9c1b51eSKate Stone SBThread SBProcess::GetThreadAtIndex(size_t index) {
418baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(lldb::SBThread, SBProcess, GetThreadAtIndex, (size_t),
419baf5664fSJonas Devlieghere                      index);
420baf5664fSJonas Devlieghere 
42117a6ad05SGreg Clayton   SBThread sb_thread;
42217a6ad05SGreg Clayton   ThreadSP thread_sp;
423acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
424b9c1b51eSKate Stone   if (process_sp) {
4257fdf9ef1SGreg Clayton     Process::StopLocker stop_locker;
4267fdf9ef1SGreg Clayton     const bool can_update = stop_locker.TryLock(&process_sp->GetRunLock());
427b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
428b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
4297fdf9ef1SGreg Clayton     thread_sp = process_sp->GetThreadList().GetThreadAtIndex(index, can_update);
43017a6ad05SGreg Clayton     sb_thread.SetThread(thread_sp);
431af67cecdSGreg Clayton   }
432ceb6b139SCaroline Tice 
433baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(sb_thread);
43430fdc8d8SChris Lattner }
43530fdc8d8SChris Lattner 
436b9c1b51eSKate Stone uint32_t SBProcess::GetNumQueues() {
437baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(uint32_t, SBProcess, GetNumQueues);
438baf5664fSJonas Devlieghere 
4395e8dce4dSJason Molenda   uint32_t num_queues = 0;
4405e8dce4dSJason Molenda   ProcessSP process_sp(GetSP());
441b9c1b51eSKate Stone   if (process_sp) {
4425e8dce4dSJason Molenda     Process::StopLocker stop_locker;
443b9c1b51eSKate Stone     if (stop_locker.TryLock(&process_sp->GetRunLock())) {
444b9c1b51eSKate Stone       std::lock_guard<std::recursive_mutex> guard(
445b9c1b51eSKate Stone           process_sp->GetTarget().GetAPIMutex());
4465e8dce4dSJason Molenda       num_queues = process_sp->GetQueueList().GetSize();
4475e8dce4dSJason Molenda     }
448a61d0a5bSGreg Clayton   }
4495e8dce4dSJason Molenda 
4505e8dce4dSJason Molenda   return num_queues;
4515e8dce4dSJason Molenda }
4525e8dce4dSJason Molenda 
453b9c1b51eSKate Stone SBQueue SBProcess::GetQueueAtIndex(size_t index) {
454baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(lldb::SBQueue, SBProcess, GetQueueAtIndex, (size_t),
455baf5664fSJonas Devlieghere                      index);
456baf5664fSJonas Devlieghere 
4575e8dce4dSJason Molenda   SBQueue sb_queue;
4585e8dce4dSJason Molenda   QueueSP queue_sp;
4595e8dce4dSJason Molenda   ProcessSP process_sp(GetSP());
460b9c1b51eSKate Stone   if (process_sp) {
4615e8dce4dSJason Molenda     Process::StopLocker stop_locker;
462b9c1b51eSKate Stone     if (stop_locker.TryLock(&process_sp->GetRunLock())) {
463b9c1b51eSKate Stone       std::lock_guard<std::recursive_mutex> guard(
464b9c1b51eSKate Stone           process_sp->GetTarget().GetAPIMutex());
4655e8dce4dSJason Molenda       queue_sp = process_sp->GetQueueList().GetQueueAtIndex(index);
4665e8dce4dSJason Molenda       sb_queue.SetQueue(queue_sp);
4675e8dce4dSJason Molenda     }
468a61d0a5bSGreg Clayton   }
4695e8dce4dSJason Molenda 
470baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(sb_queue);
4715e8dce4dSJason Molenda }
4725e8dce4dSJason Molenda 
473b9c1b51eSKate Stone uint32_t SBProcess::GetStopID(bool include_expression_stops) {
474baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(uint32_t, SBProcess, GetStopID, (bool),
475baf5664fSJonas Devlieghere                      include_expression_stops);
476baf5664fSJonas Devlieghere 
477bf2956a2SJim Ingham   ProcessSP process_sp(GetSP());
478b9c1b51eSKate Stone   if (process_sp) {
479b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
480b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
481bf2956a2SJim Ingham     if (include_expression_stops)
482bf2956a2SJim Ingham       return process_sp->GetStopID();
483bf2956a2SJim Ingham     else
484bf2956a2SJim Ingham       return process_sp->GetLastNaturalStopID();
485bf2956a2SJim Ingham   }
486bf2956a2SJim Ingham   return 0;
487bf2956a2SJim Ingham }
488bf2956a2SJim Ingham 
489b9c1b51eSKate Stone SBEvent SBProcess::GetStopEventForStopID(uint32_t stop_id) {
490baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(lldb::SBEvent, SBProcess, GetStopEventForStopID,
491baf5664fSJonas Devlieghere                      (uint32_t), stop_id);
492baf5664fSJonas Devlieghere 
49338810f43SIlia K   SBEvent sb_event;
49438810f43SIlia K   EventSP event_sp;
49538810f43SIlia K   ProcessSP process_sp(GetSP());
496b9c1b51eSKate Stone   if (process_sp) {
497b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
498b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
49938810f43SIlia K     event_sp = process_sp->GetStopEventForStopID(stop_id);
50038810f43SIlia K     sb_event.reset(event_sp);
50138810f43SIlia K   }
50238810f43SIlia K 
503baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(sb_event);
50438810f43SIlia K }
50538810f43SIlia K 
506b9c1b51eSKate Stone StateType SBProcess::GetState() {
507baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(lldb::StateType, SBProcess, GetState);
508ceb6b139SCaroline Tice 
509ceb6b139SCaroline Tice   StateType ret_val = eStateInvalid;
510acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
511b9c1b51eSKate Stone   if (process_sp) {
512b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
513b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
514acdbe816SGreg Clayton     ret_val = process_sp->GetState();
515af67cecdSGreg Clayton   }
516ceb6b139SCaroline Tice 
517ceb6b139SCaroline Tice   return ret_val;
51830fdc8d8SChris Lattner }
51930fdc8d8SChris Lattner 
520b9c1b51eSKate Stone int SBProcess::GetExitStatus() {
521baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(int, SBProcess, GetExitStatus);
522baf5664fSJonas Devlieghere 
5234838131bSGreg Clayton   int exit_status = 0;
524acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
525b9c1b51eSKate Stone   if (process_sp) {
526b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
527b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
528acdbe816SGreg Clayton     exit_status = process_sp->GetExitStatus();
529af67cecdSGreg Clayton   }
5304838131bSGreg Clayton 
5314838131bSGreg Clayton   return exit_status;
53230fdc8d8SChris Lattner }
53330fdc8d8SChris Lattner 
534b9c1b51eSKate Stone const char *SBProcess::GetExitDescription() {
535baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(const char *, SBProcess, GetExitDescription);
536baf5664fSJonas Devlieghere 
5374838131bSGreg Clayton   const char *exit_desc = NULL;
538acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
539b9c1b51eSKate Stone   if (process_sp) {
540b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
541b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
542acdbe816SGreg Clayton     exit_desc = process_sp->GetExitDescription();
543af67cecdSGreg Clayton   }
5444838131bSGreg Clayton   return exit_desc;
54530fdc8d8SChris Lattner }
54630fdc8d8SChris Lattner 
547b9c1b51eSKate Stone lldb::pid_t SBProcess::GetProcessID() {
548baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(lldb::pid_t, SBProcess, GetProcessID);
549baf5664fSJonas Devlieghere 
550ceb6b139SCaroline Tice   lldb::pid_t ret_val = LLDB_INVALID_PROCESS_ID;
551acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
552acdbe816SGreg Clayton   if (process_sp)
553acdbe816SGreg Clayton     ret_val = process_sp->GetID();
554ceb6b139SCaroline Tice 
555ceb6b139SCaroline Tice   return ret_val;
55630fdc8d8SChris Lattner }
55730fdc8d8SChris Lattner 
558b9c1b51eSKate Stone uint32_t SBProcess::GetUniqueID() {
559baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(uint32_t, SBProcess, GetUniqueID);
560baf5664fSJonas Devlieghere 
561949e8221SGreg Clayton   uint32_t ret_val = 0;
562949e8221SGreg Clayton   ProcessSP process_sp(GetSP());
563949e8221SGreg Clayton   if (process_sp)
564949e8221SGreg Clayton     ret_val = process_sp->GetUniqueID();
565949e8221SGreg Clayton   return ret_val;
566949e8221SGreg Clayton }
567949e8221SGreg Clayton 
568b9c1b51eSKate Stone ByteOrder SBProcess::GetByteOrder() const {
569baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_CONST_NO_ARGS(lldb::ByteOrder, SBProcess, GetByteOrder);
570baf5664fSJonas Devlieghere 
571cf386e24SJohnny Chen   ByteOrder byteOrder = eByteOrderInvalid;
572acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
573acdbe816SGreg Clayton   if (process_sp)
574acdbe816SGreg Clayton     byteOrder = process_sp->GetTarget().GetArchitecture().GetByteOrder();
575cf386e24SJohnny Chen 
576cf386e24SJohnny Chen 
577cf386e24SJohnny Chen   return byteOrder;
578cf386e24SJohnny Chen }
579cf386e24SJohnny Chen 
580b9c1b51eSKate Stone uint32_t SBProcess::GetAddressByteSize() const {
581baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_CONST_NO_ARGS(uint32_t, SBProcess, GetAddressByteSize);
582baf5664fSJonas Devlieghere 
583ceb6b139SCaroline Tice   uint32_t size = 0;
584acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
585acdbe816SGreg Clayton   if (process_sp)
586acdbe816SGreg Clayton     size = process_sp->GetTarget().GetArchitecture().GetAddressByteSize();
587ceb6b139SCaroline Tice 
588ceb6b139SCaroline Tice 
589ceb6b139SCaroline Tice   return size;
59030fdc8d8SChris Lattner }
59130fdc8d8SChris Lattner 
592b9c1b51eSKate Stone SBError SBProcess::Continue() {
593baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(lldb::SBError, SBProcess, Continue);
594baf5664fSJonas Devlieghere 
59530fdc8d8SChris Lattner   SBError sb_error;
596acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
5970c74e78dSGreg Clayton 
598b9c1b51eSKate Stone   if (process_sp) {
599b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
600b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
601acdbe816SGreg Clayton 
602dc6224e0SGreg Clayton     if (process_sp->GetTarget().GetDebugger().GetAsyncExecution())
603dc6224e0SGreg Clayton       sb_error.ref() = process_sp->Resume();
604dc6224e0SGreg Clayton     else
605dc6224e0SGreg Clayton       sb_error.ref() = process_sp->ResumeSynchronous(NULL);
606b9c1b51eSKate Stone   } else
60730fdc8d8SChris Lattner     sb_error.SetErrorString("SBProcess is invalid");
60830fdc8d8SChris Lattner 
609baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(sb_error);
61030fdc8d8SChris Lattner }
61130fdc8d8SChris Lattner 
612b9c1b51eSKate Stone SBError SBProcess::Destroy() {
613baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(lldb::SBError, SBProcess, Destroy);
614baf5664fSJonas Devlieghere 
61530fdc8d8SChris Lattner   SBError sb_error;
616acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
617b9c1b51eSKate Stone   if (process_sp) {
618b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
619b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
620ede3193bSJason Molenda     sb_error.SetError(process_sp->Destroy(false));
621b9c1b51eSKate Stone   } else
62230fdc8d8SChris Lattner     sb_error.SetErrorString("SBProcess is invalid");
62330fdc8d8SChris Lattner 
624baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(sb_error);
62530fdc8d8SChris Lattner }
62630fdc8d8SChris Lattner 
627b9c1b51eSKate Stone SBError SBProcess::Stop() {
628baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(lldb::SBError, SBProcess, Stop);
629baf5664fSJonas Devlieghere 
63030fdc8d8SChris Lattner   SBError sb_error;
631acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
632b9c1b51eSKate Stone   if (process_sp) {
633b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
634b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
635acdbe816SGreg Clayton     sb_error.SetError(process_sp->Halt());
636b9c1b51eSKate Stone   } else
63730fdc8d8SChris Lattner     sb_error.SetErrorString("SBProcess is invalid");
638ceb6b139SCaroline Tice 
639baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(sb_error);
64030fdc8d8SChris Lattner }
64130fdc8d8SChris Lattner 
642b9c1b51eSKate Stone SBError SBProcess::Kill() {
643baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(lldb::SBError, SBProcess, Kill);
644baf5664fSJonas Devlieghere 
64530fdc8d8SChris Lattner   SBError sb_error;
646acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
647b9c1b51eSKate Stone   if (process_sp) {
648b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
649b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
650ede3193bSJason Molenda     sb_error.SetError(process_sp->Destroy(true));
651b9c1b51eSKate Stone   } else
65230fdc8d8SChris Lattner     sb_error.SetErrorString("SBProcess is invalid");
653ceb6b139SCaroline Tice 
654baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(sb_error);
65530fdc8d8SChris Lattner }
65630fdc8d8SChris Lattner 
657b9c1b51eSKate Stone SBError SBProcess::Detach() {
658baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(lldb::SBError, SBProcess, Detach);
659baf5664fSJonas Devlieghere 
660acff8950SJim Ingham   // FIXME: This should come from a process default.
661acff8950SJim Ingham   bool keep_stopped = false;
662baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(Detach(keep_stopped));
663acff8950SJim Ingham }
664acff8950SJim Ingham 
665b9c1b51eSKate Stone SBError SBProcess::Detach(bool keep_stopped) {
666baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(lldb::SBError, SBProcess, Detach, (bool), keep_stopped);
667baf5664fSJonas Devlieghere 
66830fdc8d8SChris Lattner   SBError sb_error;
669acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
670b9c1b51eSKate Stone   if (process_sp) {
671b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
672b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
673acff8950SJim Ingham     sb_error.SetError(process_sp->Detach(keep_stopped));
674b9c1b51eSKate Stone   } else
67530fdc8d8SChris Lattner     sb_error.SetErrorString("SBProcess is invalid");
67630fdc8d8SChris Lattner 
677baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(sb_error);
67830fdc8d8SChris Lattner }
67930fdc8d8SChris Lattner 
680b9c1b51eSKate Stone SBError SBProcess::Signal(int signo) {
681baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(lldb::SBError, SBProcess, Signal, (int), signo);
682baf5664fSJonas Devlieghere 
68330fdc8d8SChris Lattner   SBError sb_error;
684acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
685b9c1b51eSKate Stone   if (process_sp) {
686b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
687b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
688acdbe816SGreg Clayton     sb_error.SetError(process_sp->Signal(signo));
689b9c1b51eSKate Stone   } else
69030fdc8d8SChris Lattner     sb_error.SetErrorString("SBProcess is invalid");
691*581af8b0SJonas Devlieghere 
692baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(sb_error);
69330fdc8d8SChris Lattner }
69430fdc8d8SChris Lattner 
695b9c1b51eSKate Stone SBUnixSignals SBProcess::GetUnixSignals() {
696baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(lldb::SBUnixSignals, SBProcess, GetUnixSignals);
697802dc402STodd Fiala 
698baf5664fSJonas Devlieghere   if (auto process_sp = GetSP())
699baf5664fSJonas Devlieghere     return LLDB_RECORD_RESULT(SBUnixSignals{process_sp});
700baf5664fSJonas Devlieghere 
701baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(SBUnixSignals{});
702802dc402STodd Fiala }
703802dc402STodd Fiala 
704b9c1b51eSKate Stone void SBProcess::SendAsyncInterrupt() {
705baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(void, SBProcess, SendAsyncInterrupt);
706baf5664fSJonas Devlieghere 
707cfc0935eSJim Ingham   ProcessSP process_sp(GetSP());
708b9c1b51eSKate Stone   if (process_sp) {
709cfc0935eSJim Ingham     process_sp->SendAsyncInterrupt();
710cfc0935eSJim Ingham   }
711cfc0935eSJim Ingham }
712cfc0935eSJim Ingham 
713b9c1b51eSKate Stone SBThread SBProcess::GetThreadByID(tid_t tid) {
714baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(lldb::SBThread, SBProcess, GetThreadByID, (lldb::tid_t),
715baf5664fSJonas Devlieghere                      tid);
716baf5664fSJonas Devlieghere 
7174838131bSGreg Clayton   SBThread sb_thread;
71817a6ad05SGreg Clayton   ThreadSP thread_sp;
719acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
720b9c1b51eSKate Stone   if (process_sp) {
7217fdf9ef1SGreg Clayton     Process::StopLocker stop_locker;
7227fdf9ef1SGreg Clayton     const bool can_update = stop_locker.TryLock(&process_sp->GetRunLock());
723b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
724b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
7257fdf9ef1SGreg Clayton     thread_sp = process_sp->GetThreadList().FindThreadByID(tid, can_update);
72617a6ad05SGreg Clayton     sb_thread.SetThread(thread_sp);
727af67cecdSGreg Clayton   }
7284838131bSGreg Clayton 
729baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(sb_thread);
73030fdc8d8SChris Lattner }
73130fdc8d8SChris Lattner 
732b9c1b51eSKate Stone SBThread SBProcess::GetThreadByIndexID(uint32_t index_id) {
733baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(lldb::SBThread, SBProcess, GetThreadByIndexID, (uint32_t),
734baf5664fSJonas Devlieghere                      index_id);
735baf5664fSJonas Devlieghere 
73618b46896SJim Ingham   SBThread sb_thread;
73718b46896SJim Ingham   ThreadSP thread_sp;
73818b46896SJim Ingham   ProcessSP process_sp(GetSP());
739b9c1b51eSKate Stone   if (process_sp) {
74018b46896SJim Ingham     Process::StopLocker stop_locker;
74118b46896SJim Ingham     const bool can_update = stop_locker.TryLock(&process_sp->GetRunLock());
742b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
743b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
744b9c1b51eSKate Stone     thread_sp =
745b9c1b51eSKate Stone         process_sp->GetThreadList().FindThreadByIndexID(index_id, can_update);
74618b46896SJim Ingham     sb_thread.SetThread(thread_sp);
74718b46896SJim Ingham   }
74818b46896SJim Ingham 
749baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(sb_thread);
75018b46896SJim Ingham }
75118b46896SJim Ingham 
752b9c1b51eSKate Stone StateType SBProcess::GetStateFromEvent(const SBEvent &event) {
753baf5664fSJonas Devlieghere   LLDB_RECORD_STATIC_METHOD(lldb::StateType, SBProcess, GetStateFromEvent,
754baf5664fSJonas Devlieghere                             (const lldb::SBEvent &), event);
755baf5664fSJonas Devlieghere 
756ceb6b139SCaroline Tice   StateType ret_val = Process::ProcessEventData::GetStateFromEvent(event.get());
757ceb6b139SCaroline Tice 
758ceb6b139SCaroline Tice   return ret_val;
75930fdc8d8SChris Lattner }
76030fdc8d8SChris Lattner 
761b9c1b51eSKate Stone bool SBProcess::GetRestartedFromEvent(const SBEvent &event) {
762baf5664fSJonas Devlieghere   LLDB_RECORD_STATIC_METHOD(bool, SBProcess, GetRestartedFromEvent,
763baf5664fSJonas Devlieghere                             (const lldb::SBEvent &), event);
764baf5664fSJonas Devlieghere 
765ea2cc5e0SPavel Labath   bool ret_val = Process::ProcessEventData::GetRestartedFromEvent(event.get());
766ea2cc5e0SPavel Labath 
767ea2cc5e0SPavel Labath   return ret_val;
76830fdc8d8SChris Lattner }
76930fdc8d8SChris Lattner 
770b9c1b51eSKate Stone size_t SBProcess::GetNumRestartedReasonsFromEvent(const lldb::SBEvent &event) {
771baf5664fSJonas Devlieghere   LLDB_RECORD_STATIC_METHOD(size_t, SBProcess, GetNumRestartedReasonsFromEvent,
772baf5664fSJonas Devlieghere                             (const lldb::SBEvent &), event);
773baf5664fSJonas Devlieghere 
7740161b49cSJim Ingham   return Process::ProcessEventData::GetNumRestartedReasons(event.get());
7750161b49cSJim Ingham }
7760161b49cSJim Ingham 
7770161b49cSJim Ingham const char *
778b9c1b51eSKate Stone SBProcess::GetRestartedReasonAtIndexFromEvent(const lldb::SBEvent &event,
779b9c1b51eSKate Stone                                               size_t idx) {
780baf5664fSJonas Devlieghere   LLDB_RECORD_STATIC_METHOD(const char *, SBProcess,
781baf5664fSJonas Devlieghere                             GetRestartedReasonAtIndexFromEvent,
782baf5664fSJonas Devlieghere                             (const lldb::SBEvent &, size_t), event, idx);
783baf5664fSJonas Devlieghere 
7840161b49cSJim Ingham   return Process::ProcessEventData::GetRestartedReasonAtIndex(event.get(), idx);
7850161b49cSJim Ingham }
7860161b49cSJim Ingham 
787b9c1b51eSKate Stone SBProcess SBProcess::GetProcessFromEvent(const SBEvent &event) {
788baf5664fSJonas Devlieghere   LLDB_RECORD_STATIC_METHOD(lldb::SBProcess, SBProcess, GetProcessFromEvent,
789baf5664fSJonas Devlieghere                             (const lldb::SBEvent &), event);
790baf5664fSJonas Devlieghere 
79175930019STodd Fiala   ProcessSP process_sp =
79275930019STodd Fiala       Process::ProcessEventData::GetProcessFromEvent(event.get());
793b9c1b51eSKate Stone   if (!process_sp) {
79405097246SAdrian Prantl     // StructuredData events also know the process they come from. Try that.
79575930019STodd Fiala     process_sp = EventDataStructuredData::GetProcessFromEvent(event.get());
79675930019STodd Fiala   }
79775930019STodd Fiala 
798baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(SBProcess(process_sp));
79930fdc8d8SChris Lattner }
80030fdc8d8SChris Lattner 
801b9c1b51eSKate Stone bool SBProcess::GetInterruptedFromEvent(const SBEvent &event) {
802baf5664fSJonas Devlieghere   LLDB_RECORD_STATIC_METHOD(bool, SBProcess, GetInterruptedFromEvent,
803baf5664fSJonas Devlieghere                             (const lldb::SBEvent &), event);
804baf5664fSJonas Devlieghere 
80506d2855fSIlia K   return Process::ProcessEventData::GetInterruptedFromEvent(event.get());
80606d2855fSIlia K }
80706d2855fSIlia K 
80875930019STodd Fiala lldb::SBStructuredData
809b9c1b51eSKate Stone SBProcess::GetStructuredDataFromEvent(const lldb::SBEvent &event) {
810baf5664fSJonas Devlieghere   LLDB_RECORD_STATIC_METHOD(lldb::SBStructuredData, SBProcess,
811baf5664fSJonas Devlieghere                             GetStructuredDataFromEvent, (const lldb::SBEvent &),
812baf5664fSJonas Devlieghere                             event);
813baf5664fSJonas Devlieghere 
814baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(SBStructuredData(event.GetSP()));
81575930019STodd Fiala }
81675930019STodd Fiala 
817b9c1b51eSKate Stone bool SBProcess::EventIsProcessEvent(const SBEvent &event) {
818baf5664fSJonas Devlieghere   LLDB_RECORD_STATIC_METHOD(bool, SBProcess, EventIsProcessEvent,
819baf5664fSJonas Devlieghere                             (const lldb::SBEvent &), event);
820baf5664fSJonas Devlieghere 
82175930019STodd Fiala   return (event.GetBroadcasterClass() == SBProcess::GetBroadcasterClass()) &&
82275930019STodd Fiala          !EventIsStructuredDataEvent(event);
82375930019STodd Fiala }
82475930019STodd Fiala 
825b9c1b51eSKate Stone bool SBProcess::EventIsStructuredDataEvent(const lldb::SBEvent &event) {
826baf5664fSJonas Devlieghere   LLDB_RECORD_STATIC_METHOD(bool, SBProcess, EventIsStructuredDataEvent,
827baf5664fSJonas Devlieghere                             (const lldb::SBEvent &), event);
828baf5664fSJonas Devlieghere 
82975930019STodd Fiala   EventSP event_sp = event.GetSP();
83075930019STodd Fiala   EventData *event_data = event_sp ? event_sp->GetData() : nullptr;
831b9c1b51eSKate Stone   return event_data && (event_data->GetFlavor() ==
832b9c1b51eSKate Stone                         EventDataStructuredData::GetFlavorString());
833e6bc6cb9SJim Ingham }
83430fdc8d8SChris Lattner 
835b9c1b51eSKate Stone SBBroadcaster SBProcess::GetBroadcaster() const {
836baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_CONST_NO_ARGS(lldb::SBBroadcaster, SBProcess,
837baf5664fSJonas Devlieghere                                    GetBroadcaster);
838baf5664fSJonas Devlieghere 
839ceb6b139SCaroline Tice 
840acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
841acdbe816SGreg Clayton 
842acdbe816SGreg Clayton   SBBroadcaster broadcaster(process_sp.get(), false);
843ceb6b139SCaroline Tice 
844ceb6b139SCaroline Tice 
845baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(broadcaster);
84630fdc8d8SChris Lattner }
84730fdc8d8SChris Lattner 
848b9c1b51eSKate Stone const char *SBProcess::GetBroadcasterClass() {
849baf5664fSJonas Devlieghere   LLDB_RECORD_STATIC_METHOD_NO_ARGS(const char *, SBProcess,
850baf5664fSJonas Devlieghere                                     GetBroadcasterClass);
851baf5664fSJonas Devlieghere 
8524bddaeb5SJim Ingham   return Process::GetStaticBroadcasterClass().AsCString();
8534bddaeb5SJim Ingham }
8544bddaeb5SJim Ingham 
855b9c1b51eSKate Stone size_t SBProcess::ReadMemory(addr_t addr, void *dst, size_t dst_len,
856b9c1b51eSKate Stone                              SBError &sb_error) {
857ceb6b139SCaroline Tice 
85830fdc8d8SChris Lattner   size_t bytes_read = 0;
85930fdc8d8SChris Lattner 
860acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
861acdbe816SGreg Clayton 
8624838131bSGreg Clayton 
863b9c1b51eSKate Stone   if (process_sp) {
8647fdf9ef1SGreg Clayton     Process::StopLocker stop_locker;
865b9c1b51eSKate Stone     if (stop_locker.TryLock(&process_sp->GetRunLock())) {
866b9c1b51eSKate Stone       std::lock_guard<std::recursive_mutex> guard(
867b9c1b51eSKate Stone           process_sp->GetTarget().GetAPIMutex());
8687fdf9ef1SGreg Clayton       bytes_read = process_sp->ReadMemory(addr, dst, dst_len, sb_error.ref());
869b9c1b51eSKate Stone     } else {
8707fdf9ef1SGreg Clayton       sb_error.SetErrorString("process is running");
8717fdf9ef1SGreg Clayton     }
872b9c1b51eSKate Stone   } else {
87330fdc8d8SChris Lattner     sb_error.SetErrorString("SBProcess is invalid");
87430fdc8d8SChris Lattner   }
87530fdc8d8SChris Lattner 
87630fdc8d8SChris Lattner   return bytes_read;
87730fdc8d8SChris Lattner }
87830fdc8d8SChris Lattner 
879b9c1b51eSKate Stone size_t SBProcess::ReadCStringFromMemory(addr_t addr, void *buf, size_t size,
880b9c1b51eSKate Stone                                         lldb::SBError &sb_error) {
881e91b7957SGreg Clayton   size_t bytes_read = 0;
882acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
883b9c1b51eSKate Stone   if (process_sp) {
8847fdf9ef1SGreg Clayton     Process::StopLocker stop_locker;
885b9c1b51eSKate Stone     if (stop_locker.TryLock(&process_sp->GetRunLock())) {
886b9c1b51eSKate Stone       std::lock_guard<std::recursive_mutex> guard(
887b9c1b51eSKate Stone           process_sp->GetTarget().GetAPIMutex());
888b9c1b51eSKate Stone       bytes_read = process_sp->ReadCStringFromMemory(addr, (char *)buf, size,
889b9c1b51eSKate Stone                                                      sb_error.ref());
890b9c1b51eSKate Stone     } else {
8917fdf9ef1SGreg Clayton       sb_error.SetErrorString("process is running");
8927fdf9ef1SGreg Clayton     }
893b9c1b51eSKate Stone   } else {
894e91b7957SGreg Clayton     sb_error.SetErrorString("SBProcess is invalid");
895e91b7957SGreg Clayton   }
896e91b7957SGreg Clayton   return bytes_read;
897e91b7957SGreg Clayton }
898e91b7957SGreg Clayton 
899b9c1b51eSKate Stone uint64_t SBProcess::ReadUnsignedFromMemory(addr_t addr, uint32_t byte_size,
900b9c1b51eSKate Stone                                            lldb::SBError &sb_error) {
901baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(uint64_t, SBProcess, ReadUnsignedFromMemory,
902baf5664fSJonas Devlieghere                      (lldb::addr_t, uint32_t, lldb::SBError &), addr, byte_size,
903baf5664fSJonas Devlieghere                      sb_error);
904baf5664fSJonas Devlieghere 
9057fdf9ef1SGreg Clayton   uint64_t value = 0;
906acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
907b9c1b51eSKate Stone   if (process_sp) {
9087fdf9ef1SGreg Clayton     Process::StopLocker stop_locker;
909b9c1b51eSKate Stone     if (stop_locker.TryLock(&process_sp->GetRunLock())) {
910b9c1b51eSKate Stone       std::lock_guard<std::recursive_mutex> guard(
911b9c1b51eSKate Stone           process_sp->GetTarget().GetAPIMutex());
912b9c1b51eSKate Stone       value = process_sp->ReadUnsignedIntegerFromMemory(addr, byte_size, 0,
913b9c1b51eSKate Stone                                                         sb_error.ref());
914b9c1b51eSKate Stone     } else {
9157fdf9ef1SGreg Clayton       sb_error.SetErrorString("process is running");
9167fdf9ef1SGreg Clayton     }
917b9c1b51eSKate Stone   } else {
918e91b7957SGreg Clayton     sb_error.SetErrorString("SBProcess is invalid");
919e91b7957SGreg Clayton   }
9207fdf9ef1SGreg Clayton   return value;
921e91b7957SGreg Clayton }
922e91b7957SGreg Clayton 
923b9c1b51eSKate Stone lldb::addr_t SBProcess::ReadPointerFromMemory(addr_t addr,
924b9c1b51eSKate Stone                                               lldb::SBError &sb_error) {
925baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(lldb::addr_t, SBProcess, ReadPointerFromMemory,
926baf5664fSJonas Devlieghere                      (lldb::addr_t, lldb::SBError &), addr, sb_error);
927baf5664fSJonas Devlieghere 
928e91b7957SGreg Clayton   lldb::addr_t ptr = LLDB_INVALID_ADDRESS;
929acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
930b9c1b51eSKate Stone   if (process_sp) {
9317fdf9ef1SGreg Clayton     Process::StopLocker stop_locker;
932b9c1b51eSKate Stone     if (stop_locker.TryLock(&process_sp->GetRunLock())) {
933b9c1b51eSKate Stone       std::lock_guard<std::recursive_mutex> guard(
934b9c1b51eSKate Stone           process_sp->GetTarget().GetAPIMutex());
9357fdf9ef1SGreg Clayton       ptr = process_sp->ReadPointerFromMemory(addr, sb_error.ref());
936b9c1b51eSKate Stone     } else {
9377fdf9ef1SGreg Clayton       sb_error.SetErrorString("process is running");
9387fdf9ef1SGreg Clayton     }
939b9c1b51eSKate Stone   } else {
940e91b7957SGreg Clayton     sb_error.SetErrorString("SBProcess is invalid");
941e91b7957SGreg Clayton   }
942e91b7957SGreg Clayton   return ptr;
943e91b7957SGreg Clayton }
944e91b7957SGreg Clayton 
945b9c1b51eSKate Stone size_t SBProcess::WriteMemory(addr_t addr, const void *src, size_t src_len,
946b9c1b51eSKate Stone                               SBError &sb_error) {
94730fdc8d8SChris Lattner   size_t bytes_written = 0;
94830fdc8d8SChris Lattner 
949acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
950acdbe816SGreg Clayton 
951b9c1b51eSKate Stone   if (process_sp) {
9527fdf9ef1SGreg Clayton     Process::StopLocker stop_locker;
953b9c1b51eSKate Stone     if (stop_locker.TryLock(&process_sp->GetRunLock())) {
954b9c1b51eSKate Stone       std::lock_guard<std::recursive_mutex> guard(
955b9c1b51eSKate Stone           process_sp->GetTarget().GetAPIMutex());
956b9c1b51eSKate Stone       bytes_written =
957b9c1b51eSKate Stone           process_sp->WriteMemory(addr, src, src_len, sb_error.ref());
958b9c1b51eSKate Stone     } else {
9597fdf9ef1SGreg Clayton       sb_error.SetErrorString("process is running");
9607fdf9ef1SGreg Clayton     }
96130fdc8d8SChris Lattner   }
96230fdc8d8SChris Lattner 
96330fdc8d8SChris Lattner   return bytes_written;
96430fdc8d8SChris Lattner }
96530fdc8d8SChris Lattner 
966b9c1b51eSKate Stone bool SBProcess::GetDescription(SBStream &description) {
967baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(bool, SBProcess, GetDescription, (lldb::SBStream &),
968baf5664fSJonas Devlieghere                      description);
969baf5664fSJonas Devlieghere 
970da7bc7d0SGreg Clayton   Stream &strm = description.ref();
971da7bc7d0SGreg Clayton 
972acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
973b9c1b51eSKate Stone   if (process_sp) {
974dde9cff3SCaroline Tice     char path[PATH_MAX];
975dde9cff3SCaroline Tice     GetTarget().GetExecutable().GetPath(path, sizeof(path));
976acdbe816SGreg Clayton     Module *exe_module = process_sp->GetTarget().GetExecutableModulePointer();
9771d273166SGreg Clayton     const char *exe_name = NULL;
9781d273166SGreg Clayton     if (exe_module)
9791d273166SGreg Clayton       exe_name = exe_module->GetFileSpec().GetFilename().AsCString();
9801d273166SGreg Clayton 
981d01b2953SDaniel Malea     strm.Printf("SBProcess: pid = %" PRIu64 ", state = %s, threads = %d%s%s",
982b9c1b51eSKate Stone                 process_sp->GetID(), lldb_private::StateAsCString(GetState()),
983b9c1b51eSKate Stone                 GetNumThreads(), exe_name ? ", executable = " : "",
9841d273166SGreg Clayton                 exe_name ? exe_name : "");
985b9c1b51eSKate Stone   } else
986da7bc7d0SGreg Clayton     strm.PutCString("No value");
987dde9cff3SCaroline Tice 
988dde9cff3SCaroline Tice   return true;
989dde9cff3SCaroline Tice }
9908f343b09SGreg Clayton 
9918f343b09SGreg Clayton uint32_t
992b9c1b51eSKate Stone SBProcess::GetNumSupportedHardwareWatchpoints(lldb::SBError &sb_error) const {
993baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_CONST(uint32_t, SBProcess,
994baf5664fSJonas Devlieghere                            GetNumSupportedHardwareWatchpoints,
995baf5664fSJonas Devlieghere                            (lldb::SBError &), sb_error);
996baf5664fSJonas Devlieghere 
997f9ef60d2SJohnny Chen   uint32_t num = 0;
998f9ef60d2SJohnny Chen   ProcessSP process_sp(GetSP());
999b9c1b51eSKate Stone   if (process_sp) {
1000b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
1001b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
1002f9ef60d2SJohnny Chen     sb_error.SetError(process_sp->GetWatchpointSupportInfo(num));
1003b9c1b51eSKate Stone   } else {
1004f9ef60d2SJohnny Chen     sb_error.SetErrorString("SBProcess is invalid");
1005f9ef60d2SJohnny Chen   }
1006f9ef60d2SJohnny Chen   return num;
1007f9ef60d2SJohnny Chen }
1008f9ef60d2SJohnny Chen 
1009b9c1b51eSKate Stone uint32_t SBProcess::LoadImage(lldb::SBFileSpec &sb_remote_image_spec,
1010b9c1b51eSKate Stone                               lldb::SBError &sb_error) {
1011baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(uint32_t, SBProcess, LoadImage,
1012baf5664fSJonas Devlieghere                      (lldb::SBFileSpec &, lldb::SBError &),
1013baf5664fSJonas Devlieghere                      sb_remote_image_spec, sb_error);
1014baf5664fSJonas Devlieghere 
10154fbd67acSTamas Berghammer   return LoadImage(SBFileSpec(), sb_remote_image_spec, sb_error);
10164fbd67acSTamas Berghammer }
10174fbd67acSTamas Berghammer 
1018b9c1b51eSKate Stone uint32_t SBProcess::LoadImage(const lldb::SBFileSpec &sb_local_image_spec,
10194fbd67acSTamas Berghammer                               const lldb::SBFileSpec &sb_remote_image_spec,
1020b9c1b51eSKate Stone                               lldb::SBError &sb_error) {
1021baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(
1022baf5664fSJonas Devlieghere       uint32_t, SBProcess, LoadImage,
1023baf5664fSJonas Devlieghere       (const lldb::SBFileSpec &, const lldb::SBFileSpec &, lldb::SBError &),
1024baf5664fSJonas Devlieghere       sb_local_image_spec, sb_remote_image_spec, sb_error);
1025baf5664fSJonas Devlieghere 
1026acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
1027b9c1b51eSKate Stone   if (process_sp) {
10287fdf9ef1SGreg Clayton     Process::StopLocker stop_locker;
1029b9c1b51eSKate Stone     if (stop_locker.TryLock(&process_sp->GetRunLock())) {
1030b9c1b51eSKate Stone       std::lock_guard<std::recursive_mutex> guard(
1031b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
10323cb132a0STamas Berghammer       PlatformSP platform_sp = process_sp->GetTarget().GetPlatform();
1033b9c1b51eSKate Stone       return platform_sp->LoadImage(process_sp.get(), *sb_local_image_spec,
1034b9c1b51eSKate Stone                                     *sb_remote_image_spec, sb_error.ref());
1035b9c1b51eSKate Stone     } else {
10367fdf9ef1SGreg Clayton       sb_error.SetErrorString("process is running");
10377fdf9ef1SGreg Clayton     }
1038abc5d72fSJim Ingham   } else {
1039abc5d72fSJim Ingham     sb_error.SetErrorString("process is invalid");
10407fdf9ef1SGreg Clayton   }
10418f343b09SGreg Clayton   return LLDB_INVALID_IMAGE_TOKEN;
10428f343b09SGreg Clayton }
10438f343b09SGreg Clayton 
10440d231f71SJim Ingham uint32_t SBProcess::LoadImageUsingPaths(const lldb::SBFileSpec &image_spec,
10450d231f71SJim Ingham                                         SBStringList &paths,
10460d231f71SJim Ingham                                         lldb::SBFileSpec &loaded_path,
10470d231f71SJim Ingham                                         lldb::SBError &error) {
1048baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(uint32_t, SBProcess, LoadImageUsingPaths,
1049baf5664fSJonas Devlieghere                      (const lldb::SBFileSpec &, lldb::SBStringList &,
1050baf5664fSJonas Devlieghere                       lldb::SBFileSpec &, lldb::SBError &),
1051baf5664fSJonas Devlieghere                      image_spec, paths, loaded_path, error);
1052baf5664fSJonas Devlieghere 
10530d231f71SJim Ingham   ProcessSP process_sp(GetSP());
10540d231f71SJim Ingham   if (process_sp) {
10550d231f71SJim Ingham     Process::StopLocker stop_locker;
10560d231f71SJim Ingham     if (stop_locker.TryLock(&process_sp->GetRunLock())) {
10570d231f71SJim Ingham       std::lock_guard<std::recursive_mutex> guard(
10580d231f71SJim Ingham         process_sp->GetTarget().GetAPIMutex());
10590d231f71SJim Ingham       PlatformSP platform_sp = process_sp->GetTarget().GetPlatform();
10600d231f71SJim Ingham       size_t num_paths = paths.GetSize();
10610d231f71SJim Ingham       std::vector<std::string> paths_vec;
10620d231f71SJim Ingham       paths_vec.reserve(num_paths);
10630d231f71SJim Ingham       for (size_t i = 0; i < num_paths; i++)
10640d231f71SJim Ingham         paths_vec.push_back(paths.GetStringAtIndex(i));
10650d231f71SJim Ingham       FileSpec loaded_spec;
10660d231f71SJim Ingham 
1067*581af8b0SJonas Devlieghere       uint32_t token = platform_sp->LoadImageUsingPaths(
1068*581af8b0SJonas Devlieghere           process_sp.get(), *image_spec, paths_vec, error.ref(), &loaded_spec);
10690d231f71SJim Ingham       if (token != LLDB_INVALID_IMAGE_TOKEN)
10700d231f71SJim Ingham         loaded_path = loaded_spec;
10710d231f71SJim Ingham       return token;
10720d231f71SJim Ingham     } else {
10730d231f71SJim Ingham       error.SetErrorString("process is running");
10740d231f71SJim Ingham     }
10750d231f71SJim Ingham   } else {
10760d231f71SJim Ingham     error.SetErrorString("process is invalid");
10770d231f71SJim Ingham   }
10780d231f71SJim Ingham 
10790d231f71SJim Ingham   return LLDB_INVALID_IMAGE_TOKEN;
10800d231f71SJim Ingham }
10810d231f71SJim Ingham 
1082b9c1b51eSKate Stone lldb::SBError SBProcess::UnloadImage(uint32_t image_token) {
1083baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(lldb::SBError, SBProcess, UnloadImage, (uint32_t),
1084baf5664fSJonas Devlieghere                      image_token);
1085baf5664fSJonas Devlieghere 
10868f343b09SGreg Clayton   lldb::SBError sb_error;
1087acdbe816SGreg Clayton   ProcessSP process_sp(GetSP());
1088b9c1b51eSKate Stone   if (process_sp) {
10897fdf9ef1SGreg Clayton     Process::StopLocker stop_locker;
1090b9c1b51eSKate Stone     if (stop_locker.TryLock(&process_sp->GetRunLock())) {
1091b9c1b51eSKate Stone       std::lock_guard<std::recursive_mutex> guard(
1092b9c1b51eSKate Stone           process_sp->GetTarget().GetAPIMutex());
10933cb132a0STamas Berghammer       PlatformSP platform_sp = process_sp->GetTarget().GetPlatform();
1094b9c1b51eSKate Stone       sb_error.SetError(
1095b9c1b51eSKate Stone           platform_sp->UnloadImage(process_sp.get(), image_token));
1096b9c1b51eSKate Stone     } else {
10977fdf9ef1SGreg Clayton       sb_error.SetErrorString("process is running");
10987fdf9ef1SGreg Clayton     }
1099b9c1b51eSKate Stone   } else
11008f343b09SGreg Clayton     sb_error.SetErrorString("invalid process");
1101baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(sb_error);
11028f343b09SGreg Clayton }
11038c71337aSJason Molenda 
1104b9c1b51eSKate Stone lldb::SBError SBProcess::SendEventData(const char *event_data) {
1105baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(lldb::SBError, SBProcess, SendEventData, (const char *),
1106baf5664fSJonas Devlieghere                      event_data);
1107baf5664fSJonas Devlieghere 
1108a332978bSJason Molenda   lldb::SBError sb_error;
1109a332978bSJason Molenda   ProcessSP process_sp(GetSP());
1110b9c1b51eSKate Stone   if (process_sp) {
1111a332978bSJason Molenda     Process::StopLocker stop_locker;
1112b9c1b51eSKate Stone     if (stop_locker.TryLock(&process_sp->GetRunLock())) {
1113b9c1b51eSKate Stone       std::lock_guard<std::recursive_mutex> guard(
1114b9c1b51eSKate Stone           process_sp->GetTarget().GetAPIMutex());
1115a332978bSJason Molenda       sb_error.SetError(process_sp->SendEventData(event_data));
1116b9c1b51eSKate Stone     } else {
1117a332978bSJason Molenda       sb_error.SetErrorString("process is running");
1118a332978bSJason Molenda     }
1119b9c1b51eSKate Stone   } else
1120a332978bSJason Molenda     sb_error.SetErrorString("invalid process");
1121baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(sb_error);
1122a332978bSJason Molenda }
1123a332978bSJason Molenda 
1124b9c1b51eSKate Stone uint32_t SBProcess::GetNumExtendedBacktraceTypes() {
1125baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(uint32_t, SBProcess, GetNumExtendedBacktraceTypes);
1126baf5664fSJonas Devlieghere 
11278c71337aSJason Molenda   ProcessSP process_sp(GetSP());
1128b9c1b51eSKate Stone   if (process_sp && process_sp->GetSystemRuntime()) {
11298c71337aSJason Molenda     SystemRuntime *runtime = process_sp->GetSystemRuntime();
113095d005c7SJason Molenda     return runtime->GetExtendedBacktraceTypes().size();
11318c71337aSJason Molenda   }
11328c71337aSJason Molenda   return 0;
11338c71337aSJason Molenda }
11348c71337aSJason Molenda 
1135b9c1b51eSKate Stone const char *SBProcess::GetExtendedBacktraceTypeAtIndex(uint32_t idx) {
1136baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(const char *, SBProcess, GetExtendedBacktraceTypeAtIndex,
1137baf5664fSJonas Devlieghere                      (uint32_t), idx);
1138baf5664fSJonas Devlieghere 
11398c71337aSJason Molenda   ProcessSP process_sp(GetSP());
1140b9c1b51eSKate Stone   if (process_sp && process_sp->GetSystemRuntime()) {
11418c71337aSJason Molenda     SystemRuntime *runtime = process_sp->GetSystemRuntime();
1142b9c1b51eSKate Stone     const std::vector<ConstString> &names =
1143b9c1b51eSKate Stone         runtime->GetExtendedBacktraceTypes();
1144b9c1b51eSKate Stone     if (idx < names.size()) {
11458c71337aSJason Molenda       return names[idx].AsCString();
11468c71337aSJason Molenda     }
11478c71337aSJason Molenda   }
11488c71337aSJason Molenda   return NULL;
11498c71337aSJason Molenda }
1150a51ea382SKuba Brecka 
1151b9c1b51eSKate Stone SBThreadCollection SBProcess::GetHistoryThreads(addr_t addr) {
1152baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(lldb::SBThreadCollection, SBProcess, GetHistoryThreads,
1153baf5664fSJonas Devlieghere                      (lldb::addr_t), addr);
1154baf5664fSJonas Devlieghere 
1155a51ea382SKuba Brecka   ProcessSP process_sp(GetSP());
1156a51ea382SKuba Brecka   SBThreadCollection threads;
1157b9c1b51eSKate Stone   if (process_sp) {
1158a51ea382SKuba Brecka     threads = SBThreadCollection(process_sp->GetHistoryThreads(addr));
1159a51ea382SKuba Brecka   }
1160baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(threads);
1161a51ea382SKuba Brecka }
116263927548SKuba Brecka 
1163b9c1b51eSKate Stone bool SBProcess::IsInstrumentationRuntimePresent(
1164b9c1b51eSKate Stone     InstrumentationRuntimeType type) {
1165baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(bool, SBProcess, IsInstrumentationRuntimePresent,
1166baf5664fSJonas Devlieghere                      (lldb::InstrumentationRuntimeType), type);
1167baf5664fSJonas Devlieghere 
116863927548SKuba Brecka   ProcessSP process_sp(GetSP());
116963927548SKuba Brecka   if (!process_sp)
117063927548SKuba Brecka     return false;
117163927548SKuba Brecka 
1172b9c1b51eSKate Stone   InstrumentationRuntimeSP runtime_sp =
1173b9c1b51eSKate Stone       process_sp->GetInstrumentationRuntime(type);
117463927548SKuba Brecka 
117563927548SKuba Brecka   if (!runtime_sp.get())
117663927548SKuba Brecka     return false;
117763927548SKuba Brecka 
117863927548SKuba Brecka   return runtime_sp->IsActive();
117963927548SKuba Brecka }
1180f7d1893fSAdrian McCarthy 
1181b9c1b51eSKate Stone lldb::SBError SBProcess::SaveCore(const char *file_name) {
1182baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(lldb::SBError, SBProcess, SaveCore, (const char *),
1183baf5664fSJonas Devlieghere                      file_name);
1184baf5664fSJonas Devlieghere 
1185f7d1893fSAdrian McCarthy   lldb::SBError error;
1186f7d1893fSAdrian McCarthy   ProcessSP process_sp(GetSP());
1187b9c1b51eSKate Stone   if (!process_sp) {
1188f7d1893fSAdrian McCarthy     error.SetErrorString("SBProcess is invalid");
1189baf5664fSJonas Devlieghere     return LLDB_RECORD_RESULT(error);
1190f7d1893fSAdrian McCarthy   }
1191f7d1893fSAdrian McCarthy 
1192b9c1b51eSKate Stone   std::lock_guard<std::recursive_mutex> guard(
1193b9c1b51eSKate Stone       process_sp->GetTarget().GetAPIMutex());
1194f7d1893fSAdrian McCarthy 
1195b9c1b51eSKate Stone   if (process_sp->GetState() != eStateStopped) {
1196f7d1893fSAdrian McCarthy     error.SetErrorString("the process is not stopped");
1197baf5664fSJonas Devlieghere     return LLDB_RECORD_RESULT(error);
1198f7d1893fSAdrian McCarthy   }
1199f7d1893fSAdrian McCarthy 
12008f3be7a3SJonas Devlieghere   FileSpec core_file(file_name);
1201f7d1893fSAdrian McCarthy   error.ref() = PluginManager::SaveCore(process_sp, core_file);
1202baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(error);
1203f7d1893fSAdrian McCarthy }
120426036843SHoward Hellyer 
120526036843SHoward Hellyer lldb::SBError
1206b9c1b51eSKate Stone SBProcess::GetMemoryRegionInfo(lldb::addr_t load_addr,
1207b9c1b51eSKate Stone                                SBMemoryRegionInfo &sb_region_info) {
1208baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD(lldb::SBError, SBProcess, GetMemoryRegionInfo,
1209baf5664fSJonas Devlieghere                      (lldb::addr_t, lldb::SBMemoryRegionInfo &), load_addr,
1210baf5664fSJonas Devlieghere                      sb_region_info);
1211baf5664fSJonas Devlieghere 
121226036843SHoward Hellyer   lldb::SBError sb_error;
121326036843SHoward Hellyer   ProcessSP process_sp(GetSP());
1214b9c1b51eSKate Stone   if (process_sp) {
121526036843SHoward Hellyer     Process::StopLocker stop_locker;
1216b9c1b51eSKate Stone     if (stop_locker.TryLock(&process_sp->GetRunLock())) {
1217b9c1b51eSKate Stone       std::lock_guard<std::recursive_mutex> guard(
1218b9c1b51eSKate Stone           process_sp->GetTarget().GetAPIMutex());
121936788bbbSTatyana Krasnukha 
1220b9c1b51eSKate Stone       sb_error.ref() =
122136788bbbSTatyana Krasnukha           process_sp->GetMemoryRegionInfo(load_addr, sb_region_info.ref());
1222b9c1b51eSKate Stone     } else {
122326036843SHoward Hellyer       sb_error.SetErrorString("process is running");
122426036843SHoward Hellyer     }
1225b9c1b51eSKate Stone   } else {
122626036843SHoward Hellyer     sb_error.SetErrorString("SBProcess is invalid");
122726036843SHoward Hellyer   }
1228baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(sb_error);
122926036843SHoward Hellyer }
123026036843SHoward Hellyer 
1231b9c1b51eSKate Stone lldb::SBMemoryRegionInfoList SBProcess::GetMemoryRegions() {
1232baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(lldb::SBMemoryRegionInfoList, SBProcess,
1233baf5664fSJonas Devlieghere                              GetMemoryRegions);
1234baf5664fSJonas Devlieghere 
123526036843SHoward Hellyer   lldb::SBMemoryRegionInfoList sb_region_list;
123636788bbbSTatyana Krasnukha 
123726036843SHoward Hellyer   ProcessSP process_sp(GetSP());
123826036843SHoward Hellyer   Process::StopLocker stop_locker;
123936788bbbSTatyana Krasnukha   if (process_sp && stop_locker.TryLock(&process_sp->GetRunLock())) {
1240b9c1b51eSKate Stone     std::lock_guard<std::recursive_mutex> guard(
1241b9c1b51eSKate Stone         process_sp->GetTarget().GetAPIMutex());
124236788bbbSTatyana Krasnukha 
124336788bbbSTatyana Krasnukha     process_sp->GetMemoryRegions(sb_region_list.ref());
124426036843SHoward Hellyer   }
124536788bbbSTatyana Krasnukha 
1246baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(sb_region_list);
124726036843SHoward Hellyer }
1248141a6263SVadim Macagon 
1249141a6263SVadim Macagon lldb::SBProcessInfo SBProcess::GetProcessInfo() {
1250baf5664fSJonas Devlieghere   LLDB_RECORD_METHOD_NO_ARGS(lldb::SBProcessInfo, SBProcess, GetProcessInfo);
1251baf5664fSJonas Devlieghere 
1252141a6263SVadim Macagon   lldb::SBProcessInfo sb_proc_info;
1253141a6263SVadim Macagon   ProcessSP process_sp(GetSP());
1254141a6263SVadim Macagon   ProcessInstanceInfo proc_info;
1255141a6263SVadim Macagon   if (process_sp && process_sp->GetProcessInfo(proc_info)) {
1256141a6263SVadim Macagon     sb_proc_info.SetProcessInfo(proc_info);
1257141a6263SVadim Macagon   }
1258baf5664fSJonas Devlieghere   return LLDB_RECORD_RESULT(sb_proc_info);
1259141a6263SVadim Macagon }
1260