mirror of
https://github.com/SabreTools/BinaryObjectScanner.git
synced 2026-02-11 21:29:18 +00:00
2708 lines
84 KiB
C#
2708 lines
84 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,
|
|
}
|
|
|
|
public enum FixedFileInfoFileSubtype : uint
|
|
{
|
|
/// <summary>
|
|
/// The driver type is unknown by the system.
|
|
/// The font type is unknown by the system.
|
|
/// </summary>
|
|
VFT2_UNKNOWN = 0x00000000,
|
|
|
|
#region VFT_DRV
|
|
|
|
/// <summary>
|
|
/// The file contains a printer driver.
|
|
/// </summary>
|
|
VFT2_DRV_PRINTER = 0x00000001,
|
|
|
|
/// <summary>
|
|
/// The file contains a keyboard driver.
|
|
/// </summary>
|
|
VFT2_DRV_KEYBOARD = 0x00000002,
|
|
|
|
/// <summary>
|
|
/// The file contains a language driver.
|
|
/// </summary>
|
|
VFT2_DRV_LANGUAGE = 0x00000003,
|
|
|
|
/// <summary>
|
|
/// The file contains a display driver.
|
|
/// </summary>
|
|
VFT2_DRV_DISPLAY = 0x00000004,
|
|
|
|
/// <summary>
|
|
/// The file contains a mouse driver.
|
|
/// </summary>
|
|
VFT2_DRV_MOUSE = 0x00000005,
|
|
|
|
/// <summary>
|
|
/// The file contains a network driver.
|
|
/// </summary>
|
|
VFT2_DRV_NETWORK = 0x00000006,
|
|
|
|
/// <summary>
|
|
/// The file contains a system driver.
|
|
/// </summary>
|
|
VFT2_DRV_SYSTEM = 0x00000007,
|
|
|
|
/// <summary>
|
|
/// The file contains an installable driver.
|
|
/// </summary>
|
|
VFT2_DRV_INSTALLABLE = 0x00000008,
|
|
|
|
/// <summary>
|
|
/// The file contains a sound driver.
|
|
/// </summary>
|
|
VFT2_DRV_SOUND = 0x00000009,
|
|
|
|
/// <summary>
|
|
/// The file contains a communications driver.
|
|
/// </summary>
|
|
VFT2_DRV_COMM = 0x0000000A,
|
|
|
|
/// <summary>
|
|
/// The file contains a versioned printer driver.
|
|
/// </summary>
|
|
VFT2_DRV_VERSIONED_PRINTER = 0x0000000C,
|
|
|
|
#endregion
|
|
|
|
#region VFT_FONT
|
|
|
|
/// <summary>
|
|
/// The file contains a raster font.
|
|
/// </summary>
|
|
VFT2_FONT_RASTER = 0x00000001,
|
|
|
|
/// <summary>
|
|
/// The file contains a vector font.
|
|
/// </summary>
|
|
VFT2_FONT_VECTOR = 0x00000002,
|
|
|
|
/// <summary>
|
|
/// The file contains a TrueType font.
|
|
/// </summary>
|
|
VFT2_FONT_TRUETYPE = 0x00000003,
|
|
|
|
#endregion
|
|
}
|
|
|
|
public enum FixedFileInfoFileType : uint
|
|
{
|
|
/// <summary>
|
|
/// The file type is unknown to the system.
|
|
/// </summary>
|
|
VFT_UNKNOWN = 0x00000000,
|
|
|
|
/// <summary>
|
|
/// The file contains an application.
|
|
/// </summary>
|
|
VFT_APP = 0x00000001,
|
|
|
|
/// <summary>
|
|
/// The file contains a DLL.
|
|
/// </summary>
|
|
VFT_DLL = 0x00000002,
|
|
|
|
/// <summary>
|
|
/// The file contains a device driver. If FileType is VFT_DRV, FileSubtype
|
|
/// contains a more specific description of the driver.
|
|
/// </summary>
|
|
VFT_DRV = 0x00000003,
|
|
|
|
/// <summary>
|
|
/// The file contains a font. If FileType is VFT_FONT, FileSubtype contains
|
|
/// a more specific description of the font file.
|
|
/// </summary>
|
|
VFT_FONT = 0x00000004,
|
|
|
|
/// <summary>
|
|
/// The file contains a virtual device.
|
|
/// </summary>
|
|
VFT_VXD = 0x00000005,
|
|
|
|
/// <summary>
|
|
/// The file contains a static-link library.
|
|
/// </summary>
|
|
VFT_STATIC_LIB = 0x00000007,
|
|
}
|
|
|
|
[Flags]
|
|
public enum FixedFileInfoFlags : uint
|
|
{
|
|
/// <summary>
|
|
/// The file contains debugging information or is compiled with debugging
|
|
/// features enabled.
|
|
/// </summary>
|
|
VS_FF_DEBUG = 0x00000001,
|
|
|
|
/// <summary>
|
|
/// The file is a development version, not a commercially released product.
|
|
/// </summary>
|
|
VS_FF_PRERELEASE = 0x00000002,
|
|
|
|
/// <summary>
|
|
/// The file has been modified and is not identical to the original shipping
|
|
/// file of the same version number.
|
|
/// </summary>
|
|
VS_FF_PATCHED = 0x00000004,
|
|
|
|
/// <summary>
|
|
/// The file was not built using standard release procedures. If this flag is
|
|
/// set, the StringFileInfo structure should contain a PrivateBuild entry.
|
|
/// </summary>
|
|
VS_FF_PRIVATEBUILD = 0x00000008,
|
|
|
|
/// <summary>
|
|
/// The file's version structure was created dynamically; therefore, some
|
|
/// of the members in this structure may be empty or incorrect. This flag
|
|
/// should never be set in a file's VS_VERSIONINFO data.
|
|
/// </summary>
|
|
VS_FF_INFOINFERRED = 0x00000010,
|
|
|
|
/// <summary>
|
|
/// The file was built by the original company using standard release
|
|
/// procedures but is a variation of the normal file of the same version number.
|
|
/// If this flag is set, the StringFileInfo structure should contain a SpecialBuild
|
|
/// entry.
|
|
/// </summary>
|
|
VS_FF_SPECIALBUILD = 0x00000020,
|
|
}
|
|
|
|
[Flags]
|
|
public enum FixedFileInfoOS : uint
|
|
{
|
|
/// <summary>
|
|
/// The operating system for which the file was designed is
|
|
/// unknown to the system.
|
|
/// </summary>
|
|
VOS_UNKNOWN = 0x00000000,
|
|
|
|
/// <summary>
|
|
/// The file was designed for 16-bit Windows.
|
|
/// </summary>
|
|
VOS__WINDOWS16 = 0x00000001,
|
|
|
|
/// <summary>
|
|
/// The file was designed for 16-bit Presentation Manager.
|
|
/// </summary>
|
|
VOS__PM16 = 0x00000002,
|
|
|
|
/// <summary>
|
|
/// The file was designed for 32-bit Presentation Manager.
|
|
/// </summary>
|
|
VOS__PM32 = 0x00000003,
|
|
|
|
/// <summary>
|
|
/// The file was designed for 32-bit Windows.
|
|
/// </summary>
|
|
VOS__WINDOWS32 = 0x00000004,
|
|
|
|
/// <summary>
|
|
/// The file was designed for MS-DOS.
|
|
/// </summary>
|
|
VOS_DOS = 0x00010000,
|
|
|
|
/// <summary>
|
|
/// The file was designed for 16-bit OS/2.
|
|
/// </summary>
|
|
VOS_OS216 = 0x00020000,
|
|
|
|
/// <summary>
|
|
/// The file was designed for 32-bit OS/2.
|
|
/// </summary>
|
|
VOS_OS232 = 0x00030000,
|
|
|
|
/// <summary>
|
|
/// The file was designed for Windows NT.
|
|
/// </summary>
|
|
VOS_NT = 0x00040000,
|
|
}
|
|
|
|
[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 VersionResourceType : ushort
|
|
{
|
|
BinaryData = 0,
|
|
TextData = 1,
|
|
}
|
|
|
|
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,
|
|
}
|
|
}
|