ntimage.h 77 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862
  1. //
  2. // Copyright (c) Microsoft. All rights reserved.
  3. // Licensed under the MIT license. See LICENSE file in the project root for full license information.
  4. //
  5. //
  6. //
  7. // ===========================================================================
  8. // File: ntimage.h
  9. //
  10. // ===========================================================================
  11. //
  12. //Abstract:
  13. //
  14. // This is the include file that describes all image structures.
  15. //
  16. //Author:
  17. //
  18. //
  19. //
  20. //Revision History:
  21. //
  22. #ifndef _NTIMAGE_
  23. #define _NTIMAGE_
  24. #if _MSC_VER > 1000
  25. #pragma once
  26. #endif
  27. //
  28. // Define the linker version number.
  29. #define IMAGE_MAJOR_LINKER_VERSION 2
  30. // begin_winnt
  31. //
  32. // Image Format
  33. //
  34. #ifndef _MAC
  35. #include "pshpack4.h" // 4 byte packing is the default
  36. #define IMAGE_DOS_SIGNATURE 0x5A4D // MZ
  37. #define IMAGE_OS2_SIGNATURE 0x454E // NE
  38. #define IMAGE_OS2_SIGNATURE_LE 0x454C // LE
  39. #define IMAGE_VXD_SIGNATURE 0x454C // LE
  40. #define IMAGE_NT_SIGNATURE 0x00004550 // PE00
  41. #include "pshpack2.h" // 16 bit headers are 2 byte packed
  42. #else
  43. #include "pshpack1.h"
  44. #define IMAGE_DOS_SIGNATURE 0x4D5A // MZ
  45. #define IMAGE_OS2_SIGNATURE 0x4E45 // NE
  46. #define IMAGE_OS2_SIGNATURE_LE 0x4C45 // LE
  47. #define IMAGE_NT_SIGNATURE 0x50450000 // PE00
  48. #endif
  49. typedef struct _IMAGE_DOS_HEADER { // DOS .EXE header
  50. USHORT e_magic; // Magic number
  51. USHORT e_cblp; // Bytes on last page of file
  52. USHORT e_cp; // Pages in file
  53. USHORT e_crlc; // Relocations
  54. USHORT e_cparhdr; // Size of header in paragraphs
  55. USHORT e_minalloc; // Minimum extra paragraphs needed
  56. USHORT e_maxalloc; // Maximum extra paragraphs needed
  57. USHORT e_ss; // Initial (relative) SS value
  58. USHORT e_sp; // Initial SP value
  59. USHORT e_csum; // Checksum
  60. USHORT e_ip; // Initial IP value
  61. USHORT e_cs; // Initial (relative) CS value
  62. USHORT e_lfarlc; // File address of relocation table
  63. USHORT e_ovno; // Overlay number
  64. USHORT e_res[4]; // Reserved words
  65. USHORT e_oemid; // OEM identifier (for e_oeminfo)
  66. USHORT e_oeminfo; // OEM information; e_oemid specific
  67. USHORT e_res2[10]; // Reserved words
  68. LONG e_lfanew; // File address of new exe header
  69. } IMAGE_DOS_HEADER, *PIMAGE_DOS_HEADER;
  70. typedef struct _IMAGE_OS2_HEADER { // OS/2 .EXE header
  71. USHORT ne_magic; // Magic number
  72. CHAR ne_ver; // Version number
  73. CHAR ne_rev; // Revision number
  74. USHORT ne_enttab; // Offset of Entry Table
  75. USHORT ne_cbenttab; // Number of bytes in Entry Table
  76. LONG ne_crc; // Checksum of whole file
  77. USHORT ne_flags; // Flag word
  78. USHORT ne_autodata; // Automatic data segment number
  79. USHORT ne_heap; // Initial heap allocation
  80. USHORT ne_stack; // Initial stack allocation
  81. LONG ne_csip; // Initial CS:IP setting
  82. LONG ne_sssp; // Initial SS:SP setting
  83. USHORT ne_cseg; // Count of file segments
  84. USHORT ne_cmod; // Entries in Module Reference Table
  85. USHORT ne_cbnrestab; // Size of non-resident name table
  86. USHORT ne_segtab; // Offset of Segment Table
  87. USHORT ne_rsrctab; // Offset of Resource Table
  88. USHORT ne_restab; // Offset of resident name table
  89. USHORT ne_modtab; // Offset of Module Reference Table
  90. USHORT ne_imptab; // Offset of Imported Names Table
  91. LONG ne_nrestab; // Offset of Non-resident Names Table
  92. USHORT ne_cmovent; // Count of movable entries
  93. USHORT ne_align; // Segment alignment shift count
  94. USHORT ne_cres; // Count of resource segments
  95. UCHAR ne_exetyp; // Target Operating system
  96. UCHAR ne_flagsothers; // Other .EXE flags
  97. USHORT ne_pretthunks; // offset to return thunks
  98. USHORT ne_psegrefbytes; // offset to segment ref. bytes
  99. USHORT ne_swaparea; // Minimum code swap area size
  100. USHORT ne_expver; // Expected Windows version number
  101. } IMAGE_OS2_HEADER, *PIMAGE_OS2_HEADER;
  102. typedef struct _IMAGE_VXD_HEADER { // Windows VXD header
  103. USHORT e32_magic; // Magic number
  104. UCHAR e32_border; // The byte ordering for the VXD
  105. UCHAR e32_worder; // The word ordering for the VXD
  106. ULONG e32_level; // The EXE format level for now = 0
  107. USHORT e32_cpu; // The CPU type
  108. USHORT e32_os; // The OS type
  109. ULONG e32_ver; // Module version
  110. ULONG e32_mflags; // Module flags
  111. ULONG e32_mpages; // Module # pages
  112. ULONG e32_startobj; // Object # for instruction pointer
  113. ULONG e32_eip; // Extended instruction pointer
  114. ULONG e32_stackobj; // Object # for stack pointer
  115. ULONG e32_esp; // Extended stack pointer
  116. ULONG e32_pagesize; // VXD page size
  117. ULONG e32_lastpagesize; // Last page size in VXD
  118. ULONG e32_fixupsize; // Fixup section size
  119. ULONG e32_fixupsum; // Fixup section checksum
  120. ULONG e32_ldrsize; // Loader section size
  121. ULONG e32_ldrsum; // Loader section checksum
  122. ULONG e32_objtab; // Object table offset
  123. ULONG e32_objcnt; // Number of objects in module
  124. ULONG e32_objmap; // Object page map offset
  125. ULONG e32_itermap; // Object iterated data map offset
  126. ULONG e32_rsrctab; // Offset of Resource Table
  127. ULONG e32_rsrccnt; // Number of resource entries
  128. ULONG e32_restab; // Offset of resident name table
  129. ULONG e32_enttab; // Offset of Entry Table
  130. ULONG e32_dirtab; // Offset of Module Directive Table
  131. ULONG e32_dircnt; // Number of module directives
  132. ULONG e32_fpagetab; // Offset of Fixup Page Table
  133. ULONG e32_frectab; // Offset of Fixup Record Table
  134. ULONG e32_impmod; // Offset of Import Module Name Table
  135. ULONG e32_impmodcnt; // Number of entries in Import Module Name Table
  136. ULONG e32_impproc; // Offset of Import Procedure Name Table
  137. ULONG e32_pagesum; // Offset of Per-Page Checksum Table
  138. ULONG e32_datapage; // Offset of Enumerated Data Pages
  139. ULONG e32_preload; // Number of preload pages
  140. ULONG e32_nrestab; // Offset of Non-resident Names Table
  141. ULONG e32_cbnrestab; // Size of Non-resident Name Table
  142. ULONG e32_nressum; // Non-resident Name Table Checksum
  143. ULONG e32_autodata; // Object # for automatic data object
  144. ULONG e32_debuginfo; // Offset of the debugging information
  145. ULONG e32_debuglen; // The length of the debugging info. in bytes
  146. ULONG e32_instpreload; // Number of instance pages in preload section of VXD file
  147. ULONG e32_instdemand; // Number of instance pages in demand load section of VXD file
  148. ULONG e32_heapsize; // Size of heap - for 16-bit apps
  149. UCHAR e32_res3[12]; // Reserved words
  150. ULONG e32_winresoff;
  151. ULONG e32_winreslen;
  152. USHORT e32_devid; // Device ID for VxD
  153. USHORT e32_ddkver; // DDK version for VxD
  154. } IMAGE_VXD_HEADER, *PIMAGE_VXD_HEADER;
  155. #ifndef _MAC
  156. #include "poppack.h" // Back to 4 byte packing
  157. #endif
  158. //
  159. // File header format.
  160. //
  161. typedef struct _IMAGE_FILE_HEADER {
  162. USHORT Machine;
  163. USHORT NumberOfSections;
  164. ULONG TimeDateStamp;
  165. ULONG PointerToSymbolTable;
  166. ULONG NumberOfSymbols;
  167. USHORT SizeOfOptionalHeader;
  168. USHORT Characteristics;
  169. } IMAGE_FILE_HEADER, *PIMAGE_FILE_HEADER;
  170. #define IMAGE_SIZEOF_FILE_HEADER 20
  171. #define IMAGE_FILE_RELOCS_STRIPPED 0x0001 // Relocation info stripped from file.
  172. #define IMAGE_FILE_EXECUTABLE_IMAGE 0x0002 // File is executable (i.e. no unresolved externel references).
  173. #define IMAGE_FILE_LINE_NUMS_STRIPPED 0x0004 // Line nunbers stripped from file.
  174. #define IMAGE_FILE_LOCAL_SYMS_STRIPPED 0x0008 // Local symbols stripped from file.
  175. #define IMAGE_FILE_AGGRESIVE_WS_TRIM 0x0010 // Agressively trim working set
  176. #define IMAGE_FILE_LARGE_ADDRESS_AWARE 0x0020 // App can handle >2gb addresses
  177. #define IMAGE_FILE_BYTES_REVERSED_LO 0x0080 // Bytes of machine word are reversed.
  178. #define IMAGE_FILE_32BIT_MACHINE 0x0100 // 32 bit word machine.
  179. #define IMAGE_FILE_DEBUG_STRIPPED 0x0200 // Debugging info stripped from file in .DBG file
  180. #define IMAGE_FILE_REMOVABLE_RUN_FROM_SWAP 0x0400 // If Image is on removable media, copy and run from the swap file.
  181. #define IMAGE_FILE_NET_RUN_FROM_SWAP 0x0800 // If Image is on Net, copy and run from the swap file.
  182. #define IMAGE_FILE_SYSTEM 0x1000 // System File.
  183. #define IMAGE_FILE_DLL 0x2000 // File is a DLL.
  184. #define IMAGE_FILE_UP_SYSTEM_ONLY 0x4000 // File should only be run on a UP machine
  185. #define IMAGE_FILE_BYTES_REVERSED_HI 0x8000 // Bytes of machine word are reversed.
  186. #define IMAGE_FILE_MACHINE_UNKNOWN 0
  187. #define IMAGE_FILE_MACHINE_I386 0x014c // Intel 386.
  188. #define IMAGE_FILE_MACHINE_R3000 0x0162 // MIPS little-endian, 0x160 big-endian
  189. #define IMAGE_FILE_MACHINE_R4000 0x0166 // MIPS little-endian
  190. #define IMAGE_FILE_MACHINE_R10000 0x0168 // MIPS little-endian
  191. #define IMAGE_FILE_MACHINE_WCEMIPSV2 0x0169 // MIPS little-endian WCE v2
  192. #define IMAGE_FILE_MACHINE_ALPHA 0x0184 // Alpha_AXP
  193. #define IMAGE_FILE_MACHINE_SH3 0x01a2 // SH3 little-endian
  194. #define IMAGE_FILE_MACHINE_SH3DSP 0x01a3
  195. #define IMAGE_FILE_MACHINE_SH3E 0x01a4 // SH3E little-endian
  196. #define IMAGE_FILE_MACHINE_SH4 0x01a6 // SH4 little-endian
  197. #define IMAGE_FILE_MACHINE_SH5 0x01a8 // SH5
  198. #define IMAGE_FILE_MACHINE_ARM 0x01c0 // ARM Little-Endian
  199. #define IMAGE_FILE_MACHINE_THUMB 0x01c2
  200. #define IMAGE_FILE_MACHINE_ARMNT 0x01c4 // ARM Thumb-2 Little-Endian
  201. #define IMAGE_FILE_MACHINE_AM33 0x01d3
  202. #define IMAGE_FILE_MACHINE_POWERPC 0x01F0 // IBM PowerPC Little-Endian
  203. #define IMAGE_FILE_MACHINE_POWERPCFP 0x01f1
  204. #define IMAGE_FILE_MACHINE_IA64 0x0200 // Intel 64
  205. #define IMAGE_FILE_MACHINE_MIPS16 0x0266 // MIPS
  206. #define IMAGE_FILE_MACHINE_ALPHA64 0x0284 // ALPHA64
  207. #define IMAGE_FILE_MACHINE_MIPSFPU 0x0366 // MIPS
  208. #define IMAGE_FILE_MACHINE_MIPSFPU16 0x0466 // MIPS
  209. #define IMAGE_FILE_MACHINE_AXP64 IMAGE_FILE_MACHINE_ALPHA64
  210. #define IMAGE_FILE_MACHINE_TRICORE 0x0520 // Infineon
  211. #define IMAGE_FILE_MACHINE_CEF 0x0CEF
  212. #define IMAGE_FILE_MACHINE_EBC 0x0EBC // EFI Byte Code
  213. #define IMAGE_FILE_MACHINE_AMD64 0x8664 // AMD64 (K8)
  214. #define IMAGE_FILE_MACHINE_M32R 0x9041 // M32R little-endian
  215. #define IMAGE_FILE_MACHINE_CEE 0xC0EE
  216. //
  217. // Directory format.
  218. //
  219. typedef struct _IMAGE_DATA_DIRECTORY {
  220. ULONG VirtualAddress;
  221. ULONG Size;
  222. } IMAGE_DATA_DIRECTORY, *PIMAGE_DATA_DIRECTORY;
  223. #define IMAGE_NUMBEROF_DIRECTORY_ENTRIES 16
  224. //
  225. // Optional header format.
  226. //
  227. typedef struct _IMAGE_OPTIONAL_HEADER {
  228. //
  229. // Standard fields.
  230. //
  231. USHORT Magic;
  232. UCHAR MajorLinkerVersion;
  233. UCHAR MinorLinkerVersion;
  234. ULONG SizeOfCode;
  235. ULONG SizeOfInitializedData;
  236. ULONG SizeOfUninitializedData;
  237. ULONG AddressOfEntryPoint;
  238. ULONG BaseOfCode;
  239. ULONG BaseOfData;
  240. //
  241. // NT additional fields.
  242. //
  243. ULONG ImageBase;
  244. ULONG SectionAlignment;
  245. ULONG FileAlignment;
  246. USHORT MajorOperatingSystemVersion;
  247. USHORT MinorOperatingSystemVersion;
  248. USHORT MajorImageVersion;
  249. USHORT MinorImageVersion;
  250. USHORT MajorSubsystemVersion;
  251. USHORT MinorSubsystemVersion;
  252. ULONG Win32VersionValue;
  253. ULONG SizeOfImage;
  254. ULONG SizeOfHeaders;
  255. ULONG CheckSum;
  256. USHORT Subsystem;
  257. USHORT DllCharacteristics;
  258. ULONG SizeOfStackReserve;
  259. ULONG SizeOfStackCommit;
  260. ULONG SizeOfHeapReserve;
  261. ULONG SizeOfHeapCommit;
  262. ULONG LoaderFlags;
  263. ULONG NumberOfRvaAndSizes;
  264. IMAGE_DATA_DIRECTORY DataDirectory[IMAGE_NUMBEROF_DIRECTORY_ENTRIES];
  265. } IMAGE_OPTIONAL_HEADER32, *PIMAGE_OPTIONAL_HEADER32;
  266. typedef struct _IMAGE_ROM_OPTIONAL_HEADER {
  267. USHORT Magic;
  268. UCHAR MajorLinkerVersion;
  269. UCHAR MinorLinkerVersion;
  270. ULONG SizeOfCode;
  271. ULONG SizeOfInitializedData;
  272. ULONG SizeOfUninitializedData;
  273. ULONG AddressOfEntryPoint;
  274. ULONG BaseOfCode;
  275. ULONG BaseOfData;
  276. ULONG BaseOfBss;
  277. ULONG GprMask;
  278. ULONG CprMask[4];
  279. ULONG GpValue;
  280. } IMAGE_ROM_OPTIONAL_HEADER, *PIMAGE_ROM_OPTIONAL_HEADER;
  281. typedef struct _IMAGE_OPTIONAL_HEADER64 {
  282. USHORT Magic;
  283. UCHAR MajorLinkerVersion;
  284. UCHAR MinorLinkerVersion;
  285. ULONG SizeOfCode;
  286. ULONG SizeOfInitializedData;
  287. ULONG SizeOfUninitializedData;
  288. ULONG AddressOfEntryPoint;
  289. ULONG BaseOfCode;
  290. ULONGLONG ImageBase;
  291. ULONG SectionAlignment;
  292. ULONG FileAlignment;
  293. USHORT MajorOperatingSystemVersion;
  294. USHORT MinorOperatingSystemVersion;
  295. USHORT MajorImageVersion;
  296. USHORT MinorImageVersion;
  297. USHORT MajorSubsystemVersion;
  298. USHORT MinorSubsystemVersion;
  299. ULONG Win32VersionValue;
  300. ULONG SizeOfImage;
  301. ULONG SizeOfHeaders;
  302. ULONG CheckSum;
  303. USHORT Subsystem;
  304. USHORT DllCharacteristics;
  305. ULONGLONG SizeOfStackReserve;
  306. ULONGLONG SizeOfStackCommit;
  307. ULONGLONG SizeOfHeapReserve;
  308. ULONGLONG SizeOfHeapCommit;
  309. ULONG LoaderFlags;
  310. ULONG NumberOfRvaAndSizes;
  311. IMAGE_DATA_DIRECTORY DataDirectory[IMAGE_NUMBEROF_DIRECTORY_ENTRIES];
  312. } IMAGE_OPTIONAL_HEADER64, *PIMAGE_OPTIONAL_HEADER64;
  313. #define IMAGE_SIZEOF_ROM_OPTIONAL_HEADER 56
  314. #define IMAGE_SIZEOF_STD_OPTIONAL_HEADER 28
  315. #define IMAGE_SIZEOF_NT_OPTIONAL32_HEADER 224
  316. #define IMAGE_SIZEOF_NT_OPTIONAL64_HEADER 240
  317. #define IMAGE_NT_OPTIONAL_HDR32_MAGIC 0x10b
  318. #define IMAGE_NT_OPTIONAL_HDR64_MAGIC 0x20b
  319. #define IMAGE_ROM_OPTIONAL_HDR_MAGIC 0x107
  320. #ifdef _WIN64
  321. typedef IMAGE_OPTIONAL_HEADER64 IMAGE_OPTIONAL_HEADER;
  322. typedef PIMAGE_OPTIONAL_HEADER64 PIMAGE_OPTIONAL_HEADER;
  323. #define IMAGE_SIZEOF_NT_OPTIONAL_HEADER IMAGE_SIZEOF_NT_OPTIONAL64_HEADER
  324. #define IMAGE_NT_OPTIONAL_HDR_MAGIC IMAGE_NT_OPTIONAL_HDR64_MAGIC
  325. #else
  326. typedef IMAGE_OPTIONAL_HEADER32 IMAGE_OPTIONAL_HEADER;
  327. typedef PIMAGE_OPTIONAL_HEADER32 PIMAGE_OPTIONAL_HEADER;
  328. #define IMAGE_SIZEOF_NT_OPTIONAL_HEADER IMAGE_SIZEOF_NT_OPTIONAL32_HEADER
  329. #define IMAGE_NT_OPTIONAL_HDR_MAGIC IMAGE_NT_OPTIONAL_HDR32_MAGIC
  330. #endif
  331. typedef struct _IMAGE_NT_HEADERS64 {
  332. ULONG Signature;
  333. IMAGE_FILE_HEADER FileHeader;
  334. IMAGE_OPTIONAL_HEADER64 OptionalHeader;
  335. } IMAGE_NT_HEADERS64, *PIMAGE_NT_HEADERS64;
  336. typedef struct _IMAGE_NT_HEADERS {
  337. ULONG Signature;
  338. IMAGE_FILE_HEADER FileHeader;
  339. IMAGE_OPTIONAL_HEADER32 OptionalHeader;
  340. } IMAGE_NT_HEADERS32, *PIMAGE_NT_HEADERS32;
  341. typedef struct _IMAGE_ROM_HEADERS {
  342. IMAGE_FILE_HEADER FileHeader;
  343. IMAGE_ROM_OPTIONAL_HEADER OptionalHeader;
  344. } IMAGE_ROM_HEADERS, *PIMAGE_ROM_HEADERS;
  345. #ifdef _WIN64
  346. typedef IMAGE_NT_HEADERS64 IMAGE_NT_HEADERS;
  347. typedef PIMAGE_NT_HEADERS64 PIMAGE_NT_HEADERS;
  348. #else
  349. typedef IMAGE_NT_HEADERS32 IMAGE_NT_HEADERS;
  350. typedef PIMAGE_NT_HEADERS32 PIMAGE_NT_HEADERS;
  351. #endif
  352. // IMAGE_FIRST_SECTION doesn't need 32/64 versions since the file header is the same either way.
  353. #define IMAGE_FIRST_SECTION( ntheader ) ((PIMAGE_SECTION_HEADER) \
  354. ((ULONG_PTR)ntheader + \
  355. FIELD_OFFSET( IMAGE_NT_HEADERS, OptionalHeader ) + \
  356. VAL16(((PIMAGE_NT_HEADERS)(ntheader))->FileHeader.SizeOfOptionalHeader) \
  357. ))
  358. // Subsystem Values
  359. #define IMAGE_SUBSYSTEM_UNKNOWN 0 // Unknown subsystem.
  360. #define IMAGE_SUBSYSTEM_NATIVE 1 // Image doesn't require a subsystem.
  361. #define IMAGE_SUBSYSTEM_WINDOWS_GUI 2 // Image runs in the Windows GUI subsystem.
  362. #define IMAGE_SUBSYSTEM_WINDOWS_CUI 3 // Image runs in the Windows character subsystem.
  363. // end_winnt
  364. // reserved 4 // Old Windows CE subsystem.
  365. // begin_winnt
  366. #define IMAGE_SUBSYSTEM_OS2_CUI 5 // image runs in the OS/2 character subsystem.
  367. #define IMAGE_SUBSYSTEM_POSIX_CUI 7 // image runs in the Posix character subsystem.
  368. #define IMAGE_SUBSYSTEM_NATIVE_WINDOWS 8 // image is a native Win9x driver.
  369. #define IMAGE_SUBSYSTEM_WINDOWS_CE_GUI 9 // Image runs in the Windows CE subsystem.
  370. #define IMAGE_SUBSYSTEM_EFI_APPLICATION 10 //
  371. #define IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER 11 //
  372. #define IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER 12 //
  373. #define IMAGE_SUBSYSTEM_EFI_ROM 13
  374. #define IMAGE_SUBSYSTEM_XBOX 14
  375. // DllCharacteristics Entries
  376. // IMAGE_LIBRARY_PROCESS_INIT 0x0001 // Reserved.
  377. // IMAGE_LIBRARY_PROCESS_TERM 0x0002 // Reserved.
  378. // IMAGE_LIBRARY_THREAD_INIT 0x0004 // Reserved.
  379. // IMAGE_LIBRARY_THREAD_TERM 0x0008 // Reserved.
  380. #define IMAGE_DLLCHARACTERISTICS_HIGH_ENTROPY_VA 0x0020 // Image can handle a high entropy 64-bit virtual address space.
  381. #define IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE 0x0040 // DLL can move
  382. #define IMAGE_DLLCHARACTERISTICS_NX_COMPAT 0x0100 // Image ix NX compatible
  383. #define IMAGE_DLLCHARACTERISTICS_NO_SEH 0x0400 // Image does not use SEH. No SE handler may reside in this image
  384. #define IMAGE_DLLCHARACTERISTICS_NO_BIND 0x0800 // Do not bind this image.
  385. #define IMAGE_DLLCHARACTERISTICS_APPCONTAINER 0x1000 // Image should execute in an AppContainer
  386. #define IMAGE_DLLCHARACTERISTICS_WDM_DRIVER 0x2000 // Driver uses WDM model
  387. // 0x4000 // Reserved.
  388. #define IMAGE_DLLCHARACTERISTICS_TERMINAL_SERVER_AWARE 0x8000
  389. // end_winnt
  390. #define IMAGE_DLLCHARACTERISTICS_X86_THUNK 0x1000 // Image is a Wx86 Thunk DLL
  391. // Note: The Borland linker sets IMAGE_LIBRARY_xxx flags in DllCharacteristics
  392. // LoaderFlags Values
  393. #define IMAGE_LOADER_FLAGS_COMPLUS 0x00000001 // COM+ image
  394. #define IMAGE_LOADER_FLAGS_SYSTEM_GLOBAL 0x01000000 // Global subsections apply across TS sessions.
  395. // begin_winnt
  396. // Directory Entries
  397. #define IMAGE_DIRECTORY_ENTRY_EXPORT 0 // Export Directory
  398. #define IMAGE_DIRECTORY_ENTRY_IMPORT 1 // Import Directory
  399. #define IMAGE_DIRECTORY_ENTRY_RESOURCE 2 // Resource Directory
  400. #define IMAGE_DIRECTORY_ENTRY_EXCEPTION 3 // Exception Directory
  401. #define IMAGE_DIRECTORY_ENTRY_SECURITY 4 // Security Directory
  402. #define IMAGE_DIRECTORY_ENTRY_BASERELOC 5 // Base Relocation Table
  403. #define IMAGE_DIRECTORY_ENTRY_DEBUG 6 // Debug Directory
  404. // IMAGE_DIRECTORY_ENTRY_COPYRIGHT 7 // (X86 usage)
  405. #define IMAGE_DIRECTORY_ENTRY_ARCHITECTURE 7 // Architecture Specific Data
  406. #define IMAGE_DIRECTORY_ENTRY_GLOBALPTR 8 // RVA of GP
  407. #define IMAGE_DIRECTORY_ENTRY_TLS 9 // TLS Directory
  408. #define IMAGE_DIRECTORY_ENTRY_LOAD_CONFIG 10 // Load Configuration Directory
  409. #define IMAGE_DIRECTORY_ENTRY_BOUND_IMPORT 11 // Bound Import Directory in headers
  410. #define IMAGE_DIRECTORY_ENTRY_IAT 12 // Import Address Table
  411. #define IMAGE_DIRECTORY_ENTRY_DELAY_IMPORT 13 // Delay Load Import Descriptors
  412. #define IMAGE_DIRECTORY_ENTRY_COM_DESCRIPTOR 14 // COM Runtime descriptor
  413. #ifdef _MSC_VER
  414. //
  415. // Non-COFF Object file header
  416. //
  417. typedef struct ANON_OBJECT_HEADER {
  418. USHORT Sig1; // Must be IMAGE_FILE_MACHINE_UNKNOWN
  419. USHORT Sig2; // Must be 0xffff
  420. USHORT Version; // >= 1 (implies the CLSID field is present)
  421. USHORT Machine;
  422. ULONG TimeDateStamp;
  423. CLSID ClassID; // Used to invoke CoCreateInstance
  424. ULONG SizeOfData; // Size of data that follows the header
  425. } ANON_OBJECT_HEADER;
  426. #endif
  427. //
  428. // Section header format.
  429. //
  430. #define IMAGE_SIZEOF_SHORT_NAME 8
  431. typedef struct _IMAGE_SECTION_HEADER {
  432. UCHAR Name[IMAGE_SIZEOF_SHORT_NAME];
  433. union {
  434. ULONG PhysicalAddress;
  435. ULONG VirtualSize;
  436. } Misc;
  437. ULONG VirtualAddress;
  438. ULONG SizeOfRawData;
  439. ULONG PointerToRawData;
  440. ULONG PointerToRelocations;
  441. ULONG PointerToLinenumbers;
  442. USHORT NumberOfRelocations;
  443. USHORT NumberOfLinenumbers;
  444. ULONG Characteristics;
  445. } IMAGE_SECTION_HEADER, *PIMAGE_SECTION_HEADER;
  446. #define IMAGE_SIZEOF_SECTION_HEADER 40
  447. //
  448. // Section characteristics.
  449. //
  450. // IMAGE_SCN_TYPE_REG 0x00000000 // Reserved.
  451. // IMAGE_SCN_TYPE_DSECT 0x00000001 // Reserved.
  452. // IMAGE_SCN_TYPE_NOLOAD 0x00000002 // Reserved.
  453. // IMAGE_SCN_TYPE_GROUP 0x00000004 // Reserved.
  454. #define IMAGE_SCN_TYPE_NO_PAD 0x00000008 // Reserved.
  455. // IMAGE_SCN_TYPE_COPY 0x00000010 // Reserved.
  456. #define IMAGE_SCN_CNT_CODE 0x00000020 // Section contains code.
  457. #define IMAGE_SCN_CNT_INITIALIZED_DATA 0x00000040 // Section contains initialized data.
  458. #define IMAGE_SCN_CNT_UNINITIALIZED_DATA 0x00000080 // Section contains uninitialized data.
  459. #define IMAGE_SCN_LNK_OTHER 0x00000100 // Reserved.
  460. #define IMAGE_SCN_LNK_INFO 0x00000200 // Section contains comments or some other type of information.
  461. // IMAGE_SCN_TYPE_OVER 0x00000400 // Reserved.
  462. #define IMAGE_SCN_LNK_REMOVE 0x00000800 // Section contents will not become part of image.
  463. #define IMAGE_SCN_LNK_COMDAT 0x00001000 // Section contents comdat.
  464. // 0x00002000 // Reserved.
  465. // IMAGE_SCN_MEM_PROTECTED - Obsolete 0x00004000
  466. #define IMAGE_SCN_NO_DEFER_SPEC_EXC 0x00004000 // Reset speculative exceptions handling bits in the TLB entries for this section.
  467. #define IMAGE_SCN_GPREL 0x00008000 // Section content can be accessed relative to GP
  468. #define IMAGE_SCN_MEM_FARDATA 0x00008000
  469. // IMAGE_SCN_MEM_SYSHEAP - Obsolete 0x00010000
  470. #define IMAGE_SCN_MEM_PURGEABLE 0x00020000
  471. #define IMAGE_SCN_MEM_16BIT 0x00020000
  472. #define IMAGE_SCN_MEM_LOCKED 0x00040000
  473. #define IMAGE_SCN_MEM_PRELOAD 0x00080000
  474. #define IMAGE_SCN_ALIGN_1BYTES 0x00100000 //
  475. #define IMAGE_SCN_ALIGN_2BYTES 0x00200000 //
  476. #define IMAGE_SCN_ALIGN_4BYTES 0x00300000 //
  477. #define IMAGE_SCN_ALIGN_8BYTES 0x00400000 //
  478. #define IMAGE_SCN_ALIGN_16BYTES 0x00500000 // Default alignment if no others are specified.
  479. #define IMAGE_SCN_ALIGN_32BYTES 0x00600000 //
  480. #define IMAGE_SCN_ALIGN_64BYTES 0x00700000 //
  481. #define IMAGE_SCN_ALIGN_128BYTES 0x00800000 //
  482. #define IMAGE_SCN_ALIGN_256BYTES 0x00900000 //
  483. #define IMAGE_SCN_ALIGN_512BYTES 0x00A00000 //
  484. #define IMAGE_SCN_ALIGN_1024BYTES 0x00B00000 //
  485. #define IMAGE_SCN_ALIGN_2048BYTES 0x00C00000 //
  486. #define IMAGE_SCN_ALIGN_4096BYTES 0x00D00000 //
  487. #define IMAGE_SCN_ALIGN_8192BYTES 0x00E00000 //
  488. // Unused 0x00F00000
  489. #define IMAGE_SCN_ALIGN_MASK 0x00F00000
  490. #define IMAGE_SCN_LNK_NRELOC_OVFL 0x01000000 // Section contains extended relocations.
  491. #define IMAGE_SCN_MEM_DISCARDABLE 0x02000000 // Section can be discarded.
  492. #define IMAGE_SCN_MEM_NOT_CACHED 0x04000000 // Section is not cachable.
  493. #define IMAGE_SCN_MEM_NOT_PAGED 0x08000000 // Section is not pageable.
  494. #define IMAGE_SCN_MEM_SHARED 0x10000000 // Section is shareable.
  495. #define IMAGE_SCN_MEM_EXECUTE 0x20000000 // Section is executable.
  496. #define IMAGE_SCN_MEM_READ 0x40000000 // Section is readable.
  497. #define IMAGE_SCN_MEM_WRITE 0x80000000 // Section is writeable.
  498. //
  499. // TLS Chaacteristic Flags
  500. //
  501. #define IMAGE_SCN_SCALE_INDEX 0x00000001 // Tls index is scaled
  502. #ifndef _MAC
  503. #include "pshpack2.h" // Symbols, relocs, and linenumbers are 2 byte packed
  504. #endif
  505. //
  506. // Symbol format.
  507. //
  508. typedef struct _IMAGE_SYMBOL {
  509. union {
  510. UCHAR ShortName[8];
  511. struct {
  512. ULONG Short; // if 0, use LongName
  513. ULONG Long; // offset into string table
  514. } Name;
  515. ULONG LongName[2]; // PUCHAR[2]
  516. } N;
  517. ULONG Value;
  518. SHORT SectionNumber;
  519. USHORT Type;
  520. UCHAR StorageClass;
  521. UCHAR NumberOfAuxSymbols;
  522. } IMAGE_SYMBOL;
  523. typedef IMAGE_SYMBOL UNALIGNED *PIMAGE_SYMBOL;
  524. #define IMAGE_SIZEOF_SYMBOL 18
  525. //
  526. // Section values.
  527. //
  528. // Symbols have a section number of the section in which they are
  529. // defined. Otherwise, section numbers have the following meanings:
  530. //
  531. #define IMAGE_SYM_UNDEFINED (SHORT)0 // Symbol is undefined or is common.
  532. #define IMAGE_SYM_ABSOLUTE (SHORT)-1 // Symbol is an absolute value.
  533. #define IMAGE_SYM_DEBUG (SHORT)-2 // Symbol is a special debug item.
  534. #define IMAGE_SYM_SECTION_MAX 0xFEFF // Values 0xFF00-0xFFFF are special
  535. //
  536. // Type (fundamental) values.
  537. //
  538. #define IMAGE_SYM_TYPE_NULL 0x0000 // no type.
  539. #define IMAGE_SYM_TYPE_VOID 0x0001 //
  540. #define IMAGE_SYM_TYPE_CHAR 0x0002 // type character.
  541. #define IMAGE_SYM_TYPE_SHORT 0x0003 // type short integer.
  542. #define IMAGE_SYM_TYPE_INT 0x0004 //
  543. #define IMAGE_SYM_TYPE_LONG 0x0005 //
  544. #define IMAGE_SYM_TYPE_FLOAT 0x0006 //
  545. #define IMAGE_SYM_TYPE_DOUBLE 0x0007 //
  546. #define IMAGE_SYM_TYPE_STRUCT 0x0008 //
  547. #define IMAGE_SYM_TYPE_UNION 0x0009 //
  548. #define IMAGE_SYM_TYPE_ENUM 0x000A // enumeration.
  549. #define IMAGE_SYM_TYPE_MOE 0x000B // member of enumeration.
  550. #define IMAGE_SYM_TYPE_UCHAR 0x000C //
  551. #define IMAGE_SYM_TYPE_USHORT 0x000D //
  552. #define IMAGE_SYM_TYPE_UINT 0x000E //
  553. #define IMAGE_SYM_TYPE_ULONG 0x000F //
  554. #define IMAGE_SYM_TYPE_PCODE 0x8000 //
  555. //
  556. // Type (derived) values.
  557. //
  558. #define IMAGE_SYM_DTYPE_NULL 0 // no derived type.
  559. #define IMAGE_SYM_DTYPE_POINTER 1 // pointer.
  560. #define IMAGE_SYM_DTYPE_FUNCTION 2 // function.
  561. #define IMAGE_SYM_DTYPE_ARRAY 3 // array.
  562. //
  563. // Storage classes.
  564. //
  565. #define IMAGE_SYM_CLASS_END_OF_FUNCTION (UCHAR)-1
  566. #define IMAGE_SYM_CLASS_NULL 0x0000
  567. #define IMAGE_SYM_CLASS_AUTOMATIC 0x0001
  568. #define IMAGE_SYM_CLASS_EXTERNAL 0x0002
  569. #define IMAGE_SYM_CLASS_STATIC 0x0003
  570. #define IMAGE_SYM_CLASS_REGISTER 0x0004
  571. #define IMAGE_SYM_CLASS_EXTERNAL_DEF 0x0005
  572. #define IMAGE_SYM_CLASS_LABEL 0x0006
  573. #define IMAGE_SYM_CLASS_UNDEFINED_LABEL 0x0007
  574. #define IMAGE_SYM_CLASS_MEMBER_OF_STRUCT 0x0008
  575. #define IMAGE_SYM_CLASS_ARGUMENT 0x0009
  576. #define IMAGE_SYM_CLASS_STRUCT_TAG 0x000A
  577. #define IMAGE_SYM_CLASS_MEMBER_OF_UNION 0x000B
  578. #define IMAGE_SYM_CLASS_UNION_TAG 0x000C
  579. #define IMAGE_SYM_CLASS_TYPE_DEFINITION 0x000D
  580. #define IMAGE_SYM_CLASS_UNDEFINED_STATIC 0x000E
  581. #define IMAGE_SYM_CLASS_ENUM_TAG 0x000F
  582. #define IMAGE_SYM_CLASS_MEMBER_OF_ENUM 0x0010
  583. #define IMAGE_SYM_CLASS_REGISTER_PARAM 0x0011
  584. #define IMAGE_SYM_CLASS_BIT_FIELD 0x0012
  585. #define IMAGE_SYM_CLASS_FAR_EXTERNAL 0x0044 //
  586. #define IMAGE_SYM_CLASS_BLOCK 0x0064
  587. #define IMAGE_SYM_CLASS_FUNCTION 0x0065
  588. #define IMAGE_SYM_CLASS_END_OF_STRUCT 0x0066
  589. #define IMAGE_SYM_CLASS_FILE 0x0067
  590. // new
  591. #define IMAGE_SYM_CLASS_SECTION 0x0068
  592. #define IMAGE_SYM_CLASS_WEAK_EXTERNAL 0x0069
  593. #define IMAGE_SYM_CLASS_CLR_TOKEN 0x006B
  594. // type packing constants
  595. #define N_BTMASK 0x000F
  596. #define N_TMASK 0x0030
  597. #define N_TMASK1 0x00C0
  598. #define N_TMASK2 0x00F0
  599. #define N_BTSHFT 4
  600. #define N_TSHIFT 2
  601. // MACROS
  602. // Basic Type of x
  603. #define BTYPE(x) ((x) & N_BTMASK)
  604. // Is x a pointer?
  605. #ifndef ISPTR
  606. #define ISPTR(x) (((x) & N_TMASK) == (IMAGE_SYM_DTYPE_POINTER << N_BTSHFT))
  607. #endif
  608. // Is x a function?
  609. #ifndef ISFCN
  610. #define ISFCN(x) (((x) & N_TMASK) == (IMAGE_SYM_DTYPE_FUNCTION << N_BTSHFT))
  611. #endif
  612. // Is x an array?
  613. #ifndef ISARY
  614. #define ISARY(x) (((x) & N_TMASK) == (IMAGE_SYM_DTYPE_ARRAY << N_BTSHFT))
  615. #endif
  616. // Is x a structure, union, or enumeration TAG?
  617. #ifndef ISTAG
  618. #define ISTAG(x) ((x)==IMAGE_SYM_CLASS_STRUCT_TAG || (x)==IMAGE_SYM_CLASS_UNION_TAG || (x)==IMAGE_SYM_CLASS_ENUM_TAG)
  619. #endif
  620. #ifndef INCREF
  621. #define INCREF(x) ((((x)&~N_BTMASK)<<N_TSHIFT)|(IMAGE_SYM_DTYPE_POINTER<<N_BTSHFT)|((x)&N_BTMASK))
  622. #endif
  623. #ifndef DECREF
  624. #define DECREF(x) ((((x)>>N_TSHIFT)&~N_BTMASK)|((x)&N_BTMASK))
  625. #endif
  626. //
  627. // Auxiliary entry format.
  628. //
  629. typedef union _IMAGE_AUX_SYMBOL {
  630. struct {
  631. ULONG TagIndex; // struct, union, or enum tag index
  632. union {
  633. struct {
  634. USHORT Linenumber; // declaration line number
  635. USHORT Size; // size of struct, union, or enum
  636. } LnSz;
  637. ULONG TotalSize;
  638. } Misc;
  639. union {
  640. struct { // if ISFCN, tag, or .bb
  641. ULONG PointerToLinenumber;
  642. ULONG PointerToNextFunction;
  643. } Function;
  644. struct { // if ISARY, up to 4 dimen.
  645. USHORT Dimension[4];
  646. } Array;
  647. } FcnAry;
  648. USHORT TvIndex; // tv index
  649. } Sym;
  650. struct {
  651. UCHAR Name[IMAGE_SIZEOF_SYMBOL];
  652. } File;
  653. struct {
  654. ULONG Length; // section length
  655. USHORT NumberOfRelocations; // number of relocation entries
  656. USHORT NumberOfLinenumbers; // number of line numbers
  657. ULONG CheckSum; // checksum for communal
  658. SHORT Number; // section number to associate with
  659. UCHAR Selection; // communal selection type
  660. } Section;
  661. } IMAGE_AUX_SYMBOL;
  662. typedef IMAGE_AUX_SYMBOL UNALIGNED *PIMAGE_AUX_SYMBOL;
  663. #define IMAGE_SIZEOF_AUX_SYMBOL 18
  664. typedef enum IMAGE_AUX_SYMBOL_TYPE {
  665. IMAGE_AUX_SYMBOL_TYPE_TOKEN_DEF = 1,
  666. } IMAGE_AUX_SYMBOL_TYPE;
  667. #include "pshpack2.h"
  668. typedef struct IMAGE_AUX_SYMBOL_TOKEN_DEF {
  669. UCHAR bAuxType; // IMAGE_AUX_SYMBOL_TYPE
  670. UCHAR bReserved; // Must be 0
  671. ULONG SymbolTableIndex;
  672. UCHAR rgbReserved[12]; // Must be 0
  673. } IMAGE_AUX_SYMBOL_TOKEN_DEF;
  674. typedef IMAGE_AUX_SYMBOL_TOKEN_DEF UNALIGNED *PIMAGE_AUX_SYMBOL_TOKEN_DEF;
  675. #include "poppack.h"
  676. //
  677. // Communal selection types.
  678. //
  679. #define IMAGE_COMDAT_SELECT_NODUPLICATES 1
  680. #define IMAGE_COMDAT_SELECT_ANY 2
  681. #define IMAGE_COMDAT_SELECT_SAME_SIZE 3
  682. #define IMAGE_COMDAT_SELECT_EXACT_MATCH 4
  683. #define IMAGE_COMDAT_SELECT_ASSOCIATIVE 5
  684. #define IMAGE_COMDAT_SELECT_LARGEST 6
  685. #define IMAGE_COMDAT_SELECT_NEWEST 7
  686. #define IMAGE_WEAK_EXTERN_SEARCH_NOLIBRARY 1
  687. #define IMAGE_WEAK_EXTERN_SEARCH_LIBRARY 2
  688. #define IMAGE_WEAK_EXTERN_SEARCH_ALIAS 3
  689. //
  690. // Relocation format.
  691. //
  692. typedef struct _IMAGE_RELOCATION {
  693. union {
  694. ULONG VirtualAddress;
  695. ULONG RelocCount; // Set to the real count when IMAGE_SCN_LNK_NRELOC_OVFL is set
  696. };
  697. ULONG SymbolTableIndex;
  698. USHORT Type;
  699. } IMAGE_RELOCATION;
  700. typedef IMAGE_RELOCATION UNALIGNED *PIMAGE_RELOCATION;
  701. #define IMAGE_SIZEOF_RELOCATION 10
  702. //
  703. // I386 relocation types.
  704. //
  705. #define IMAGE_REL_I386_ABSOLUTE 0x0000 // Reference is absolute, no relocation is necessary
  706. #define IMAGE_REL_I386_DIR16 0x0001 // Direct 16-bit reference to the symbols virtual address
  707. #define IMAGE_REL_I386_REL16 0x0002 // PC-relative 16-bit reference to the symbols virtual address
  708. #define IMAGE_REL_I386_DIR32 0x0006 // Direct 32-bit reference to the symbols virtual address
  709. #define IMAGE_REL_I386_DIR32NB 0x0007 // Direct 32-bit reference to the symbols virtual address, base not included
  710. #define IMAGE_REL_I386_SEG12 0x0009 // Direct 16-bit reference to the segment-selector bits of a 32-bit virtual address
  711. #define IMAGE_REL_I386_SECTION 0x000A
  712. #define IMAGE_REL_I386_SECREL 0x000B
  713. #define IMAGE_REL_I386_TOKEN 0x000C // clr token
  714. #define IMAGE_REL_I386_SECREL7 0x000D // 7 bit offset from base of section containing target
  715. #define IMAGE_REL_I386_REL32 0x0014 // PC-relative 32-bit reference to the symbols virtual address
  716. //
  717. // MIPS relocation types.
  718. //
  719. #define IMAGE_REL_MIPS_ABSOLUTE 0x0000 // Reference is absolute, no relocation is necessary
  720. #define IMAGE_REL_MIPS_REFHALF 0x0001
  721. #define IMAGE_REL_MIPS_REFWORD 0x0002
  722. #define IMAGE_REL_MIPS_JMPADDR 0x0003
  723. #define IMAGE_REL_MIPS_REFHI 0x0004
  724. #define IMAGE_REL_MIPS_REFLO 0x0005
  725. #define IMAGE_REL_MIPS_GPREL 0x0006
  726. #define IMAGE_REL_MIPS_LITERAL 0x0007
  727. #define IMAGE_REL_MIPS_SECTION 0x000A
  728. #define IMAGE_REL_MIPS_SECREL 0x000B
  729. #define IMAGE_REL_MIPS_SECRELLO 0x000C // Low 16-bit section relative referemce (used for >32k TLS)
  730. #define IMAGE_REL_MIPS_SECRELHI 0x000D // High 16-bit section relative reference (used for >32k TLS)
  731. #define IMAGE_REL_MIPS_TOKEN 0x000E // clr token
  732. #define IMAGE_REL_MIPS_JMPADDR16 0x0010
  733. #define IMAGE_REL_MIPS_REFWORDNB 0x0022
  734. #define IMAGE_REL_MIPS_PAIR 0x0025
  735. //
  736. // Alpha Relocation types.
  737. //
  738. #define IMAGE_REL_ALPHA_ABSOLUTE 0x0000
  739. #define IMAGE_REL_ALPHA_REFLONG 0x0001
  740. #define IMAGE_REL_ALPHA_REFQUAD 0x0002
  741. #define IMAGE_REL_ALPHA_GPREL32 0x0003
  742. #define IMAGE_REL_ALPHA_LITERAL 0x0004
  743. #define IMAGE_REL_ALPHA_LITUSE 0x0005
  744. #define IMAGE_REL_ALPHA_GPDISP 0x0006
  745. #define IMAGE_REL_ALPHA_BRADDR 0x0007
  746. #define IMAGE_REL_ALPHA_HINT 0x0008
  747. #define IMAGE_REL_ALPHA_INLINE_REFLONG 0x0009
  748. #define IMAGE_REL_ALPHA_REFHI 0x000A
  749. #define IMAGE_REL_ALPHA_REFLO 0x000B
  750. #define IMAGE_REL_ALPHA_PAIR 0x000C
  751. #define IMAGE_REL_ALPHA_MATCH 0x000D
  752. #define IMAGE_REL_ALPHA_SECTION 0x000E
  753. #define IMAGE_REL_ALPHA_SECREL 0x000F
  754. #define IMAGE_REL_ALPHA_REFLONGNB 0x0010
  755. #define IMAGE_REL_ALPHA_SECRELLO 0x0011 // Low 16-bit section relative reference
  756. #define IMAGE_REL_ALPHA_SECRELHI 0x0012 // High 16-bit section relative reference
  757. #define IMAGE_REL_ALPHA_REFQ3 0x0013 // High 16 bits of 48 bit reference
  758. #define IMAGE_REL_ALPHA_REFQ2 0x0014 // Middle 16 bits of 48 bit reference
  759. #define IMAGE_REL_ALPHA_REFQ1 0x0015 // Low 16 bits of 48 bit reference
  760. #define IMAGE_REL_ALPHA_GPRELLO 0x0016 // Low 16-bit GP relative reference
  761. #define IMAGE_REL_ALPHA_GPRELHI 0x0017 // High 16-bit GP relative reference
  762. //
  763. // IBM PowerPC relocation types.
  764. //
  765. #define IMAGE_REL_PPC_ABSOLUTE 0x0000 // NOP
  766. #define IMAGE_REL_PPC_ADDR64 0x0001 // 64-bit address
  767. #define IMAGE_REL_PPC_ADDR32 0x0002 // 32-bit address
  768. #define IMAGE_REL_PPC_ADDR24 0x0003 // 26-bit address, shifted left 2 (branch absolute)
  769. #define IMAGE_REL_PPC_ADDR16 0x0004 // 16-bit address
  770. #define IMAGE_REL_PPC_ADDR14 0x0005 // 16-bit address, shifted left 2 (load doubleword)
  771. #define IMAGE_REL_PPC_REL24 0x0006 // 26-bit PC-relative offset, shifted left 2 (branch relative)
  772. #define IMAGE_REL_PPC_REL14 0x0007 // 16-bit PC-relative offset, shifted left 2 (br cond relative)
  773. #define IMAGE_REL_PPC_TOCREL16 0x0008 // 16-bit offset from TOC base
  774. #define IMAGE_REL_PPC_TOCREL14 0x0009 // 16-bit offset from TOC base, shifted left 2 (load doubleword)
  775. #define IMAGE_REL_PPC_ADDR32NB 0x000A // 32-bit addr w/o image base
  776. #define IMAGE_REL_PPC_SECREL 0x000B // va of containing section (as in an image sectionhdr)
  777. #define IMAGE_REL_PPC_SECTION 0x000C // sectionheader number
  778. #define IMAGE_REL_PPC_IFGLUE 0x000D // substitute TOC restore instruction iff symbol is glue code
  779. #define IMAGE_REL_PPC_IMGLUE 0x000E // symbol is glue code; virtual address is TOC restore instruction
  780. #define IMAGE_REL_PPC_SECREL16 0x000F // va of containing section (limited to 16 bits)
  781. #define IMAGE_REL_PPC_REFHI 0x0010
  782. #define IMAGE_REL_PPC_REFLO 0x0011
  783. #define IMAGE_REL_PPC_PAIR 0x0012
  784. #define IMAGE_REL_PPC_SECRELLO 0x0013 // Low 16-bit section relative reference (used for >32k TLS)
  785. #define IMAGE_REL_PPC_SECRELHI 0x0014 // High 16-bit section relative reference (used for >32k TLS)
  786. #define IMAGE_REL_PPC_GPREL 0x0015
  787. #define IMAGE_REL_PPC_TOKEN 0x0016 // clr token
  788. #define IMAGE_REL_PPC_TYPEMASK 0x00FF // mask to isolate above values in IMAGE_RELOCATION.Type
  789. // Flag bits in IMAGE_RELOCATION.TYPE
  790. #define IMAGE_REL_PPC_NEG 0x0100 // subtract reloc value rather than adding it
  791. #define IMAGE_REL_PPC_BRTAKEN 0x0200 // fix branch prediction bit to predict branch taken
  792. #define IMAGE_REL_PPC_BRNTAKEN 0x0400 // fix branch prediction bit to predict branch not taken
  793. #define IMAGE_REL_PPC_TOCDEFN 0x0800 // toc slot defined in file (or, data in toc)
  794. //
  795. // Hitachi SH3 relocation types.
  796. //
  797. #define IMAGE_REL_SH3_ABSOLUTE 0x0000 // No relocation
  798. #define IMAGE_REL_SH3_DIRECT16 0x0001 // 16 bit direct
  799. #define IMAGE_REL_SH3_DIRECT32 0x0002 // 32 bit direct
  800. #define IMAGE_REL_SH3_DIRECT8 0x0003 // 8 bit direct, -128..255
  801. #define IMAGE_REL_SH3_DIRECT8_WORD 0x0004 // 8 bit direct .W (0 ext.)
  802. #define IMAGE_REL_SH3_DIRECT8_LONG 0x0005 // 8 bit direct .L (0 ext.)
  803. #define IMAGE_REL_SH3_DIRECT4 0x0006 // 4 bit direct (0 ext.)
  804. #define IMAGE_REL_SH3_DIRECT4_WORD 0x0007 // 4 bit direct .W (0 ext.)
  805. #define IMAGE_REL_SH3_DIRECT4_LONG 0x0008 // 4 bit direct .L (0 ext.)
  806. #define IMAGE_REL_SH3_PCREL8_WORD 0x0009 // 8 bit PC relative .W
  807. #define IMAGE_REL_SH3_PCREL8_LONG 0x000A // 8 bit PC relative .L
  808. #define IMAGE_REL_SH3_PCREL12_WORD 0x000B // 12 LSB PC relative .W
  809. #define IMAGE_REL_SH3_STARTOF_SECTION 0x000C // Start of EXE section
  810. #define IMAGE_REL_SH3_SIZEOF_SECTION 0x000D // Size of EXE section
  811. #define IMAGE_REL_SH3_SECTION 0x000E // Section table index
  812. #define IMAGE_REL_SH3_SECREL 0x000F // Offset within section
  813. #define IMAGE_REL_SH3_DIRECT32_NB 0x0010 // 32 bit direct not based
  814. #define IMAGE_REL_SH3_GPREL4_LONG 0x0011 // GP-relative addressing
  815. #define IMAGE_REL_SH3_TOKEN 0x0012 // clr token
  816. #define IMAGE_REL_ARM_ABSOLUTE 0x0000 // No relocation required
  817. #define IMAGE_REL_ARM_ADDR32 0x0001 // 32 bit address
  818. #define IMAGE_REL_ARM_ADDR32NB 0x0002 // 32 bit address w/o image base
  819. #define IMAGE_REL_ARM_BRANCH24 0x0003 // 24 bit offset << 2 & sign ext.
  820. #define IMAGE_REL_ARM_BRANCH11 0x0004 // Thumb: 2 11 bit offsets
  821. #define IMAGE_REL_ARM_TOKEN 0x0005 // clr token
  822. #define IMAGE_REL_ARM_GPREL12 0x0006 // GP-relative addressing (ARM)
  823. #define IMAGE_REL_ARM_GPREL7 0x0007 // GP-relative addressing (Thumb)
  824. #define IMAGE_REL_ARM_BLX24 0x0008
  825. #define IMAGE_REL_ARM_BLX11 0x0009
  826. #define IMAGE_REL_ARM_SECTION 0x000E // Section table index
  827. #define IMAGE_REL_ARM_SECREL 0x000F // Offset within section
  828. //
  829. // ARM64 relocation types
  830. //
  831. #define IMAGE_REL_ARM64_ABSOLUTE 0x0000
  832. #define IMAGE_REL_ARM64_ADDR32 0x0001
  833. #define IMAGE_REL_ARM64_ADDR32NB 0x0002
  834. #define IMAGE_REL_ARM64_BRANCH26 0x0003
  835. #define IMAGE_REL_ARM64_PAGEBASE_REL21 0x0004
  836. #define IMAGE_REL_ARM64_REL21 0x0005
  837. #define IMAGE_REL_ARM64_PAGEOFFSET_12A 0x0006
  838. #define IMAGE_REL_ARM64_PAGEOFFSET_12L 0x0007
  839. #define IMAGE_REL_ARM64_SECREL 0x0008
  840. #define IMAGE_REL_ARM64_SECREL_LOW12A 0x0009
  841. #define IMAGE_REL_ARM64_SECREL_HIGH12A 0x000A
  842. #define IMAGE_REL_ARM64_SECREL_LOW12L 0x000B
  843. #define IMAGE_REL_ARM64_TOKEN 0x000C
  844. #define IMAGE_REL_ARM64_SECTION 0x000D
  845. #define IMAGE_REL_ARM64_ADDR64 0x000E
  846. #define IMAGE_REL_AM_ABSOLUTE 0x0000
  847. #define IMAGE_REL_AM_ADDR32 0x0001
  848. #define IMAGE_REL_AM_ADDR32NB 0x0002
  849. #define IMAGE_REL_AM_CALL32 0x0003
  850. #define IMAGE_REL_AM_FUNCINFO 0x0004
  851. #define IMAGE_REL_AM_REL32_1 0x0005
  852. #define IMAGE_REL_AM_REL32_2 0x0006
  853. #define IMAGE_REL_AM_SECREL 0x0007
  854. #define IMAGE_REL_AM_SECTION 0x0008
  855. #define IMAGE_REL_AM_TOKEN 0x0009
  856. //
  857. // X86-64 relocations
  858. //
  859. #define IMAGE_REL_AMD64_ABSOLUTE 0x0000 // Reference is absolute, no relocation is necessary
  860. #define IMAGE_REL_AMD64_ADDR64 0x0001 // 64-bit address (VA).
  861. #define IMAGE_REL_AMD64_ADDR32 0x0002 // 32-bit address (VA).
  862. #define IMAGE_REL_AMD64_ADDR32NB 0x0003 // 32-bit address w/o image base (RVA).
  863. #define IMAGE_REL_AMD64_REL32 0x0004 // 32-bit relative address from byte following reloc
  864. #define IMAGE_REL_AMD64_REL32_1 0x0005 // 32-bit relative address from byte distance 1 from reloc
  865. #define IMAGE_REL_AMD64_REL32_2 0x0006 // 32-bit relative address from byte distance 2 from reloc
  866. #define IMAGE_REL_AMD64_REL32_3 0x0007 // 32-bit relative address from byte distance 3 from reloc
  867. #define IMAGE_REL_AMD64_REL32_4 0x0008 // 32-bit relative address from byte distance 4 from reloc
  868. #define IMAGE_REL_AMD64_REL32_5 0x0009 // 32-bit relative address from byte distance 5 from reloc
  869. #define IMAGE_REL_AMD64_SECTION 0x000A // Section index
  870. #define IMAGE_REL_AMD64_SECREL 0x000B // 32 bit offset from base of section containing target
  871. #define IMAGE_REL_AMD64_SECREL7 0x000C // 7 bit unsigned offset from base of section containing target
  872. #define IMAGE_REL_AMD64_TOKEN 0x000D // 32 bit metadata token
  873. //
  874. // IA64 relocation types.
  875. //
  876. #define IMAGE_REL_IA64_ABSOLUTE 0x0000
  877. #define IMAGE_REL_IA64_IMM14 0x0001
  878. #define IMAGE_REL_IA64_IMM22 0x0002
  879. #define IMAGE_REL_IA64_IMM64 0x0003
  880. #define IMAGE_REL_IA64_DIR32 0x0004
  881. #define IMAGE_REL_IA64_DIR64 0x0005
  882. #define IMAGE_REL_IA64_PCREL21B 0x0006
  883. #define IMAGE_REL_IA64_PCREL21M 0x0007
  884. #define IMAGE_REL_IA64_PCREL21F 0x0008
  885. #define IMAGE_REL_IA64_GPREL22 0x0009
  886. #define IMAGE_REL_IA64_LTOFF22 0x000A
  887. #define IMAGE_REL_IA64_SECTION 0x000B
  888. #define IMAGE_REL_IA64_SECREL22 0x000C
  889. #define IMAGE_REL_IA64_SECREL64I 0x000D
  890. #define IMAGE_REL_IA64_SECREL32 0x000E
  891. //
  892. #define IMAGE_REL_IA64_DIR32NB 0x0010
  893. #define IMAGE_REL_IA64_SREL14 0x0011
  894. #define IMAGE_REL_IA64_SREL22 0x0012
  895. #define IMAGE_REL_IA64_SREL32 0x0013
  896. #define IMAGE_REL_IA64_UREL32 0x0014
  897. #define IMAGE_REL_IA64_PCREL60X 0x0015 // This is always a BRL and never converted
  898. #define IMAGE_REL_IA64_PCREL60B 0x0016 // If possible, convert to MBB bundle with NOP.B in slot 1
  899. #define IMAGE_REL_IA64_PCREL60F 0x0017 // If possible, convert to MFB bundle with NOP.F in slot 1
  900. #define IMAGE_REL_IA64_PCREL60I 0x0018 // If possible, convert to MIB bundle with NOP.I in slot 1
  901. #define IMAGE_REL_IA64_PCREL60M 0x0019 // If possible, convert to MMB bundle with NOP.M in slot 1
  902. #define IMAGE_REL_IA64_IMMGPREL64 0x001A
  903. #define IMAGE_REL_IA64_TOKEN 0x001B // clr token
  904. #define IMAGE_REL_IA64_GPREL32 0x001C
  905. #define IMAGE_REL_IA64_ADDEND 0x001F
  906. //
  907. // CEF relocation types.
  908. //
  909. #define IMAGE_REL_CEF_ABSOLUTE 0x0000 // Reference is absolute, no relocation is necessary
  910. #define IMAGE_REL_CEF_ADDR32 0x0001 // 32-bit address (VA).
  911. #define IMAGE_REL_CEF_ADDR64 0x0002 // 64-bit address (VA).
  912. #define IMAGE_REL_CEF_ADDR32NB 0x0003 // 32-bit address w/o image base (RVA).
  913. #define IMAGE_REL_CEF_SECTION 0x0004 // Section index
  914. #define IMAGE_REL_CEF_SECREL 0x0005 // 32 bit offset from base of section containing target
  915. #define IMAGE_REL_CEF_TOKEN 0x0006 // 32 bit metadata token
  916. //
  917. // clr relocation types.
  918. //
  919. #define IMAGE_REL_CEE_ABSOLUTE 0x0000 // Reference is absolute, no relocation is necessary
  920. #define IMAGE_REL_CEE_ADDR32 0x0001 // 32-bit address (VA).
  921. #define IMAGE_REL_CEE_ADDR64 0x0002 // 64-bit address (VA).
  922. #define IMAGE_REL_CEE_ADDR32NB 0x0003 // 32-bit address w/o image base (RVA).
  923. #define IMAGE_REL_CEE_SECTION 0x0004 // Section index
  924. #define IMAGE_REL_CEE_SECREL 0x0005 // 32 bit offset from base of section containing target
  925. #define IMAGE_REL_CEE_TOKEN 0x0006 // 32 bit metadata token
  926. #define IMAGE_REL_M32R_ABSOLUTE 0x0000 // No relocation required
  927. #define IMAGE_REL_M32R_ADDR32 0x0001 // 32 bit address
  928. #define IMAGE_REL_M32R_ADDR32NB 0x0002 // 32 bit address w/o image base
  929. #define IMAGE_REL_M32R_ADDR24 0x0003 // 24 bit address
  930. #define IMAGE_REL_M32R_GPREL16 0x0004 // GP relative addressing
  931. #define IMAGE_REL_M32R_PCREL24 0x0005 // 24 bit offset << 2 & sign ext.
  932. #define IMAGE_REL_M32R_PCREL16 0x0006 // 16 bit offset << 2 & sign ext.
  933. #define IMAGE_REL_M32R_PCREL8 0x0007 // 8 bit offset << 2 & sign ext.
  934. #define IMAGE_REL_M32R_REFHALF 0x0008 // 16 MSBs
  935. #define IMAGE_REL_M32R_REFHI 0x0009 // 16 MSBs; adj for LSB sign ext.
  936. #define IMAGE_REL_M32R_REFLO 0x000A // 16 LSBs
  937. #define IMAGE_REL_M32R_PAIR 0x000B // Link HI and LO
  938. #define IMAGE_REL_M32R_SECTION 0x000C // Section table index
  939. #define IMAGE_REL_M32R_SECREL32 0x000D // 32 bit section relative reference
  940. #define IMAGE_REL_M32R_TOKEN 0x000E // clr token
  941. #define EXT_IMM64(Value, Address, Size, InstPos, ValPos) /* Intel-IA64-Filler */ \
  942. Value |= (((ULONGLONG)((*(Address) >> InstPos) & (((ULONGLONG)1 << Size) - 1))) << ValPos) // Intel-IA64-Filler
  943. #define INS_IMM64(Value, Address, Size, InstPos, ValPos) /* Intel-IA64-Filler */\
  944. *(PULONG)Address = (*(PULONG)Address & ~(((1 << Size) - 1) << InstPos)) | /* Intel-IA64-Filler */\
  945. ((ULONG)((((ULONGLONG)Value >> ValPos) & (((ULONGLONG)1 << Size) - 1))) << InstPos) // Intel-IA64-Filler
  946. #define EMARCH_ENC_I17_IMM7B_INST_WORD_X 3 // Intel-IA64-Filler
  947. #define EMARCH_ENC_I17_IMM7B_SIZE_X 7 // Intel-IA64-Filler
  948. #define EMARCH_ENC_I17_IMM7B_INST_WORD_POS_X 4 // Intel-IA64-Filler
  949. #define EMARCH_ENC_I17_IMM7B_VAL_POS_X 0 // Intel-IA64-Filler
  950. #define EMARCH_ENC_I17_IMM9D_INST_WORD_X 3 // Intel-IA64-Filler
  951. #define EMARCH_ENC_I17_IMM9D_SIZE_X 9 // Intel-IA64-Filler
  952. #define EMARCH_ENC_I17_IMM9D_INST_WORD_POS_X 18 // Intel-IA64-Filler
  953. #define EMARCH_ENC_I17_IMM9D_VAL_POS_X 7 // Intel-IA64-Filler
  954. #define EMARCH_ENC_I17_IMM5C_INST_WORD_X 3 // Intel-IA64-Filler
  955. #define EMARCH_ENC_I17_IMM5C_SIZE_X 5 // Intel-IA64-Filler
  956. #define EMARCH_ENC_I17_IMM5C_INST_WORD_POS_X 13 // Intel-IA64-Filler
  957. #define EMARCH_ENC_I17_IMM5C_VAL_POS_X 16 // Intel-IA64-Filler
  958. #define EMARCH_ENC_I17_IC_INST_WORD_X 3 // Intel-IA64-Filler
  959. #define EMARCH_ENC_I17_IC_SIZE_X 1 // Intel-IA64-Filler
  960. #define EMARCH_ENC_I17_IC_INST_WORD_POS_X 12 // Intel-IA64-Filler
  961. #define EMARCH_ENC_I17_IC_VAL_POS_X 21 // Intel-IA64-Filler
  962. #define EMARCH_ENC_I17_IMM41a_INST_WORD_X 1 // Intel-IA64-Filler
  963. #define EMARCH_ENC_I17_IMM41a_SIZE_X 10 // Intel-IA64-Filler
  964. #define EMARCH_ENC_I17_IMM41a_INST_WORD_POS_X 14 // Intel-IA64-Filler
  965. #define EMARCH_ENC_I17_IMM41a_VAL_POS_X 22 // Intel-IA64-Filler
  966. #define EMARCH_ENC_I17_IMM41b_INST_WORD_X 1 // Intel-IA64-Filler
  967. #define EMARCH_ENC_I17_IMM41b_SIZE_X 8 // Intel-IA64-Filler
  968. #define EMARCH_ENC_I17_IMM41b_INST_WORD_POS_X 24 // Intel-IA64-Filler
  969. #define EMARCH_ENC_I17_IMM41b_VAL_POS_X 32 // Intel-IA64-Filler
  970. #define EMARCH_ENC_I17_IMM41c_INST_WORD_X 2 // Intel-IA64-Filler
  971. #define EMARCH_ENC_I17_IMM41c_SIZE_X 23 // Intel-IA64-Filler
  972. #define EMARCH_ENC_I17_IMM41c_INST_WORD_POS_X 0 // Intel-IA64-Filler
  973. #define EMARCH_ENC_I17_IMM41c_VAL_POS_X 40 // Intel-IA64-Filler
  974. #define EMARCH_ENC_I17_SIGN_INST_WORD_X 3 // Intel-IA64-Filler
  975. #define EMARCH_ENC_I17_SIGN_SIZE_X 1 // Intel-IA64-Filler
  976. #define EMARCH_ENC_I17_SIGN_INST_WORD_POS_X 27 // Intel-IA64-Filler
  977. #define EMARCH_ENC_I17_SIGN_VAL_POS_X 63 // Intel-IA64-Filler
  978. //
  979. // Line number format.
  980. //
  981. typedef struct _IMAGE_LINENUMBER {
  982. union {
  983. ULONG SymbolTableIndex; // Symbol table index of function name if Linenumber is 0.
  984. ULONG VirtualAddress; // Virtual address of line number.
  985. } Type;
  986. USHORT Linenumber; // Line number.
  987. } IMAGE_LINENUMBER;
  988. typedef IMAGE_LINENUMBER UNALIGNED *PIMAGE_LINENUMBER;
  989. #define IMAGE_SIZEOF_LINENUMBER 6
  990. #ifndef _MAC
  991. #include "poppack.h" // Back to 4 byte packing
  992. #endif
  993. //
  994. // Based relocation format.
  995. //
  996. typedef struct _IMAGE_BASE_RELOCATION {
  997. ULONG VirtualAddress;
  998. ULONG SizeOfBlock;
  999. // USHORT TypeOffset[1];
  1000. } IMAGE_BASE_RELOCATION;
  1001. typedef IMAGE_BASE_RELOCATION UNALIGNED * PIMAGE_BASE_RELOCATION;
  1002. #define IMAGE_SIZEOF_BASE_RELOCATION 8
  1003. //
  1004. // Based relocation types.
  1005. //
  1006. #define IMAGE_REL_BASED_ABSOLUTE 0
  1007. #define IMAGE_REL_BASED_HIGH 1
  1008. #define IMAGE_REL_BASED_LOW 2
  1009. #define IMAGE_REL_BASED_HIGHLOW 3
  1010. #define IMAGE_REL_BASED_HIGHADJ 4
  1011. #define IMAGE_REL_BASED_MACHINE_SPECIFIC_5 5
  1012. #define IMAGE_REL_BASED_RESERVED 6
  1013. #define IMAGE_REL_BASED_MACHINE_SPECIFIC_7 7
  1014. #define IMAGE_REL_BASED_MACHINE_SPECIFIC_8 8
  1015. #define IMAGE_REL_BASED_MACHINE_SPECIFIC_9 9
  1016. #define IMAGE_REL_BASED_DIR64 10
  1017. //
  1018. // Platform-specific based relocation types.
  1019. //
  1020. #define IMAGE_REL_BASED_IA64_IMM64 9
  1021. #define IMAGE_REL_BASED_MIPS_JMPADDR 5
  1022. #define IMAGE_REL_BASED_MIPS_JMPADDR16 9
  1023. #define IMAGE_REL_BASED_ARM_MOV32 5
  1024. #define IMAGE_REL_BASED_THUMB_MOV32 7
  1025. //
  1026. // Archive format.
  1027. //
  1028. #define IMAGE_ARCHIVE_START_SIZE 8
  1029. #define IMAGE_ARCHIVE_START "!<arch>\n"
  1030. #define IMAGE_ARCHIVE_END "`\n"
  1031. #define IMAGE_ARCHIVE_PAD "\n"
  1032. #define IMAGE_ARCHIVE_LINKER_MEMBER "/ "
  1033. #define IMAGE_ARCHIVE_LONGNAMES_MEMBER "// "
  1034. typedef struct _IMAGE_ARCHIVE_MEMBER_HEADER {
  1035. UCHAR Name[16]; // File member name - `/' terminated.
  1036. UCHAR Date[12]; // File member date - decimal.
  1037. UCHAR UserID[6]; // File member user id - decimal.
  1038. UCHAR GroupID[6]; // File member group id - decimal.
  1039. UCHAR Mode[8]; // File member mode - octal.
  1040. UCHAR Size[10]; // File member size - decimal.
  1041. UCHAR EndHeader[2]; // String to end header.
  1042. } IMAGE_ARCHIVE_MEMBER_HEADER, *PIMAGE_ARCHIVE_MEMBER_HEADER;
  1043. #define IMAGE_SIZEOF_ARCHIVE_MEMBER_HDR 60
  1044. //
  1045. // DLL support.
  1046. //
  1047. //
  1048. // Export Format
  1049. //
  1050. typedef struct _IMAGE_EXPORT_DIRECTORY {
  1051. ULONG Characteristics;
  1052. ULONG TimeDateStamp;
  1053. USHORT MajorVersion;
  1054. USHORT MinorVersion;
  1055. ULONG Name;
  1056. ULONG Base;
  1057. ULONG NumberOfFunctions;
  1058. ULONG NumberOfNames;
  1059. ULONG AddressOfFunctions; // RVA from base of image
  1060. ULONG AddressOfNames; // RVA from base of image
  1061. ULONG AddressOfNameOrdinals; // RVA from base of image
  1062. } IMAGE_EXPORT_DIRECTORY, *PIMAGE_EXPORT_DIRECTORY;
  1063. //
  1064. // Import Format
  1065. //
  1066. typedef struct _IMAGE_IMPORT_BY_NAME {
  1067. USHORT Hint;
  1068. UCHAR Name[1];
  1069. } IMAGE_IMPORT_BY_NAME, *PIMAGE_IMPORT_BY_NAME;
  1070. #include "pshpack8.h" // Use align 8 for the 64-bit IAT.
  1071. typedef struct _IMAGE_THUNK_DATA64 {
  1072. union {
  1073. ULONGLONG ForwarderString; // PUCHAR
  1074. ULONGLONG Function; // PULONG
  1075. ULONGLONG Ordinal;
  1076. ULONGLONG AddressOfData; // PIMAGE_IMPORT_BY_NAME
  1077. } u1;
  1078. } IMAGE_THUNK_DATA64;
  1079. typedef IMAGE_THUNK_DATA64 * PIMAGE_THUNK_DATA64;
  1080. #include "poppack.h" // Back to 4 byte packing
  1081. typedef struct _IMAGE_THUNK_DATA32 {
  1082. union {
  1083. ULONG ForwarderString; // PUCHAR
  1084. ULONG Function; // PULONG
  1085. ULONG Ordinal;
  1086. ULONG AddressOfData; // PIMAGE_IMPORT_BY_NAME
  1087. } u1;
  1088. } IMAGE_THUNK_DATA32;
  1089. typedef IMAGE_THUNK_DATA32 * PIMAGE_THUNK_DATA32;
  1090. #define IMAGE_ORDINAL_FLAG64 0x8000000000000000
  1091. #define IMAGE_ORDINAL_FLAG32 0x80000000
  1092. #define IMAGE_ORDINAL64(Ordinal) (Ordinal & 0xffff)
  1093. #define IMAGE_ORDINAL32(Ordinal) (Ordinal & 0xffff)
  1094. #define IMAGE_SNAP_BY_ORDINAL64(Ordinal) ((Ordinal & IMAGE_ORDINAL_FLAG64) != 0)
  1095. #define IMAGE_SNAP_BY_ORDINAL32(Ordinal) ((Ordinal & IMAGE_ORDINAL_FLAG32) != 0)
  1096. //
  1097. // Thread Local Storage
  1098. //
  1099. #ifdef _MSC_VER
  1100. typedef VOID
  1101. (NTAPI *PIMAGE_TLS_CALLBACK) (
  1102. PVOID DllHandle,
  1103. ULONG Reason,
  1104. PVOID Reserved
  1105. );
  1106. #endif
  1107. typedef struct _IMAGE_TLS_DIRECTORY64 {
  1108. ULONGLONG StartAddressOfRawData;
  1109. ULONGLONG EndAddressOfRawData;
  1110. ULONGLONG AddressOfIndex; // PULONG
  1111. ULONGLONG AddressOfCallBacks; // PIMAGE_TLS_CALLBACK *;
  1112. ULONG SizeOfZeroFill;
  1113. ULONG Characteristics;
  1114. } IMAGE_TLS_DIRECTORY64;
  1115. typedef IMAGE_TLS_DIRECTORY64 * PIMAGE_TLS_DIRECTORY64;
  1116. typedef struct _IMAGE_TLS_DIRECTORY32 {
  1117. ULONG StartAddressOfRawData;
  1118. ULONG EndAddressOfRawData;
  1119. ULONG AddressOfIndex; // PULONG
  1120. ULONG AddressOfCallBacks; // PIMAGE_TLS_CALLBACK *
  1121. ULONG SizeOfZeroFill;
  1122. ULONG Characteristics;
  1123. } IMAGE_TLS_DIRECTORY32;
  1124. typedef IMAGE_TLS_DIRECTORY32 * PIMAGE_TLS_DIRECTORY32;
  1125. #ifdef _WIN64
  1126. #define IMAGE_ORDINAL_FLAG IMAGE_ORDINAL_FLAG64
  1127. #define IMAGE_ORDINAL(Ordinal) IMAGE_ORDINAL64(Ordinal)
  1128. typedef IMAGE_THUNK_DATA64 IMAGE_THUNK_DATA;
  1129. typedef PIMAGE_THUNK_DATA64 PIMAGE_THUNK_DATA;
  1130. #define IMAGE_SNAP_BY_ORDINAL(Ordinal) IMAGE_SNAP_BY_ORDINAL64(Ordinal)
  1131. typedef IMAGE_TLS_DIRECTORY64 IMAGE_TLS_DIRECTORY;
  1132. typedef PIMAGE_TLS_DIRECTORY64 PIMAGE_TLS_DIRECTORY;
  1133. #else
  1134. #define IMAGE_ORDINAL_FLAG IMAGE_ORDINAL_FLAG32
  1135. #define IMAGE_ORDINAL(Ordinal) IMAGE_ORDINAL32(Ordinal)
  1136. typedef IMAGE_THUNK_DATA32 IMAGE_THUNK_DATA;
  1137. typedef PIMAGE_THUNK_DATA32 PIMAGE_THUNK_DATA;
  1138. #define IMAGE_SNAP_BY_ORDINAL(Ordinal) IMAGE_SNAP_BY_ORDINAL32(Ordinal)
  1139. typedef IMAGE_TLS_DIRECTORY32 IMAGE_TLS_DIRECTORY;
  1140. typedef PIMAGE_TLS_DIRECTORY32 PIMAGE_TLS_DIRECTORY;
  1141. #endif
  1142. typedef struct _IMAGE_IMPORT_DESCRIPTOR {
  1143. union {
  1144. ULONG Characteristics; // 0 for terminating null import descriptor
  1145. ULONG OriginalFirstThunk; // RVA to original unbound IAT (PIMAGE_THUNK_DATA)
  1146. } u;
  1147. ULONG TimeDateStamp; // 0 if not bound,
  1148. // -1 if bound, and real date\time stamp
  1149. // in IMAGE_DIRECTORY_ENTRY_BOUND_IMPORT (new BIND)
  1150. // O.W. date/time stamp of DLL bound to (Old BIND)
  1151. ULONG ForwarderChain; // -1 if no forwarders
  1152. ULONG Name;
  1153. ULONG FirstThunk; // RVA to IAT (if bound this IAT has actual addresses)
  1154. } IMAGE_IMPORT_DESCRIPTOR;
  1155. typedef IMAGE_IMPORT_DESCRIPTOR UNALIGNED *PIMAGE_IMPORT_DESCRIPTOR;
  1156. //
  1157. // New format import descriptors pointed to by DataDirectory[ IMAGE_DIRECTORY_ENTRY_BOUND_IMPORT ]
  1158. //
  1159. typedef struct _IMAGE_BOUND_IMPORT_DESCRIPTOR {
  1160. ULONG TimeDateStamp;
  1161. USHORT OffsetModuleName;
  1162. USHORT NumberOfModuleForwarderRefs;
  1163. // Array of zero or more IMAGE_BOUND_FORWARDER_REF follows
  1164. } IMAGE_BOUND_IMPORT_DESCRIPTOR, *PIMAGE_BOUND_IMPORT_DESCRIPTOR;
  1165. typedef struct _IMAGE_BOUND_FORWARDER_REF {
  1166. ULONG TimeDateStamp;
  1167. USHORT OffsetModuleName;
  1168. USHORT Reserved;
  1169. } IMAGE_BOUND_FORWARDER_REF, *PIMAGE_BOUND_FORWARDER_REF;
  1170. //
  1171. // Resource Format.
  1172. //
  1173. //
  1174. // Resource directory consists of two counts, following by a variable length
  1175. // array of directory entries. The first count is the number of entries at
  1176. // beginning of the array that have actual names associated with each entry.
  1177. // The entries are in ascending order, case insensitive strings. The second
  1178. // count is the number of entries that immediately follow the named entries.
  1179. // This second count identifies the number of entries that have 16-bit integer
  1180. // Ids as their name. These entries are also sorted in ascending order.
  1181. //
  1182. // This structure allows fast lookup by either name or number, but for any
  1183. // given resource entry only one form of lookup is supported, not both.
  1184. // This is consistant with the syntax of the .RC file and the .RES file.
  1185. //
  1186. typedef struct _IMAGE_RESOURCE_DIRECTORY {
  1187. ULONG Characteristics;
  1188. ULONG TimeDateStamp;
  1189. USHORT MajorVersion;
  1190. USHORT MinorVersion;
  1191. USHORT NumberOfNamedEntries;
  1192. USHORT NumberOfIdEntries;
  1193. // IMAGE_RESOURCE_DIRECTORY_ENTRY DirectoryEntries[];
  1194. } IMAGE_RESOURCE_DIRECTORY, *PIMAGE_RESOURCE_DIRECTORY;
  1195. #define IMAGE_RESOURCE_NAME_IS_STRING 0x80000000
  1196. #define IMAGE_RESOURCE_DATA_IS_DIRECTORY 0x80000000
  1197. //
  1198. // Each directory contains the 32-bit Name of the entry and an offset,
  1199. // relative to the beginning of the resource directory of the data associated
  1200. // with this directory entry. If the name of the entry is an actual text
  1201. // string instead of an integer Id, then the high order bit of the name field
  1202. // is set to one and the low order 31-bits are an offset, relative to the
  1203. // beginning of the resource directory of the string, which is of type
  1204. // IMAGE_RESOURCE_DIRECTORY_STRING. Otherwise the high bit is clear and the
  1205. // low-order 16-bits are the integer Id that identify this resource directory
  1206. // entry. If the directory entry is yet another resource directory (i.e. a
  1207. // subdirectory), then the high order bit of the offset field will be
  1208. // set to indicate this. Otherwise the high bit is clear and the offset
  1209. // field points to a resource data entry.
  1210. //
  1211. typedef struct _IMAGE_RESOURCE_DIRECTORY_ENTRY {
  1212. union {
  1213. struct {
  1214. ULONG NameOffset:31;
  1215. ULONG NameIsString:1;
  1216. };
  1217. ULONG Name;
  1218. USHORT Id;
  1219. };
  1220. union {
  1221. ULONG OffsetToData;
  1222. struct {
  1223. ULONG OffsetToDirectory:31;
  1224. ULONG DataIsDirectory:1;
  1225. };
  1226. };
  1227. } IMAGE_RESOURCE_DIRECTORY_ENTRY, *PIMAGE_RESOURCE_DIRECTORY_ENTRY;
  1228. //
  1229. // For resource directory entries that have actual string names, the Name
  1230. // field of the directory entry points to an object of the following type.
  1231. // All of these string objects are stored together after the last resource
  1232. // directory entry and before the first resource data object. This minimizes
  1233. // the impact of these variable length objects on the alignment of the fixed
  1234. // size directory entry objects.
  1235. //
  1236. typedef struct _IMAGE_RESOURCE_DIRECTORY_STRING {
  1237. USHORT Length;
  1238. CHAR NameString[ 1 ];
  1239. } IMAGE_RESOURCE_DIRECTORY_STRING, *PIMAGE_RESOURCE_DIRECTORY_STRING;
  1240. typedef struct _IMAGE_RESOURCE_DIR_STRING_U {
  1241. USHORT Length;
  1242. WCHAR NameString[ 1 ];
  1243. } IMAGE_RESOURCE_DIR_STRING_U, *PIMAGE_RESOURCE_DIR_STRING_U;
  1244. //
  1245. // Each resource data entry describes a leaf node in the resource directory
  1246. // tree. It contains an offset, relative to the beginning of the resource
  1247. // directory of the data for the resource, a size field that gives the number
  1248. // of bytes of data at that offset, a CodePage that should be used when
  1249. // decoding code point values within the resource data. Typically for new
  1250. // applications the code page would be the unicode code page.
  1251. //
  1252. typedef struct _IMAGE_RESOURCE_DATA_ENTRY {
  1253. ULONG OffsetToData;
  1254. ULONG Size;
  1255. ULONG CodePage;
  1256. ULONG Reserved;
  1257. } IMAGE_RESOURCE_DATA_ENTRY, *PIMAGE_RESOURCE_DATA_ENTRY;
  1258. //
  1259. // Load Configuration Directory Entry
  1260. //
  1261. typedef struct {
  1262. ULONG Characteristics;
  1263. ULONG TimeDateStamp;
  1264. USHORT MajorVersion;
  1265. USHORT MinorVersion;
  1266. ULONG GlobalFlagsClear;
  1267. ULONG GlobalFlagsSet;
  1268. ULONG CriticalSectionDefaultTimeout;
  1269. ULONG DeCommitFreeBlockThreshold;
  1270. ULONG DeCommitTotalFreeThreshold;
  1271. ULONG LockPrefixTable; // VA
  1272. ULONG MaximumAllocationSize;
  1273. ULONG VirtualMemoryThreshold;
  1274. ULONG ProcessHeapFlags;
  1275. ULONG ProcessAffinityMask;
  1276. USHORT CSDVersion;
  1277. USHORT Reserved1;
  1278. ULONG EditList; // VA
  1279. ULONG Reserved[ 1 ];
  1280. } IMAGE_LOAD_CONFIG_DIRECTORY32, *PIMAGE_LOAD_CONFIG_DIRECTORY32;
  1281. typedef struct {
  1282. ULONG Characteristics;
  1283. ULONG TimeDateStamp;
  1284. USHORT MajorVersion;
  1285. USHORT MinorVersion;
  1286. ULONG GlobalFlagsClear;
  1287. ULONG GlobalFlagsSet;
  1288. ULONG CriticalSectionDefaultTimeout;
  1289. ULONGLONG DeCommitFreeBlockThreshold;
  1290. ULONGLONG DeCommitTotalFreeThreshold;
  1291. ULONGLONG LockPrefixTable; // VA
  1292. ULONGLONG MaximumAllocationSize;
  1293. ULONGLONG VirtualMemoryThreshold;
  1294. ULONGLONG ProcessAffinityMask;
  1295. ULONG ProcessHeapFlags;
  1296. USHORT CSDVersion;
  1297. USHORT Reserved1;
  1298. ULONGLONG EditList; // VA
  1299. ULONG Reserved[ 2 ];
  1300. } IMAGE_LOAD_CONFIG_DIRECTORY64, *PIMAGE_LOAD_CONFIG_DIRECTORY64;
  1301. #ifdef _WIN64
  1302. typedef IMAGE_LOAD_CONFIG_DIRECTORY64 IMAGE_LOAD_CONFIG_DIRECTORY;
  1303. typedef PIMAGE_LOAD_CONFIG_DIRECTORY64 PIMAGE_LOAD_CONFIG_DIRECTORY;
  1304. #else
  1305. typedef IMAGE_LOAD_CONFIG_DIRECTORY32 IMAGE_LOAD_CONFIG_DIRECTORY;
  1306. typedef PIMAGE_LOAD_CONFIG_DIRECTORY32 PIMAGE_LOAD_CONFIG_DIRECTORY;
  1307. #endif
  1308. //
  1309. // WIN CE Exception table format
  1310. //
  1311. //
  1312. // Function table entry format. Function table is pointed to by the
  1313. // IMAGE_DIRECTORY_ENTRY_EXCEPTION directory entry.
  1314. //
  1315. typedef struct _IMAGE_CE_RUNTIME_FUNCTION_ENTRY {
  1316. ULONG FuncStart;
  1317. ULONG PrologLen : 8;
  1318. ULONG FuncLen : 22;
  1319. ULONG ThirtyTwoBit : 1;
  1320. ULONG ExceptionFlag : 1;
  1321. } IMAGE_CE_RUNTIME_FUNCTION_ENTRY, * PIMAGE_CE_RUNTIME_FUNCTION_ENTRY;
  1322. typedef struct _IMAGE_ALPHA64_RUNTIME_FUNCTION_ENTRY {
  1323. ULONGLONG BeginAddress;
  1324. ULONGLONG EndAddress;
  1325. ULONGLONG ExceptionHandler;
  1326. ULONGLONG HandlerData;
  1327. ULONGLONG PrologEndAddress;
  1328. } IMAGE_ALPHA64_RUNTIME_FUNCTION_ENTRY, *PIMAGE_ALPHA64_RUNTIME_FUNCTION_ENTRY;
  1329. typedef struct _IMAGE_ALPHA_RUNTIME_FUNCTION_ENTRY {
  1330. ULONG BeginAddress;
  1331. ULONG EndAddress;
  1332. ULONG ExceptionHandler;
  1333. ULONG HandlerData;
  1334. ULONG PrologEndAddress;
  1335. } IMAGE_ALPHA_RUNTIME_FUNCTION_ENTRY, *PIMAGE_ALPHA_RUNTIME_FUNCTION_ENTRY;
  1336. typedef struct _IMAGE_RUNTIME_FUNCTION_ENTRY {
  1337. ULONG BeginAddress;
  1338. ULONG EndAddress;
  1339. ULONG UnwindInfoAddress;
  1340. } _IMAGE_RUNTIME_FUNCTION_ENTRY, *_PIMAGE_RUNTIME_FUNCTION_ENTRY;
  1341. typedef _IMAGE_RUNTIME_FUNCTION_ENTRY IMAGE_IA64_RUNTIME_FUNCTION_ENTRY;
  1342. typedef _PIMAGE_RUNTIME_FUNCTION_ENTRY PIMAGE_IA64_RUNTIME_FUNCTION_ENTRY;
  1343. #if defined(_AXP64_)
  1344. typedef IMAGE_ALPHA64_RUNTIME_FUNCTION_ENTRY IMAGE_AXP64_RUNTIME_FUNCTION_ENTRY;
  1345. typedef PIMAGE_ALPHA64_RUNTIME_FUNCTION_ENTRY PIMAGE_AXP64_RUNTIME_FUNCTION_ENTRY;
  1346. typedef IMAGE_ALPHA64_RUNTIME_FUNCTION_ENTRY IMAGE_RUNTIME_FUNCTION_ENTRY;
  1347. typedef PIMAGE_ALPHA64_RUNTIME_FUNCTION_ENTRY PIMAGE_RUNTIME_FUNCTION_ENTRY;
  1348. #elif defined(_ALPHA_)
  1349. typedef IMAGE_ALPHA_RUNTIME_FUNCTION_ENTRY IMAGE_RUNTIME_FUNCTION_ENTRY;
  1350. typedef PIMAGE_ALPHA_RUNTIME_FUNCTION_ENTRY PIMAGE_RUNTIME_FUNCTION_ENTRY;
  1351. #else
  1352. typedef _IMAGE_RUNTIME_FUNCTION_ENTRY IMAGE_RUNTIME_FUNCTION_ENTRY;
  1353. typedef _PIMAGE_RUNTIME_FUNCTION_ENTRY PIMAGE_RUNTIME_FUNCTION_ENTRY;
  1354. #endif
  1355. //
  1356. // Debug Format
  1357. //
  1358. typedef struct _IMAGE_DEBUG_DIRECTORY {
  1359. ULONG Characteristics;
  1360. ULONG TimeDateStamp;
  1361. USHORT MajorVersion;
  1362. USHORT MinorVersion;
  1363. ULONG Type;
  1364. ULONG SizeOfData;
  1365. ULONG AddressOfRawData;
  1366. ULONG PointerToRawData;
  1367. } IMAGE_DEBUG_DIRECTORY, *PIMAGE_DEBUG_DIRECTORY;
  1368. // end_winnt
  1369. //
  1370. // begin_winnt
  1371. typedef struct _IMAGE_COFF_SYMBOLS_HEADER {
  1372. ULONG NumberOfSymbols;
  1373. ULONG LvaToFirstSymbol;
  1374. ULONG NumberOfLinenumbers;
  1375. ULONG LvaToFirstLinenumber;
  1376. ULONG RvaToFirstByteOfCode;
  1377. ULONG RvaToLastByteOfCode;
  1378. ULONG RvaToFirstByteOfData;
  1379. ULONG RvaToLastByteOfData;
  1380. } IMAGE_COFF_SYMBOLS_HEADER, *PIMAGE_COFF_SYMBOLS_HEADER;
  1381. #define FRAME_FPO 0
  1382. #define FRAME_TRAP 1
  1383. #define FRAME_TSS 2
  1384. #define FRAME_NONFPO 3
  1385. typedef struct _FPO_DATA {
  1386. ULONG ulOffStart; // offset 1st byte of function code
  1387. ULONG cbProcSize; // # bytes in function
  1388. ULONG cdwLocals; // # bytes in locals/4
  1389. USHORT cdwParams; // # bytes in params/4
  1390. USHORT cbProlog : 8; // # bytes in prolog
  1391. USHORT cbRegs : 3; // # regs saved
  1392. USHORT fHasSEH : 1; // TRUE if SEH in func
  1393. USHORT fUseBP : 1; // TRUE if EBP has been allocated
  1394. USHORT reserved : 1; // reserved for future use
  1395. USHORT cbFrame : 2; // frame type
  1396. } FPO_DATA, *PFPO_DATA;
  1397. #define SIZEOF_RFPO_DATA 16
  1398. #define IMAGE_DEBUG_MISC_EXENAME 1
  1399. typedef struct _IMAGE_DEBUG_MISC {
  1400. ULONG DataType; // type of misc data, see defines
  1401. ULONG Length; // total length of record, rounded to four
  1402. // byte multiple.
  1403. BOOLEAN Unicode; // TRUE if data is unicode string
  1404. UCHAR Reserved[ 3 ];
  1405. UCHAR Data[ 1 ]; // Actual data
  1406. } IMAGE_DEBUG_MISC, *PIMAGE_DEBUG_MISC;
  1407. //
  1408. // Function table extracted from MIPS/ALPHA/IA64 images. Does not contain
  1409. // information needed only for runtime support. Just those fields for
  1410. // each entry needed by a debugger.
  1411. //
  1412. typedef struct _IMAGE_FUNCTION_ENTRY {
  1413. ULONG StartingAddress;
  1414. ULONG EndingAddress;
  1415. ULONG EndOfPrologue;
  1416. } IMAGE_FUNCTION_ENTRY, *PIMAGE_FUNCTION_ENTRY;
  1417. typedef struct _IMAGE_FUNCTION_ENTRY64 {
  1418. ULONGLONG StartingAddress;
  1419. ULONGLONG EndingAddress;
  1420. union {
  1421. ULONGLONG EndOfPrologue;
  1422. ULONGLONG UnwindInfoAddress;
  1423. } u;
  1424. } IMAGE_FUNCTION_ENTRY64, *PIMAGE_FUNCTION_ENTRY64;
  1425. //
  1426. // Debugging information can be stripped from an image file and placed
  1427. // in a separate .DBG file, whose file name part is the same as the
  1428. // image file name part (e.g. symbols for CMD.EXE could be stripped
  1429. // and placed in CMD.DBG). This is indicated by the IMAGE_FILE_DEBUG_STRIPPED
  1430. // flag in the Characteristics field of the file header. The beginning of
  1431. // the .DBG file contains the following structure which captures certain
  1432. // information from the image file. This allows a debug to proceed even if
  1433. // the original image file is not accessable. This header is followed by
  1434. // zero of more IMAGE_SECTION_HEADER structures, followed by zero or more
  1435. // IMAGE_DEBUG_DIRECTORY structures. The latter structures and those in
  1436. // the image file contain file offsets relative to the beginning of the
  1437. // .DBG file.
  1438. //
  1439. // If symbols have been stripped from an image, the IMAGE_DEBUG_MISC structure
  1440. // is left in the image file, but not mapped. This allows a debugger to
  1441. // compute the name of the .DBG file, from the name of the image in the
  1442. // IMAGE_DEBUG_MISC structure.
  1443. //
  1444. typedef struct _IMAGE_SEPARATE_DEBUG_HEADER {
  1445. USHORT Signature;
  1446. USHORT Flags;
  1447. USHORT Machine;
  1448. USHORT Characteristics;
  1449. ULONG TimeDateStamp;
  1450. ULONG CheckSum;
  1451. ULONG ImageBase;
  1452. ULONG SizeOfImage;
  1453. ULONG NumberOfSections;
  1454. ULONG ExportedNamesSize;
  1455. ULONG DebugDirectorySize;
  1456. ULONG SectionAlignment;
  1457. ULONG Reserved[2];
  1458. } IMAGE_SEPARATE_DEBUG_HEADER, *PIMAGE_SEPARATE_DEBUG_HEADER;
  1459. typedef struct _NON_PAGED_DEBUG_INFO {
  1460. USHORT Signature;
  1461. USHORT Flags;
  1462. ULONG Size;
  1463. USHORT Machine;
  1464. USHORT Characteristics;
  1465. ULONG TimeDateStamp;
  1466. ULONG CheckSum;
  1467. ULONG SizeOfImage;
  1468. ULONGLONG ImageBase;
  1469. //DebugDirectorySize
  1470. //IMAGE_DEBUG_DIRECTORY
  1471. } NON_PAGED_DEBUG_INFO, *PNON_PAGED_DEBUG_INFO;
  1472. #ifndef _MAC
  1473. #define IMAGE_SEPARATE_DEBUG_SIGNATURE 0x4944
  1474. #define NON_PAGED_DEBUG_SIGNATURE 0x494E
  1475. #else
  1476. #define IMAGE_SEPARATE_DEBUG_SIGNATURE 0x4449 // DI
  1477. #define NON_PAGED_DEBUG_SIGNATURE 0x4E49 // NI
  1478. #endif
  1479. #define IMAGE_SEPARATE_DEBUG_FLAGS_MASK 0x8000
  1480. #define IMAGE_SEPARATE_DEBUG_MISMATCH 0x8000 // when DBG was updated, the
  1481. // old checksum didn't match.
  1482. //
  1483. // The .arch section is made up of headers, each describing an amask position/value
  1484. // pointing to an array of IMAGE_ARCHITECTURE_ENTRY's. Each "array" (both the header
  1485. // and entry arrays) are terminiated by a quadword of 0xffffffffL.
  1486. //
  1487. // NOTE: There may be quadwords of 0 sprinkled around and must be skipped.
  1488. //
  1489. typedef struct _ImageArchitectureHeader {
  1490. unsigned int AmaskValue: 1; // 1 -> code section depends on mask bit
  1491. // 0 -> new instruction depends on mask bit
  1492. int :7; // MBZ
  1493. unsigned int AmaskShift: 8; // Amask bit in question for this fixup
  1494. int :16; // MBZ
  1495. ULONG FirstEntryRVA; // RVA into .arch section to array of ARCHITECTURE_ENTRY's
  1496. } IMAGE_ARCHITECTURE_HEADER, *PIMAGE_ARCHITECTURE_HEADER;
  1497. typedef struct _ImageArchitectureEntry {
  1498. ULONG FixupInstRVA; // RVA of instruction to fixup
  1499. ULONG NewInst; // fixup instruction (see alphaops.h)
  1500. } IMAGE_ARCHITECTURE_ENTRY, *PIMAGE_ARCHITECTURE_ENTRY;
  1501. #include "poppack.h" // Back to the initial value
  1502. // The following structure defines the new import object. Note the values of the first two fields,
  1503. // which must be set as stated in order to differentiate old and new import members.
  1504. // Following this structure, the linker emits two null-terminated strings used to recreate the
  1505. // import at the time of use. The first string is the import's name, the second is the dll's name.
  1506. #define IMPORT_OBJECT_HDR_SIG2 0xffff
  1507. typedef struct IMPORT_OBJECT_HEADER {
  1508. USHORT Sig1; // Must be IMAGE_FILE_MACHINE_UNKNOWN
  1509. USHORT Sig2; // Must be IMPORT_OBJECT_HDR_SIG2.
  1510. USHORT Version;
  1511. USHORT Machine;
  1512. ULONG TimeDateStamp; // Time/date stamp
  1513. ULONG SizeOfData; // particularly useful for incremental links
  1514. union {
  1515. USHORT Ordinal; // if grf & IMPORT_OBJECT_ORDINAL
  1516. USHORT Hint;
  1517. } u;
  1518. USHORT Type : 2; // IMPORT_TYPE
  1519. USHORT NameType : 3; // IMPORT_NAME_TYPE
  1520. USHORT Reserved : 11; // Reserved. Must be zero.
  1521. } IMPORT_OBJECT_HEADER;
  1522. typedef enum IMPORT_OBJECT_TYPE
  1523. {
  1524. IMPORT_OBJECT_CODE = 0,
  1525. IMPORT_OBJECT_DATA = 1,
  1526. IMPORT_OBJECT_CONST = 2,
  1527. } IMPORT_OBJECT_TYPE;
  1528. typedef enum IMPORT_OBJECT_NAME_TYPE
  1529. {
  1530. IMPORT_OBJECT_ORDINAL = 0, // Import by ordinal
  1531. IMPORT_OBJECT_NAME = 1, // Import name == public symbol name.
  1532. IMPORT_OBJECT_NAME_NO_PREFIX = 2, // Import name == public symbol name skipping leading ?, @, or optionally _.
  1533. IMPORT_OBJECT_NAME_UNDECORATE = 3, // Import name == public symbol name skipping leading ?, @, or optionally _
  1534. // and truncating at first @
  1535. } IMPORT_OBJECT_NAME_TYPE;
  1536. // end_winnt
  1537. // The structure is used by the NT loader for clr URT support. It
  1538. // is a duplicate of the definition in corhdr.h.
  1539. // begin_winnt
  1540. #ifndef __IMAGE_COR20_HEADER_DEFINED__
  1541. #define __IMAGE_COR20_HEADER_DEFINED__
  1542. typedef enum ReplacesCorHdrNumericDefines
  1543. {
  1544. // COM+ Header entry point flags.
  1545. COMIMAGE_FLAGS_ILONLY =0x00000001,
  1546. COMIMAGE_FLAGS_32BITREQUIRED =0x00000002,
  1547. COMIMAGE_FLAGS_IL_LIBRARY =0x00000004,
  1548. COMIMAGE_FLAGS_STRONGNAMESIGNED =0x00000008,
  1549. COMIMAGE_FLAGS_NATIVE_ENTRYPOINT =0x00000010,
  1550. COMIMAGE_FLAGS_TRACKDEBUGDATA =0x00010000,
  1551. // Version flags for image.
  1552. COR_VERSION_MAJOR_V2 =2,
  1553. COR_VERSION_MAJOR =COR_VERSION_MAJOR_V2,
  1554. COR_VERSION_MINOR =0,
  1555. COR_DELETED_NAME_LENGTH =8,
  1556. COR_VTABLEGAP_NAME_LENGTH =8,
  1557. // Maximum size of a NativeType descriptor.
  1558. NATIVE_TYPE_MAX_CB =1,
  1559. COR_ILMETHOD_SECT_SMALL_MAX_DATASIZE=0xFF,
  1560. // #defines for the MIH FLAGS
  1561. IMAGE_COR_MIH_METHODRVA =0x01,
  1562. IMAGE_COR_MIH_EHRVA =0x02,
  1563. IMAGE_COR_MIH_BASICBLOCK =0x08,
  1564. // V-table constants
  1565. COR_VTABLE_32BIT =0x01, // V-table slots are 32-bits in size.
  1566. COR_VTABLE_64BIT =0x02, // V-table slots are 64-bits in size.
  1567. COR_VTABLE_FROM_UNMANAGED =0x04, // If set, transition from unmanaged.
  1568. COR_VTABLE_CALL_MOST_DERIVED =0x10, // Call most derived method described by
  1569. // EATJ constants
  1570. IMAGE_COR_EATJ_THUNK_SIZE =32, // Size of a jump thunk reserved range.
  1571. // Max name lengths
  1572. //<TODO> Change to unlimited name lengths. </TODO>
  1573. MAX_CLASS_NAME =1024,
  1574. MAX_PACKAGE_NAME =1024,
  1575. } ReplacesCorHdrNumericDefines;
  1576. // COM+ 2.0 header structure.
  1577. typedef struct IMAGE_COR20_HEADER
  1578. {
  1579. // Header versioning
  1580. ULONG cb;
  1581. USHORT MajorRuntimeVersion;
  1582. USHORT MinorRuntimeVersion;
  1583. // Symbol table and startup information
  1584. IMAGE_DATA_DIRECTORY MetaData;
  1585. ULONG Flags;
  1586. // If COMIMAGE_FLAGS_NATIVE_ENTRYPOINT is not set, EntryPointToken represents a managed entrypoint.
  1587. // If COMIMAGE_FLAGS_NATIVE_ENTRYPOINT is set, EntryPointRVA represents an RVA to a native entrypoint.
  1588. union {
  1589. ULONG EntryPointToken;
  1590. ULONG EntryPointRVA;
  1591. };
  1592. // Binding information
  1593. IMAGE_DATA_DIRECTORY Resources;
  1594. IMAGE_DATA_DIRECTORY StrongNameSignature;
  1595. // Regular fixup and binding information
  1596. IMAGE_DATA_DIRECTORY CodeManagerTable;
  1597. IMAGE_DATA_DIRECTORY VTableFixups;
  1598. IMAGE_DATA_DIRECTORY ExportAddressTableJumps;
  1599. // Precompiled image info (internal use only - set to zero)
  1600. IMAGE_DATA_DIRECTORY ManagedNativeHeader;
  1601. } IMAGE_COR20_HEADER, *PIMAGE_COR20_HEADER;
  1602. #endif // __IMAGE_COR20_HEADER_DEFINED__
  1603. //
  1604. // End Image Format
  1605. //
  1606. // end_winnt
  1607. #endif // _NTIMAGE_