summaryrefslogtreecommitdiffhomepage
path: root/src/hdrdump
diff options
context:
space:
mode:
authormidipix <writeonce@midipix.org>2025-05-30 22:16:01 +0000
committermidipix <writeonce@midipix.org>2025-05-30 23:44:08 +0000
commit9e2275f12aea1d90c206ea597f42cdd82f9a38ae (patch)
tree51c582d37514aa079818f8f845353910a5b08cd5 /src/hdrdump
parent77fbc135fe043aa259c264ba60088491d1a4bbfc (diff)
downloadperk-9e2275f12aea1d90c206ea597f42cdd82f9a38ae.tar.bz2
perk-9e2275f12aea1d90c206ea597f42cdd82f9a38ae.tar.xz
library api: _hexdump_ (header and section pretty printing) namespace overhaul.
Diffstat (limited to 'src/hdrdump')
-rw-r--r--src/hdrdump/pe_hdrdump_coff_image_hdr.c65
-rw-r--r--src/hdrdump/pe_hdrdump_coff_object_hdr.c64
-rw-r--r--src/hdrdump/pe_hdrdump_coff_opt_hdr.c211
-rw-r--r--src/hdrdump/pe_hdrdump_export_hdr.c68
-rw-r--r--src/hdrdump/pe_hdrdump_image_dos_hdr.c76
-rw-r--r--src/hdrdump/pe_hdrdump_import_tbl.c109
-rw-r--r--src/hdrdump/pe_hdrdump_sec_tbl.c83
7 files changed, 0 insertions, 676 deletions
diff --git a/src/hdrdump/pe_hdrdump_coff_image_hdr.c b/src/hdrdump/pe_hdrdump_coff_image_hdr.c
deleted file mode 100644
index 3ce0e2c..0000000
--- a/src/hdrdump/pe_hdrdump_coff_image_hdr.c
+++ /dev/null
@@ -1,65 +0,0 @@
-/***************************************************************/
-/* perk: PE Resource Kit */
-/* Copyright (C) 2015--2021 SysDeer Technologies, LLC */
-/* Released under GPLv2 and GPLv3; see COPYING.PERK. */
-/***************************************************************/
-
-#include <stdio.h>
-
-#include <perk/perk.h>
-#include <perk/perk_consts.h>
-#include <perk/perk_structs.h>
-#include <perk/perk_output.h>
-#include "perk_driver_impl.h"
-#include "perk_hdrdump_impl.h"
-#include "perk_dprintf_impl.h"
-#include "perk_errinfo_impl.h"
-
-#define PE_ADDR meta->r_coff
-#define PE_RAW_STRUCT coff_image_hdr
-#define PE_OUTPUT(x) PE_OUTPUT_TABLE(x)
-
-int pe_hdrdump_coff_image_hdr(
- const struct pe_driver_ctx * dctx,
- const struct pe_image_meta * meta)
-{
- int bits;
- uint64_t faddr;
- uint64_t vaddr;
- char * ch;
- char buf[8192];
-
- if (!PE_ADDR)
- return 0;
-
- if ((bits = pe_image_bits(meta)) < 0)
- return PERK_CUSTOM_ERROR(
- dctx,PERK_ERR_UNSUPPORTED_ABI);
-
- faddr = (char *)(PE_ADDR) - (char *)meta->r_image.map_addr;
- vaddr = meta->m_opt.oh_mem.coh_image_base + faddr;
-
- ch = buf;
- ch += pe_output_hex_header(
- ch,
- "struct pe_raw_coff_image_hdr",
- faddr,vaddr,bits);
-
- ch += PE_OUTPUT(cfh_signature);
- ch += PE_OUTPUT(cfh_machine);
- ch += PE_OUTPUT(cfh_num_of_sections);
- ch += PE_OUTPUT(cfh_time_date_stamp);
- ch += PE_OUTPUT(cfh_ptr_to_sym_tbl);
- ch += PE_OUTPUT(cfh_num_of_syms);
- ch += PE_OUTPUT(cfh_size_of_opt_hdr);
- ch += PE_OUTPUT(cfh_characteristics);
-
- ch += pe_output_hex_footer(ch);
-
- *ch = 0;
-
- if (pe_dprintf(pe_driver_fdout(dctx),"%s",buf) < 0)
- return PERK_FILE_ERROR(dctx);
-
- return 0;
-}
diff --git a/src/hdrdump/pe_hdrdump_coff_object_hdr.c b/src/hdrdump/pe_hdrdump_coff_object_hdr.c
deleted file mode 100644
index 0011a34..0000000
--- a/src/hdrdump/pe_hdrdump_coff_object_hdr.c
+++ /dev/null
@@ -1,64 +0,0 @@
-/***************************************************************/
-/* perk: PE Resource Kit */
-/* Copyright (C) 2015--2021 SysDeer Technologies, LLC */
-/* Released under GPLv2 and GPLv3; see COPYING.PERK. */
-/***************************************************************/
-
-#include <stdio.h>
-
-#include <perk/perk.h>
-#include <perk/perk_consts.h>
-#include <perk/perk_structs.h>
-#include <perk/perk_output.h>
-#include "perk_driver_impl.h"
-#include "perk_hdrdump_impl.h"
-#include "perk_dprintf_impl.h"
-#include "perk_errinfo_impl.h"
-
-#define PE_ADDR meta->r_obj
-#define PE_RAW_STRUCT coff_object_hdr
-#define PE_OUTPUT(x) PE_OUTPUT_TABLE(x)
-
-int pe_hdrdump_coff_object_hdr(
- const struct pe_driver_ctx * dctx,
- const struct pe_image_meta * meta)
-{
- int bits;
- uint64_t faddr;
- uint64_t vaddr;
- char * ch;
- char buf[8192];
-
- if (!PE_ADDR)
- return 0;
-
- if ((bits = pe_image_bits(meta)) < 0)
- return PERK_CUSTOM_ERROR(
- dctx,PERK_ERR_UNSUPPORTED_ABI);
-
- faddr = (char *)(PE_ADDR) - (char *)meta->r_image.map_addr;
- vaddr = meta->m_opt.oh_mem.coh_image_base + faddr;
-
- ch = buf;
- ch += pe_output_hex_header(
- ch,
- "struct pe_raw_coff_object_hdr",
- faddr,vaddr,bits);
-
- ch += PE_OUTPUT(cfh_machine);
- ch += PE_OUTPUT(cfh_num_of_sections);
- ch += PE_OUTPUT(cfh_time_date_stamp);
- ch += PE_OUTPUT(cfh_ptr_to_sym_tbl);
- ch += PE_OUTPUT(cfh_num_of_syms);
- ch += PE_OUTPUT(cfh_size_of_opt_hdr);
- ch += PE_OUTPUT(cfh_characteristics);
-
- ch += pe_output_hex_footer(ch);
-
- *ch = 0;
-
- if (pe_dprintf(pe_driver_fdout(dctx),"%s",buf) < 0)
- return PERK_FILE_ERROR(dctx);
-
- return 0;
-}
diff --git a/src/hdrdump/pe_hdrdump_coff_opt_hdr.c b/src/hdrdump/pe_hdrdump_coff_opt_hdr.c
deleted file mode 100644
index fbec549..0000000
--- a/src/hdrdump/pe_hdrdump_coff_opt_hdr.c
+++ /dev/null
@@ -1,211 +0,0 @@
-/***************************************************************/
-/* perk: PE Resource Kit */
-/* Copyright (C) 2015--2021 SysDeer Technologies, LLC */
-/* Released under GPLv2 and GPLv3; see COPYING.PERK. */
-/***************************************************************/
-
-#include <stdio.h>
-
-#include <perk/perk.h>
-#include <perk/perk_consts.h>
-#include <perk/perk_structs.h>
-#include <perk/perk_output.h>
-#include "perk_driver_impl.h"
-#include "perk_hdrdump_impl.h"
-#include "perk_dprintf_impl.h"
-#include "perk_errinfo_impl.h"
-
-#define PE_ADDR &meta->r_opt->opt_hdr_32
-#define PE_RAW_STRUCT opt_hdr_32
-#define PE_OUTPUT(x) PE_OUTPUT_TABLE(x)
-
-static int pe_hdrdump_opt_hdr_32(
- const struct pe_driver_ctx * dctx,
- const struct pe_image_meta * meta)
-{
- void * uaddr;
- const char * haddr;
- const char * maddr;
- uintptr_t faddr;
- uintptr_t vaddr;
- char * ch;
- char buf[8192];
-
- uaddr = &meta->r_opt->opt_hdr_32;
- maddr = meta->r_image.map_addr;
-
- haddr = uaddr;
- faddr = haddr - maddr;
- vaddr = meta->m_opt.oh_mem.coh_image_base + faddr;
-
- ch = buf;
- ch += pe_output_hex_header(
- ch,
- "struct pe_raw_opt_hdr_32",
- faddr,vaddr,32);
-
- ch += PE_OUTPUT(coh_magic);
- ch += PE_OUTPUT(coh_major_linker_ver);
- ch += PE_OUTPUT(coh_minor_linker_ver);
- ch += PE_OUTPUT(coh_size_of_code);
- ch += PE_OUTPUT(coh_size_of_inited_data);
- ch += PE_OUTPUT(coh_size_of_uninited_data);
- ch += PE_OUTPUT(coh_entry_point);
- ch += PE_OUTPUT(coh_base_of_code);
- ch += PE_OUTPUT(coh_base_of_data);
- ch += PE_OUTPUT(coh_image_base);
- ch += PE_OUTPUT(coh_section_align);
- ch += PE_OUTPUT(coh_file_align);
- ch += PE_OUTPUT(coh_major_os_ver);
- ch += PE_OUTPUT(coh_minor_os_ver);
- ch += PE_OUTPUT(coh_major_image_ver);
- ch += PE_OUTPUT(coh_minor_image_ver);
- ch += PE_OUTPUT(coh_major_subsys_ver);
- ch += PE_OUTPUT(coh_minor_subsys_ver);
- ch += PE_OUTPUT(coh_win32_ver);
- ch += PE_OUTPUT(coh_size_of_image);
- ch += PE_OUTPUT(coh_size_of_headers);
- ch += PE_OUTPUT(coh_checksum);
- ch += PE_OUTPUT(coh_subsystem);
- ch += PE_OUTPUT(coh_dll_characteristics);
- ch += PE_OUTPUT(coh_size_of_stack_reserve);
- ch += PE_OUTPUT(coh_size_of_stack_commit);
- ch += PE_OUTPUT(coh_size_of_heap_reserve);
- ch += PE_OUTPUT(coh_size_of_heap_commit);
- ch += PE_OUTPUT(coh_loader_flags);
- ch += PE_OUTPUT(coh_rva_and_sizes);
- ch += PE_OUTPUT(coh_export_tbl);
- ch += PE_OUTPUT(coh_import_tbl);
- ch += PE_OUTPUT(coh_resource_tbl);
- ch += PE_OUTPUT(coh_exception_tbl);
- ch += PE_OUTPUT(coh_certificate_tbl);
- ch += PE_OUTPUT(coh_base_reloc_tbl);
- ch += PE_OUTPUT(coh_debug);
- ch += PE_OUTPUT(coh_arch);
- ch += PE_OUTPUT(coh_global_ptr);
- ch += PE_OUTPUT(coh_tls_tbl);
- ch += PE_OUTPUT(coh_load_config_tbl);
- ch += PE_OUTPUT(coh_bound_import);
- ch += PE_OUTPUT(coh_iat);
- ch += PE_OUTPUT(coh_delay_import_descriptor);
- ch += PE_OUTPUT(coh_clr_runtime_hdr);
- ch += PE_OUTPUT(coh_reserved);
-
- ch += pe_output_hex_footer(ch);
-
- *ch = 0;
-
- if (pe_dprintf(pe_driver_fdout(dctx),"%s",buf) < 0)
- return PERK_FILE_ERROR(dctx);
-
- return 0;
-}
-
-#undef PE_ADDR
-#undef PE_RAW_STRUCT
-#undef PE_OUTPUT
-
-#define PE_ADDR &meta->r_opt->opt_hdr_64
-#define PE_RAW_STRUCT opt_hdr_64
-#define PE_OUTPUT(x) PE_OUTPUT_TABLE(x)
-
-static int pe_hdrdump_opt_hdr_64(
- const struct pe_driver_ctx * dctx,
- const struct pe_image_meta * meta)
-{
- void * uaddr;
- const char * haddr;
- const char * maddr;
- uintptr_t faddr;
- uintptr_t vaddr;
- char * ch;
- char buf[8192];
-
- uaddr = PE_ADDR;
- maddr = meta->r_image.map_addr;
-
- haddr = uaddr;
- faddr = haddr - maddr;
- vaddr = meta->m_opt.oh_mem.coh_image_base + faddr;
-
- ch = buf;
- ch += pe_output_hex_header(
- ch,
- "struct pe_raw_opt_hdr_64",
- faddr,vaddr,64);
-
- ch += PE_OUTPUT(coh_magic);
- ch += PE_OUTPUT(coh_major_linker_ver);
- ch += PE_OUTPUT(coh_minor_linker_ver);
- ch += PE_OUTPUT(coh_size_of_code);
- ch += PE_OUTPUT(coh_size_of_inited_data);
- ch += PE_OUTPUT(coh_size_of_uninited_data);
- ch += PE_OUTPUT(coh_entry_point);
- ch += PE_OUTPUT(coh_base_of_code);
- ch += PE_OUTPUT(coh_image_base);
- ch += PE_OUTPUT(coh_section_align);
- ch += PE_OUTPUT(coh_file_align);
- ch += PE_OUTPUT(coh_major_os_ver);
- ch += PE_OUTPUT(coh_minor_os_ver);
- ch += PE_OUTPUT(coh_major_image_ver);
- ch += PE_OUTPUT(coh_minor_image_ver);
- ch += PE_OUTPUT(coh_major_subsys_ver);
- ch += PE_OUTPUT(coh_minor_subsys_ver);
- ch += PE_OUTPUT(coh_win32_ver);
- ch += PE_OUTPUT(coh_size_of_image);
- ch += PE_OUTPUT(coh_size_of_headers);
- ch += PE_OUTPUT(coh_checksum);
- ch += PE_OUTPUT(coh_subsystem);
- ch += PE_OUTPUT(coh_dll_characteristics);
- ch += PE_OUTPUT(coh_size_of_stack_reserve);
- ch += PE_OUTPUT(coh_size_of_stack_commit);
- ch += PE_OUTPUT(coh_size_of_heap_reserve);
- ch += PE_OUTPUT(coh_size_of_heap_commit);
- ch += PE_OUTPUT(coh_loader_flags);
- ch += PE_OUTPUT(coh_rva_and_sizes);
- ch += PE_OUTPUT(coh_export_tbl);
- ch += PE_OUTPUT(coh_import_tbl);
- ch += PE_OUTPUT(coh_resource_tbl);
- ch += PE_OUTPUT(coh_exception_tbl);
- ch += PE_OUTPUT(coh_certificate_tbl);
- ch += PE_OUTPUT(coh_base_reloc_tbl);
- ch += PE_OUTPUT(coh_debug);
- ch += PE_OUTPUT(coh_arch);
- ch += PE_OUTPUT(coh_global_ptr);
- ch += PE_OUTPUT(coh_tls_tbl);
- ch += PE_OUTPUT(coh_load_config_tbl);
- ch += PE_OUTPUT(coh_bound_import);
- ch += PE_OUTPUT(coh_iat);
- ch += PE_OUTPUT(coh_delay_import_descriptor);
- ch += PE_OUTPUT(coh_clr_runtime_hdr);
- ch += PE_OUTPUT(coh_reserved);
-
- ch += pe_output_hex_footer(ch);
-
- *ch = 0;
-
- if (pe_dprintf(pe_driver_fdout(dctx),"%s",buf) < 0)
- return PERK_FILE_ERROR(dctx);
-
- return 0;
-}
-
-int pe_hdrdump_coff_opt_hdr(
- const struct pe_driver_ctx * dctx,
- const struct pe_image_meta * meta)
-{
- if (!meta->r_opt)
- return 0;
-
- switch (pe_image_bits(meta)) {
- case 32:
- return pe_hdrdump_opt_hdr_32(dctx,meta);
-
- case 64:
- return pe_hdrdump_opt_hdr_64(dctx,meta);
-
- default:
- return PERK_CUSTOM_ERROR(
- dctx,PERK_ERR_UNSUPPORTED_ABI);
- }
-}
diff --git a/src/hdrdump/pe_hdrdump_export_hdr.c b/src/hdrdump/pe_hdrdump_export_hdr.c
deleted file mode 100644
index a413097..0000000
--- a/src/hdrdump/pe_hdrdump_export_hdr.c
+++ /dev/null
@@ -1,68 +0,0 @@
-/***************************************************************/
-/* perk: PE Resource Kit */
-/* Copyright (C) 2015--2021 SysDeer Technologies, LLC */
-/* Released under GPLv2 and GPLv3; see COPYING.PERK. */
-/***************************************************************/
-
-#include <stdio.h>
-
-#include <perk/perk.h>
-#include <perk/perk_consts.h>
-#include <perk/perk_structs.h>
-#include <perk/perk_output.h>
-#include "perk_driver_impl.h"
-#include "perk_hdrdump_impl.h"
-#include "perk_dprintf_impl.h"
-#include "perk_errinfo_impl.h"
-
-#define PE_ADDR meta->r_edata
-#define PE_RAW_STRUCT export_hdr
-#define PE_OUTPUT(x) PE_OUTPUT_TABLE(x)
-
-int pe_hdrdump_export_hdr(
- const struct pe_driver_ctx * dctx,
- const struct pe_image_meta * meta)
-{
- int bits;
- uint64_t faddr;
- uint64_t vaddr;
- char * ch;
- char buf[8192];
-
- if (!PE_ADDR)
- return 0;
-
- if ((bits = pe_image_bits(meta)) < 0)
- return PERK_CUSTOM_ERROR(
- dctx,PERK_ERR_UNSUPPORTED_ABI);
-
- faddr = (char *)(PE_ADDR) - (char *)meta->r_image.map_addr;
- vaddr = meta->m_opt.oh_mem.coh_image_base + meta->m_edata.eh_virtual_addr;
-
- ch = buf;
- ch += pe_output_hex_header(
- ch,
- "struct pe_raw_export_hdr",
- faddr,vaddr,bits);
-
- ch += PE_OUTPUT(eh_export_flags);
- ch += PE_OUTPUT(eh_time_date_stamp);
- ch += PE_OUTPUT(eh_major_ver);
- ch += PE_OUTPUT(eh_minor_ver);
- ch += PE_OUTPUT(eh_name_rva);
- ch += PE_OUTPUT(eh_ordinal_base);
- ch += PE_OUTPUT(eh_addr_tbl_entries);
- ch += PE_OUTPUT(eh_num_of_name_ptrs);
- ch += PE_OUTPUT(eh_export_addr_tbl_rva);
- ch += PE_OUTPUT(eh_name_ptr_rva);
- ch += PE_OUTPUT(eh_ordinal_tbl_rva);
-
- ch += pe_output_hex_footer(ch);
-
- *ch = 0;
-
- if (pe_dprintf(pe_driver_fdout(dctx),"%s",buf) < 0)
- return PERK_FILE_ERROR(dctx);
-
- return 0;
-}
diff --git a/src/hdrdump/pe_hdrdump_image_dos_hdr.c b/src/hdrdump/pe_hdrdump_image_dos_hdr.c
deleted file mode 100644
index c290079..0000000
--- a/src/hdrdump/pe_hdrdump_image_dos_hdr.c
+++ /dev/null
@@ -1,76 +0,0 @@
-/***************************************************************/
-/* perk: PE Resource Kit */
-/* Copyright (C) 2015--2021 SysDeer Technologies, LLC */
-/* Released under GPLv2 and GPLv3; see COPYING.PERK. */
-/***************************************************************/
-
-#include <stdio.h>
-
-#include <perk/perk.h>
-#include <perk/perk_consts.h>
-#include <perk/perk_structs.h>
-#include <perk/perk_output.h>
-#include "perk_driver_impl.h"
-#include "perk_hdrdump_impl.h"
-#include "perk_dprintf_impl.h"
-#include "perk_errinfo_impl.h"
-
-#define PE_ADDR meta->r_dos
-#define PE_RAW_STRUCT image_dos_hdr
-#define PE_OUTPUT(x) PE_OUTPUT_TABLE(x)
-
-int pe_hdrdump_image_dos_hdr(
- const struct pe_driver_ctx * dctx,
- const struct pe_image_meta * meta)
-{
- int bits;
- uint64_t faddr;
- uint64_t vaddr;
- char * ch;
- char buf[8192];
-
- if (!PE_ADDR)
- return 0;
-
- if ((bits = pe_image_bits(meta)) < 0)
- return PERK_CUSTOM_ERROR(
- dctx,PERK_ERR_UNSUPPORTED_ABI);
-
- faddr = 0;
- vaddr = meta->m_opt.oh_mem.coh_image_base;
-
- ch = buf;
- ch += pe_output_hex_header(
- ch,
- "struct pe_raw_image_dos_hdr",
- faddr,vaddr,bits);
-
- ch += PE_OUTPUT(dos_magic);
- ch += PE_OUTPUT(dos_cblp);
- ch += PE_OUTPUT(dos_cp);
- ch += PE_OUTPUT(dos_crlc);
- ch += PE_OUTPUT(dos_cparhdr);
- ch += PE_OUTPUT(dos_minalloc);
- ch += PE_OUTPUT(dos_maxalloc);
- ch += PE_OUTPUT(dos_ss);
- ch += PE_OUTPUT(dos_sp);
- ch += PE_OUTPUT(dos_csum);
- ch += PE_OUTPUT(dos_ip);
- ch += PE_OUTPUT(dos_cs);
- ch += PE_OUTPUT(dos_lfarlc);
- ch += PE_OUTPUT(dos_ovno);
- ch += PE_OUTPUT(dos_res);
- ch += PE_OUTPUT(dos_oemid);
- ch += PE_OUTPUT(dos_oeminfo);
- ch += PE_OUTPUT(dos_res2);
- ch += PE_OUTPUT(dos_lfanew);
-
- ch += pe_output_hex_footer(ch);
-
- *ch = 0;
-
- if (pe_dprintf(pe_driver_fdout(dctx),"%s",buf) < 0)
- return PERK_FILE_ERROR(dctx);
-
- return 0;
-}
diff --git a/src/hdrdump/pe_hdrdump_import_tbl.c b/src/hdrdump/pe_hdrdump_import_tbl.c
deleted file mode 100644
index f7cdb24..0000000
--- a/src/hdrdump/pe_hdrdump_import_tbl.c
+++ /dev/null
@@ -1,109 +0,0 @@
-/***************************************************************/
-/* perk: PE Resource Kit */
-/* Copyright (C) 2015--2021 SysDeer Technologies, LLC */
-/* Released under GPLv2 and GPLv3; see COPYING.PERK. */
-/***************************************************************/
-
-#include <stdio.h>
-
-#include <perk/perk.h>
-#include <perk/perk_consts.h>
-#include <perk/perk_structs.h>
-#include <perk/perk_output.h>
-#include "perk_driver_impl.h"
-#include "perk_hdrdump_impl.h"
-#include "perk_dprintf_impl.h"
-#include "perk_errinfo_impl.h"
-
-#define PE_ADDR &meta->r_idata[idx]
-#define PE_RAW_STRUCT import_hdr
-#define PE_OUTPUT(x) PE_OUTPUT_TABLE(x)
-
-static int pe_hdrdump_import_hdr_impl(
- const struct pe_driver_ctx * dctx,
- const struct pe_image_meta * meta,
- int32_t idx)
-{
- int bits;
- uint64_t faddr;
- uint64_t vaddr;
- char * ch;
- char hdr[64];
- char buf[8192];
-
- if ((bits = pe_image_bits(meta)) < 0)
- return PERK_CUSTOM_ERROR(
- dctx,PERK_ERR_UNSUPPORTED_ABI);
-
- /* import header */
- sprintf(
- hdr,
- "struct pe_raw_import_hdr [%d]",
- idx);
-
- faddr = (char *)(PE_ADDR) - (char *)meta->r_image.map_addr;
- vaddr = meta->m_opt.oh_mem.coh_image_base + meta->m_idata[idx].ih_virtual_addr;
-
- ch = buf;
- ch += pe_output_hex_header(
- ch,hdr,
- faddr,vaddr,bits);
-
- ch += PE_OUTPUT(ih_import_lookup_tbl_rva);
- ch += PE_OUTPUT(ih_time_date_stamp);
- ch += PE_OUTPUT(ih_forwarder_chain);
- ch += PE_OUTPUT(ih_name_rva);
- ch += PE_OUTPUT(ih_import_addr_tbl_rva);
-
- ch += pe_output_hex_footer(ch);
-
- /* import name for all but the null header */
- if (idx == meta->m_stats.t_nimplibs) {
- (void)0;
-
- } else if (meta->m_idata[idx].ih_name_rva) {
- sprintf(
- hdr,
- "struct pe_raw_import_name [%d]",
- idx);
-
- faddr = meta->m_idata[idx].ih_name - (char *)meta->r_image.map_addr;
- vaddr = meta->m_idata[idx].ih_name_rva;
-
- ch += pe_output_hex_header(
- ch,hdr,
- faddr,vaddr,bits);
-
- ch += pe_output_raw_element(
- ch,
- meta->m_idata[idx].ih_name,
- "ih_name",0,
- strlen(meta->m_idata[idx].ih_name) + 1);
-
- ch += pe_output_hex_footer(ch);
- }
-
- *ch = 0;
-
- /* fdout */
- if (pe_dprintf(pe_driver_fdout(dctx),"%s",buf) < 0)
- return PERK_FILE_ERROR(dctx);
-
- return 0;
-}
-
-int pe_hdrdump_import_tbl(
- const struct pe_driver_ctx * dctx,
- const struct pe_image_meta * meta)
-{
- int idx;
-
- if (meta->m_stats.t_nimplibs == 0)
- return 0;
-
- for (idx=0; idx<=meta->m_stats.t_nimplibs; idx++)
- if (pe_hdrdump_import_hdr_impl(dctx,meta,idx) < 0)
- return PERK_NESTED_ERROR(dctx);
-
- return 0;
-}
diff --git a/src/hdrdump/pe_hdrdump_sec_tbl.c b/src/hdrdump/pe_hdrdump_sec_tbl.c
deleted file mode 100644
index 8379d6d..0000000
--- a/src/hdrdump/pe_hdrdump_sec_tbl.c
+++ /dev/null
@@ -1,83 +0,0 @@
-/***************************************************************/
-/* perk: PE Resource Kit */
-/* Copyright (C) 2015--2021 SysDeer Technologies, LLC */
-/* Released under GPLv2 and GPLv3; see COPYING.PERK. */
-/***************************************************************/
-
-#include <stdio.h>
-
-#include <perk/perk.h>
-#include <perk/perk_consts.h>
-#include <perk/perk_structs.h>
-#include <perk/perk_output.h>
-#include "perk_driver_impl.h"
-#include "perk_hdrdump_impl.h"
-#include "perk_dprintf_impl.h"
-#include "perk_errinfo_impl.h"
-
-#define PE_ADDR &meta->r_sectbl[idx]
-#define PE_RAW_STRUCT sec_hdr
-#define PE_OUTPUT(x) PE_OUTPUT_TABLE(x)
-
-static int pe_hdrdump_sec_hdr_impl(
- const struct pe_driver_ctx * dctx,
- const struct pe_image_meta * meta,
- uint32_t idx)
-{
- int bits;
- uint64_t faddr;
- uint64_t vaddr;
- char * ch;
- char hdr[64];
- char buf[8192];
-
- if ((bits = pe_image_bits(meta)) < 0)
- return PERK_CUSTOM_ERROR(
- dctx,PERK_ERR_UNSUPPORTED_ABI);
-
- sprintf(
- hdr,
- "struct pe_raw_sec_hdr [%d]",
- idx);
-
- faddr = (char *)(PE_ADDR) - (char *)meta->r_image.map_addr;
- vaddr = meta->m_opt.oh_mem.coh_image_base + faddr;
-
- ch = buf;
- ch += pe_output_hex_header(
- ch,hdr,
- faddr,vaddr,bits);
-
- ch += PE_OUTPUT(sh_name);
- ch += PE_OUTPUT(sh_virtual_size);
- ch += PE_OUTPUT(sh_virtual_addr);
- ch += PE_OUTPUT(sh_size_of_raw_data);
- ch += PE_OUTPUT(sh_ptr_to_raw_data);
- ch += PE_OUTPUT(sh_ptr_to_relocs);
- ch += PE_OUTPUT(sh_ptr_to_line_nums);
- ch += PE_OUTPUT(sh_num_of_relocs);
- ch += PE_OUTPUT(sh_num_of_line_nums);
- ch += PE_OUTPUT(sh_characteristics);
-
- ch += pe_output_hex_footer(ch);
-
- *ch = 0;
-
- if (pe_dprintf(pe_driver_fdout(dctx),"%s",buf) < 0)
- return PERK_FILE_ERROR(dctx);
-
- return 0;
-}
-
-int pe_hdrdump_sec_tbl(
- const struct pe_driver_ctx * dctx,
- const struct pe_image_meta * meta)
-{
- uint32_t idx;
-
- for (idx=0; idx<meta->m_coff.cfh_num_of_sections; idx++)
- if (pe_hdrdump_sec_hdr_impl(dctx,meta,idx) < 0)
- return PERK_NESTED_ERROR(dctx);
-
- return 0;
-}