// Copyright 2014 The Crashpad Authors // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #ifndef CRASHPAD_COMPAT_NON_WIN_WINNT_H_ #define CRASHPAD_COMPAT_NON_WIN_WINNT_H_ #include //! \file //! \anchor VER_SUITE_x //! \name VER_SUITE_* //! //! \brief Installable product values for MINIDUMP_SYSTEM_INFO::SuiteMask. //! \{ #define VER_SUITE_SMALLBUSINESS 0x0001 #define VER_SUITE_ENTERPRISE 0x0002 #define VER_SUITE_BACKOFFICE 0x0004 #define VER_SUITE_COMMUNICATIONS 0x0008 #define VER_SUITE_TERMINAL 0x0010 #define VER_SUITE_SMALLBUSINESS_RESTRICTED 0x0020 #define VER_SUITE_EMBEDDEDNT 0x0040 #define VER_SUITE_DATACENTER 0x0080 #define VER_SUITE_SINGLEUSERTS 0x0100 #define VER_SUITE_PERSONAL 0x0200 #define VER_SUITE_BLADE 0x0400 #define VER_SUITE_EMBEDDED_RESTRICTED 0x0800 #define VER_SUITE_SECURITY_APPLIANCE 0x1000 #define VER_SUITE_STORAGE_SERVER 0x2000 #define VER_SUITE_COMPUTE_SERVER 0x4000 #define VER_SUITE_WH_SERVER 0x8000 //! \} //! \brief The maximum number of exception parameters present in the //! MINIDUMP_EXCEPTION::ExceptionInformation array. #define EXCEPTION_MAXIMUM_PARAMETERS 15 //! \anchor PROCESSOR_ARCHITECTURE_x //! \name PROCESSOR_ARCHITECTURE_* //! //! \brief CPU type values for MINIDUMP_SYSTEM_INFO::ProcessorArchitecture. //! //! \sa crashpad::MinidumpCPUArchitecture //! \{ #define PROCESSOR_ARCHITECTURE_INTEL 0 #define PROCESSOR_ARCHITECTURE_MIPS 1 #define PROCESSOR_ARCHITECTURE_ALPHA 2 #define PROCESSOR_ARCHITECTURE_PPC 3 #define PROCESSOR_ARCHITECTURE_SHX 4 #define PROCESSOR_ARCHITECTURE_ARM 5 #define PROCESSOR_ARCHITECTURE_IA64 6 #define PROCESSOR_ARCHITECTURE_ALPHA64 7 #define PROCESSOR_ARCHITECTURE_MSIL 8 #define PROCESSOR_ARCHITECTURE_AMD64 9 #define PROCESSOR_ARCHITECTURE_IA32_ON_WIN64 10 #define PROCESSOR_ARCHITECTURE_NEUTRAL 11 #define PROCESSOR_ARCHITECTURE_ARM64 12 #define PROCESSOR_ARCHITECTURE_ARM32_ON_WIN64 13 #define PROCESSOR_ARCHITECTURE_UNKNOWN 0xffff //! \} //! \anchor PF_x //! \name PF_* //! //! \brief CPU feature values for \ref CPU_INFORMATION::ProcessorFeatures //! "CPU_INFORMATION::OtherCpuInfo::ProcessorFeatures". //! //! \{ #define PF_FLOATING_POINT_PRECISION_ERRATA 0 #define PF_FLOATING_POINT_EMULATED 1 #define PF_COMPARE_EXCHANGE_DOUBLE 2 #define PF_MMX_INSTRUCTIONS_AVAILABLE 3 #define PF_PPC_MOVEMEM_64BIT_OK 4 #define PF_ALPHA_BYTE_INSTRUCTIONS 5 #define PF_XMMI_INSTRUCTIONS_AVAILABLE 6 #define PF_3DNOW_INSTRUCTIONS_AVAILABLE 7 #define PF_RDTSC_INSTRUCTION_AVAILABLE 8 #define PF_PAE_ENABLED 9 #define PF_XMMI64_INSTRUCTIONS_AVAILABLE 10 #define PF_SSE_DAZ_MODE_AVAILABLE 11 #define PF_NX_ENABLED 12 #define PF_SSE3_INSTRUCTIONS_AVAILABLE 13 #define PF_COMPARE_EXCHANGE128 14 #define PF_COMPARE64_EXCHANGE128 15 #define PF_CHANNELS_ENABLED 16 #define PF_XSAVE_ENABLED 17 #define PF_ARM_VFP_32_REGISTERS_AVAILABLE 18 #define PF_ARM_NEON_INSTRUCTIONS_AVAILABLE 19 #define PF_SECOND_LEVEL_ADDRESS_TRANSLATION 20 #define PF_VIRT_FIRMWARE_ENABLED 21 #define PF_RDWRFSGSBASE_AVAILABLE 22 #define PF_FASTFAIL_AVAILABLE 23 #define PF_ARM_DIVIDE_INSTRUCTION_AVAILABLE 24 #define PF_ARM_64BIT_LOADSTORE_ATOMIC 25 #define PF_ARM_EXTERNAL_CACHE_AVAILABLE 26 #define PF_ARM_FMAC_INSTRUCTIONS_AVAILABLE 27 #define PF_RDRAND_INSTRUCTION_AVAILABLE 28 #define PF_ARM_V8_INSTRUCTIONS_AVAILABLE 29 #define PF_ARM_V8_CRYPTO_INSTRUCTIONS_AVAILABLE 30 #define PF_ARM_V8_CRC32_INSTRUCTIONS_AVAILABLE 31 #define PF_RDTSCP_INSTRUCTION_AVAILABLE 32 //! \} //! \anchor PAGE_x //! \name PAGE_* //! //! \brief Memory protection constants for MINIDUMP_MEMORY_INFO::Protect and //! MINIDUMP_MEMORY_INFO::AllocationProtect. //! \{ #define PAGE_NOACCESS 0x1 #define PAGE_READONLY 0x2 #define PAGE_READWRITE 0x4 #define PAGE_WRITECOPY 0x8 #define PAGE_EXECUTE 0x10 #define PAGE_EXECUTE_READ 0x20 #define PAGE_EXECUTE_READWRITE 0x40 #define PAGE_EXECUTE_WRITECOPY 0x80 #define PAGE_GUARD 0x100 #define PAGE_NOCACHE 0x200 #define PAGE_WRITECOMBINE 0x400 //! \} //! \anchor MEM_x //! \name MEM_* //! //! \brief Memory state and type constants for MINIDUMP_MEMORY_INFO::State and //! MINIDUMP_MEMORY_INFO::Type. //! \{ #define MEM_COMMIT 0x1000 #define MEM_RESERVE 0x2000 #define MEM_DECOMMIT 0x4000 #define MEM_RELEASE 0x8000 #define MEM_FREE 0x10000 #define MEM_PRIVATE 0x20000 #define MEM_MAPPED 0x40000 #define MEM_RESET 0x80000 //! \} //! \brief The maximum number of distinct identifiable features that could //! possibly be carried in an XSAVE area. //! //! This corresponds to the number of bits in the XSAVE state-component bitmap, //! XSAVE_BV. See Intel Software Developer’s Manual, Volume 1: Basic //! Architecture (253665-060), 13.4.2 “XSAVE Header”. #define MAXIMUM_XSTATE_FEATURES (64) //! \anchor XSTATE_x //! \name XSTATE_* //! //! \brief Offsets and constants for extended state. //! \{ #define XSTATE_COMPACTION_ENABLE (63) #define XSTATE_COMPACTION_ENABLE_MASK (1ull << XSTATE_COMPACTION_ENABLE) #define XSTATE_CET_U (11) #define XSTATE_MASK_CET_U (1ull << XSTATE_CET_U) //! \} //! \brief The location of a single state component within an XSAVE area. struct XSTATE_FEATURE { //! \brief The location of a state component within a CPU-specific context //! structure. //! //! This is equivalent to the difference (`ptrdiff_t`) between the return //! value of `LocateXStateFeature()` and its \a Context argument. uint32_t Offset; //! \brief The size of a state component with a CPU-specific context //! structure. //! //! This is equivalent to the size returned by `LocateXStateFeature()` in \a //! Length. uint32_t Size; }; //! \anchor IMAGE_DEBUG_MISC_x //! \name IMAGE_DEBUG_MISC_* //! //! Data type values for IMAGE_DEBUG_MISC::DataType. //! \{ //! \brief A pointer to a `.dbg` file. //! //! IMAGE_DEBUG_MISC::Data will contain the path or file name of the `.dbg` file //! associated with the module. #define IMAGE_DEBUG_MISC_EXENAME 1 //! \} //! \brief Miscellaneous debugging record. //! //! This structure is referenced by MINIDUMP_MODULE::MiscRecord. It is obsolete, //! superseded by the CodeView record. struct IMAGE_DEBUG_MISC { //! \brief The type of data carried in the #Data field. //! //! This is a value of \ref IMAGE_DEBUG_MISC_x "IMAGE_DEBUG_MISC_*". uint32_t DataType; //! \brief The length of this structure in bytes, including the entire #Data //! field and its `NUL` terminator. //! //! \note The Windows documentation states that this field is rounded up to //! nearest nearest 4-byte multiple. uint32_t Length; //! \brief The encoding of the #Data field. //! //! If this field is `0`, #Data contains narrow or multibyte character data. //! If this field is `1`, #Data is UTF-16-encoded. //! //! On Windows, with this field set to `0`, #Data will be encoded in the code //! page of the system that linked the module. On other operating systems, //! UTF-8 may be used. uint8_t Unicode; uint8_t Reserved[3]; //! \brief The data carried within this structure. //! //! For string data, this field will be `NUL`-terminated. If #Unicode is `1`, //! this field is UTF-16-encoded, and will be terminated by a UTF-16 `NUL` //! code unit (two `NUL` bytes). uint8_t Data[1]; }; //! \anchor VER_NT_x //! \name VER_NT_* //! //! \brief Operating system type values for MINIDUMP_SYSTEM_INFO::ProductType. //! //! \sa crashpad::MinidumpOSType //! \{ #define VER_NT_WORKSTATION 1 #define VER_NT_DOMAIN_CONTROLLER 2 #define VER_NT_SERVER 3 //! \} //! \anchor VER_PLATFORM_x //! \name VER_PLATFORM_* //! //! \brief Operating system family values for MINIDUMP_SYSTEM_INFO::PlatformId. //! //! \sa crashpad::MinidumpOS //! \{ #define VER_PLATFORM_WIN32s 0 #define VER_PLATFORM_WIN32_WINDOWS 1 #define VER_PLATFORM_WIN32_NT 2 //! \} #endif // CRASHPAD_COMPAT_NON_WIN_WINNT_H_