Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 1 | //===-- SWIG Interface for SBProcess ----------------------------*- C++ -*-===// |
| 2 | // |
Chandler Carruth | 2946cd7 | 2019-01-19 08:50:56 +0000 | [diff] [blame] | 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 |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 6 | // |
| 7 | //===----------------------------------------------------------------------===// |
| 8 | |
| 9 | namespace lldb { |
| 10 | |
| 11 | %feature("docstring", |
| 12 | "Represents the process associated with the target program. |
| 13 | |
| 14 | SBProcess supports thread iteration. For example (from test/lldbutil.py), |
| 15 | |
| 16 | # ================================================== |
| 17 | # Utility functions related to Threads and Processes |
| 18 | # ================================================== |
| 19 | |
| 20 | def get_stopped_threads(process, reason): |
| 21 | '''Returns the thread(s) with the specified stop reason in a list. |
| 22 | |
| 23 | The list can be empty if no such thread exists. |
| 24 | ''' |
| 25 | threads = [] |
| 26 | for t in process: |
| 27 | if t.GetStopReason() == reason: |
| 28 | threads.append(t) |
| 29 | return threads |
| 30 | |
| 31 | ... |
| 32 | " |
| 33 | ) SBProcess; |
| 34 | class SBProcess |
| 35 | { |
| 36 | public: |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 37 | enum |
| 38 | { |
| 39 | eBroadcastBitStateChanged = (1 << 0), |
| 40 | eBroadcastBitInterrupt = (1 << 1), |
| 41 | eBroadcastBitSTDOUT = (1 << 2), |
Han Ming Ong | ab3b8b2 | 2012-11-17 00:21:04 +0000 | [diff] [blame] | 42 | eBroadcastBitSTDERR = (1 << 3), |
Todd Fiala | 7593001 | 2016-08-19 04:21:48 +0000 | [diff] [blame] | 43 | eBroadcastBitProfileData = (1 << 4), |
| 44 | eBroadcastBitStructuredData = (1 << 5) |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 45 | }; |
| 46 | |
| 47 | SBProcess (); |
| 48 | |
| 49 | SBProcess (const lldb::SBProcess& rhs); |
| 50 | |
| 51 | ~SBProcess(); |
| 52 | |
Jim Ingham | 4bddaeb | 2012-02-16 06:50:00 +0000 | [diff] [blame] | 53 | static const char * |
| 54 | GetBroadcasterClassName (); |
| 55 | |
Jim Ingham | d7b30ef | 2012-10-26 19:18:04 +0000 | [diff] [blame] | 56 | const char * |
| 57 | GetPluginName (); |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 58 | |
Jim Ingham | d7b30ef | 2012-10-26 19:18:04 +0000 | [diff] [blame] | 59 | const char * |
| 60 | GetShortPluginName (); |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 61 | |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 62 | void |
| 63 | Clear (); |
| 64 | |
| 65 | bool |
| 66 | IsValid() const; |
| 67 | |
Pavel Labath | 7f5237b | 2019-03-11 13:58:46 +0000 | [diff] [blame] | 68 | explicit operator bool() const; |
| 69 | |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 70 | lldb::SBTarget |
| 71 | GetTarget() const; |
| 72 | |
| 73 | lldb::ByteOrder |
| 74 | GetByteOrder() const; |
| 75 | |
Johnny Chen | 49cb85d | 2011-11-28 21:39:07 +0000 | [diff] [blame] | 76 | %feature("autodoc", " |
| 77 | Writes data into the current process's stdin. API client specifies a Python |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 78 | string as the only argument.") PutSTDIN; |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 79 | size_t |
| 80 | PutSTDIN (const char *src, size_t src_len); |
| 81 | |
Johnny Chen | d80e5e9 | 2011-11-28 19:12:25 +0000 | [diff] [blame] | 82 | %feature("autodoc", " |
| 83 | Reads data from the current process's stdout stream. API client specifies |
| 84 | the size of the buffer to read data into. It returns the byte buffer in a |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 85 | Python string.") GetSTDOUT; |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 86 | size_t |
| 87 | GetSTDOUT (char *dst, size_t dst_len) const; |
| 88 | |
Johnny Chen | d80e5e9 | 2011-11-28 19:12:25 +0000 | [diff] [blame] | 89 | %feature("autodoc", " |
| 90 | Reads data from the current process's stderr stream. API client specifies |
| 91 | the size of the buffer to read data into. It returns the byte buffer in a |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 92 | Python string.") GetSTDERR; |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 93 | size_t |
| 94 | GetSTDERR (char *dst, size_t dst_len) const; |
| 95 | |
Han Ming Ong | ab3b8b2 | 2012-11-17 00:21:04 +0000 | [diff] [blame] | 96 | size_t |
| 97 | GetAsyncProfileData(char *dst, size_t dst_len) const; |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 98 | |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 99 | void |
Lawrence D'Anna | 322f12a | 2019-10-14 20:15:28 +0000 | [diff] [blame] | 100 | ReportEventState (const lldb::SBEvent &event, SBFile out) const; |
| 101 | |
| 102 | void |
| 103 | ReportEventState (const lldb::SBEvent &event, FileSP BORROWED) const; |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 104 | |
| 105 | void |
| 106 | AppendEventStateReport (const lldb::SBEvent &event, lldb::SBCommandReturnObject &result); |
| 107 | |
| 108 | %feature("docstring", " |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 109 | Remote connection related functions. These will fail if the |
| 110 | process is not in eStateConnected. They are intended for use |
| 111 | when connecting to an externally managed debugserver instance.") RemoteAttachToProcessWithID; |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 112 | bool |
| 113 | RemoteAttachToProcessWithID (lldb::pid_t pid, |
| 114 | lldb::SBError& error); |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 115 | |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 116 | %feature("docstring", |
| 117 | "See SBTarget.Launch for argument description and usage." |
| 118 | ) RemoteLaunch; |
| 119 | bool |
| 120 | RemoteLaunch (char const **argv, |
| 121 | char const **envp, |
| 122 | const char *stdin_path, |
| 123 | const char *stdout_path, |
| 124 | const char *stderr_path, |
| 125 | const char *working_directory, |
| 126 | uint32_t launch_flags, |
| 127 | bool stop_at_entry, |
| 128 | lldb::SBError& error); |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 129 | |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 130 | //------------------------------------------------------------------ |
| 131 | // Thread related functions |
| 132 | //------------------------------------------------------------------ |
| 133 | uint32_t |
| 134 | GetNumThreads (); |
| 135 | |
Jim Ingham | 18b4689 | 2012-07-13 20:18:18 +0000 | [diff] [blame] | 136 | %feature("autodoc", " |
| 137 | Returns the INDEX'th thread from the list of current threads. The index |
| 138 | of a thread is only valid for the current stop. For a persistent thread |
| 139 | identifier use either the thread ID or the IndexID. See help on SBThread |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 140 | for more details.") GetThreadAtIndex; |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 141 | lldb::SBThread |
| 142 | GetThreadAtIndex (size_t index); |
| 143 | |
Jim Ingham | 18b4689 | 2012-07-13 20:18:18 +0000 | [diff] [blame] | 144 | %feature("autodoc", " |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 145 | Returns the thread with the given thread ID.") GetThreadByID; |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 146 | lldb::SBThread |
| 147 | GetThreadByID (lldb::tid_t sb_thread_id); |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 148 | |
Jim Ingham | 18b4689 | 2012-07-13 20:18:18 +0000 | [diff] [blame] | 149 | %feature("autodoc", " |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 150 | Returns the thread with the given thread IndexID.") GetThreadByIndexID; |
Jim Ingham | 18b4689 | 2012-07-13 20:18:18 +0000 | [diff] [blame] | 151 | lldb::SBThread |
| 152 | GetThreadByIndexID (uint32_t index_id); |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 153 | |
Jim Ingham | 18b4689 | 2012-07-13 20:18:18 +0000 | [diff] [blame] | 154 | %feature("autodoc", " |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 155 | Returns the currently selected thread.") GetSelectedThread; |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 156 | lldb::SBThread |
| 157 | GetSelectedThread () const; |
| 158 | |
Greg Clayton | a4d8747 | 2013-01-18 23:41:08 +0000 | [diff] [blame] | 159 | %feature("autodoc", " |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 160 | Lazily create a thread on demand through the current OperatingSystem plug-in, if the current OperatingSystem plug-in supports it.") CreateOSPluginThread; |
Greg Clayton | a4d8747 | 2013-01-18 23:41:08 +0000 | [diff] [blame] | 161 | lldb::SBThread |
| 162 | CreateOSPluginThread (lldb::tid_t tid, lldb::addr_t context); |
| 163 | |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 164 | bool |
| 165 | SetSelectedThread (const lldb::SBThread &thread); |
| 166 | |
| 167 | bool |
Greg Clayton | ea561dc | 2012-10-12 23:32:11 +0000 | [diff] [blame] | 168 | SetSelectedThreadByID (lldb::tid_t tid); |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 169 | |
Jim Ingham | 18b4689 | 2012-07-13 20:18:18 +0000 | [diff] [blame] | 170 | bool |
| 171 | SetSelectedThreadByIndexID (uint32_t index_id); |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 172 | |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 173 | //------------------------------------------------------------------ |
Jason Molenda | 5e8dce4 | 2013-12-13 00:29:16 +0000 | [diff] [blame] | 174 | // Queue related functions |
| 175 | //------------------------------------------------------------------ |
| 176 | uint32_t |
| 177 | GetNumQueues (); |
| 178 | |
| 179 | lldb::SBQueue |
| 180 | GetQueueAtIndex (uint32_t index); |
| 181 | |
| 182 | //------------------------------------------------------------------ |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 183 | // Stepping related functions |
| 184 | //------------------------------------------------------------------ |
| 185 | |
| 186 | lldb::StateType |
| 187 | GetState (); |
| 188 | |
| 189 | int |
| 190 | GetExitStatus (); |
| 191 | |
| 192 | const char * |
| 193 | GetExitDescription (); |
| 194 | |
Greg Clayton | 949e822 | 2013-01-16 17:29:04 +0000 | [diff] [blame] | 195 | %feature("autodoc", " |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 196 | Returns the process ID of the process.") GetProcessID; |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 197 | lldb::pid_t |
| 198 | GetProcessID (); |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 199 | |
Greg Clayton | 949e822 | 2013-01-16 17:29:04 +0000 | [diff] [blame] | 200 | %feature("autodoc", " |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 201 | Returns an integer ID that is guaranteed to be unique across all process instances. This is not the process ID, just a unique integer for comparison and caching purposes.") GetUniqueID; |
Greg Clayton | 949e822 | 2013-01-16 17:29:04 +0000 | [diff] [blame] | 202 | uint32_t |
| 203 | GetUniqueID(); |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 204 | |
| 205 | uint32_t |
| 206 | GetAddressByteSize() const; |
| 207 | |
| 208 | %feature("docstring", " |
| 209 | Kills the process and shuts down all threads that were spawned to |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 210 | track and monitor process.") Destroy; |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 211 | lldb::SBError |
| 212 | Destroy (); |
| 213 | |
| 214 | lldb::SBError |
| 215 | Continue (); |
| 216 | |
| 217 | lldb::SBError |
| 218 | Stop (); |
| 219 | |
| 220 | %feature("docstring", "Same as Destroy(self).") Destroy; |
| 221 | lldb::SBError |
| 222 | Kill (); |
| 223 | |
| 224 | lldb::SBError |
| 225 | Detach (); |
| 226 | |
| 227 | %feature("docstring", "Sends the process a unix signal.") Signal; |
| 228 | lldb::SBError |
| 229 | Signal (int signal); |
| 230 | |
Todd Fiala | 802dc402 | 2014-06-23 19:30:49 +0000 | [diff] [blame] | 231 | lldb::SBUnixSignals |
| 232 | GetUnixSignals(); |
| 233 | |
Jim Ingham | bf2956a2 | 2013-01-08 23:22:42 +0000 | [diff] [blame] | 234 | %feature("docstring", " |
| 235 | Returns a stop id that will increase every time the process executes. If |
| 236 | include_expression_stops is true, then stops caused by expression evaluation |
| 237 | will cause the returned value to increase, otherwise the counter returned will |
| 238 | only increase when execution is continued explicitly by the user. Note, the value |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 239 | will always increase, but may increase by more than one per stop.") GetStopID; |
Jim Ingham | bf2956a2 | 2013-01-08 23:22:42 +0000 | [diff] [blame] | 240 | uint32_t |
| 241 | GetStopID(bool include_expression_stops = false); |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 242 | |
Jim Ingham | cfc0935 | 2012-07-27 23:57:19 +0000 | [diff] [blame] | 243 | void |
| 244 | SendAsyncInterrupt(); |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 245 | |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 246 | %feature("autodoc", " |
| 247 | Reads memory from the current process's address space and removes any |
| 248 | traps that may have been inserted into the memory. It returns the byte |
| 249 | buffer in a Python string. Example: |
| 250 | |
| 251 | # Read 4 bytes from address 'addr' and assume error.Success() is True. |
| 252 | content = process.ReadMemory(addr, 4, error) |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 253 | new_bytes = bytearray(content)") ReadMemory; |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 254 | size_t |
| 255 | ReadMemory (addr_t addr, void *buf, size_t size, lldb::SBError &error); |
| 256 | |
| 257 | %feature("autodoc", " |
| 258 | Writes memory to the current process's address space and maintains any |
| 259 | traps that might be present due to software breakpoints. Example: |
| 260 | |
| 261 | # Create a Python string from the byte array. |
| 262 | new_value = str(bytes) |
| 263 | result = process.WriteMemory(addr, new_value, error) |
| 264 | if not error.Success() or result != len(bytes): |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 265 | print('SBProcess.WriteMemory() failed!')") WriteMemory; |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 266 | size_t |
| 267 | WriteMemory (addr_t addr, const void *buf, size_t size, lldb::SBError &error); |
| 268 | |
Greg Clayton | e91b795 | 2011-12-15 03:14:23 +0000 | [diff] [blame] | 269 | %feature("autodoc", " |
| 270 | Reads a NULL terminated C string from the current process's address space. |
| 271 | It returns a python string of the exact length, or truncates the string if |
| 272 | the maximum character limit is reached. Example: |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 273 | |
| 274 | # Read a C string of at most 256 bytes from address '0x1000' |
Greg Clayton | e91b795 | 2011-12-15 03:14:23 +0000 | [diff] [blame] | 275 | error = lldb.SBError() |
Johnny Chen | 80e3e84 | 2011-12-15 22:34:59 +0000 | [diff] [blame] | 276 | cstring = process.ReadCStringFromMemory(0x1000, 256, error) |
Greg Clayton | e91b795 | 2011-12-15 03:14:23 +0000 | [diff] [blame] | 277 | if error.Success(): |
Zachary Turner | 5f3fd80 | 2015-10-16 17:52:32 +0000 | [diff] [blame] | 278 | print('cstring: ', cstring) |
Greg Clayton | e91b795 | 2011-12-15 03:14:23 +0000 | [diff] [blame] | 279 | else |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 280 | print('error: ', error)") ReadCStringFromMemory; |
Greg Clayton | e91b795 | 2011-12-15 03:14:23 +0000 | [diff] [blame] | 281 | |
| 282 | size_t |
Zachary Turner | 4407396 | 2016-01-25 23:21:18 +0000 | [diff] [blame] | 283 | ReadCStringFromMemory (addr_t addr, void *char_buf, size_t size, lldb::SBError &error); |
Greg Clayton | e91b795 | 2011-12-15 03:14:23 +0000 | [diff] [blame] | 284 | |
| 285 | %feature("autodoc", " |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 286 | Reads an unsigned integer from memory given a byte size and an address. |
Greg Clayton | e91b795 | 2011-12-15 03:14:23 +0000 | [diff] [blame] | 287 | Returns the unsigned integer that was read. Example: |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 288 | |
Greg Clayton | e91b795 | 2011-12-15 03:14:23 +0000 | [diff] [blame] | 289 | # Read a 4 byte unsigned integer from address 0x1000 |
| 290 | error = lldb.SBError() |
| 291 | uint = ReadUnsignedFromMemory(0x1000, 4, error) |
| 292 | if error.Success(): |
Zachary Turner | 5f3fd80 | 2015-10-16 17:52:32 +0000 | [diff] [blame] | 293 | print('integer: %u' % uint) |
Greg Clayton | e91b795 | 2011-12-15 03:14:23 +0000 | [diff] [blame] | 294 | else |
Pavel Labath | 27e9d98 | 2019-04-21 12:48:53 +0000 | [diff] [blame] | 295 | print('error: ', error)") ReadUnsignedFromMemory; |
Greg Clayton | e91b795 | 2011-12-15 03:14:23 +0000 | [diff] [blame] | 296 | |
| 297 | uint64_t |
| 298 | ReadUnsignedFromMemory (addr_t addr, uint32_t byte_size, lldb::SBError &error); |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 299 | |
Greg Clayton | e91b795 | 2011-12-15 03:14:23 +0000 | [diff] [blame] | 300 | %feature("autodoc", " |
| 301 | Reads a pointer from memory from an address and returns the value. Example: |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 302 | |
Greg Clayton | e91b795 | 2011-12-15 03:14:23 +0000 | [diff] [blame] | 303 | # Read a pointer from address 0x1000 |
| 304 | error = lldb.SBError() |
| 305 | ptr = ReadPointerFromMemory(0x1000, error) |
| 306 | if error.Success(): |
Zachary Turner | 5f3fd80 | 2015-10-16 17:52:32 +0000 | [diff] [blame] | 307 | print('pointer: 0x%x' % ptr) |
Greg Clayton | e91b795 | 2011-12-15 03:14:23 +0000 | [diff] [blame] | 308 | else |
Pavel Labath | 27e9d98 | 2019-04-21 12:48:53 +0000 | [diff] [blame] | 309 | print('error: ', error)") ReadPointerFromMemory; |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 310 | |
Greg Clayton | e91b795 | 2011-12-15 03:14:23 +0000 | [diff] [blame] | 311 | lldb::addr_t |
| 312 | ReadPointerFromMemory (addr_t addr, lldb::SBError &error); |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 313 | |
Greg Clayton | e91b795 | 2011-12-15 03:14:23 +0000 | [diff] [blame] | 314 | |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 315 | // Events |
| 316 | static lldb::StateType |
| 317 | GetStateFromEvent (const lldb::SBEvent &event); |
| 318 | |
| 319 | static bool |
| 320 | GetRestartedFromEvent (const lldb::SBEvent &event); |
| 321 | |
Jim Ingham | 0161b49 | 2013-02-09 01:29:05 +0000 | [diff] [blame] | 322 | static size_t |
| 323 | GetNumRestartedReasonsFromEvent (const lldb::SBEvent &event); |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 324 | |
Jim Ingham | 0161b49 | 2013-02-09 01:29:05 +0000 | [diff] [blame] | 325 | static const char * |
| 326 | GetRestartedReasonAtIndexFromEvent (const lldb::SBEvent &event, size_t idx); |
| 327 | |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 328 | static lldb::SBProcess |
| 329 | GetProcessFromEvent (const lldb::SBEvent &event); |
| 330 | |
Jim Ingham | e6bc6cb | 2012-02-08 05:23:15 +0000 | [diff] [blame] | 331 | static bool |
Ilia K | 06d2855 | 2015-05-15 09:29:09 +0000 | [diff] [blame] | 332 | GetInterruptedFromEvent (const lldb::SBEvent &event); |
| 333 | |
Todd Fiala | 7593001 | 2016-08-19 04:21:48 +0000 | [diff] [blame] | 334 | static lldb::SBStructuredData |
| 335 | GetStructuredDataFromEvent (const lldb::SBEvent &event); |
| 336 | |
Ilia K | 06d2855 | 2015-05-15 09:29:09 +0000 | [diff] [blame] | 337 | static bool |
Jim Ingham | e6bc6cb | 2012-02-08 05:23:15 +0000 | [diff] [blame] | 338 | EventIsProcessEvent (const lldb::SBEvent &event); |
| 339 | |
Todd Fiala | 7593001 | 2016-08-19 04:21:48 +0000 | [diff] [blame] | 340 | static bool |
| 341 | EventIsStructuredDataEvent (const lldb::SBEvent &event); |
| 342 | |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 343 | lldb::SBBroadcaster |
| 344 | GetBroadcaster () const; |
| 345 | |
| 346 | bool |
| 347 | GetDescription (lldb::SBStream &description); |
| 348 | |
| 349 | uint32_t |
Johnny Chen | f9ef60d | 2012-05-23 22:34:34 +0000 | [diff] [blame] | 350 | GetNumSupportedHardwareWatchpoints (lldb::SBError &error) const; |
| 351 | |
| 352 | uint32_t |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 353 | LoadImage (lldb::SBFileSpec &image_spec, lldb::SBError &error); |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 354 | |
Jim Ingham | 0d231f7 | 2018-06-28 20:02:11 +0000 | [diff] [blame] | 355 | %feature("autodoc", " |
| 356 | Load the library whose filename is given by image_spec looking in all the |
| 357 | paths supplied in the paths argument. If successful, return a token that |
| 358 | can be passed to UnloadImage and fill loaded_path with the path that was |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 359 | successfully loaded. On failure, return |
| 360 | lldb.LLDB_INVALID_IMAGE_TOKEN.") LoadImageUsingPaths; |
| 361 | uint32_t |
Jim Ingham | 0d231f7 | 2018-06-28 20:02:11 +0000 | [diff] [blame] | 362 | LoadImageUsingPaths(const lldb::SBFileSpec &image_spec, |
| 363 | SBStringList &paths, |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 364 | lldb::SBFileSpec &loaded_path, |
Jim Ingham | 0d231f7 | 2018-06-28 20:02:11 +0000 | [diff] [blame] | 365 | SBError &error); |
| 366 | |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 367 | lldb::SBError |
| 368 | UnloadImage (uint32_t image_token); |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 369 | |
Jason Molenda | a332978 | 2014-03-29 18:54:20 +0000 | [diff] [blame] | 370 | lldb::SBError |
| 371 | SendEventData (const char *event_data); |
Johnny Chen | 39c6d0f | 2012-01-06 00:46:12 +0000 | [diff] [blame] | 372 | |
Jason Molenda | 8c71337 | 2013-11-05 11:00:35 +0000 | [diff] [blame] | 373 | %feature("autodoc", " |
| 374 | Return the number of different thread-origin extended backtraces |
| 375 | this process can support as a uint32_t. |
| 376 | When the process is stopped and you have an SBThread, lldb may be |
| 377 | able to show a backtrace of when that thread was originally created, |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 378 | or the work item was enqueued to it (in the case of a libdispatch |
| 379 | queue).") GetNumExtendedBacktraceTypes; |
| 380 | |
Jason Molenda | 8c71337 | 2013-11-05 11:00:35 +0000 | [diff] [blame] | 381 | uint32_t |
Jason Molenda | 95d005c | 2013-11-06 03:07:33 +0000 | [diff] [blame] | 382 | GetNumExtendedBacktraceTypes (); |
Jason Molenda | 8c71337 | 2013-11-05 11:00:35 +0000 | [diff] [blame] | 383 | |
| 384 | %feature("autodoc", " |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 385 | Takes an index argument, returns the name of one of the thread-origin |
| 386 | extended backtrace methods as a str.") GetExtendedBacktraceTypeAtIndex; |
Jason Molenda | 8c71337 | 2013-11-05 11:00:35 +0000 | [diff] [blame] | 387 | |
| 388 | const char * |
Jason Molenda | 95d005c | 2013-11-06 03:07:33 +0000 | [diff] [blame] | 389 | GetExtendedBacktraceTypeAtIndex (uint32_t idx); |
Jason Molenda | 8c71337 | 2013-11-05 11:00:35 +0000 | [diff] [blame] | 390 | |
Kuba Brecka | a51ea38 | 2014-09-06 01:33:13 +0000 | [diff] [blame] | 391 | lldb::SBThreadCollection |
| 392 | GetHistoryThreads (addr_t addr); |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 393 | |
Kuba Brecka | 6392754 | 2014-10-11 01:59:32 +0000 | [diff] [blame] | 394 | bool |
| 395 | IsInstrumentationRuntimePresent(lldb::InstrumentationRuntimeType type); |
Kuba Brecka | a51ea38 | 2014-09-06 01:33:13 +0000 | [diff] [blame] | 396 | |
Adrian McCarthy | f7d1893 | 2015-11-20 23:09:11 +0000 | [diff] [blame] | 397 | lldb::SBError |
| 398 | SaveCore(const char *file_name); |
| 399 | |
Ravitheja Addepally | d5d8d91 | 2017-04-26 08:48:50 +0000 | [diff] [blame] | 400 | lldb::SBTrace |
| 401 | StartTrace(SBTraceOptions &options, lldb::SBError &error); |
| 402 | |
Greg Clayton | 4d32eb6 | 2016-06-24 23:40:35 +0000 | [diff] [blame] | 403 | lldb::SBError |
| 404 | GetMemoryRegionInfo(lldb::addr_t load_addr, lldb::SBMemoryRegionInfo ®ion_info); |
| 405 | |
| 406 | lldb::SBMemoryRegionInfoList |
| 407 | GetMemoryRegions(); |
| 408 | |
Vadim Macagon | 141a626 | 2017-08-01 07:34:26 +0000 | [diff] [blame] | 409 | %feature("autodoc", " |
| 410 | Get information about the process. |
| 411 | Valid process info will only be returned when the process is alive, |
| 412 | use IsValid() to check if the info returned is valid. |
| 413 | |
| 414 | process_info = process.GetProcessInfo() |
| 415 | if process_info.IsValid(): |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 416 | process_info.GetProcessID()") GetProcessInfo; |
Vadim Macagon | 141a626 | 2017-08-01 07:34:26 +0000 | [diff] [blame] | 417 | lldb::SBProcessInfo |
| 418 | GetProcessInfo(); |
| 419 | |
Greg Clayton | 13d1950 | 2012-01-29 06:07:39 +0000 | [diff] [blame] | 420 | %pythoncode %{ |
Greg Clayton | 6b2bd93 | 2012-02-01 08:09:32 +0000 | [diff] [blame] | 421 | def __get_is_alive__(self): |
| 422 | '''Returns "True" if the process is currently alive, "False" otherwise''' |
| 423 | s = self.GetState() |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 424 | if (s == eStateAttaching or |
| 425 | s == eStateLaunching or |
| 426 | s == eStateStopped or |
| 427 | s == eStateRunning or |
| 428 | s == eStateStepping or |
| 429 | s == eStateCrashed or |
Greg Clayton | 6b2bd93 | 2012-02-01 08:09:32 +0000 | [diff] [blame] | 430 | s == eStateSuspended): |
| 431 | return True |
| 432 | return False |
| 433 | |
| 434 | def __get_is_running__(self): |
| 435 | '''Returns "True" if the process is currently running, "False" otherwise''' |
| 436 | state = self.GetState() |
| 437 | if state == eStateRunning or state == eStateStepping: |
| 438 | return True |
| 439 | return False |
| 440 | |
Greg Clayton | d458c4d | 2016-07-05 18:19:43 +0000 | [diff] [blame] | 441 | def __get_is_stopped__(self): |
Greg Clayton | 6b2bd93 | 2012-02-01 08:09:32 +0000 | [diff] [blame] | 442 | '''Returns "True" if the process is currently stopped, "False" otherwise''' |
| 443 | state = self.GetState() |
| 444 | if state == eStateStopped or state == eStateCrashed or state == eStateSuspended: |
| 445 | return True |
| 446 | return False |
| 447 | |
Greg Clayton | b62bb8c | 2012-02-03 03:22:53 +0000 | [diff] [blame] | 448 | class threads_access(object): |
Greg Clayton | 6b2bd93 | 2012-02-01 08:09:32 +0000 | [diff] [blame] | 449 | '''A helper object that will lazily hand out thread for a process when supplied an index.''' |
| 450 | def __init__(self, sbprocess): |
| 451 | self.sbprocess = sbprocess |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 452 | |
Greg Clayton | 6b2bd93 | 2012-02-01 08:09:32 +0000 | [diff] [blame] | 453 | def __len__(self): |
Filipe Cabecinhas | 1a96ef8 | 2012-05-11 20:39:42 +0000 | [diff] [blame] | 454 | if self.sbprocess: |
| 455 | return int(self.sbprocess.GetNumThreads()) |
Greg Clayton | 6b2bd93 | 2012-02-01 08:09:32 +0000 | [diff] [blame] | 456 | return 0 |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 457 | |
Greg Clayton | 6b2bd93 | 2012-02-01 08:09:32 +0000 | [diff] [blame] | 458 | def __getitem__(self, key): |
| 459 | if type(key) is int and key < len(self): |
| 460 | return self.sbprocess.GetThreadAtIndex(key) |
| 461 | return None |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 462 | |
Greg Clayton | b62bb8c | 2012-02-03 03:22:53 +0000 | [diff] [blame] | 463 | def get_threads_access_object(self): |
| 464 | '''An accessor function that returns a modules_access() object which allows lazy thread access from a lldb.SBProcess object.''' |
| 465 | return self.threads_access (self) |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 466 | |
Greg Clayton | 6b2bd93 | 2012-02-01 08:09:32 +0000 | [diff] [blame] | 467 | def get_process_thread_list(self): |
Greg Clayton | b62bb8c | 2012-02-03 03:22:53 +0000 | [diff] [blame] | 468 | '''An accessor function that returns a list() that contains all threads in a lldb.SBProcess object.''' |
Greg Clayton | 6b2bd93 | 2012-02-01 08:09:32 +0000 | [diff] [blame] | 469 | threads = [] |
Enrico Granata | beea93c | 2012-10-08 19:06:11 +0000 | [diff] [blame] | 470 | accessor = self.get_threads_access_object() |
| 471 | for idx in range(len(accessor)): |
| 472 | threads.append(accessor[idx]) |
Greg Clayton | 6b2bd93 | 2012-02-01 08:09:32 +0000 | [diff] [blame] | 473 | return threads |
Pavel Labath | 4da5a1d | 2019-04-03 11:48:38 +0000 | [diff] [blame] | 474 | |
| 475 | def __iter__(self): |
| 476 | '''Iterate over all threads in a lldb.SBProcess object.''' |
| 477 | return lldb_iter(self, 'GetNumThreads', 'GetThreadAtIndex') |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 478 | |
Pavel Labath | 4da5a1d | 2019-04-03 11:48:38 +0000 | [diff] [blame] | 479 | def __len__(self): |
| 480 | '''Return the number of threads in a lldb.SBProcess object.''' |
| 481 | return self.GetNumThreads() |
| 482 | |
Pavel Labath | eba9742 | 2019-04-18 16:23:33 +0000 | [diff] [blame] | 483 | |
Jonas Devlieghere | 89b6584 | 2019-07-02 22:18:35 +0000 | [diff] [blame] | 484 | threads = property(get_process_thread_list, None, doc='''A read only property that returns a list() of lldb.SBThread objects for this process.''') |
| 485 | thread = property(get_threads_access_object, None, doc='''A read only property that returns an object that can access threads by thread index (thread = lldb.process.thread[12]).''') |
| 486 | is_alive = property(__get_is_alive__, None, doc='''A read only property that returns a boolean value that indicates if this process is currently alive.''') |
| 487 | is_running = property(__get_is_running__, None, doc='''A read only property that returns a boolean value that indicates if this process is currently running.''') |
| 488 | is_stopped = property(__get_is_stopped__, None, doc='''A read only property that returns a boolean value that indicates if this process is currently stopped.''') |
| 489 | id = property(GetProcessID, None, doc='''A read only property that returns the process ID as an integer.''') |
| 490 | target = property(GetTarget, None, doc='''A read only property that an lldb object that represents the target (lldb.SBTarget) that owns this process.''') |
| 491 | num_threads = property(GetNumThreads, None, doc='''A read only property that returns the number of threads in this process as an integer.''') |
| 492 | selected_thread = property(GetSelectedThread, SetSelectedThread, doc='''A read/write property that gets/sets the currently selected thread in this process. The getter returns a lldb.SBThread object and the setter takes an lldb.SBThread object.''') |
| 493 | state = property(GetState, None, doc='''A read only property that returns an lldb enumeration value (see enumerations that start with "lldb.eState") that represents the current state of this process (running, stopped, exited, etc.).''') |
| 494 | exit_state = property(GetExitStatus, None, doc='''A read only property that returns an exit status as an integer of this process when the process state is lldb.eStateExited.''') |
| 495 | exit_description = property(GetExitDescription, None, doc='''A read only property that returns an exit description as a string of this process when the process state is lldb.eStateExited.''') |
| 496 | broadcaster = property(GetBroadcaster, None, doc='''A read only property that an lldb object that represents the broadcaster (lldb.SBBroadcaster) for this process.''') |
Greg Clayton | 13d1950 | 2012-01-29 06:07:39 +0000 | [diff] [blame] | 497 | %} |
| 498 | |
Johnny Chen | 357033b | 2011-07-18 20:13:38 +0000 | [diff] [blame] | 499 | }; |
| 500 | |
| 501 | } // namespace lldb |