LLDB mainline
NativeProcessAIX.h
Go to the documentation of this file.
1//===-- NativeProcessAIX.h ---------------------------------- -*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8
9#ifndef LLDB_SOURCE_PLUGINS_PROCESS_AIX_NATIVEPROCESSAIX_H
10#define LLDB_SOURCE_PLUGINS_PROCESS_AIX_NATIVEPROCESSAIX_H
11
13#include "lldb/Host/Debug.h"
19#include "lldb/lldb-types.h"
20#include "llvm/ADT/SmallPtrSet.h"
21#include <csignal>
22#include <unordered_set>
23
25/// \class NativeProcessAIX
26/// Manages communication with the inferior (debugee) process.
27///
28/// Upon construction, this class prepares and launches an inferior process
29/// for debugging.
30///
31/// Changes in the inferior process state are broadcasted.
33public:
35 public:
36 Manager(MainLoop &mainloop);
37
38 llvm::Expected<std::unique_ptr<NativeProcessProtocol>>
39 Launch(ProcessLaunchInfo &launch_info,
40 NativeDelegate &native_delegate) override;
41
42 llvm::Expected<std::unique_ptr<NativeProcessProtocol>>
43 Attach(lldb::pid_t pid, NativeDelegate &native_delegate) override;
44
45 void AddProcess(NativeProcessAIX &process) { m_processes.insert(&process); }
46
48 m_processes.erase(&process);
49 }
50
51 // Collect an event for the given tid, waiting for it if necessary.
52 void CollectThread(::pid_t tid);
53
54 private:
56
57 llvm::SmallPtrSet<NativeProcessAIX *, 2> m_processes;
58
59 void SigchldHandler();
60 };
61
62 // NativeProcessProtocol Interface
63
64 ~NativeProcessAIX() override { m_manager.RemoveProcess(*this); }
65
66 Status Resume(const ResumeActionList &resume_actions) override;
67
68 Status Halt() override;
69
70 Status Detach() override;
71
72 Status Signal(int signo) override;
73
74 Status Interrupt() override;
75
76 Status Kill() override;
77
79
80 Status ReadMemory(lldb::addr_t addr, void *buf, size_t size,
81 size_t &bytes_read) override;
82
83 Status WriteMemory(lldb::addr_t addr, const void *buf, size_t size,
84 size_t &bytes_written) override;
85
86 size_t UpdateThreads() override;
87
88 const ArchSpec &GetArchitecture() const override { return m_arch; }
89
90 Status SetBreakpoint(lldb::addr_t addr, uint32_t size,
91 bool hardware) override;
92
93 Status RemoveBreakpoint(lldb::addr_t addr, bool hardware = false) override;
94
95 Status GetLoadedModuleFileSpec(const char *module_path,
96 FileSpec &file_spec) override;
97
98 llvm::ErrorOr<std::unique_ptr<llvm::MemoryBuffer>>
99 GetAuxvData() const override {
100 return getProcFile(GetID(), "auxv");
101 }
102
103 Status GetFileLoadAddress(const llvm::StringRef &file_name,
104 lldb::addr_t &load_addr) override;
105
106 static llvm::Expected<int> PtraceWrapper(int req, lldb::pid_t pid,
107 void *addr = nullptr,
108 void *data = nullptr,
109 size_t data_size = 0);
110
112
113private:
116
117 // Private Instance Methods
118 NativeProcessAIX(::pid_t pid, int terminal_fd, NativeDelegate &delegate,
119 const ArchSpec &arch, Manager &manager,
120 llvm::ArrayRef<::pid_t> tids);
121
123
124 // Returns a list of process threads that we have attached to.
125 static llvm::Expected<std::vector<::pid_t>> Attach(::pid_t pid);
126
127 llvm::Error Detach(lldb::tid_t tid);
128
130};
131
132} // namespace lldb_private::process_aix
133
134#endif // #ifndef LLDB_SOURCE_PLUGINS_PROCESS_AIX_NATIVEPROCESSAIX_H
An architecture specification class.
Definition ArchSpec.h:31
A file utility class.
Definition FileSpec.h:57
std::unique_ptr< SignalHandle > SignalHandleUP
NativeProcessProtocol(lldb::pid_t pid, int terminal_fd, NativeDelegate &delegate)
An error handling class.
Definition Status.h:118
llvm::Expected< std::unique_ptr< NativeProcessProtocol > > Launch(ProcessLaunchInfo &launch_info, NativeDelegate &native_delegate) override
Launch a process for debugging.
llvm::SmallPtrSet< NativeProcessAIX *, 2 > m_processes
llvm::Expected< std::unique_ptr< NativeProcessProtocol > > Attach(lldb::pid_t pid, NativeDelegate &native_delegate) override
Attach to an existing process.
Status ReadMemory(lldb::addr_t addr, void *buf, size_t size, size_t &bytes_read) override
static llvm::Expected< std::vector<::pid_t > > Attach(::pid_t pid)
Status WriteMemory(lldb::addr_t addr, const void *buf, size_t size, size_t &bytes_written) override
const ArchSpec & GetArchitecture() const override
Status GetFileLoadAddress(const llvm::StringRef &file_name, lldb::addr_t &load_addr) override
Status RemoveBreakpoint(lldb::addr_t addr, bool hardware=false) override
static llvm::Expected< int > PtraceWrapper(int req, lldb::pid_t pid, void *addr=nullptr, void *data=nullptr, size_t data_size=0)
Status GetLoadedModuleFileSpec(const char *module_path, FileSpec &file_spec) override
llvm::ErrorOr< std::unique_ptr< llvm::MemoryBuffer > > GetAuxvData() const override
Status Signal(int signo) override
Sends a process a UNIX signal signal.
Status Interrupt() override
Tells a process to interrupt all operations as if by a Ctrl-C.
Status Resume(const ResumeActionList &resume_actions) override
NativeProcessAIX(::pid_t pid, int terminal_fd, NativeDelegate &delegate, const ArchSpec &arch, Manager &manager, llvm::ArrayRef<::pid_t > tids)
Status SetBreakpoint(lldb::addr_t addr, uint32_t size, bool hardware) override
bool TryHandleWaitStatus(lldb::pid_t pid, WaitStatus status)
llvm::ErrorOr< std::unique_ptr< llvm::MemoryBuffer > > getProcFile(::pid_t pid, ::pid_t tid, const llvm::Twine &file)
MainLoopPosix MainLoop
Definition MainLoop.h:20
uint64_t pid_t
Definition lldb-types.h:83
uint64_t addr_t
Definition lldb-types.h:80
uint64_t tid_t
Definition lldb-types.h:84