Files
BinaryObjectScanner/BurnOutSharp.Models/PortableExecutable/Enums.cs
2022-11-09 11:58:35 -08:00

2483 lines
78 KiB
C#

using System;
namespace BurnOutSharp.Models.PortableExecutable
{
[Flags]
public enum AcceleratorTableFlags : ushort
{
/// <summary>
/// The accelerator key is a virtual-key code. If this flag is not specified,
/// the accelerator key is assumed to specify an ASCII character code.
/// </summary>
FVIRTKEY = 0x01,
/// <summary>
/// A menu item on the menu bar is not highlighted when an accelerator is used.
/// This attribute is obsolete and retained only for backward compatibility with
/// resource files designed for 16-bit Windows.
/// </summary>
FNOINVERT = 0x02,
/// <summary>
/// The accelerator is activated only if the user presses the SHIFT key. This flag
/// applies only to virtual keys.
/// </summary>
FSHIFT = 0x04,
/// <summary>
/// The accelerator is activated only if the user presses the CTRL key. This flag
/// applies only to virtual keys.
/// </summary>
FCONTROL = 0x08,
/// <summary>
/// The accelerator is activated only if the user presses the ALT key. This flag
/// applies only to virtual keys.
/// </summary>
FALT = 0x10,
/// <summary>
/// The entry is last in an accelerator table.
/// </summary>
LastEntry = 0x80,
}
public enum BaseRelocationTypes : uint
{
/// <summary>
/// The base relocation is skipped. This type can be used to pad a block.
/// </summary>
IMAGE_REL_BASED_ABSOLUTE = 0,
/// <summary>
/// The base relocation adds the high 16 bits of the difference to the 16-bit
/// field at offset. The 16-bit field represents the high value of a 32-bit word.
/// </summary>
IMAGE_REL_BASED_HIGH = 1,
/// <summary>
/// The base relocation adds the low 16 bits of the difference to the 16-bit
/// field at offset. The 16-bit field represents the low half of a 32-bit word.
/// </summary>
IMAGE_REL_BASED_LOW = 2,
/// <summary>
/// The base relocation applies all 32 bits of the difference to the 32-bit
/// field at offset.
/// </summary>
IMAGE_REL_BASED_HIGHLOW = 3,
/// <summary>
/// The base relocation adds the high 16 bits of the difference to the 16-bit
/// field at offset. The 16-bit field represents the high value of a 32-bit word.
/// The low 16 bits of the 32-bit value are stored in the 16-bit word that follows
/// this base relocation. This means that this base relocation occupies two slots.
/// </summary>
IMAGE_REL_BASED_HIGHADJ = 4,
/// <summary>
/// The relocation interpretation is dependent on the machine type.
/// When the machine type is MIPS, the base relocation applies to a MIPS jump
/// instruction.
/// </summary>
IMAGE_REL_BASED_MIPS_JMPADDR = 5,
/// <summary>
/// This relocation is meaningful only when the machine type is ARM or Thumb.
/// The base relocation applies the 32-bit address of a symbol across a consecutive
/// MOVW/MOVT instruction pair.
/// </summary>
IMAGE_REL_BASED_ARM_MOV32 = 5,
/// <summary>
/// This relocation is only meaningful when the machine type is RISC-V. The base
/// relocation applies to the high 20 bits of a 32-bit absolute address.
/// </summary>
IMAGE_REL_BASED_RISCV_HIGH20 = 5,
/// <summary>
/// Reserved, must be zero.
/// </summary>
RESERVED6 = 6,
/// <summary>
/// This relocation is meaningful only when the machine type is Thumb. The base
/// relocation applies the 32-bit address of a symbol to a consecutive MOVW/MOVT
/// instruction pair.
/// </summary>
IMAGE_REL_BASED_THUMB_MOV32 = 7,
/// <summary>
/// This relocation is only meaningful when the machine type is RISC-V. The base
/// relocation applies to the low 12 bits of a 32-bit absolute address formed in
/// RISC-V I-type instruction format.
/// </summary>
IMAGE_REL_BASED_RISCV_LOW12I = 7,
/// <summary>
/// This relocation is only meaningful when the machine type is RISC-V. The base
/// relocation applies to the low 12 bits of a 32-bit absolute address formed in
/// RISC-V S-type instruction format.
/// </summary>
IMAGE_REL_BASED_RISCV_LOW12S = 8,
/// <summary>
/// This relocation is only meaningful when the machine type is LoongArch 32-bit.
/// The base relocation applies to a 32-bit absolute address formed in two
/// consecutive instructions.
/// </summary>
IMAGE_REL_BASED_LOONGARCH32_MARK_LA = 8,
/// <summary>
/// This relocation is only meaningful when the machine type is LoongArch 64-bit.
/// The base relocation applies to a 64-bit absolute address formed in four
/// consecutive instructions.
/// </summary>
IMAGE_REL_BASED_LOONGARCH64_MARK_LA = 8,
/// <summary>
/// The relocation is only meaningful when the machine type is MIPS. The base
/// relocation applies to a MIPS16 jump instruction.
/// </summary>
IMAGE_REL_BASED_MIPS_JMPADDR16 = 9,
/// <summary>
/// The base relocation applies the difference to the 64-bit field at offset.
/// </summary>
IMAGE_REL_BASED_DIR64 = 10,
}
public enum CallbackReason : ushort
{
/// <summary>
/// A new process has started, including the first thread.
/// </summary>
DLL_PROCESS_ATTACH = 1,
/// <summary>
/// A new thread has been created. This notification sent for
/// all but the first thread.
/// </summary>
DLL_THREAD_ATTACH = 2,
/// <summary>
/// A thread is about to be terminated. This notification sent
/// for all but the first thread.
/// </summary>
DLL_THREAD_DETACH = 3,
/// <summary>
/// A process is about to terminate, including the original thread.
/// </summary>
DLL_PROCESS_DETACH = 0,
}
[Flags]
public enum Characteristics : ushort
{
/// <summary>
/// Image only, Windows CE, and Microsoft Windows NT and later.
/// This indicates that the file does not contain base relocations
/// and must therefore be loaded at its preferred base address.
/// If the base address is not available, the loader reports an
/// error. The default behavior of the linker is to strip base
/// relocations from executable (EXE) files.
/// </summary>
IMAGE_FILE_RELOCS_STRIPPED = 0x0001,
/// <summary>
/// Image only. This indicates that the image file is valid and
/// can be run. If this flag is not set, it indicates a linker error.
/// </summary>
IMAGE_FILE_EXECUTABLE_IMAGE = 0x0002,
/// <summary>
/// COFF line numbers have been removed. This flag is deprecated
/// and should be zero.
/// </summary>
IMAGE_FILE_LINE_NUMS_STRIPPED = 0x0004,
/// <summary>
/// COFF symbol table entries for local symbols have been removed.
/// This flag is deprecated and should be zero.
/// </summary>
IMAGE_FILE_LOCAL_SYMS_STRIPPED = 0x0008,
/// <summary>
/// Obsolete. Aggressively trim working set. This flag is deprecated
/// for Windows 2000 and later and must be zero.
/// </summary>
IMAGE_FILE_AGGRESSIVE_WS_TRIM = 0x0010,
/// <summary>
/// Application can handle > 2-GB addresses.
/// </summary>
IMAGE_FILE_LARGE_ADDRESS_AWARE = 0x0020,
/// <summary>
/// This flag is reserved for future use.
/// </summary>
RESERVED = 0x0040,
/// <summary>
/// Little endian: the least significant bit (LSB) precedes the most
/// significant bit (MSB) in memory. This flag is deprecated and
/// should be zero.
/// </summary>
IMAGE_FILE_BYTES_REVERSED_LO = 0x0080,
/// <summary>
/// Machine is based on a 32-bit-word architecture.
/// </summary>
IMAGE_FILE_32BIT_MACHINE = 0x0100,
/// <summary>
/// Debugging information is removed from the image file.
/// </summary>
IMAGE_FILE_DEBUG_STRIPPED = 0x0200,
/// <summary>
/// If the image is on removable media, fully load it and
/// copy it to the swap file.
/// </summary>
IMAGE_FILE_REMOVABLE_RUN_FROM_SWAP = 0x0400,
/// <summary>
/// If the image is on network media, fully load it and copy
/// it to the swap file.
/// </summary>
IMAGE_FILE_NET_RUN_FROM_SWAP = 0x0800,
/// <summary>
/// The image file is a system file, not a user program.
/// </summary>
IMAGE_FILE_SYSTEM = 0x1000,
/// <summary>
/// The image file is a dynamic-link library (DLL). Such files
/// are considered executable files for almost all purposes,
/// although they cannot be directly run.
/// </summary>
IMAGE_FILE_DLL = 0x2000,
/// <summary>
/// The file should be run only on a uniprocessor machine.
/// </summary>
IMAGE_FILE_UP_SYSTEM_ONLY = 0x4000,
/// <summary>
/// Big endian: the MSB precedes the LSB in memory. This flag
/// is deprecated and should be zero.
/// </summary>
IMAGE_FILE_BYTES_REVERSED_HI = 0x8000,
}
public enum COMDATSelect : byte
{
/// <summary>
/// If this symbol is already defined, the linker issues a "multiply
/// defined symbol" error.
/// </summary>
IMAGE_COMDAT_SELECT_NODUPLICATES = 0x01,
/// <summary>
/// Any section that defines the same COMDAT symbol can be linked;
/// the rest are removed.
/// </summary>
IMAGE_COMDAT_SELECT_ANY = 0x02,
/// <summary>
/// The linker chooses an arbitrary section among the definitions
/// for this symbol. If all definitions are not the same size, a
/// "multiply defined symbol" error is issued.
/// </summary>
IMAGE_COMDAT_SELECT_SAME_SIZE = 0x03,
/// <summary>
/// The linker chooses an arbitrary section among the definitions
/// for this symbol. If all definitions do not match exactly, a
/// "multiply defined symbol" error is issued.
/// </summary>
IMAGE_COMDAT_SELECT_EXACT_MATCH = 0x04,
/// <summary>
/// The section is linked if a certain other COMDAT section is linked.
/// This other section is indicated by the Number field of the
/// auxiliary symbol record for the section definition. This setting
/// is useful for definitions that have components in multiple sections
/// (for example, code in one and data in another), but where all must
/// be linked or discarded as a set. The other section this section is
/// associated with must be a COMDAT section, which can be another
/// associative COMDAT section. An associative COMDAT section's section
/// association chain can't form a loop. The section association chain
/// must eventually come to a COMDAT section that doesn't have
/// IMAGE_COMDAT_SELECT_ASSOCIATIVE set.
/// </summary>
IMAGE_COMDAT_SELECT_ASSOCIATIVE = 0x05,
/// <summary>
/// The linker chooses the largest definition from among all of the
/// definitions for this symbol. If multiple definitions have this size,
/// the choice between them is arbitrary.
/// </summary>
IMAGE_COMDAT_SELECT_LARGEST = 0x06,
}
public enum DebugType : uint
{
/// <summary>
/// An unknown value that is ignored by all tools.
/// </summary>
IMAGE_DEBUG_TYPE_UNKNOWN = 0,
/// <summary>
/// The COFF debug information (line numbers, symbol table, and string table).
/// This type of debug information is also pointed to by fields in the file
/// headers.
/// </summary>
IMAGE_DEBUG_TYPE_COFF = 1,
/// <summary>
/// The Visual C++ debug information.
/// </summary>
IMAGE_DEBUG_TYPE_CODEVIEW = 2,
/// <summary>
/// The frame pointer omission (FPO) information. This information tells the
/// debugger how to interpret nonstandard stack frames, which use the EBP
/// register for a purpose other than as a frame pointer.
/// </summary>
IMAGE_DEBUG_TYPE_FPO = 3,
/// <summary>
/// The location of DBG file.
/// </summary>
IMAGE_DEBUG_TYPE_MISC = 4,
/// <summary>
/// A copy of .pdata section.
/// </summary>
IMAGE_DEBUG_TYPE_EXCEPTION = 5,
/// <summary>
/// Reserved.
/// </summary>
IMAGE_DEBUG_TYPE_FIXUP = 6,
/// <summary>
/// The mapping from an RVA in image to an RVA in source image.
/// </summary>
IMAGE_DEBUG_TYPE_OMAP_TO_SRC = 7,
/// <summary>
/// The mapping from an RVA in source image to an RVA in image.
/// </summary>
IMAGE_DEBUG_TYPE_OMAP_FROM_SRC = 8,
/// <summary>
/// Reserved for Borland.
/// </summary>
IMAGE_DEBUG_TYPE_BORLAND = 9,
/// <summary>
/// Reserved.
/// </summary>
IMAGE_DEBUG_TYPE_RESERVED10 = 10,
/// <summary>
/// Reserved.
/// </summary>
IMAGE_DEBUG_TYPE_CLSID = 11,
/// <summary>
/// PE determinism or reproducibility.
/// </summary>
IMAGE_DEBUG_TYPE_REPRO = 16,
/// <summary>
/// Extended DLL characteristics bits.
/// </summary>
IMAGE_DEBUG_TYPE_EX_DLLCHARACTERISTICS = 20,
}
[Flags]
public enum DllCharacteristics : ushort
{
/// <summary>
/// Reserved, must be zero.
/// </summary>
RESERVED0 = 0x0001,
/// <summary>
/// Reserved, must be zero.
/// </summary>
RESERVED1 = 0x0002,
/// <summary>
/// Reserved, must be zero.
/// </summary>
RESERVED2 = 0x0004,
/// <summary>
/// Reserved, must be zero.
/// </summary>
RESERVED3 = 0x0008,
/// <summary>
/// Image can handle a high entropy 64-bit virtual address space.
/// </summary>
IMAGE_DLLCHARACTERISTICS_HIGH_ENTROPY_VA = 0x0020,
/// <summary>
/// DLL can be relocated at load time.
/// </summary>
IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE = 0x0040,
/// <summary>
/// Code Integrity checks are enforced.
/// </summary>
IMAGE_DLLCHARACTERISTICS_FORCE_INTEGRITY = 0x0080,
/// <summary>
/// Image is NX compatible.
/// </summary>
IMAGE_DLLCHARACTERISTICS_NX_COMPAT = 0x0100,
/// <summary>
/// Isolation aware, but do not isolate the image.
/// </summary>
IMAGE_DLLCHARACTERISTICS_NO_ISOLATION = 0x0200,
/// <summary>
/// Does not use structured exception (SE) handling.
/// No SE handler may be called in this image.
/// </summary>
IMAGE_DLLCHARACTERISTICS_NO_SEH = 0x0400,
/// <summary>
/// Do not bind the image.
/// </summary>
IMAGE_DLLCHARACTERISTICS_NO_BIND = 0x0800,
/// <summary>
/// Image must execute in an AppContainer.
/// </summary>
IMAGE_DLLCHARACTERISTICS_APPCONTAINER = 0x1000,
/// <summary>
/// A WDM driver.
/// </summary>
IMAGE_DLLCHARACTERISTICS_WDM_DRIVER = 0x2000,
/// <summary>
/// Image supports Control Flow Guard.
/// </summary>
IMAGE_DLLCHARACTERISTICS_GUARD_CF = 0x4000,
/// <summary>
/// Terminal Server aware.
/// </summary>
IMAGE_DLLCHARACTERISTICS_TERMINAL_SERVER_AWARE = 0x8000,
}
[Flags]
public enum ExtendedDllCharacteristics : ushort
{
/// <summary>
/// Image is CET compatible.
/// </summary>
IMAGE_DLLCHARACTERISTICS_EX_CET_COMPAT = 0x0001,
}
[Flags]
public enum GuardFlags : uint
{
/// <summary>
/// Module performs control flow integrity checks using
/// system-supplied support.
/// </summary>
IMAGE_GUARD_CF_INSTRUMENTED = 0x00000100,
/// <summary>
/// Module performs control flow and write integrity checks.
/// </summary>
IMAGE_GUARD_CFW_INSTRUMENTED = 0x00000200,
/// <summary>
/// Module contains valid control flow target metadata.
/// </summary>
IMAGE_GUARD_CF_FUNCTION_TABLE_PRESENT = 0x00000400,
/// <summary>
/// Module does not make use of the /GS security cookie.
/// </summary>
IMAGE_GUARD_SECURITY_COOKIE_UNUSED = 0x00000800,
/// <summary>
/// Module supports read only delay load IAT.
/// </summary>
IMAGE_GUARD_PROTECT_DELAYLOAD_IAT = 0x00001000,
/// <summary>
/// Delayload import table in its own .didat section (with
/// nothing else in it) that can be freely reprotected.
/// </summary>
IMAGE_GUARD_DELAYLOAD_IAT_IN_ITS_OWN_SECTION = 0x00002000,
/// <summary>
/// Module contains suppressed export information. This also
/// infers that the address taken IAT table is also present
/// in the load config.
/// </summary>
IMAGE_GUARD_CF_EXPORT_SUPPRESSION_INFO_PRESENT = 0x00004000,
/// <summary>
/// Module enables suppression of exports.
/// </summary>
IMAGE_GUARD_CF_ENABLE_EXPORT_SUPPRESSION = 0x00008000,
/// <summary>
/// Module contains longjmp target information.
/// </summary>
IMAGE_GUARD_CF_LONGJUMP_TABLE_PRESENT = 0x00010000,
/// <summary>
/// Mask for the subfield that contains the stride of Control
/// Flow Guard function table entries (that is, the additional
/// count of bytes per table entry).
/// </summary>
IMAGE_GUARD_CF_FUNCTION_TABLE_SIZE_MASK = 0xF0000000,
/// <summary>
/// Additionally, the Windows SDK winnt.h header defines this
/// macro for the amount of bits to right-shift the GuardFlags
/// value to right-justify the Control Flow Guard function table
/// stride:
/// </summary>
IMAGE_GUARD_CF_FUNCTION_TABLE_SIZE_SHIFT = 28,
}
public enum ImportType : ushort
{
/// <summary>
/// Executable code.
/// </summary>
IMPORT_CODE = 0,
/// <summary>
/// Data.
/// </summary>
IMPORT_DATA = 1,
/// <summary>
/// Specified as CONST in the .def file.
/// </summary>
IMPORT_CONST = 2,
}
// Actually 3 bits
public enum ImportNameType : ushort
{
/// <summary>
/// The import is by ordinal. This indicates that the value in the
/// Ordinal/Hint field of the import header is the import's ordinal.
/// If this constant is not specified, then the Ordinal/Hint field
/// should always be interpreted as the import's hint.
/// </summary>
IMPORT_ORDINAL = 0,
/// <summary>
/// The import name is identical to the public symbol name.
/// </summary>
IMPORT_NAME = 1,
/// <summary>
/// The import name is the public symbol name, but skipping the leading
/// ?, @, or optionally _.
/// </summary>
IMPORT_NAME_NOPREFIX = 2,
/// <summary>
/// The import name is the public symbol name, but skipping the leading
/// ?, @, or optionally _, and truncating at the first @.
/// </summary>
IMPORT_NAME_UNDECORATE = 3,
}
[Flags]
public enum MemoryFlags : ushort
{
// TODO: Validate the ~ statements
MOVEABLE = 0x0010,
FIXED = 0xFFEF, // ~MOVEABLE
PURE = 0x0020,
IMPURE = 0xFFDF, // ~PURE
PRELOAD = 0x0040,
LOADONCALL = 0xFFBF, // ~PRELOAD
DISCARDABLE = 0x1000,
}
public enum MachineType : ushort
{
/// <summary>
/// The content of this field is assumed to be applicable to any machine type
/// </summary>
IMAGE_FILE_MACHINE_UNKNOWN = 0x0000,
/// <summary>
/// Matsushita AM33
/// </summary>
IMAGE_FILE_MACHINE_AM33 = 0x01D3,
/// <summary>
/// x64
/// </summary>
IMAGE_FILE_MACHINE_AMD64 = 0x8664,
/// <summary>
/// ARM little endian
/// </summary>
IMAGE_FILE_MACHINE_ARM = 0x01C0,
/// <summary>
/// ARM64 little endian
/// </summary>
IMAGE_FILE_MACHINE_ARM64 = 0xAA64,
/// <summary>
/// ARM Thumb-2 little endian
/// </summary>
IMAGE_FILE_MACHINE_ARMNT = 0x01C4,
/// <summary>
/// EFI byte code
/// </summary>
IMAGE_FILE_MACHINE_EBC = 0x0EBC,
/// <summary>
/// Intel 386 or later processors and compatible processors
/// </summary>
IMAGE_FILE_MACHINE_I386 = 0x014C,
/// <summary>
/// Intel Itanium processor family
/// </summary>
IMAGE_FILE_MACHINE_IA64 = 0x0200,
/// <summary>
/// LoongArch 32-bit processor family
/// </summary>
IMAGE_FILE_MACHINE_LOONGARCH32 = 0x6232,
/// <summary>
/// LoongArch 64-bit processor family
/// </summary>
IMAGE_FILE_MACHINE_LOONGARCH64 = 0x6264,
/// <summary>
/// Mitsubishi M32R little endian
/// </summary>
IMAGE_FILE_MACHINE_M32R = 0x9041,
/// <summary>
/// MIPS16
/// </summary>
IMAGE_FILE_MACHINE_MIPS16 = 0x0266,
/// <summary>
/// MIPS with FPU
/// </summary>
IMAGE_FILE_MACHINE_MIPSFPU = 0x0366,
/// <summary>
/// MIPS16 with FPU
/// </summary>
IMAGE_FILE_MACHINE_MIPSFPU16 = 0x0466,
/// <summary>
/// Power PC little endian
/// </summary>
IMAGE_FILE_MACHINE_POWERPC = 0x01F0,
/// <summary>
/// Power PC with floating point support
/// </summary>
IMAGE_FILE_MACHINE_POWERPCFP = 0x01F1,
/// <summary>
/// MIPS little endian
/// </summary>
IMAGE_FILE_MACHINE_R4000 = 0x0166,
/// <summary>
/// RISC-V 32-bit address space
/// </summary>
IMAGE_FILE_MACHINE_RISCV32 = 0x5032,
/// <summary>
/// RISC-V 64-bit address space
/// </summary>
IMAGE_FILE_MACHINE_RISCV64 = 0x5064,
/// <summary>
/// RISC-V 128-bit address space
/// </summary>
IMAGE_FILE_MACHINE_RISCV128 = 0x5128,
/// <summary>
/// Hitachi SH3
/// </summary>
IMAGE_FILE_MACHINE_SH3 = 0x01A2,
/// <summary>
/// Hitachi SH3 DSP
/// </summary>
IMAGE_FILE_MACHINE_SH3DSP = 0x01A3,
/// <summary>
/// Hitachi SH4
/// </summary>
IMAGE_FILE_MACHINE_SH4 = 0x01A6,
/// <summary>
/// Hitachi SH5
/// </summary>
IMAGE_FILE_MACHINE_SH5 = 0x01A8,
/// <summary>
/// Thumb
/// </summary>
IMAGE_FILE_MACHINE_THUMB = 0x01C2,
/// <summary>
/// MIPS little-endian WCE v2
/// </summary>
IMAGE_FILE_MACHINE_WCEMIPSV2 = 0x0169,
}
public enum OptionalHeaderMagicNumber : ushort
{
ROMImage = 0x0107,
PE32 = 0x010B,
PE32Plus = 0x020B,
}
public enum RelocationType : ushort
{
#region x64 Processors
/// <summary>
/// The relocation is ignored.
/// </summary>
IMAGE_REL_AMD64_ABSOLUTE = 0x0000,
/// <summary>
/// The 64-bit VA of the relocation target.
/// </summary>
IMAGE_REL_AMD64_ADDR64 = 0x0001,
/// <summary>
/// The 32-bit VA of the relocation target.
/// </summary>
IMAGE_REL_AMD64_ADDR32 = 0x0002,
/// <summary>
/// The 32-bit address without an image base (RVA).
/// </summary>
IMAGE_REL_AMD64_ADDR32NB = 0x0003,
/// <summary>
/// The 32-bit relative address from the byte following the relocation.
/// </summary>
IMAGE_REL_AMD64_REL32 = 0x0004,
/// <summary>
/// The 32-bit address relative to byte distance 1 from the relocation.
/// </summary>
IMAGE_REL_AMD64_REL32_1 = 0x0005,
/// <summary>
/// The 32-bit address relative to byte distance 2 from the relocation.
/// </summary>
IMAGE_REL_AMD64_REL32_2 = 0x0006,
/// <summary>
/// The 32-bit address relative to byte distance 3 from the relocation.
/// </summary>
IMAGE_REL_AMD64_REL32_3 = 0x0007,
/// <summary>
/// The 32-bit address relative to byte distance 4 from the relocation.
/// </summary>
IMAGE_REL_AMD64_REL32_4 = 0x0008,
/// <summary>
/// The 32-bit address relative to byte distance 5 from the relocation.
/// </summary>
IMAGE_REL_AMD64_REL32_5 = 0x0009,
/// <summary>
/// The 16-bit section index of the section that contains the target.
/// This is used to support debugging information.
/// </summary>
IMAGE_REL_AMD64_SECTION = 0x000A,
/// <summary>
/// The 32-bit offset of the target from the beginning of its section.
/// This is used to support debugging information and static thread
/// local storage.
/// </summary>
IMAGE_REL_AMD64_SECREL = 0x000B,
/// <summary>
/// A 7-bit unsigned offset from the base of the section that contains
/// the target.
/// </summary>
IMAGE_REL_AMD64_SECREL7 = 0x000C,
/// <summary>
/// CLR tokens.
/// </summary>
IMAGE_REL_AMD64_TOKEN = 0x000D,
/// <summary>
/// A 32-bit signed span-dependent value emitted into the object.
/// </summary>
IMAGE_REL_AMD64_SREL32 = 0x000E,
/// <summary>
/// A pair that must immediately follow every span-dependent value.
/// </summary>
IMAGE_REL_AMD64_PAIR = 0x000F,
/// <summary>
/// A 32-bit signed span-dependent value that is applied at link time.
/// </summary>
IMAGE_REL_AMD64_SSPAN32 = 0x0010,
#endregion
#region ARM Processors
/// <summary>
/// The relocation is ignored.
/// </summary>
IMAGE_REL_ARM_ABSOLUTE = 0x0000,
/// <summary>
/// The 32-bit VA of the target.
/// </summary>
IMAGE_REL_ARM_ADDR32 = 0x0001,
/// <summary>
/// The 32-bit RVA of the target.
/// </summary>
IMAGE_REL_ARM_ADDR32NB = 0x0002,
/// <summary>
/// The 24-bit relative displacement to the target.
/// </summary>
IMAGE_REL_ARM_BRANCH24 = 0x0003,
/// <summary>
/// The reference to a subroutine call. The reference
/// consists of two 16-bit instructions with 11-bit offsets.
/// </summary>
IMAGE_REL_ARM_BRANCH11 = 0x0004,
/// <summary>
/// The 32-bit relative address from the byte following the relocation.
/// </summary>
IMAGE_REL_ARM_REL32 = 0x000A,
/// <summary>
/// The 16-bit section index of the section that contains the target.
/// This is used to support debugging information.
/// </summary>
IMAGE_REL_ARM_SECTION = 0x000E,
/// <summary>
/// The 32-bit offset of the target from the beginning of its section.
/// This is used to support debugging information and static thread
/// local storage.
/// </summary>
IMAGE_REL_ARM_SECREL = 0x000F,
/// <summary>
/// The 32-bit VA of the target.This relocation is applied using a MOVW
/// instruction for the low 16 bits followed by a MOVT for the high 16 bits.
/// </summary>
IMAGE_REL_ARM_MOV32 = 0x0010,
/// <summary>
/// The 32-bit VA of the target.This relocation is applied using a MOVW
/// instruction for the low 16 bits followed by a MOVT for the high 16 bits.
/// </summary>
IMAGE_REL_THUMB_MOV32 = 0x0011,
/// <summary>
/// The instruction is fixed up with the 21 - bit relative displacement to
/// the 2-byte aligned target. The least significant bit of the displacement
/// is always zero and is not stored. This relocation corresponds to a
/// Thumb-2 32-bit conditional B instruction.
/// </summary>
IMAGE_REL_THUMB_BRANCH20 = 0x0012,
Unused = 0x0013,
/// <summary>
/// The instruction is fixed up with the 25-bit relative displacement to
/// the 2-byte aligned target. The least significant bit of the displacement
/// is zero and is not stored. This relocation corresponds to a Thumb-2 B
/// instruction.
/// </summary>
IMAGE_REL_THUMB_BRANCH24 = 0x0014,
/// <summary>
/// The instruction is fixed up with the 25-bit relative displacement to
/// the 4-byte aligned target. The low 2 bits of the displacement are zero
/// and are not stored. This relocation corresponds to a Thumb-2 BLX instruction.
/// </summary>
IMAGE_REL_THUMB_BLX23 = 0x0015,
/// <summary>
/// The relocation is valid only when it immediately follows a ARM_REFHI or
/// THUMB_REFHI. Its SymbolTableIndex contains a displacement and not an index
/// into the symbol table.
/// </summary>
IMAGE_REL_ARM_PAIR = 0x0016,
#endregion
#region ARM64 Processors
/// <summary>
/// The relocation is ignored.
/// </summary>
IMAGE_REL_ARM64_ABSOLUTE = 0x0000,
/// <summary>
/// The 32-bit VA of the target.
/// </summary>
IMAGE_REL_ARM64_ADDR32 = 0x0001,
/// <summary>
/// The 32-bit RVA of the target.
/// </summary>
IMAGE_REL_ARM64_ADDR32NB = 0x0002,
/// <summary>
/// The 26-bit relative displacement to the target, for B and BL instructions.
/// </summary>
IMAGE_REL_ARM64_BRANCH26 = 0x0003,
/// <summary>
/// The page base of the target, for ADRP instruction.
/// </summary>
IMAGE_REL_ARM64_PAGEBASE_REL21 = 0x0004,
/// <summary>
/// The 12-bit relative displacement to the target, for instruction ADR
/// </summary>
IMAGE_REL_ARM64_REL21 = 0x0005,
/// <summary>
/// The 12-bit page offset of the target, for instructions ADD/ADDS (immediate)
/// with zero shift.
/// </summary>
IMAGE_REL_ARM64_PAGEOFFSET_12A = 0x0006,
/// <summary>
/// The 12-bit page offset of the target, for instruction LDR (indexed,
/// unsigned immediate).
/// </summary>
IMAGE_REL_ARM64_PAGEOFFSET_12L = 0x0007,
/// <summary>
/// The 32-bit offset of the target from the beginning of its section.
/// This is used to support debugging information and static thread local storage.
/// </summary>
IMAGE_REL_ARM64_SECREL = 0x0008,
/// <summary>
/// Bit 0:11 of section offset of the target, for instructions ADD/ADDS(immediate)
/// with zero shift.
/// </summary>
IMAGE_REL_ARM64_SECREL_LOW12A = 0x0009,
/// <summary>
/// Bit 12:23 of section offset of the target, for instructions ADD/ADDS(immediate)
/// with zero shift.
/// </summary>
IMAGE_REL_ARM64_SECREL_HIGH12A = 0x000A,
/// <summary>
/// Bit 0:11 of section offset of the target, for instruction LDR(indexed,
/// unsigned immediate).
/// </summary>
IMAGE_REL_ARM64_SECREL_LOW12L = 0x000B,
/// <summary>
/// CLR token.
/// </summary>
IMAGE_REL_ARM64_TOKEN = 0x000C,
/// <summary>
/// The 16-bit section index of the section that contains the target.
/// This is used to support debugging information.
/// </summary>
IMAGE_REL_ARM64_SECTION = 0x000D,
/// <summary>
/// The 64-bit VA of the relocation target.
/// </summary>
IMAGE_REL_ARM64_ADDR64 = 0x000E,
/// <summary>
/// The 19-bit offset to the relocation target, for conditional B instruction.
/// </summary>
IMAGE_REL_ARM64_BRANCH19 = 0x000F,
/// <summary>
/// The 14-bit offset to the relocation target, for instructions TBZ and TBNZ.
/// </summary>
IMAGE_REL_ARM64_BRANCH14 = 0x0010,
/// <summary>
/// The 32-bit relative address from the byte following the relocation.
/// </summary>
IMAGE_REL_ARM64_REL32 = 0x0011,
#endregion
#region Hitachi SuperH Processors
/// <summary>
/// The relocation is ignored.
/// </summary>
IMAGE_REL_SH3_ABSOLUTE = 0x0000,
/// <summary>
/// A reference to the 16-bit location that contains the VA of
/// the target symbol.
/// </summary>
IMAGE_REL_SH3_DIRECT16 = 0x0001,
/// <summary>
/// The 32-bit VA of the target symbol.
/// </summary>
IMAGE_REL_SH3_DIRECT32 = 0x0002,
/// <summary>
/// A reference to the 8-bit location that contains the VA of
/// the target symbol.
/// </summary>
IMAGE_REL_SH3_DIRECT8 = 0x0003,
/// <summary>
/// A reference to the 8-bit instruction that contains the
/// effective 16-bit VA of the target symbol.
/// </summary>
IMAGE_REL_SH3_DIRECT8_WORD = 0x0004,
/// <summary>
/// A reference to the 8-bit instruction that contains the
/// effective 32-bit VA of the target symbol.
/// </summary>
IMAGE_REL_SH3_DIRECT8_LONG = 0x0005,
/// <summary>
/// A reference to the 8-bit location whose low 4 bits contain
/// the VA of the target symbol.
/// </summary>
IMAGE_REL_SH3_DIRECT4 = 0x0006,
/// <summary>
/// A reference to the 8-bit instruction whose low 4 bits contain
/// the effective 16-bit VA of the target symbol.
/// </summary>
IMAGE_REL_SH3_DIRECT4_WORD = 0x0007,
/// <summary>
/// A reference to the 8-bit instruction whose low 4 bits contain
/// the effective 32-bit VA of the target symbol.
/// </summary>
IMAGE_REL_SH3_DIRECT4_LONG = 0x0008,
/// <summary>
/// A reference to the 8-bit instruction that contains the
/// effective 16-bit relative offset of the target symbol.
/// </summary>
IMAGE_REL_SH3_PCREL8_WORD = 0x0009,
/// <summary>
/// A reference to the 8-bit instruction that contains the
/// effective 32-bit relative offset of the target symbol.
/// </summary>
IMAGE_REL_SH3_PCREL8_LONG = 0x000A,
/// <summary>
/// A reference to the 16-bit instruction whose low 12 bits contain
/// the effective 16-bit relative offset of the target symbol.
/// </summary>
IMAGE_REL_SH3_PCREL12_WORD = 0x000B,
/// <summary>
/// A reference to a 32-bit location that is the VA of the
/// section that contains the target symbol.
/// </summary>
IMAGE_REL_SH3_STARTOF_SECTION = 0x000C,
/// <summary>
/// A reference to the 32-bit location that is the size of the
/// section that contains the target symbol.
/// </summary>
IMAGE_REL_SH3_SIZEOF_SECTION = 0x000D,
/// <summary>
/// The 16-bit section index of the section that contains the target.
/// This is used to support debugging information.
/// </summary>
IMAGE_REL_SH3_SECTION = 0x000E,
/// <summary>
/// The 32-bit offset of the target from the beginning of its section.
/// This is used to support debugging information and static thread
/// local storage.
/// </summary>
IMAGE_REL_SH3_SECREL = 0x000F,
/// <summary>
/// The 32-bit RVA of the target symbol.
/// </summary>
IMAGE_REL_SH3_DIRECT32_NB = 0x0010,
/// <summary>
/// GP relative.
/// </summary>
IMAGE_REL_SH3_GPREL4_LONG = 0x0011,
/// <summary>
/// CLR token.
/// </summary>
IMAGE_REL_SH3_TOKEN = 0x0012,
/// <summary>
/// The offset from the current instruction in longwords. If the NOMODE
/// bit is not set, insert the inverse of the low bit at bit 32 to
/// select PTA or PTB.
/// </summary>
IMAGE_REL_SHM_PCRELPT = 0x0013,
/// <summary>
/// The low 16 bits of the 32-bit address.
/// </summary>
IMAGE_REL_SHM_REFLO = 0x0014,
/// <summary>
/// The high 16 bits of the 32-bit address.
/// </summary>
IMAGE_REL_SHM_REFHALF = 0x0015,
/// <summary>
/// The low 16 bits of the relative address.
/// </summary>
IMAGE_REL_SHM_RELLO = 0x0016,
/// <summary>
/// The high 16 bits of the relative address.
/// </summary>
IMAGE_REL_SHM_RELHALF = 0x0017,
/// <summary>
/// The relocation is valid only when it immediately follows a REFHALF,
/// RELHALF, or RELLO relocation. The SymbolTableIndex field of the
/// relocation contains a displacement and not an index into the symbol table.
/// </summary>
IMAGE_REL_SHM_PAIR = 0x0018,
/// <summary>
/// The relocation ignores section mode.
/// </summary>
IMAGE_REL_SHM_NOMODE = 0x8000,
#endregion
#region IBM PowerPC Processors
/// <summary>
/// The relocation is ignored.
/// </summary>
IMAGE_REL_PPC_ABSOLUTE = 0x0000,
/// <summary>
/// The 64-bit VA of the target.
/// </summary>
IMAGE_REL_PPC_ADDR64 = 0x0001,
/// <summary>
/// The 32-bit VA of the target.
/// </summary>
IMAGE_REL_PPC_ADDR32 = 0x0002,
/// <summary>
/// The low 24 bits of the VA of the target. This is valid only when
/// the target symbol is absolute and can be sign-extended to its
/// original value.
/// </summary>
IMAGE_REL_PPC_ADDR24 = 0x0003,
/// <summary>
/// The low 16 bits of the target's VA.
/// </summary>
IMAGE_REL_PPC_ADDR16 = 0x0004,
/// <summary>
/// The low 14 bits of the target's VA. This is valid only when the
/// target symbol is absolute and can be sign-extended to its original
/// value.
/// </summary>
IMAGE_REL_PPC_ADDR14 = 0x0005,
/// <summary>
/// A 24-bit PC-relative offset to the symbol's location.
/// </summary>
IMAGE_REL_PPC_REL24 = 0x0006,
/// <summary>
/// A 14-bit PC-relative offset to the symbol's location.
/// </summary>
IMAGE_REL_PPC_REL14 = 0x0007,
/// <summary>
/// The 32-bit RVA of the target.
/// </summary>
IMAGE_REL_PPC_ADDR32NB = 0x000A,
/// <summary>
/// The 32-bit offset of the target from the beginning of its section.
/// This is used to support debugging information and static thread
/// local storage.
/// </summary>
IMAGE_REL_PPC_SECREL = 0x000B,
/// <summary>
/// The 16-bit section index of the section that contains the target.
/// This is used to support debugging information.
/// </summary>
IMAGE_REL_PPC_SECTION = 0x000C,
/// <summary>
/// The 16-bit offset of the target from the beginning of its section.
/// This is used to support debugging information and static thread
/// local storage.
/// </summary>
IMAGE_REL_PPC_SECREL16 = 0x000F,
/// <summary>
/// The high 16 bits of the target's 32-bit VA. This is used for the
/// first instruction in a two-instruction sequence that loads a full
/// address. This relocation must be immediately followed by a PAIR
/// relocation whose SymbolTableIndex contains a signed 16-bit
/// displacement that is added to the upper 16 bits that was taken
/// from the location that is being relocated.
/// </summary>
IMAGE_REL_PPC_REFHI = 0x0010,
/// <summary>
/// The low 16 bits of the target's VA.
/// </summary>
IMAGE_REL_PPC_REFLO = 0x0011,
/// <summary>
/// A relocation that is valid only when it immediately follows a REFHI
/// or SECRELHI relocation. Its SymbolTableIndex contains a displacement
/// and not an index into the symbol table.
/// </summary>
IMAGE_REL_PPC_PAIR = 0x0012,
/// <summary>
/// The low 16 bits of the 32-bit offset of the target from the beginning
/// of its section.
/// </summary>
IMAGE_REL_PPC_SECRELLO = 0x0013,
/// <summary>
/// The 16-bit signed displacement of the target relative to the GP register.
/// </summary>
IMAGE_REL_PPC_GPREL = 0x0015,
/// <summary>
/// The CLR token.
/// </summary>
IMAGE_REL_PPC_TOKEN = 0x0016,
#endregion
#region Intel 386 Processors
/// <summary>
/// The relocation is ignored.
/// </summary>
IMAGE_REL_I386_ABSOLUTE = 0x0000,
/// <summary>
/// Not supported.
/// </summary>
IMAGE_REL_I386_DIR16 = 0x0001,
/// <summary>
/// Not supported.
/// </summary>
IMAGE_REL_I386_REL16 = 0x0002,
/// <summary>
/// The target's 32-bit VA.
/// </summary>
IMAGE_REL_I386_DIR32 = 0x0006,
/// <summary>
/// The target's 32-bit RVA.
/// </summary>
IMAGE_REL_I386_DIR32NB = 0x0007,
/// <summary>
/// Not supported.
/// </summary>
IMAGE_REL_I386_SEG12 = 0x0009,
/// <summary>
/// The 16-bit section index of the section that contains the target.
/// This is used to support debugging information.
/// </summary>
IMAGE_REL_I386_SECTION = 0x000A,
/// <summary>
/// The 32-bit offset of the target from the beginning of its section.
/// This is used to support debugging information and static thread
/// local storage.
/// </summary>
IMAGE_REL_I386_SECREL = 0x000B,
/// <summary>
/// The CLR token.
/// </summary>
IMAGE_REL_I386_TOKEN = 0x000C,
/// <summary>
/// A 7-bit offset from the base of the section that contains the target.
/// </summary>
IMAGE_REL_I386_SECREL7 = 0x000D,
/// <summary>
/// The 32-bit relative displacement to the target.This supports the x86 relative branch and call instructions.
/// </summary>
IMAGE_REL_I386_REL32 = 0x0014,
#endregion
#region Intel Itanium Processor Family (IPF)
/// <summary>
/// The relocation is ignored.
/// </summary>
IMAGE_REL_IA64_ABSOLUTE = 0x0000,
/// <summary>
/// The instruction relocation can be followed by an ADDEND relocation whose value is
/// added to the target address before it is inserted into the specified slot in the
/// IMM14 bundle. The relocation target must be absolute or the image must be fixed.
/// </summary>
IMAGE_REL_IA64_IMM14 = 0x0001,
/// <summary>
/// The instruction relocation can be followed by an ADDEND relocation whose value is
/// added to the target address before it is inserted into the specified slot in the
/// IMM22 bundle. The relocation target must be absolute or the image must be fixed.
/// </summary>
IMAGE_REL_IA64_IMM22 = 0x0002,
/// <summary>
/// The slot number of this relocation must be one (1). The relocation can be followed
/// by an ADDEND relocation whose value is added to the target address before it is
/// stored in all three slots of the IMM64 bundle.
/// </summary>
IMAGE_REL_IA64_IMM64 = 0x0003,
/// <summary>
/// The target's 32-bit VA. This is supported only for /LARGEADDRESSAWARE:NO images.
/// </summary>
IMAGE_REL_IA64_DIR32 = 0x0004,
/// <summary>
/// The target's 64-bit VA.
/// </summary>
IMAGE_REL_IA64_DIR64 = 0x0005,
/// <summary>
/// The instruction is fixed up with the 25-bit relative displacement to the 16-bit
/// aligned target. The low 4 bits of the displacement are zero and are not stored.
/// </summary>
IMAGE_REL_IA64_PCREL21B = 0x0006,
/// <summary>
/// The instruction is fixed up with the 25-bit relative displacement to the 16-bit
/// aligned target. The low 4 bits of the displacement, which are zero, are not stored.
/// </summary>
IMAGE_REL_IA64_PCREL21M = 0x0007,
/// <summary>
/// The LSBs of this relocation's offset must contain the slot number whereas the rest
/// is the bundle address. The bundle is fixed up with the 25-bit relative displacement
/// to the 16-bit aligned target. The low 4 bits of the displacement are zero and are
/// not stored.
/// </summary>
IMAGE_REL_IA64_PCREL21F = 0x0008,
/// <summary>
/// The instruction relocation can be followed by an ADDEND relocation whose value is
/// added to the target address and then a 22-bit GP-relative offset that is calculated
/// and applied to the GPREL22 bundle.
/// </summary>
IMAGE_REL_IA64_GPREL22 = 0x0009,
/// <summary>
/// The instruction is fixed up with the 22-bit GP-relative offset to the target symbol's
/// literal table entry. The linker creates this literal table entry based on this
/// relocation and the ADDEND relocation that might follow.
/// </summary>
IMAGE_REL_IA64_LTOFF22 = 0x000A,
/// <summary>
/// The 16-bit section index of the section contains the target. This is used to support
/// debugging information.
/// </summary>
IMAGE_REL_IA64_SECTION = 0x000B,
/// <summary>
/// The instruction is fixed up with the 22-bit offset of the target from the beginning of
/// its section.This relocation can be followed immediately by an ADDEND relocation,
/// whose Value field contains the 32-bit unsigned offset of the target from the beginning
/// of the section.
/// </summary>
IMAGE_REL_IA64_SECREL22 = 0x000C,
/// <summary>
/// The slot number for this relocation must be one (1). The instruction is fixed up with
/// the 64-bit offset of the target from the beginning of its section. This relocation can
/// be followed immediately by an ADDEND relocation whose Value field contains the 32-bit
/// unsigned offset of the target from the beginning of the section.
/// </summary>
IMAGE_REL_IA64_SECREL64I = 0x000D,
/// <summary>
/// The address of data to be fixed up with the 32-bit offset of the target from the beginning
/// of its section.
/// </summary>
IMAGE_REL_IA64_SECREL32 = 0x000E,
/// <summary>
/// The target's 32-bit RVA.
/// </summary>
IMAGE_REL_IA64_DIR32NB = 0x0010,
/// <summary>
/// This is applied to a signed 14-bit immediate that contains the difference between two
/// relocatable targets. This is a declarative field for the linker that indicates that the
/// compiler has already emitted this value.
/// </summary>
IMAGE_REL_IA64_SREL14 = 0x0011,
/// <summary>
/// This is applied to a signed 22-bit immediate that contains the difference between two
/// relocatable targets. This is a declarative field for the linker that indicates that the
/// compiler has already emitted this value.
/// </summary>
IMAGE_REL_IA64_SREL22 = 0x0012,
/// <summary>
/// This is applied to a signed 32-bit immediate that contains the difference between two
/// relocatable values.This is a declarative field for the linker that indicates that the
/// compiler has already emitted this value.
/// </summary>
IMAGE_REL_IA64_SREL32 = 0x0013,
/// <summary>
/// This is applied to an unsigned 32-bit immediate that contains the difference between
/// two relocatable values. This is a declarative field for the linker that indicates that
/// the compiler has already emitted this value.
/// </summary>
IMAGE_REL_IA64_UREL32 = 0x0014,
/// <summary>
/// A 60-bit PC-relative fixup that always stays as a BRL instruction of an MLX bundle.
/// </summary>
IMAGE_REL_IA64_PCREL60X = 0x0015,
/// <summary>
/// A 60-bit PC-relative fixup. If the target displacement fits in a signed 25-bit field,
/// convert the entire bundle to an MBB bundle with NOP. B in slot 1 and a 25-bit BR
/// instruction (with the 4 lowest bits all zero and dropped) in slot 2.
/// </summary>
IMAGE_REL_IA64_PCREL60B = 0x0016,
/// <summary>
/// A 60-bit PC-relative fixup. If the target displacement fits in a signed 25-bit field,
/// convert the entire bundle to an MFB bundle with NOP. F in slot 1 and a 25-bit
/// (4 lowest bits all zero and dropped) BR instruction in slot 2.
/// </summary>
IMAGE_REL_IA64_PCREL60F = 0x0017,
/// <summary>
/// A 60-bit PC-relative fixup. If the target displacement fits in a signed 25-bit field,
/// convert the entire bundle to an MIB bundle with NOP. I in slot 1 and a 25-bit
/// (4 lowest bits all zero and dropped) BR instruction in slot 2.
/// </summary>
IMAGE_REL_IA64_PCREL60I = 0x0018,
/// <summary>
/// A 60-bit PC-relative fixup. If the target displacement fits in a signed 25-bit field,
/// convert the entire bundle to an MMB bundle with NOP. M in slot 1 and a 25-bit
/// (4 lowest bits all zero and dropped) BR instruction in slot 2.
/// </summary>
IMAGE_REL_IA64_PCREL60M = 0x0019,
/// <summary>
/// A 64-bit GP-relative fixup.
/// </summary>
IMAGE_REL_IA64_IMMGPREL64 = 0x001a,
/// <summary>
/// A CLR token.
/// </summary>
IMAGE_REL_IA64_TOKEN = 0x001b,
/// <summary>
/// A 32-bit GP-relative fixup.
/// </summary>
IMAGE_REL_IA64_GPREL32 = 0x001c,
/// <summary>
/// The relocation is valid only when it immediately follows one of the following relocations:
/// IMM14, IMM22, IMM64, GPREL22, LTOFF22, LTOFF64, SECREL22, SECREL64I, or SECREL32.
/// Its value contains the addend to apply to instructions within a bundle, not for data.
/// </summary>
IMAGE_REL_IA64_ADDEND = 0x001F,
#endregion
#region MIPS Processors
/// <summary>
/// The relocation is ignored.
/// </summary>
IMAGE_REL_MIPS_ABSOLUTE = 0x0000,
/// <summary>
/// The high 16 bits of the target's 32-bit VA.
/// </summary>
IMAGE_REL_MIPS_REFHALF = 0x0001,
/// <summary>
/// The target's 32-bit VA.
/// </summary>
IMAGE_REL_MIPS_REFWORD = 0x0002,
/// <summary>
/// The low 26 bits of the target's VA. This supports the MIPS J and JAL instructions.
/// </summary>
IMAGE_REL_MIPS_JMPADDR = 0x0003,
/// <summary>
/// The high 16 bits of the target's 32-bit VA. This is used for the first instruction in a
/// two-instruction sequence that loads a full address. This relocation must be immediately
/// followed by a PAIR relocation whose SymbolTableIndex contains a signed 16-bit displacement
/// that is added to the upper 16 bits that are taken from the location that is being relocated.
/// </summary>
IMAGE_REL_MIPS_REFHI = 0x0004,
/// <summary>
/// The low 16 bits of the target's VA.
/// </summary>
IMAGE_REL_MIPS_REFLO = 0x0005,
/// <summary>
/// A 16-bit signed displacement of the target relative to the GP register.
/// </summary>
IMAGE_REL_MIPS_GPREL = 0x0006,
/// <summary>
/// The same as IMAGE_REL_MIPS_GPREL.
/// </summary>
IMAGE_REL_MIPS_LITERAL = 0x0007,
/// <summary>
/// The 16-bit section index of the section contains the target.
/// This is used to support debugging information.
/// </summary>
IMAGE_REL_MIPS_SECTION = 0x000A,
/// <summary>
/// The 32-bit offset of the target from the beginning of its section.
/// This is used to support debugging information and static thread local storage.
/// </summary>
IMAGE_REL_MIPS_SECREL = 0x000B,
/// <summary>
/// The low 16 bits of the 32-bit offset of the target from the beginning of its section.
/// </summary>
IMAGE_REL_MIPS_SECRELLO = 0x000C,
/// <summary>
/// The high 16 bits of the 32-bit offset of the target from the beginning of its section.
/// An IMAGE_REL_MIPS_PAIR relocation must immediately follow this one. The SymbolTableIndex
/// of the PAIR relocation contains a signed 16-bit displacement that is added to the upper
/// 16 bits that are taken from the location that is being relocated.
/// </summary>
IMAGE_REL_MIPS_SECRELHI = 0x000D,
/// <summary>
/// The low 26 bits of the target's VA. This supports the MIPS16 JAL instruction.
/// </summary>
IMAGE_REL_MIPS_JMPADDR16 = 0x0010,
/// <summary>
/// The target's 32-bit RVA.
/// </summary>
IMAGE_REL_MIPS_REFWORDNB = 0x0022,
/// <summary>
/// The relocation is valid only when it immediately follows a REFHI or SECRELHI relocation.
/// Its SymbolTableIndex contains a displacement and not an index into the symbol table.
/// </summary>
IMAGE_REL_MIPS_PAIR = 0x0025,
#endregion
#region Mitsubishi M32R
/// <summary>
/// The relocation is ignored.
/// </summary>
IMAGE_REL_M32R_ABSOLUTE = 0x0000,
/// <summary>
/// The target's 32-bit VA.
/// </summary>
IMAGE_REL_M32R_ADDR32 = 0x0001,
/// <summary>
/// The target's 32-bit RVA.
/// </summary>
IMAGE_REL_M32R_ADDR32NB = 0x0002,
/// <summary>
/// The target's 24-bit VA.
/// </summary>
IMAGE_REL_M32R_ADDR24 = 0x0003,
/// <summary>
/// The target's 16-bit offset from the GP register.
/// </summary>
IMAGE_REL_M32R_GPREL16 = 0x0004,
/// <summary>
/// The target's 24-bit offset from the program counter (PC), shifted left by
/// 2 bits and sign-extended
/// </summary>
IMAGE_REL_M32R_PCREL24 = 0x0005,
/// <summary>
/// The target's 16-bit offset from the PC, shifted left by 2 bits and
/// sign-extended
/// </summary>
IMAGE_REL_M32R_PCREL16 = 0x0006,
/// <summary>
/// The target's 8-bit offset from the PC, shifted left by 2 bits and
/// sign-extended
/// </summary>
IMAGE_REL_M32R_PCREL8 = 0x0007,
/// <summary>
/// The 16 MSBs of the target VA.
/// </summary>
IMAGE_REL_M32R_REFHALF = 0x0008,
/// <summary>
/// The 16 MSBs of the target VA, adjusted for LSB sign extension. This is used for
/// the first instruction in a two-instruction sequence that loads a full 32-bit address.
/// This relocation must be immediately followed by a PAIR relocation whose SymbolTableIndex
/// contains a signed 16-bit displacement that is added to the upper 16 bits that are
/// taken from the location that is being relocated.
/// </summary>
IMAGE_REL_M32R_REFHI = 0x0009,
/// <summary>
/// The 16 LSBs of the target VA.
/// </summary>
IMAGE_REL_M32R_REFLO = 0x000A,
/// <summary>
/// The relocation must follow the REFHI relocation.Its SymbolTableIndex contains a displacement
/// and not an index into the symbol table.
/// </summary>
IMAGE_REL_M32R_PAIR = 0x000B,
/// <summary>
/// The 16-bit section index of the section that contains the target. This is used to support
/// debugging information.
/// </summary>
IMAGE_REL_M32R_SECTION = 0x000C,
/// <summary>
/// The 32-bit offset of the target from the beginning of its section.This is used to support
/// debugging information and static thread local storage.
/// </summary>
IMAGE_REL_M32R_SECREL = 0x000D,
/// <summary>
/// The CLR token.
/// </summary>
IMAGE_REL_M32R_TOKEN = 0x000E,
#endregion
}
public enum ResourceType : uint
{
RT_NEWRESOURCE = 0x2000,
RT_ERROR = 0x7FFF,
/// <summary>
/// Hardware-dependent cursor resource.
/// </summary>
RT_CURSOR = 1,
/// <summary>
/// Bitmap resource.
/// </summary>
RT_BITMAP = 2,
/// <summary>
/// Hardware-dependent icon resource.
/// </summary>
RT_ICON = 3,
/// <summary>
/// Menu resource.
/// </summary>
RT_MENU = 4,
/// <summary>
/// Dialog box.
/// </summary>
RT_DIALOG = 5,
/// <summary>
/// String-table entry.
/// </summary>
RT_STRING = 6,
/// <summary>
/// Font directory resource.
/// </summary>
RT_FONTDIR = 7,
/// <summary>
/// Font resource.
/// </summary>
RT_FONT = 8,
/// <summary>
/// Accelerator table.
/// </summary>
RT_ACCELERATOR = 9,
/// <summary>
/// Application-defined resource (raw data).
/// </summary>
RT_RCDATA = 10,
/// <summary>
/// Message-table entry.
/// </summary>
RT_MESSAGETABLE = 11,
/// <summary>
/// Hardware-independent cursor resource.
/// </summary>
RT_GROUP_CURSOR = RT_CURSOR + 11,
/// <summary>
/// Hardware-independent icon resource.
/// </summary>
RT_GROUP_ICON = RT_ICON + 11,
/// <summary>
/// Version resource.
/// </summary>
RT_VERSION = 16,
/// <summary>
/// Allows a resource editing tool to associate a string with an .rc file.
/// Typically, the string is the name of the header file that provides symbolic
/// names. The resource compiler parses the string but otherwise ignores the
/// value. For example, `1 DLGINCLUDE "MyFile.h"`
/// </summary>
RT_DLGINCLUDE = 17,
/// <summary>
/// Plug and Play resource.
/// </summary>
RT_PLUGPLAY = 19,
/// <summary>
/// VXD.
/// </summary>
RT_VXD = 20,
/// <summary>
/// Animated cursor.
/// </summary>
RT_ANICURSOR = 21,
/// <summary>
/// Animated icon.
/// </summary>
RT_ANIICON = 22,
/// <summary>
/// HTML resource.
/// </summary>
RT_HTML = 23,
/// <summary>
/// Side-by-Side Assembly Manifest.
/// </summary>
RT_MANIFEST = 24,
RT_NEWBITMAP = (RT_BITMAP | RT_NEWRESOURCE),
RT_NEWMENU = (RT_MENU | RT_NEWRESOURCE),
RT_NEWDIALOG = (RT_DIALOG | RT_NEWRESOURCE),
}
[Flags]
public enum SectionFlags : uint
{
/// <summary>
/// Reserved for future use.
/// </summary>
RESERVED0 = 0x00000001,
/// <summary>
/// Reserved for future use.
/// </summary>
RESERVED1 = 0x00000002,
/// <summary>
/// Reserved for future use.
/// </summary>
RESERVED2 = 0x00000004,
/// <summary>
/// The section should not be padded to the next boundary.
/// This flag is obsolete and is replaced by IMAGE_SCN_ALIGN_1BYTES.
/// This is valid only for object files.
/// </summary>
IMAGE_SCN_TYPE_NO_PAD = 0x00000008,
/// <summary>
/// Reserved for future use.
/// </summary>
RESERVED4 = 0x00000010,
/// <summary>
/// The section contains executable code.
/// </summary>
IMAGE_SCN_CNT_CODE = 0x00000020,
/// <summary>
/// The section contains initialized data.
/// </summary>
IMAGE_SCN_CNT_INITIALIZED_DATA = 0x00000040,
/// <summary>
/// The section contains uninitialized data.
/// </summary>
IMAGE_SCN_CNT_UNINITIALIZED_DATA = 0x00000080,
/// <summary>
/// Reserved for future use.
/// </summary>
IMAGE_SCN_LNK_OTHER = 0x00000100,
/// <summary>
/// The section contains comments or other information. The .drectve
/// section has this type. This is valid for object files only.
/// </summary>
IMAGE_SCN_LNK_INFO = 0x00000200,
/// <summary>
/// Reserved for future use.
/// </summary>
RESERVED10 = 0x00000400,
/// <summary>
/// The section will not become part of the image. This is valid
/// only for object files.
/// </summary>
IMAGE_SCN_LNK_REMOVE = 0x00000800,
/// <summary>
/// The section contains COMDAT data. For more information, see COMDAT Sections
/// (Object Only). This is valid only for object files.
/// </summary>
IMAGE_SCN_LNK_COMDAT = 0x00001000,
/// <summary>
/// The section contains data referenced through the global pointer (GP).
/// </summary>
IMAGE_SCN_GPREL = 0x00008000,
/// <summary>
/// Reserved for future use.
/// </summary>
IMAGE_SCN_MEM_PURGEABLE = 0x00010000,
/// <summary>
/// Reserved for future use.
/// </summary>
IMAGE_SCN_MEM_16BIT = 0x00020000,
/// <summary>
/// Reserved for future use.
/// </summary>
IMAGE_SCN_MEM_LOCKED = 0x00040000,
/// <summary>
/// Reserved for future use.
/// </summary>
IMAGE_SCN_MEM_PRELOAD = 0x00080000,
/// <summary>
/// Align data on a 1-byte boundary. Valid only for object files.
/// </summary>
IMAGE_SCN_ALIGN_1BYTES = 0x00100000,
/// <summary>
/// Align data on a 2-byte boundary. Valid only for object files.
/// </summary>
IMAGE_SCN_ALIGN_2BYTES = 0x00200000,
/// <summary>
/// Align data on a 4-byte boundary. Valid only for object files.
/// </summary>
IMAGE_SCN_ALIGN_4BYTES = 0x00300000,
/// <summary>
/// Align data on an 8-byte boundary. Valid only for object files.
/// </summary>
IMAGE_SCN_ALIGN_8BYTES = 0x00400000,
/// <summary>
/// Align data on a 16-byte boundary. Valid only for object files.
/// </summary>
IMAGE_SCN_ALIGN_16BYTES = 0x00500000,
/// <summary>
/// Align data on a 32-byte boundary. Valid only for object files.
/// </summary>
IMAGE_SCN_ALIGN_32BYTES = 0x00600000,
/// <summary>
/// Align data on a 64-byte boundary. Valid only for object files.
/// </summary>
IMAGE_SCN_ALIGN_64BYTES = 0x00700000,
/// <summary>
/// Align data on a 128-byte boundary. Valid only for object files.
/// </summary>
IMAGE_SCN_ALIGN_128BYTES = 0x00800000,
/// <summary>
/// Align data on a 256-byte boundary. Valid only for object files.
/// </summary>
IMAGE_SCN_ALIGN_256BYTES = 0x00900000,
/// <summary>
/// Align data on a 512-byte boundary. Valid only for object files.
/// </summary>
IMAGE_SCN_ALIGN_512BYTES = 0x00A00000,
/// <summary>
/// Align data on a 1024-byte boundary. Valid only for object files.
/// </summary>
IMAGE_SCN_ALIGN_1024BYTES = 0x00B00000,
/// <summary>
/// Align data on a 2048-byte boundary. Valid only for object files.
/// </summary>
IMAGE_SCN_ALIGN_2048BYTES = 0x00C00000,
/// <summary>
/// Align data on a 4096-byte boundary. Valid only for object files.
/// </summary>
IMAGE_SCN_ALIGN_4096BYTES = 0x00D00000,
/// <summary>
/// Align data on an 8192-byte boundary. Valid only for object files.
/// </summary>
IMAGE_SCN_ALIGN_8192BYTES = 0x00E00000,
/// <summary>
/// The section contains extended relocations.
/// </summary>
IMAGE_SCN_LNK_NRELOC_OVFL = 0x01000000,
/// <summary>
/// The section can be discarded as needed.
/// </summary>
IMAGE_SCN_MEM_DISCARDABLE = 0x02000000,
/// <summary>
/// The section cannot be cached.
/// </summary>
IMAGE_SCN_MEM_NOT_CACHED = 0x04000000,
/// <summary>
/// The section is not pageable.
/// </summary>
IMAGE_SCN_MEM_NOT_PAGED = 0x08000000,
/// <summary>
/// The section can be shared in memory.
/// </summary>
IMAGE_SCN_MEM_SHARED = 0x10000000,
/// <summary>
/// The section can be executed as code.
/// </summary>
IMAGE_SCN_MEM_EXECUTE = 0x20000000,
/// <summary>
/// The section can be read.
/// </summary>
IMAGE_SCN_MEM_READ = 0x40000000,
/// <summary>
/// The section can be written to.
/// </summary>
IMAGE_SCN_MEM_WRITE = 0x80000000,
}
public enum SectionNumber
{
/// <summary>
/// The symbol record is not yet assigned a section. A value of
/// zero indicates that a reference to an external symbol is
/// defined elsewhere. A value of non-zero is a common symbol
/// with a size that is specified by the value.
/// </summary>
IMAGE_SYM_UNDEFINED = 0,
/// <summary>
/// The symbol has an absolute (non-relocatable) value and
/// is not an address.
/// </summary>
IMAGE_SYM_ABSOLUTE = -1,
/// <summary>
/// The symbol provides general type or debugging information
/// but does not correspond to a section. Microsoft tools use
/// this setting along with .file records (storage class FILE).
/// </summary>
IMAGE_SYM_DEBUG = -2,
}
public enum StorageClass : byte
{
/// <summary>
/// A special symbol that represents the end of function, for debugging purposes.
/// </summary>
IMAGE_SYM_CLASS_END_OF_FUNCTION = 0xFF,
/// <summary>
/// No assigned storage class.
/// </summary>
IMAGE_SYM_CLASS_NULL = 0x00,
/// <summary>
/// The automatic (stack) variable.The Value field specifies the stack frame offset.
/// </summary>
IMAGE_SYM_CLASS_AUTOMATIC = 0x01,
/// <summary>
/// A value that Microsoft tools use for external symbols. The Value field indicates
/// the size if the section number is IMAGE_SYM_UNDEFINED (0). If the section number
/// is not zero, then the Value field specifies the offset within the section.
/// </summary>
IMAGE_SYM_CLASS_EXTERNAL = 0x02,
/// <summary>
/// The offset of the symbol within the section. If the Value field is zero, then
/// the symbol represents a section name.
/// </summary>
IMAGE_SYM_CLASS_STATIC = 0x03,
/// <summary>
/// A register variable.The Value field specifies the register number.
/// </summary>
IMAGE_SYM_CLASS_REGISTER = 0x04,
/// <summary>
/// A symbol that is defined externally.
/// </summary>
IMAGE_SYM_CLASS_EXTERNAL_DEF = 0x05,
/// <summary>
/// A code label that is defined within the module. The Value field specifies the
/// offset of the symbol within the section.
/// </summary>
IMAGE_SYM_CLASS_LABEL = 0x06,
/// <summary>
/// A reference to a code label that is not defined.
/// </summary>
IMAGE_SYM_CLASS_UNDEFINED_LABEL = 0x07,
/// <summary>
/// The structure member. The Value field specifies the n th member.
/// </summary>
IMAGE_SYM_CLASS_MEMBER_OF_STRUCT = 0x08,
/// <summary>
/// A formal argument (parameter) of a function. The Value field specifies the
/// n th argument.
/// </summary>
IMAGE_SYM_CLASS_ARGUMENT = 0x09,
/// <summary>
/// The structure tag-name entry.
/// </summary>
IMAGE_SYM_CLASS_STRUCT_TAG = 0x0A,
/// <summary>
/// A union member. The Value field specifies the n th member.
/// </summary>
IMAGE_SYM_CLASS_MEMBER_OF_UNION = 0x0B,
/// <summary>
/// The Union tag-name entry.
/// </summary>
IMAGE_SYM_CLASS_UNION_TAG = 0x0C,
/// <summary>
/// A Typedef entry.
/// </summary>
IMAGE_SYM_CLASS_TYPE_DEFINITION = 0x0D,
/// <summary>
/// A static data declaration.
/// </summary>
IMAGE_SYM_CLASS_UNDEFINED_STATIC = 0x0E,
/// <summary>
/// An enumerated type tagname entry.
/// </summary>
IMAGE_SYM_CLASS_ENUM_TAG = 0x0F,
/// <summary>
/// A member of an enumeration. The Value field specifies the
/// n th member.
/// </summary>
IMAGE_SYM_CLASS_MEMBER_OF_ENUM = 0x10,
/// <summary>
/// A register parameter.
/// </summary>
IMAGE_SYM_CLASS_REGISTER_PARAM = 0x11,
/// <summary>
/// A bit-field reference. The Value field specifies the
/// n th bit in the bit field.
/// </summary>
IMAGE_SYM_CLASS_BIT_FIELD = 0x12,
/// <summary>
/// A .bb (beginning of block) or .eb (end of block) record.
/// The Value field is the relocatable address of the code location.
/// </summary>
IMAGE_SYM_CLASS_BLOCK = 0x64,
/// <summary>
/// A value that Microsoft tools use for symbol records that define the extent
/// of a function: begin function (.bf ), end function (.ef), and lines in
/// function (.lf). For .lf records, the Value field gives the number of source
/// lines in the function. For .ef records, the Value field gives the size of
/// the function code.
/// </summary>
IMAGE_SYM_CLASS_FUNCTION = 0x65,
/// <summary>
/// An end-of-structure entry.
/// </summary>
IMAGE_SYM_CLASS_END_OF_STRUCT = 0x66,
/// <summary>
/// A value that Microsoft tools, as well as traditional COFF format, use for the
/// source-file symbol record. The symbol is followed by auxiliary records that
/// name the file.
/// </summary>
IMAGE_SYM_CLASS_FILE = 0x67,
/// <summary>
/// A definition of a section (Microsoft tools use STATIC storage class instead).
/// </summary>
IMAGE_SYM_CLASS_SECTION = 0x68,
/// <summary>
/// A weak external.For more information, see Auxiliary Format 3: Weak Externals.
/// </summary>
IMAGE_SYM_CLASS_WEAK_EXTERNAL = 0x69,
/// <summary>
/// A CLR token symbol. The name is an ASCII string that consists of the hexadecimal
/// value of the token. For more information, see CLR Token Definition (Object Only).
/// </summary>
IMAGE_SYM_CLASS_CLR_TOKEN = 0x6A,
}
public enum SymbolType : ushort
{
/// <summary>
/// No type information or unknown base type. Microsoft tools use this setting
/// </summary>
IMAGE_SYM_TYPE_NULL = 0x00,
/// <summary>
/// No valid type; used with void pointers and functions
/// </summary>
IMAGE_SYM_TYPE_VOID = 0x01,
/// <summary>
/// A character (signed byte)
/// </summary>
IMAGE_SYM_TYPE_CHAR = 0x02,
/// <summary>
/// A 2-byte signed integer
/// </summary>
IMAGE_SYM_TYPE_SHORT = 0x03,
/// <summary>
/// A natural integer type (normally 4 bytes in Windows)
/// </summary>
IMAGE_SYM_TYPE_INT = 0x04,
/// <summary>
/// A 4-byte signed integer
/// </summary>
IMAGE_SYM_TYPE_LONG = 0x05,
/// <summary>
/// A 4-byte floating-point number
/// </summary>
IMAGE_SYM_TYPE_FLOAT = 0x06,
/// <summary>
/// An 8-byte floating-point number
/// </summary>
IMAGE_SYM_TYPE_DOUBLE = 0x07,
/// <summary>
/// A structure
/// </summary>
IMAGE_SYM_TYPE_STRUCT = 0x08,
/// <summary>
/// A union
/// </summary>
IMAGE_SYM_TYPE_UNION = 0x09,
/// <summary>
/// An enumerated type
/// </summary>
IMAGE_SYM_TYPE_ENUM = 0x0A,
/// <summary>
/// A member of enumeration (a specific value)
/// </summary>
IMAGE_SYM_TYPE_MOE = 0x0B,
/// <summary>
/// A byte; unsigned 1-byte integer
/// </summary>
IMAGE_SYM_TYPE_BYTE = 0x0C,
/// <summary>
/// A word; unsigned 2-byte integer
/// </summary>
IMAGE_SYM_TYPE_WORD = 0x0D,
/// <summary>
/// An unsigned integer of natural size (normally, 4 bytes)
/// </summary>
IMAGE_SYM_TYPE_UINT = 0x0E,
/// <summary>
/// An unsigned 4-byte integer
/// </summary>
IMAGE_SYM_TYPE_DWORD = 0x0F,
/// <summary>
/// A function pointer
/// </summary>
IMAGE_SYM_TYPE_FUNC = 0x20,
}
public enum SymbolDerivedType : byte
{
/// <summary>
/// No derived type; the symbol is a simple scalar variable.
/// </summary>
IMAGE_SYM_DTYPE_NULL = 0x00,
/// <summary>
/// The symbol is a pointer to base type.
/// </summary>
IMAGE_SYM_DTYPE_POINTER = 0x01,
/// <summary>
/// The symbol is a function that returns a base type.
/// </summary>
IMAGE_SYM_DTYPE_FUNCTION = 0x02,
/// <summary>
/// The symbol is an array of base type.
/// </summary>
IMAGE_SYM_DTYPE_ARRAY = 0x03,
}
public enum WindowsCertificateRevision : ushort
{
/// <summary>
/// Version 1, legacy version of the Win_Certificate structure. It is supported
/// only for purposes of verifying legacy Authenticode signatures
/// </summary>
WIN_CERT_REVISION_1_0 = 0x0100,
/// <summary>
/// Version 2 is the current version of the Win_Certificate structure.
/// </summary>
WIN_CERT_REVISION_2_0 = 0x0200,
}
public enum WindowsCertificateType : ushort
{
/// <summary>
/// bCertificate contains an X.509 Certificate
/// </summary>
/// <remarks>
/// Not Supported
/// </remarks>
WIN_CERT_TYPE_X509 = 0x0001,
/// <summary>
/// bCertificate contains a PKCS#7 SignedData structure
/// </summary>
WIN_CERT_TYPE_PKCS_SIGNED_DATA = 0x0002,
/// <summary>
/// Reserved
/// </summary>
WIN_CERT_TYPE_RESERVED_1 = 0x0003,
/// <summary>
/// Terminal Server Protocol Stack Certificate signing
/// </summary>
/// <remarks>
/// Not Supported
/// </remarks>
WIN_CERT_TYPE_TS_STACK_SIGNED = 0x0004,
}
public enum WindowsSubsystem : ushort
{
/// <summary>
/// An unknown subsystem
/// </summary>
IMAGE_SUBSYSTEM_UNKNOWN = 0x0000,
/// <summary>
/// Device drivers and native Windows processes
/// </summary>
IMAGE_SUBSYSTEM_NATIVE = 0x0001,
/// <summary>
/// The Windows graphical user interface (GUI) subsystem
/// </summary>
IMAGE_SUBSYSTEM_WINDOWS_GUI = 0x0002,
/// <summary>
/// The Windows character subsystem
/// </summary>
IMAGE_SUBSYSTEM_WINDOWS_CUI = 0x0003,
/// <summary>
/// The OS/2 character subsystem
/// </summary>
IMAGE_SUBSYSTEM_OS2_CUI = 0x0005,
/// <summary>
/// The Posix character subsystem
/// </summary>
IMAGE_SUBSYSTEM_POSIX_CUI = 0x0007,
/// <summary>
/// Native Win9x driver
/// </summary>
IMAGE_SUBSYSTEM_NATIVE_WINDOWS = 0x0008,
/// <summary>
/// Windows CE
/// </summary>
IMAGE_SUBSYSTEM_WINDOWS_CE_GUI = 0x0009,
/// <summary>
/// An Extensible Firmware Interface (EFI) application
/// </summary>
IMAGE_SUBSYSTEM_EFI_APPLICATION = 0x000A,
/// <summary>
/// An EFI driver with boot services
/// </summary>
IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER = 0x000B,
/// <summary>
/// An EFI driver with run-time services
/// </summary>
IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER = 0x000C,
/// <summary>
/// An EFI ROM image
/// </summary>
IMAGE_SUBSYSTEM_EFI_ROM = 0x000D,
/// <summary>
/// XBOX
/// </summary>
IMAGE_SUBSYSTEM_XBOX = 0x000E,
/// <summary>
/// Windows boot application.
/// </summary>
IMAGE_SUBSYSTEM_WINDOWS_BOOT_APPLICATION = 0x0010,
}
}