Crashpad
|
A MemorySnapshot which wraps and filters sensitive information from another MemorySnapshot. More...
#include "snapshot/sanitized/memory_snapshot_sanitized.h"
Public Member Functions | |
MemorySnapshotSanitized (const MemorySnapshot *snapshot, RangeSet *ranges, bool is_64_bit) | |
Constructs this object. More... | |
uint64_t | Address () const override |
The base address of the memory snapshot in the snapshot process’ address space. | |
size_t | Size () const override |
The size of the memory snapshot. | |
bool | Read (Delegate *delegate) const override |
Calls Delegate::MemorySnapshotDelegateRead(), providing it with the memory snapshot’s data. More... | |
const MemorySnapshot * | MergeWithOtherSnapshot (const MemorySnapshot *other) const override |
Creates a new MemorySnapshot based on merging this one with other. More... | |
Static Public Attributes | |
static constexpr uint64_t | kDefaced = 0x0defaced0defaced |
Redacted data is replaced with this value, casted to the appropriate size for a pointer in the target process. | |
static constexpr uint64_t | kSmallWordMax = 4096 |
Pointer-aligned data smaller than this value is not redacted. | |
A MemorySnapshot which wraps and filters sensitive information from another MemorySnapshot.
This class redacts all data from the wrapped MemorySnapshot unless:
crashpad::internal::MemorySnapshotSanitized::MemorySnapshotSanitized | ( | const MemorySnapshot * | snapshot, |
RangeSet * | ranges, | ||
bool | is_64_bit | ||
) |
Constructs this object.
[in] | snapshot | The MemorySnapshot to sanitize. |
[in] | ranges | A set of whitelisted address ranges. |
[in] | is_64_bit | true if this memory is for a 64-bit process. |
|
inlineoverridevirtual |
Creates a new MemorySnapshot based on merging this one with other.
The ranges described by the two snapshots must either overlap or abut, and must be of the same concrete type.
nullptr
with an error logged. Implements crashpad::MemorySnapshot.
|
overridevirtual |
Calls Delegate::MemorySnapshotDelegateRead(), providing it with the memory snapshot’s data.
Implementations do not necessarily read the memory snapshot data prior to this method being called. Memory snapshot data may be loaded lazily and may be discarded after being passed to the delegate. This provides clean memory management without burdening a snapshot implementation with the requirement that it track all memory region data simultaneously.
false
on failure, otherwise, the return value of Delegate::MemorySnapshotDelegateRead(), which should be true
on success and false
on failure. Implements crashpad::MemorySnapshot.