mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 03:02:36 +01:00
db01c87a41
Summary: This will allow updating MinidumpYAML and LLDB to use this common definition. Reviewers: labath, jhenderson, clayborg Reviewed By: labath Subscribers: llvm-commits Tags: #llvm Differential Revision: https://reviews.llvm.org/D68656 llvm-svn: 375239
272 lines
8.9 KiB
C++
272 lines
8.9 KiB
C++
//===- Minidump.h - Minidump constants and structures -----------*- C++ -*-===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This header constants and data structures pertaining to the Windows Minidump
|
|
// core file format.
|
|
//
|
|
// Reference:
|
|
// https://msdn.microsoft.com/en-us/library/windows/desktop/ms679293(v=vs.85).aspx
|
|
// https://chromium.googlesource.com/breakpad/breakpad/
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_BINARYFORMAT_MINIDUMP_H
|
|
#define LLVM_BINARYFORMAT_MINIDUMP_H
|
|
|
|
#include "llvm/ADT/BitmaskEnum.h"
|
|
#include "llvm/ADT/DenseMapInfo.h"
|
|
#include "llvm/Support/Endian.h"
|
|
|
|
namespace llvm {
|
|
namespace minidump {
|
|
|
|
LLVM_ENABLE_BITMASK_ENUMS_IN_NAMESPACE();
|
|
|
|
/// The minidump header is the first part of a minidump file. It identifies the
|
|
/// file as a minidump file, and gives the location of the stream directory.
|
|
struct Header {
|
|
static constexpr uint32_t MagicSignature = 0x504d444d; // PMDM
|
|
static constexpr uint16_t MagicVersion = 0xa793;
|
|
|
|
support::ulittle32_t Signature;
|
|
// The high 16 bits of version field are implementation specific. The low 16
|
|
// bits should be MagicVersion.
|
|
support::ulittle32_t Version;
|
|
support::ulittle32_t NumberOfStreams;
|
|
support::ulittle32_t StreamDirectoryRVA;
|
|
support::ulittle32_t Checksum;
|
|
support::ulittle32_t TimeDateStamp;
|
|
support::ulittle64_t Flags;
|
|
};
|
|
static_assert(sizeof(Header) == 32, "");
|
|
|
|
/// The type of a minidump stream identifies its contents. Streams numbers after
|
|
/// LastReserved are for application-defined data streams.
|
|
enum class StreamType : uint32_t {
|
|
#define HANDLE_MDMP_STREAM_TYPE(CODE, NAME) NAME = CODE,
|
|
#include "llvm/BinaryFormat/MinidumpConstants.def"
|
|
Unused = 0,
|
|
LastReserved = 0x0000ffff,
|
|
};
|
|
|
|
/// Specifies the location (and size) of various objects in the minidump file.
|
|
/// The location is relative to the start of the file.
|
|
struct LocationDescriptor {
|
|
support::ulittle32_t DataSize;
|
|
support::ulittle32_t RVA;
|
|
};
|
|
static_assert(sizeof(LocationDescriptor) == 8, "");
|
|
|
|
/// Describes a single memory range (both its VM address and where to find it in
|
|
/// the file) of the process from which this minidump file was generated.
|
|
struct MemoryDescriptor {
|
|
support::ulittle64_t StartOfMemoryRange;
|
|
LocationDescriptor Memory;
|
|
};
|
|
static_assert(sizeof(MemoryDescriptor) == 16, "");
|
|
|
|
struct MemoryInfoListHeader {
|
|
support::ulittle32_t SizeOfHeader;
|
|
support::ulittle32_t SizeOfEntry;
|
|
support::ulittle64_t NumberOfEntries;
|
|
|
|
MemoryInfoListHeader() = default;
|
|
MemoryInfoListHeader(uint32_t SizeOfHeader, uint32_t SizeOfEntry,
|
|
uint64_t NumberOfEntries)
|
|
: SizeOfHeader(SizeOfHeader), SizeOfEntry(SizeOfEntry),
|
|
NumberOfEntries(NumberOfEntries) {}
|
|
};
|
|
static_assert(sizeof(MemoryInfoListHeader) == 16, "");
|
|
|
|
enum class MemoryProtection : uint32_t {
|
|
#define HANDLE_MDMP_PROTECT(CODE, NAME, NATIVENAME) NAME = CODE,
|
|
#include "llvm/BinaryFormat/MinidumpConstants.def"
|
|
LLVM_MARK_AS_BITMASK_ENUM(/*LargestValue=*/0xffffffffu),
|
|
};
|
|
|
|
enum class MemoryState : uint32_t {
|
|
#define HANDLE_MDMP_MEMSTATE(CODE, NAME, NATIVENAME) NAME = CODE,
|
|
#include "llvm/BinaryFormat/MinidumpConstants.def"
|
|
LLVM_MARK_AS_BITMASK_ENUM(/*LargestValue=*/0xffffffffu),
|
|
};
|
|
|
|
enum class MemoryType : uint32_t {
|
|
#define HANDLE_MDMP_MEMTYPE(CODE, NAME, NATIVENAME) NAME = CODE,
|
|
#include "llvm/BinaryFormat/MinidumpConstants.def"
|
|
LLVM_MARK_AS_BITMASK_ENUM(/*LargestValue=*/0xffffffffu),
|
|
};
|
|
|
|
struct MemoryInfo {
|
|
support::ulittle64_t BaseAddress;
|
|
support::ulittle64_t AllocationBase;
|
|
support::little_t<MemoryProtection> AllocationProtect;
|
|
support::ulittle32_t Reserved0;
|
|
support::ulittle64_t RegionSize;
|
|
support::little_t<MemoryState> State;
|
|
support::little_t<MemoryProtection> Protect;
|
|
support::little_t<MemoryType> Type;
|
|
support::ulittle32_t Reserved1;
|
|
};
|
|
static_assert(sizeof(MemoryInfo) == 48, "");
|
|
|
|
/// Specifies the location and type of a single stream in the minidump file. The
|
|
/// minidump stream directory is an array of entries of this type, with its size
|
|
/// given by Header.NumberOfStreams.
|
|
struct Directory {
|
|
support::little_t<StreamType> Type;
|
|
LocationDescriptor Location;
|
|
};
|
|
static_assert(sizeof(Directory) == 12, "");
|
|
|
|
/// The processor architecture of the system that generated this minidump. Used
|
|
/// in the ProcessorArch field of the SystemInfo stream.
|
|
enum class ProcessorArchitecture : uint16_t {
|
|
#define HANDLE_MDMP_ARCH(CODE, NAME) NAME = CODE,
|
|
#include "llvm/BinaryFormat/MinidumpConstants.def"
|
|
};
|
|
|
|
/// The OS Platform of the system that generated this minidump. Used in the
|
|
/// PlatformId field of the SystemInfo stream.
|
|
enum class OSPlatform : uint32_t {
|
|
#define HANDLE_MDMP_PLATFORM(CODE, NAME) NAME = CODE,
|
|
#include "llvm/BinaryFormat/MinidumpConstants.def"
|
|
};
|
|
|
|
/// Detailed information about the processor of the system that generated this
|
|
/// minidump. Its interpretation depends on the ProcessorArchitecture enum.
|
|
union CPUInfo {
|
|
struct X86Info {
|
|
char VendorID[12]; // cpuid 0: ebx, edx, ecx
|
|
support::ulittle32_t VersionInfo; // cpuid 1: eax
|
|
support::ulittle32_t FeatureInfo; // cpuid 1: edx
|
|
support::ulittle32_t AMDExtendedFeatures; // cpuid 0x80000001, ebx
|
|
} X86;
|
|
struct ArmInfo {
|
|
support::ulittle32_t CPUID;
|
|
support::ulittle32_t ElfHWCaps; // linux specific, 0 otherwise
|
|
} Arm;
|
|
struct OtherInfo {
|
|
uint8_t ProcessorFeatures[16];
|
|
} Other;
|
|
};
|
|
static_assert(sizeof(CPUInfo) == 24, "");
|
|
|
|
/// The SystemInfo stream, containing various information about the system where
|
|
/// this minidump was generated.
|
|
struct SystemInfo {
|
|
support::little_t<ProcessorArchitecture> ProcessorArch;
|
|
support::ulittle16_t ProcessorLevel;
|
|
support::ulittle16_t ProcessorRevision;
|
|
|
|
uint8_t NumberOfProcessors;
|
|
uint8_t ProductType;
|
|
|
|
support::ulittle32_t MajorVersion;
|
|
support::ulittle32_t MinorVersion;
|
|
support::ulittle32_t BuildNumber;
|
|
support::little_t<OSPlatform> PlatformId;
|
|
support::ulittle32_t CSDVersionRVA;
|
|
|
|
support::ulittle16_t SuiteMask;
|
|
support::ulittle16_t Reserved;
|
|
|
|
CPUInfo CPU;
|
|
};
|
|
static_assert(sizeof(SystemInfo) == 56, "");
|
|
|
|
struct VSFixedFileInfo {
|
|
support::ulittle32_t Signature;
|
|
support::ulittle32_t StructVersion;
|
|
support::ulittle32_t FileVersionHigh;
|
|
support::ulittle32_t FileVersionLow;
|
|
support::ulittle32_t ProductVersionHigh;
|
|
support::ulittle32_t ProductVersionLow;
|
|
support::ulittle32_t FileFlagsMask;
|
|
support::ulittle32_t FileFlags;
|
|
support::ulittle32_t FileOS;
|
|
support::ulittle32_t FileType;
|
|
support::ulittle32_t FileSubtype;
|
|
support::ulittle32_t FileDateHigh;
|
|
support::ulittle32_t FileDateLow;
|
|
};
|
|
static_assert(sizeof(VSFixedFileInfo) == 52, "");
|
|
|
|
inline bool operator==(const VSFixedFileInfo &LHS, const VSFixedFileInfo &RHS) {
|
|
return memcmp(&LHS, &RHS, sizeof(VSFixedFileInfo)) == 0;
|
|
}
|
|
|
|
struct Module {
|
|
support::ulittle64_t BaseOfImage;
|
|
support::ulittle32_t SizeOfImage;
|
|
support::ulittle32_t Checksum;
|
|
support::ulittle32_t TimeDateStamp;
|
|
support::ulittle32_t ModuleNameRVA;
|
|
VSFixedFileInfo VersionInfo;
|
|
LocationDescriptor CvRecord;
|
|
LocationDescriptor MiscRecord;
|
|
support::ulittle64_t Reserved0;
|
|
support::ulittle64_t Reserved1;
|
|
};
|
|
static_assert(sizeof(Module) == 108, "");
|
|
|
|
/// Describes a single thread in the minidump file. Part of the ThreadList
|
|
/// stream.
|
|
struct Thread {
|
|
support::ulittle32_t ThreadId;
|
|
support::ulittle32_t SuspendCount;
|
|
support::ulittle32_t PriorityClass;
|
|
support::ulittle32_t Priority;
|
|
support::ulittle64_t EnvironmentBlock;
|
|
MemoryDescriptor Stack;
|
|
LocationDescriptor Context;
|
|
};
|
|
static_assert(sizeof(Thread) == 48, "");
|
|
|
|
struct Exception {
|
|
static constexpr size_t MaxParameters = 15;
|
|
|
|
support::ulittle32_t ExceptionCode;
|
|
support::ulittle32_t ExceptionFlags;
|
|
support::ulittle64_t ExceptionRecord;
|
|
support::ulittle64_t ExceptionAddress;
|
|
support::ulittle32_t NumberParameters;
|
|
support::ulittle32_t UnusedAlignment;
|
|
support::ulittle64_t ExceptionInformation[MaxParameters];
|
|
};
|
|
static_assert(sizeof(Exception) == 152, "");
|
|
|
|
struct ExceptionStream {
|
|
support::ulittle32_t ThreadId;
|
|
support::ulittle32_t UnusedAlignment;
|
|
Exception ExceptionRecord;
|
|
LocationDescriptor ThreadContext;
|
|
};
|
|
static_assert(sizeof(ExceptionStream) == 168, "");
|
|
|
|
} // namespace minidump
|
|
|
|
template <> struct DenseMapInfo<minidump::StreamType> {
|
|
static minidump::StreamType getEmptyKey() { return minidump::StreamType(-1); }
|
|
|
|
static minidump::StreamType getTombstoneKey() {
|
|
return minidump::StreamType(-2);
|
|
}
|
|
|
|
static unsigned getHashValue(minidump::StreamType Val) {
|
|
return DenseMapInfo<uint32_t>::getHashValue(static_cast<uint32_t>(Val));
|
|
}
|
|
|
|
static bool isEqual(minidump::StreamType LHS, minidump::StreamType RHS) {
|
|
return LHS == RHS;
|
|
}
|
|
};
|
|
|
|
} // namespace llvm
|
|
|
|
#endif // LLVM_BINARYFORMAT_MINIDUMP_H
|