93#define IMAGE_NUMBEROF_DIRECTORY_ENTRIES 16
176#define IMAGE_NUMBEROF_DIRECTORY_ENTRIES 16
179#define IMAGE_SCN_CNT_CODE 0x00000020
180#define IMAGE_SCN_CNT_INITIALIZED_DATA 0x00000040
181#define IMAGE_SCN_CNT_UNINITIALIZED_DATA 0x00000080
182#define IMAGE_SCN_MEM_DISCARDABLE 0x02000000
183#define IMAGE_SCN_MEM_NOT_CACHED 0x04000000
184#define IMAGE_SCN_MEM_NOT_PAGED 0x08000000
185#define IMAGE_SCN_MEM_SHARED 0x10000000
186#define IMAGE_SCN_MEM_EXECUTE 0x20000000
187#define IMAGE_SCN_MEM_READ 0x40000000
188#define IMAGE_SCN_MEM_WRITE 0x80000000
203#define IMAGE_DATA_DIRECTORY_EXPORT 0
204#define IMAGE_DATA_DIRECTORY_IMPORT 1
248#define IMAGE_IMPORT_LOOKUP_TABLE_FLAG_PE32 0x80000000
251#define IMAGE_IMPORT_LOOKUP_TABLE_FLAG_PE32P 0x8000000000000000
261#define IMAGE_IMPORT_LOOKUP_TABLE_FLAG IMAGE_IMPORT_LOOKUP_TABLE_FLAG_PE32
struct _IMAGE_RELOCATION_ENTRY_ IMAGE_RELOCATION_ENTRY
void AuPEPrintExports(void *image)
AuPEPrintExports – print all function exports for DEBUG purpose.
Definition pe.cpp:72
bool AuPEFileIsDynamicallyLinked(void *image)
AuPEFileIsDynamicallyLinked – checks if the current binary image is dynamically linked.
Definition pe.cpp:244
struct _IMAGE_FILE_HEADER_ * PIMAGE_FILE_HEADER
PeMachineType
Definition pe.h:63
@ IMAGE_FILE_MACHINE_THUMB
Definition pe.h:68
@ IMAGE_FILE_MACHINE_ARM
Definition pe.h:65
@ IMAGE_FILE_MACHINE_EBC
Definition pe.h:66
@ IMAGE_FILE_MACHINE_AMD64
Definition pe.h:64
@ IMAGE_FILE_MACHINE_I386
Definition pe.h:67
@ IMAGE_FILE_MACHINE_ARM64
Definition pe.h:69
@ IMAGE_FILE_MACHINE_ARMNT
Definition pe.h:70
struct _IMAGE_IMPORT_HINT_TABLE * PIMAGE_IMPORT_HINT_TABLE
unsigned long long * PIMAGE_IMPORT_LOOKUP_TABLE_PE32P
Definition pe.h:252
struct _IMAGE_DOS_HEADER_ IMAGE_DOS_HEADER
struct _IMAGE_OPTIONAL_HEADER_PE32PLUS IMAGE_OPTIONAL_HEADER_PE32PLUS
void AuKernelLinkDLL(void *image)
AuKernelLinkDLL – Links a dll library to kernel symbols.
Definition pe.cpp:96
struct _IMAGE_IMPORT_DIRECTORY * PIMAGE_IMPORT_DIRECTORY
struct _IMAGE_RELOCATION_BLOCK_ * PIMAGE_RELOCATION_BLOCK
IMAGE_IMPORT_LOOKUP_TABLE_PE32 * PIMAGE_IMPORT_LOOKUP_TABLE
Definition pe.h:257
struct _IMAGE_DATA_DIRECTORY_ IMAGE_DATA_DIRECTORY
struct _IMAGE_OPTIONAL_HEADER_PE32PLUS * PIMAGE_OPTIONAL_HEADER_PE32PLUS
uint32_t * PIMAGE_IMPORT_LOOKUP_TABLE_PE32
Definition pe.h:249
struct _IMAGE_NT_HEADERS_PE32PLUS * PIMAGE_NT_HEADERS
Definition pe.h:256
struct _IMAGE_NT_HEADERS_PE32_ * PIMAGE_NT_HEADERS_PE32
Definition pe.h:60
struct _IMAGE_OPTIONAL_HEADER_PE32_ * PIMAGE_OPTIONAL_HEADER_PE32
struct _IMAGE_SECTION_HEADER SECTION_HEADER
struct _IMAGE_EXPORT_DIRECTORY * PIMAGE_EXPORT_DIRECTORY
struct _IMAGE_RELOCATION_BLOCK_ IMAGE_RELOCATION_BLOCK
struct _IMAGE_SECTION_HEADER * PSECTION_HEADER
struct _IMAGE_OPTIONAL_HEADER_PE32_ IMAGE_OPTIONAL_HEADER_PE32
void AuKernelLinkImports(void *image)
Definition pe.cpp:125
void AuKernelRelocatePE(void *image, PIMAGE_NT_HEADERS nt, int diff)
AuKernelRelocatePE – relocates the image from its actual base address.
Definition pe.cpp:187
PeOptionalMagic
Definition pe.h:83
@ MAGIC_PE32P
Definition pe.h:85
@ MAGIC_PE32
Definition pe.h:84
struct _IMAGE_IMPORT_DIRECTORY IMAGE_IMPORT_DIRECTORY
struct _IMAGE_DOS_HEADER_ * PIMAGE_DOS_HEADER
struct _IMAGE_EXPORT_DIRECTORY IMAGE_EXPORT_DIRECTORY
IMAGE_IMPORT_LOOKUP_TABLE_PE32 IMAGE_IMPORT_LOOKUP_TABLE
Definition pe.h:257
struct _IMAGE_RELOCATION_ENTRY_ * PIMAGE_RELOCATION_ENTRY
struct _IMAGE_NT_HEADERS_PE32PLUS_ * PIMAGE_NT_HEADERS_PE32PLUS
Definition pe.h:61
struct _IMAGE_NT_HEADERS_PE32PLUS_ IMAGE_NT_HEADERS_PE32PLYS
Definition pe.h:61
unsigned long long IMAGE_IMPORT_LOOKUP_TABLE_PE32P
Definition pe.h:252
void * AuGetProcAddress(void *image, const char *procname)
AuGetProcAddress – get procedure address in a dll image.
Definition pe.cpp:41
struct _IMAGE_IMPORT_HINT_TABLE IMAGE_IMPORT_HINT_TABLE
struct _IMAGE_NT_HEADERS_PE32_ IMAGE_NT_HEADERS_PE32
Definition pe.h:60
struct _IMAGE_DATA_DIRECTORY_ * PIMAGE_DATA_DIRECTORY
struct _IMAGE_FILE_HEADER_ IMAGE_FILE_HEADER
uint32_t IMAGE_IMPORT_LOOKUP_TABLE_PE32
Definition pe.h:249
unsigned int uint32_t
Definition acefiex.h:163
unsigned char uint8_t
Definition acefiex.h:161
COMPILER_DEPENDENT_UINT64 uint64_t
Definition acefiex.h:165
unsigned short int uint16_t
Definition acefiex.h:162
#define IMAGE_NUMBEROF_DIRECTORY_ENTRIES
Definition pe_.h:94
uint32_t VirtualAddress
Definition pe.h:89
uint32_t Size
Definition pe.h:90
uint32_t TimeDateStamp
Definition pe.h:208
uint32_t AddressOfNames
Definition pe.h:216
uint32_t NumberOfFunctions
Definition pe.h:213
uint32_t Base
Definition pe.h:212
uint32_t NumberOfNames
Definition pe.h:214
uint16_t MajorVersion
Definition pe.h:209
uint32_t Characteristics
Definition pe.h:207
uint32_t AddressOfFunctions
Definition pe.h:215
uint32_t AddressOfNameOrdinal
Definition pe.h:217
uint16_t MinorVersion
Definition pe.h:210
uint32_t Name
Definition pe.h:211
uint32_t Characteristics
Definition pe.h:222
uint32_t OriginalFirstThunk
Definition pe.h:223
uint32_t ThunkTableRva
Definition pe.h:228
uint32_t ForwarderChain
Definition pe.h:226
uint32_t TimeDateStamp
Definition pe.h:225
uint32_t NameRva
Definition pe.h:227
char name[2]
Definition pe.h:244
uint16_t Hint
Definition pe.h:243
IMAGE_RELOCATION_ENTRY entries[0]
Definition pe.h:239
uint32_t BlockSize
Definition pe.h:238
uint32_t PageRVA
Definition pe.h:237
uint16_t offset
Definition pe.h:232
uint16_t type
Definition pe.h:233