Crashpad
|
A ModuleSnapshot of a code module (binary image) loaded into a running (or crashed) process on an iOS system. More...
#include "snapshot/ios/module_snapshot_ios.h"
Public Member Functions | |
bool | Initialize (const dyld_image_info *image) |
Initializes the object. More... | |
bool | InitializeDyld (const dyld_all_image_infos *images) |
Initializes the object specifically for the dyld module. More... | |
void | GetCrashpadOptions (CrashpadInfoClientOptions *options) |
Returns options from the module’s CrashpadInfo structure. More... | |
std::string | Name () const override |
Returns the module’s pathname. | |
uint64_t | Address () const override |
Returns the base address that the module is loaded at in the snapshot process. | |
uint64_t | Size () const override |
Returns the size that the module occupies in the snapshot process’ address space, starting at its base address. More... | |
time_t | Timestamp () const override |
Returns the module’s timestamp, if known. More... | |
void | FileVersion (uint16_t *version_0, uint16_t *version_1, uint16_t *version_2, uint16_t *version_3) const override |
Returns the module’s file version in the version_* parameters. More... | |
void | SourceVersion (uint16_t *version_0, uint16_t *version_1, uint16_t *version_2, uint16_t *version_3) const override |
Returns the module’s source version in the version_* parameters. More... | |
ModuleType | GetModuleType () const override |
Returns the module’s type. | |
void | UUIDAndAge (UUID *uuid, uint32_t *age) const override |
Returns the module’s UUID in the uuid parameter, and the age of that UUID in age. More... | |
std::string | DebugFileName () const override |
Returns the module’s debug file info name. More... | |
std::vector< uint8_t > | BuildID () const override |
Returns the module’s build ID. More... | |
std::vector< std::string > | AnnotationsVector () const override |
Returns string annotations recorded in the module. More... | |
std::map< std::string, std::string > | AnnotationsSimpleMap () const override |
Returns key-value string annotations recorded in the module. More... | |
std::vector< AnnotationSnapshot > | AnnotationObjects () const override |
Returns the typed annotation objects recorded in the module. More... | |
std::set< CheckedRange< uint64_t > > | ExtraMemoryRanges () const override |
Returns a set of extra memory ranges specified in the module as being desirable to include in the crash dump. | |
std::vector< const UserMinidumpStream * > | CustomMinidumpStreams () const override |
Returns a list of custom minidump stream specified in the module to be included in the crash dump. More... | |
Static Public Member Functions | |
static const dyld_all_image_infos * | DyldAllImageInfo () |
Additional Inherited Members | |
Public Types inherited from crashpad::ModuleSnapshot | |
enum | ModuleType |
A module’s type. More... | |
A ModuleSnapshot of a code module (binary image) loaded into a running (or crashed) process on an iOS system.
|
overridevirtual |
Returns the typed annotation objects recorded in the module.
This method retrieves annotations recorded in a module. These annotations are intended for diagnostic use, including crash analysis. Annotation objects are strongly-typed name-value pairs. The names are not unique.
For macOS snapshots, these annotations are found by interpreting the __DATA,crashpad_info
section as CrashpadInfo
. Clients can use the Crashpad client interface to store annotations in this structure. Most annotations under the client’s direct control will be retrievable by this method. For clients such as Chrome, this includes the process type.
The annotations returned by this method do not duplicate those returned by AnnotationsVector() or AnnotationsSimpleMap().
Implements crashpad::ModuleSnapshot.
|
overridevirtual |
Returns key-value string annotations recorded in the module.
This method retrieves annotations recorded in a module. These annotations are intended for diagnostic use, including crash analysis. “Simple annotations” are structured as a sequence of key-value pairs, where all keys and values are strings. These are referred to in Chrome as “crash keys.”
For macOS snapshots, these annotations are found by interpreting the __DATA,crashpad_info
section as CrashpadInfo
. Clients can use the Crashpad client interface to store annotations in this structure. Most annotations under the client’s direct control will be retrievable by this method. For clients such as Chrome, this includes the process type.
The annotations returned by this method do not duplicate those returned by AnnotationsVector() or AnnotationObjects(). Additional annotations related to the process, system, or snapshot producer may be obtained by calling ProcessSnapshot::AnnotationsSimpleMap().
Implements crashpad::ModuleSnapshot.
|
overridevirtual |
Returns string annotations recorded in the module.
This method retrieves annotations recorded in a module. These annotations are intended for diagnostic use, including crash analysis. A module may contain multiple annotations, so they are returned in a vector.
For macOS snapshots, these annotations are found by interpreting the module’s __DATA,__crash_info
section as crashreporter_annotations_t
. System libraries using the crash reporter client interface may reference annotations in this structure. Additional annotations messages may be found in other locations, which may be module-specific. The dynamic linker (dyld
) can provide an annotation at its _error_string
symbol.
The annotations returned by this method do not duplicate those returned by AnnotationsSimpleMap() or AnnotationObjects().
Implements crashpad::ModuleSnapshot.
|
overridevirtual |
Returns the module’s build ID.
On ELF platforms, the build ID is a variable-length byte stream that identifies a library uniquely, and is usually used to look up its debug symbols when stored separately. This will return an empty vector if it is unsupported.
BuildID() and UUIDAndAge() are never available in the same place. When UUIDAndAge() is unavailable, it will be filled out with the contents of BuildID() (either 0-padded or truncated) and age will be zero.
Implements crashpad::ModuleSnapshot.
|
overridevirtual |
Returns a list of custom minidump stream specified in the module to be included in the crash dump.
Implements crashpad::ModuleSnapshot.
|
overridevirtual |
Returns the module’s debug file info name.
On Windows, this references the PDB file, which contains symbol information held separately from the module itself. On other platforms, this is normally the basename of the module, because the debug info file’s name is not relevant even in split-debug scenarios.
Implements crashpad::ModuleSnapshot.
|
overridevirtual |
Returns the module’s file version in the version_* parameters.
If no file version can be determined, the version_* parameters are set to 0
.
For macOS snapshots, this is taken from the module’s LC_ID_DYLIB
load command for shared libraries, and is 0
for other module types.
Implements crashpad::ModuleSnapshot.
void crashpad::internal::ModuleSnapshotIOS::GetCrashpadOptions | ( | CrashpadInfoClientOptions * | options | ) |
Returns options from the module’s CrashpadInfo structure.
[out] | options | Options set in the module’s CrashpadInfo structure. |
bool crashpad::internal::ModuleSnapshotIOS::Initialize | ( | const dyld_image_info * | image | ) |
Initializes the object.
[in] | image | The mach-o image to be loaded. |
true
if the snapshot could be created. bool crashpad::internal::ModuleSnapshotIOS::InitializeDyld | ( | const dyld_all_image_infos * | images | ) |
Initializes the object specifically for the dyld module.
[in] | images | The structure containing the necessary dyld information. |
true
if the snapshot could be created.
|
overridevirtual |
Returns the size that the module occupies in the snapshot process’ address space, starting at its base address.
For macOS snapshots, this method only reports the size of the __TEXT
segment, because segments may not be loaded contiguously.
Implements crashpad::ModuleSnapshot.
|
overridevirtual |
Returns the module’s source version in the version_* parameters.
If no source version can be determined, the version_* parameters are set to 0
.
For macOS snapshots, this is taken from the module’s LC_SOURCE_VERSION
load command.
Implements crashpad::ModuleSnapshot.
|
overridevirtual |
Returns the module’s timestamp, if known.
The timestamp is typically the modification time of the file that provided the module in time_t
format, seconds since the POSIX epoch. If the module’s timestamp is unknown, this method returns 0
.
Implements crashpad::ModuleSnapshot.
|
overridevirtual |
Returns the module’s UUID in the uuid parameter, and the age of that UUID in age.
A snapshot module’s UUID is taken directly from the module itself. If the module does not have a UUID, the uuid parameter will be zeroed out.
age is the number of times the UUID has been reused. This occurs on Windows with incremental linking. On other platforms age will always be 0
.
Implements crashpad::ModuleSnapshot.