Abstract base class for accessing the memory of another process.
More...
#include "util/process/process_memory.h"
|
bool | Read (VMAddress address, VMSize size, void *buffer) const |
| Copies memory from the target process into a caller-provided buffer in the current process.
|
|
bool | ReadCString (VMAddress address, std::string *string) const |
| Reads a NUL -terminated C string from the target process into a string in the current process.
|
|
bool | ReadCStringSizeLimited (VMAddress address, VMSize size, std::string *string) const |
| Reads a NUL -terminated C string from the target process into a string in the current process.
|
|
|
class | ProcessMemorySanitized |
|
Abstract base class for accessing the memory of another process.
Implementations are platform-specific.
◆ Read()
bool crashpad::ProcessMemory::Read |
( |
VMAddress | address, |
|
|
VMSize | size, |
|
|
void * | buffer ) const |
Copies memory from the target process into a caller-provided buffer in the current process.
- Parameters
-
[in] | address | The address, in the target process' address space, of the memory region to copy. |
[in] | size | The size, in bytes, of the memory region to copy. buffer must be at least this size. |
[out] | buffer | The buffer into which the contents of the other process' memory will be copied. |
- Returns
true
on success, with buffer filled appropriately. false
on failure, with a message logged.
◆ ReadCString()
bool crashpad::ProcessMemory::ReadCString |
( |
VMAddress | address, |
|
|
std::string * | string ) const |
|
inline |
Reads a NUL
-terminated C string from the target process into a string in the current process.
The length of the string need not be known ahead of time. This method will read contiguous memory until a NUL
terminator is found.
- Parameters
-
[in] | address | The address, in the target process’s address space, of the string to copy. |
[out] | string | The string read from the other process. |
- Returns
true
on success, with string set appropriately. false
on failure, with a message logged. Failures can occur, for example, when encountering unmapped or unreadable pages.
◆ ReadCStringSizeLimited()
bool crashpad::ProcessMemory::ReadCStringSizeLimited |
( |
VMAddress | address, |
|
|
VMSize | size, |
|
|
std::string * | string ) const |
|
inline |
Reads a NUL
-terminated C string from the target process into a string in the current process.
- Parameters
-
[in] | address | The address, in the target process’s address space, of the string to copy. |
[in] | size | The maximum number of bytes to read. The string is required to be NUL -terminated within this many bytes. |
[out] | string | The string read from the other process. |
- Returns
true
on success, with string set appropriately. false
on failure, with a message logged. Failures can occur, for example, when a NUL
terminator is not found within size bytes, or when encountering unmapped or unreadable pages.
The documentation for this class was generated from the following files:
- util/process/process_memory.h
- util/process/process_memory.cc