diff options
author | midipix <writeonce@midipix.org> | 2015-05-02 10:05:51 -0400 |
---|---|---|
committer | midipix <writeonce@midipix.org> | 2016-11-10 23:35:18 -0500 |
commit | c0fbae7a40c662ae77f59f5f919cd6b88e38a85d (patch) | |
tree | ad6aaca1b75a1f4b5e9ac533220e382f49489c94 /include/perk/perk.h | |
parent | 99ace9f6a21b254216f60613e91191d902daeeb8 (diff) | |
download | perk-c0fbae7a40c662ae77f59f5f919cd6b88e38a85d.tar.bz2 perk-c0fbae7a40c662ae77f59f5f919cd6b88e38a85d.tar.xz |
initial commit.
Diffstat (limited to 'include/perk/perk.h')
-rw-r--r-- | include/perk/perk.h | 98 |
1 files changed, 98 insertions, 0 deletions
diff --git a/include/perk/perk.h b/include/perk/perk.h new file mode 100644 index 0000000..00d24d5 --- /dev/null +++ b/include/perk/perk.h @@ -0,0 +1,98 @@ +#ifndef PERK_H +#define PERK_H + +#include <stdint.h> +#include <stdio.h> + +#include <perk/perk_consts.h> +#include <perk/perk_structs.h> +#include <perk/perk_meta.h> +#include <perk/perk_output.h> + +#ifdef __cplusplus +extern "C" { +#endif + +/* pre-alpha */ +#ifndef PERK_APP +#ifndef PERK_PRE_ALPHA +#error libperk: pre-alpha: ABI is not final! +#error to use the library, please pass -DPERK_PRE_ALPHA to the compiler. +#endif +#endif + +/* exec flags */ +#define PERK_HELP 0x01 + +/* errors */ +#define PERK_OK 0x00 +#define PERK_BAD_OPT 0xA1 +#define PERK_BAD_OPT_VAL 0xA2 +#define PERK_IO_ERROR 0xA3 +#define PERK_MAP_ERROR 0xA4 +#define PERK_BAD_DOS_HEADER 0xA5 +#define PERK_BAD_COFF_HEADER 0xA6 +#define PERK_BAD_IMAGE_TYPE 0xA7 +#define PERK_MALFORMED_IMAGE 0xA8 + +struct pe_raw_image { + char * addr; + size_t size; +}; + +struct pe_image_summary { + uint32_t num_of_export_syms; + uint32_t num_of_implibs; + uint32_t num_of_relocs; +}; + +struct pe_image_meta { + struct pe_raw_image image; + struct pe_image_summary summary; + + struct pe_meta_image_dos_hdr dos; + struct pe_meta_coff_file_hdr coff; + struct pe_meta_opt_hdr opt; + struct pe_meta_sec_hdr * sectbl; + + struct pe_image_dos_hdr * ados; + struct pe_coff_file_hdr * acoff; + union pe_opt_hdr * aopt; + struct pe_sec_hdr * asectbl; + + struct pe_meta_export_hdr edata; + struct pe_export_hdr * aedata; + struct pe_meta_sec_hdr * hedata; + + struct pe_meta_import_hdr * idata; + struct pe_import_hdr * aidata; + struct pe_meta_sec_hdr * hidata; +}; + +/* utility api */ +int pe_output_export_symbols (const struct pe_image_meta *, uint32_t flags, FILE *); + +/* high-level api */ +int pe_map_raw_image (int fd, const char * name, struct pe_raw_image *); +int pe_unmap_raw_image (struct pe_raw_image *); + +int pe_get_image_meta (const struct pe_raw_image *, struct pe_image_meta **); +int pe_free_image_meta (struct pe_image_meta *); + +int pe_get_named_section_index (const struct pe_image_meta *, const char * name); +int pe_get_block_section_index (const struct pe_image_meta *, const struct pe_block *); + +/* low-level api */ +int pe_read_dos_header (const struct pe_image_dos_hdr *, struct pe_meta_image_dos_hdr *); +int pe_read_coff_header (const struct pe_coff_file_hdr *, struct pe_meta_coff_file_hdr *); +int pe_read_optional_header (const union pe_opt_hdr *, struct pe_meta_opt_hdr *); +int pe_read_section_header (const struct pe_sec_hdr *, struct pe_meta_sec_hdr *); +int pe_read_export_header (const struct pe_export_hdr *, struct pe_meta_export_hdr *); +int pe_read_import_header (const struct pe_import_hdr *, struct pe_meta_import_hdr *); +int pe_read_import_lookup_item (const struct pe_import_lookup_item *, struct pe_meta_import_lookup_item *,uint32_t magic); + +#ifdef __cplusplus +} +#endif + +#endif |