My favorites | Sign in
Project Home Downloads Issues Source
Checkout   Browse   Changes    
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689

struc IMAGE_DOS_HEADER
.e_magic resw 1
.e_cblp resw 1
.e_cp resw 1
.e_crlc resw 1
.e_cparhdr resw 1
.e_minalloc resw 1
.e_maxalloc resw 1
.e_ss resw 1
.e_sp resw 1
.e_csum resw 1
.e_ip resw 1
.e_cs resw 1
.e_lfarlc resw 1
.e_ovno resw 1
.e_res resw 4
.e_oemid resw 1
.e_oeminfo resw 1
.e_res2 resw 10
.e_lfanew resd 1
endstruc

struc IMAGE_NT_HEADERS
.Signature resd 1
; .FileHeader resb IMAGE_FILE_HEADER_size
; .OptionalHeader resb IMAGE_OPTIONAL_HEADER32_size
endstruc

struc IMAGE_FILE_HEADER
.Machine resw 1
.NumberOfSections resw 1
.TimeDateStamp resd 1
.PointerToSymbolTable resd 1
.NumberOfSymbols resd 1
.SizeOfOptionalHeader resw 1
.Characteristics resw 1
endstruc

;IMAGE_THUNK_DATA EQU <IMAGE_THUNK_DATA32>
;IMAGE_TLS_DIRECTORY EQU <IMAGE_TLS_DIRECTORY32>

;IMAGE_OPTIONAL_HEADER equ <IMAGE_OPTIONAL_HEADER32>
struc IMAGE_OPTIONAL_HEADER32
.Magic resw 1
.MajorLinkerVersion resb 1
.MinorLinkerVersion resb 1
.SizeOfCode resd 1
.SizeOfInitializedData resd 1
.SizeOfUninitializedData resd 1
.AddressOfEntryPoint resd 1
.BaseOfCode resd 1
.BaseOfData resd 1
.ImageBase resd 1
.SectionAlignment resd 1
.FileAlignment resd 1
.MajorOperatingSystemVersion resw 1
.MinorOperatingSystemVersion resw 1
.MajorImageVersion resw 1
.MinorImageVersion resw 1
.MajorSubsystemVersion resw 1
.MinorSubsystemVersion resw 1
.Win32VersionValue resd 1
.SizeOfImage resd 1
.SizeOfHeaders resd 1
.CheckSum resd 1
.Subsystem resw 1
.DllCharacteristics resw 1
.SizeOfStackReserve resd 1
.SizeOfStackCommit resd 1
.SizeOfHeapReserve resd 1
.SizeOfHeapCommit resd 1
.LoaderFlags resd 1
.NumberOfRvaAndSizes resd 1
.DataDirectory resb 0
endstruc

struc IMAGE_OPTIONAL_HEADER64
.Magic resw 1
.MajorLinkerVersion resb 1
.MinorLinkerVersion resb 1
.SizeOfCode resd 1
.SizeOfInitializedData resd 1
.SizeOfUninitializedData resd 1
.AddressOfEntryPoint resd 1
.BaseOfCode resd 1
.ImageBase resq 1
.SectionAlignment resd 1
.FileAlignment resd 1
.MajorOperatingSystemVersion resw 1
.MinorOperatingSystemVersion resw 1
.MajorImageVersion resw 1
.MinorImageVersion resw 1
.MajorSubsystemVersion resw 1
.MinorSubsystemVersion resw 1
.Win32VersionValue resd 1
.SizeOfImage resd 1
.SizeOfHeaders resd 1
.CheckSum resd 1
.Subsystem resw 1
.DllCharacteristics resw 1
.SizeOfStackReserve resq 1
.SizeOfStackCommit resq 1
.SizeOfHeapReserve resq 1
.SizeOfHeapCommit resq 1
.LoaderFlags resd 1
.NumberOfRvaAndSizes resd 1
.DataDirectory resb 0
endstruc

struc IMAGE_DATA_DIRECTORY
VirtualAddress resd 1
isize resd 1
endstruc

struc IMAGE_DATA_DIRECTORY2
ExportsVA resd 1
ExportsSize resd 1
ImportsVA resd 1
ImportsSize resd 1
endstruc

struc IMAGE_DATA_DIRECTORY_16
.ExportsVA resd 1
.ExportsSize resd 1
.ImportsVA resd 1
.ImportsSize resd 1
.ResourceVA resd 1
.ResourceSize resd 1
.Exception resd 2
.Security resd 2
.FixupsVA resd 1
.FixupsSize resd 1
.DebugVA resd 1
.DebugSize resd 1
.Description resd 2
.MIPS resd 2
.TLSVA resd 1
.TLSSize resd 1
.Load resd 2
.BoundImportsVA resd 1
.BoundImportsSize resd 1
.IATVA resd 1
.IATSize resd 1
.DelayImportsVA resd 1
.DelayImportsSize resd 1
.COM resd 2
.reserved resd 2
endstruc

IMAGE_SIZEOF_SHORT_NAME equ 8

struc IMAGE_SECTION_HEADER
.Name resb IMAGE_SIZEOF_SHORT_NAME
.VirtualSize resd 1
.VirtualAddress resd 1
.SizeOfRawData resd 1
.PointerToRawData resd 1
.PointerToRelocations resd 1
.PointerToLinenumbers resd 1
.NumberOfRelocations resw 1
.NumberOfLinenumbers resw 1
.Characteristics resd 1
endstruc

struc IMAGE_IMPORT_DESCRIPTOR
.OriginalFirstThunk resd 1 ; Characteristics
.TimeDateStamp resd 1
.ForwarderChain resd 1
.Name1 resd 1
.FirstThunk resd 1
endstruc

struc IMAGE_RESOURCE_DIRECTORY
.Characteristics resd 1
.TimeDateStamp resd 1
.MajorVersion resw 1
.MinorVersion resw 1
.NumberOfNamedEntries resw 1
.NumberOfIdEntries resw 1
endstruc

;struc IMAGE_RESOURCE_DIRECTORY_ENTRY
; union
; rName RECORD NameIsString:1,NameOffset:31
; Name1 resd ?
; Id resw ?
; ends
; union
; OffsetToData resd ?
; rDirectory RECORD DataIsDirectory:1,OffsetToDirectory:31
; ends
;endstruc
;
;struc IMAGE_IMPORT_BY_NAME
; Hint resw 1
; Name1 resb ?
;IMAGE_IMPORT_BY_NAME ENDS
;
;struc IMAGE_THUNK_DATA32
; union u1
; ForwarderString resd ?
; Function resd ?
; Ordinal resd ?
; AddressOfData resd ?
; ends
;endstruc

struc IMAGE_TLS_DIRECTORY32
.StartAddressOfRawData resd 1
.EndAddressOfRawData resd 1
.AddressOfIndex resd 1
.AddressOfCallBacks resd 1
.SizeOfZeroFill resd 1
.Characteristics resd 1
endstruc

struc exceptionHandler
.pException resd 1 ; EXCEPTION_RECORD
.pRegistrationRecord resd 1 ; EXCEPTION_REGISTRATION_RECORD
.pContext resd 1 ; CONTEXT
endstruc

EXCEPTION_MAXIMUM_PARAMETERS equ 15

struc EXCEPTION_RECORD
.ExceptionCode resd 1
.ExceptionFlags resd 1
.pExceptionRecord resd 1
.ExceptionAddress resd 1
.NumberParameters resd 1
.ExceptionInformation resd EXCEPTION_MAXIMUM_PARAMETERS
endstruc

struc EXCEPTION_REGISTRATION_RECORD
.Next resd 1 ; PEXCEPTION_REGISTRATION_RECORD
.Handler resd 1 ; PEXCEPTION_DISPOSITION
endstruc

CONTEXT_i386 equ 00010000h
CONTEXT_CONTROL equ CONTEXT_i386 | 00000001h
CONTEXT_INTEGER equ CONTEXT_i386 | 00000002h
CONTEXT_SEGMENTS equ CONTEXT_i386 | 00000004h
CONTEXT_FLOATING_POINT equ CONTEXT_i386 | 00000008h
CONTEXT_DEBUG_REGISTERS equ CONTEXT_i386 | 00000010h
CONTEXT_EXTENDED_REGISTERS equ CONTEXT_i386 | 00000020h
CONTEXT_FULL equ CONTEXT_CONTROL | CONTEXT_INTEGER | CONTEXT_SEGMENTS
CONTEXT_ALL equ CONTEXT_FULL | CONTEXT_FLOATING_POINT | CONTEXT_DEBUG_REGISTERS | CONTEXT_EXTENDED_REGISTERS

SIZE_OF_80387_REGISTERS equ 80
MAXIMUM_SUPPORTED_EXTENSION equ 512

struc CONTEXT
.ContextFlags resd 1
;CONTEXT_DEBUG_REGISTERS
.iDr0 resd 1
.iDr1 resd 1
.iDr2 resd 1
.iDr3 resd 1
.iDr6 resd 1
.iDr7 resd 1
;CONTEXT_FLOATING_POINT
.ControlWord resd 1
.StatusWord resd 1
.TagWord resd 1
.ErrorOffset resd 1
.ErrorSelector resd 1
.DataOffset resd 1
.DataSelector resd 1
.RegisterArea resb SIZE_OF_80387_REGISTERS
.Cr0NpxState resd 1
;CONTEXT_SEGMENTS
.regGs resd 1
.regFs resd 1
.regEs resd 1
.regDs resd 1
;CONTEXT_INTEGER
.regEdi resd 1
.regEsi resd 1
.regEbx resd 1
.regEdx resd 1
.regEcx resd 1
.regEax resd 1
;CONTEXT_CONTROL
.regEbp resd 1
.regEip resd 1
.regCs resd 1
.regFlag resd 1
.regEsp resd 1
.regSs resd 1
;CONTEXT_EXTENDED_REGISTERS
.ExtendedRegisters resb MAXIMUM_SUPPORTED_EXTENSION
endstruc

ExceptionContinueExecution equ 0
;ExceptionContinueSearch equ 1
;ExceptionNestedException equ 2
;ExceptionCollidedUnwind equ 3

struc PROCESS_INFORMATION
.hProcess resd 1
.hThread resd 1
.dwProcessId resd 1
.dwThreadId resd 1
endstruc

struc STARTUPINFO
.cb resd 1
.lpReserved resd 1
.lpDesktop resd 1
.lpTitle resd 1
.dwX resd 1
.dwY resd 1
.dwXSize resd 1
.dwYSize resd 1
.dwXCountChars resd 1
.dwYCountChars resd 1
.dwFillAttribute resd 1
.dwFlags resd 1
.wShowWindow resw 1
.cbReserved2 resw 1
.lpReserved2 resd 1
.hStdInput resd 1
.hStdOutput resd 1
.hStdError resd 1
endstruc

;Section characteristics
IMAGE_SCN_CNT_CODE equ 000000020h
IMAGE_SCN_CNT_INITIALIZED_DATA equ 000000040h
IMAGE_SCN_CNT_UNINITIALIZED_DATA equ 000000080h
IMAGE_SCN_LNK_OTHER equ 000000100h
IMAGE_SCN_LNK_INFO equ 000000200h
IMAGE_SCN_LNK_REMOVE equ 000000800h
IMAGE_SCN_LNK_COMDAT equ 000001000h
IMAGE_SCN_MEM_FARDATA equ 000008000h
IMAGE_SCN_MEM_PURGEABLE equ 000020000h
IMAGE_SCN_MEM_16BIT equ 000020000h
IMAGE_SCN_MEM_LOCKED equ 000040000h
IMAGE_SCN_MEM_PRELOAD equ 000080000h
IMAGE_SCN_ALIGN_1BYTES equ 000100000h
IMAGE_SCN_ALIGN_2BYTES equ 000200000h
IMAGE_SCN_ALIGN_4BYTES equ 000300000h
IMAGE_SCN_ALIGN_8BYTES equ 000400000h
IMAGE_SCN_ALIGN_16BYTES equ 000500000h
IMAGE_SCN_ALIGN_32BYTES equ 000600000h
IMAGE_SCN_ALIGN_64BYTES equ 000700000h
IMAGE_SCN_ALIGN_128BYTES equ 000800000h
IMAGE_SCN_ALIGN_256BYTES equ 000900000h
IMAGE_SCN_ALIGN_512BYTES equ 000A00000h
IMAGE_SCN_ALIGN_1024BYTES equ 000B00000h
IMAGE_SCN_ALIGN_2048BYTES equ 000C00000h
IMAGE_SCN_ALIGN_4096BYTES equ 000D00000h
IMAGE_SCN_ALIGN_8192BYTES equ 000E00000h
IMAGE_SCN_ALIGN_MASK equ 000F00000h
IMAGE_SCN_LNK_NRELOC_OVFL equ 001000000h
IMAGE_SCN_MEM_DISCARDABLE equ 002000000h
IMAGE_SCN_MEM_NOT_CACHED equ 004000000h
IMAGE_SCN_MEM_NOT_PAGED equ 008000000h
IMAGE_SCN_MEM_SHARED equ 010000000h
IMAGE_SCN_MEM_EXECUTE equ 020000000h
IMAGE_SCN_MEM_READ equ 040000000h
IMAGE_SCN_MEM_WRITE equ 080000000h

IMAGE_FILE_MACHINE_I386 equ 014ch
IMAGE_FILE_MACHINE_AMD64 equ 8664h

IMAGE_FILE_RELOCS_STRIPPED equ 00001h
IMAGE_FILE_EXECUTABLE_IMAGE equ 00002h
IMAGE_FILE_LINE_NUMS_STRIPPED equ 00004h
IMAGE_FILE_LOCAL_SYMS_STRIPPED equ 00008h
IMAGE_FILE_AGGRESIVE_WS_TRIM equ 00010h
IMAGE_FILE_LARGE_ADDRESS_AWARE equ 00020h
IMAGE_FILE_16BIT_MACHINE equ 00040h
IMAGE_FILE_BYTES_REVERSED_LO equ 00080h
IMAGE_FILE_32BIT_MACHINE equ 00100h
IMAGE_FILE_DEBUG_STRIPPED equ 00200h
IMAGE_FILE_REMOVABLE_RUN_FROM_SWAP equ 00400h
IMAGE_FILE_NET_RUN_FROM_SWAP equ 00800h
IMAGE_FILE_SYSTEM equ 01000h
IMAGE_FILE_DLL equ 02000h
IMAGE_FILE_UP_SYSTEM_ONLY equ 04000h
IMAGE_FILE_BYTES_REVERSED_HI equ 08000h

IMAGE_SUBSYSTEM_NATIVE equ 1
IMAGE_SUBSYSTEM_WINDOWS_GUI equ 2
IMAGE_SUBSYSTEM_WINDOWS_CUI equ 3

IMAGE_NT_OPTIONAL_HDR32_MAGIC equ 010bh
IMAGE_NT_OPTIONAL_HDR64_MAGIC equ 020bh

MB_ICONINFORMATION equ 040h
MB_ICONERROR equ 10h

;relocations types
IMAGE_REL_BASED_ABSOLUTE equ 0
IMAGE_REL_BASED_HIGHLOW equ 3

DLL_PROCESS_DETACH equ 0
DLL_PROCESS_ATTACH equ 1

OPEN_EXISTING equ 3

FILE_SHARE_READ equ 1h

STATUS_DEVICE_CONFIGURATION_ERROR equ 0C0000182h

STATUS_GUARD_PAGE_VIOLATION equ 080000001h
BREAKPOINT equ 080000003h
SINGLE_STEP equ 80000004h
ACCESS_VIOLATION equ 0c0000005h
INVALID_HANDLE equ 0C0000008h
INVALID_LOCK_SEQUENCE equ 0C000001eh
INTEGER_DIVIDE_BY_ZERO equ 0C0000094h
INTEGER_OVERFLOW equ 0C0000095h
PRIVILEGED_INSTRUCTION equ 0C0000096h

PAGE_READONLY equ 2
PAGE_READWRITE equ 4
PAGE_EXECUTE_READWRITE equ 40h
PAGE_GUARD equ 100h

PROCESS_CREATE_THREAD equ 2
PROCESS_QUERY_INFORMATION equ 0400h
PROCESS_VM_OPERATION equ 08h
PROCESS_VM_READ equ 010h
PROCESS_VM_WRITE equ 020h

FILE_BEGIN equ 0
CREATE_NEW equ 1

DEBUG_PROCESS equ 1h
CREATE_SUSPENDED equ 4

RT_STRING equ 6
RT_RCDATA equ 10
RT_VERSION equ 16

GENERIC_READ equ 80000000h
GENERIC_WRITE equ 40000000h

MEM_COMMIT equ 1000h
MEM_RELEASE equ 08000h

IMAGE_RESOURCE_NAME_IS_STRING equ 80000000h
IMAGE_RESOURCE_DATA_IS_DIRECTORY equ 80000000h

%define PREFIX_FS db 64h
%define PREFIX_OPERANDSIZE db 66h
%define PREFIX_ADDRESSSIZE db 67h

%macro setSEH 1
push %1
push dword [fs:0]
mov [fs:0], esp
%endmacro

%macro clearSEH 0
pop dword [fs:0]
add esp, 4
%endmacro

%macro getPEB 1
mov %1, [fs:30h]
%endmacro

%macro getTEB 1
mov %1, [fs:30h]
%endmacro

struc PEB
.InheritedAddressSpace resb 1
.ReadImageFileExecOptions resb 1
.BeingDebugged resb 1
.Spare resb 1
.Mutant resd 1
.ImageBaseAddress resd 1
.LoaderData resd 1 ; PPEB_LDR_DATA
.ProcessParameters resd 1 ; PRTL_USER_PROCESS_PARAMETERS
.SubSystemData resd 1
.ProcessHeap resd 1
.FastPebLock resd 1
.FastPebLockRoutine resd 1 ; PPEBLOCKROUTINE
.FastPebUnlockRoutine resd 1 ; PPEBLOCKROUTINE
.EnvironmentUpdateCount resd 1
.KernelCallbackTable resd 1
.EventLogSection resd 1
.EventLog resd 1
.FreeList resd 1 ; PPEB_FREE_BLOCK
.TlsExpansionCounter resd 1
.TlsBitmap resd 1
.TlsBitmapBits resd 2
.ReadOnlySharedMemoryBase resd 1
.ReadOnlySharedMemoryHeap resd 1
.ReadOnlyStaticServerData resd 1
.AnsiCodePageData resd 1
.OemCodePageData resd 1
.UnicodeCaseTableData resd 1
.NumberOfProcessors resd 1
.NtGlobalFlag resd 1
.Spare2 resb 4
.CriticalSectionTimeout resd 2 ; LARGE_INTEGER
.HeapSegmentReserve resd 1
.HeapSegmentCommit resd 1
.HeapDeCommitTotalFreeThreshold resd 1
.HeapDeCommitFreeBlockThreshold resd 1
.NumberOfHeaps resd 1
.MaximumNumberOfHeaps resd 1
.ProcessHeaps resd 1
.GdiSharedHandleTable resd 1
.ProcessStarterHelper resd 1
.GdiDCAttributeList resd 1
.LoaderLock resd 1
.OSMajorVersion resd 1
.OSMinorVersion resd 1
.OSBuildNumber resd 1
.OSPlatformId resd 1
.ImageSubSystem resd 1
.ImageSubSystemMajorVersion resd 1
.ImageSubSystemMinorVersion resd 1
.ImageProcessAffinityMask resd 1 ; some docs don't mention that field
.GdiHandleBuffer resd 022h
.PostProcessInitRoutine resd 1
.TlsExpansionBitmap resd 1
.TlsExpansionBitmapBits resd 32
.SessionId resd 1
endstruc

struc _HEAP ; only the start
.Entry resd 2
.Signature resd 1
.Flags resd 1
.ForceFlags resd 1
.VirtualMemoryThreshold resd 1
.SegmentReserve resd 1
.SegmentCommit resd 1
endstruc

HEAP_GROWABLE equ 2

FLG_HEAP_ENABLE_FREE_CHECK equ 010h
FLG_HEAP_ENABLE_TAIL_CHECK equ 020h
FLG_HEAP_VALIDATE_PARAMETERS equ 040h

struc PEB_LDR_DATA
.Length resd 1
.Initialized resd 1
.SsHandle resd 1
.InLoadOrderModuleList resd 2
.InMemoryOrderModuleList resd 2
.InInitializationOrderModuleList resd 2
.EntryInProgress resd 1
endstruc

struc LDR_MODULE
.InLoadOrderModuleList resd 2
.InMemoryOrderModuleList resd 2
.InInitializationOrderModuleList resd 2
.BaseAddress resd 1
.EntryPoint resd 1
.SizeOfImage resd 1
.FullDllName resd 1
.BaseDllName resd 1
.Flags resd 1
.LoadCount resd 1
.TlsIndex resd 1
.HashTableEntry resd 1
.TimeDateStamp resd 1
endstruc

%macro IceBP 0
db 0f1h
%endmacro

struc _IMAGE_DELAY_IMPORT_DESCRIPTOR
.grAttrs resd 1 ; attributes
.rvaDLLName resd 1 ; RVA to dll name
.rvaHmod resd 1 ; RVA of module handle
.rvaIAT resd 1 ; RVA of the IAT
.rvaINT resd 1 ; RVA of the INT
.rvaBoundIAT resd 1 ; RVA of the optional bound IAT
.rvaUnloadIAT resd 1 ; RVA of optional copy of original IAT
.dwTimeStamp resd 1 ; 0 if not bound
endstruc

IMAGE_DEBUG_TYPE_COFF equ 1
IMAGE_DEBUG_TYPE_CODEVIEW equ 2
IMAGE_DEBUG_TYPE_BORLAND equ 9

struc IMAGE_DEBUG_DIRECTORY
.Characteristics resd 1 ;unused
.TimeDateStamp resd 1 ;minor
.MajorVersion resw 1 ;unused
.MinorVersion resw 1 ;unused
.Type1 resd 1 ;1 Coff/2 CV-PDB/9 Borland
.SizeOfData resd 1
.AddressOfRawData resd 1 ;rva
.PointerToRawData resd 1 ;offset
endstruc

struc IMAGE_COR20_HEADER
.cb resd 1 ;size of header
.MajorRuntimeVersion resw 1
.MinorRuntimeVersion resw 1
.MetaData resd 1 ;rva
.Flags resd 1
.EntryPointToken resd 1
.Resources resd 1 ;rva
.StrongNameSignature resd 1 ;rva
.CodeManagerTable resd 1 ;rva
.VTableFixups resd 1 ;rva
.ExportAddressTableJumps resd 1 ;rva
.ManagedNativeHeader resd 1 ;rva, set to 0 on binaries
endstruc

struc IMAGE_LOAD_CONFIG_DIRECTORY
.Characteristics resd 1 ; 64 for x86
.TimeDateStamp resd 1
.MajorVersion resw 1
.MinorVersion resw 1
.GlobalFlagsClear resd 1
.GlobalFlagsSet resd 1
.CriticalSectionDefaultTimeout resd 1
.DeCommitFreeBlockThreshold resd 1
.DeCommitTotalFreeThreshold resd 1
.LockPrefixTable resd 1 ; VA
.MaximumAllocationSize resd 1
.VirtualMemoryThreshold resd 1
.ProcessHeapFlags resd 1
.ProcessAffinityMask resd 1
.CSDVersion resw 1
.Reserved1 resw 1
.EditList resd 1 ;VA
.Reserved resd 1 ;VA
.SecurityCookie resd 1 ;VA
.SEHandlerTable resd 1 ;VA
.SEHandlerCount resd 1 ;VA
endstruc

struc IMAGE_LOAD_CONFIG_DIRECTORY64
.Characteristics resd 1
.TimeDateStamp resd 1
.MajorVersion resw 1
.MinorVersion resw 1
.GlobalFlagsClear resd 1
.GlobalFlagsSet resd 1
.CriticalSectionDefaultTimeout resd 1
.DeCommitFreeBlockThreshold resq 1
.DeCommitTotalFreeThreshold resq 1
.LockPrefixTable resq 1 ; VA
.MaximumAllocationSize resq 1
.VirtualMemoryThreshold resq 1
.ProcessAffinityMask resq 1 ; swapped place
.ProcessHeapFlags resd 1 ; swapped place
.CSDVersion resw 1
.Reserved1 resw 1
.EditList resq 1 ;VA
.SecurityCookie resq 1 ;VA
.SEHandlerTable resq 1 ;VA
.SEHandlerCount resq 1 ;VA
endstruc

struc IMAGE_COFF_SYMBOLS_HEADER
.NumberOfSymbols resd 1
.LvaToFirstSymbol resd 1 ; VA
.NumberOfLinenumbers resd 1
.LvaToFirstLinenumber resd 1 ; VA
.RvaToFirstByteOfCode resd 1 ;RVA
.RvaToLastByteOfCode resd 1 ;RVA
.RvaToFirstByteOfData resd 1 ;RVA
.RvaToLastByteOfData resd 1 ;RVA
endstruc

%macro _ 0
nop
%endmacro

%macro _c 0
int3
align 4, int3
%endmacro

%macro _d 0
db 0
align 16, db 0
%endmacro


; Ange Albertini, BSD Licence 2009-2011

Change log

r544 by ange.albertini on May 11, 2011   Diff
minor alignment change
Go to: 
Project members, sign in to write a code review

Older revisions

r406 by ange.albertini on Mar 7, 2011   Diff
added _c _d _ macros to consts
onesec now writeable section, for
higher compatibility:

all import*.asm: reorganized code,
...
r375 by ange.albertini on Feb 12, 2011   Diff
added debug, load_config, COM
directories
r372 by ange.albertini on Feb 12, 2011   Diff
delay imports example now working,
added to makefile
All revisions of this file

File info

Size: 21486 bytes, 689 lines
Powered by Google Project Hosting