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