Blame src/hdrdump/pe_hdrdump_import_tbl.c

8f30d9
/***************************************************************/
8f30d9
/*  perk: PE Resource Kit                                      */
8f30d9
/*  Copyright (C) 2015--2017  Z. Gilboa                        */
8f30d9
/*  Released under GPLv2 and GPLv3; see COPYING.PERK.          */
8f30d9
/***************************************************************/
8f30d9
8f30d9
#include <stdio.h>
8f30d9
8f30d9
#include <perk/perk.h>
8f30d9
#include <perk/perk_output.h>
8f30d9
#include "perk_driver_impl.h"
8f30d9
#include "perk_hdrdump_impl.h"
8f30d9
#include "perk_dprintf_impl.h"
8f30d9
#include "perk_errinfo_impl.h"
8f30d9
8f30d9
#define PE_ADDR       &meta->r_idata[idx]
8f30d9
#define PE_RAW_STRUCT import_hdr
8f30d9
#define PE_OUTPUT(x)  PE_OUTPUT_TABLE(x)
8f30d9
8f30d9
static int pe_hdrdump_import_hdr_impl(
8f30d9
	const struct pe_driver_ctx *	dctx,
8f30d9
	const struct pe_image_meta *	meta,
0a52ca
	int32_t				idx)
8f30d9
{
8f30d9
	int		bits;
8f30d9
	uint64_t	faddr;
8f30d9
	uint64_t	vaddr;
8f30d9
	char *		ch;
8f30d9
	char		hdr[64];
8f30d9
	char		buf[8192];
8f30d9
8f30d9
	if ((bits = pe_image_bits(meta)) < 0)
8f30d9
		return PERK_CUSTOM_ERROR(
8f30d9
			dctx,PERK_ERR_UNSUPPORTED_ABI);
8f30d9
0a52ca
	/* import header */
8f30d9
	sprintf(
8f30d9
		hdr,
8f30d9
		"struct pe_raw_import_hdr [%d]",
8f30d9
		idx);
8f30d9
8f30d9
	faddr = (char *)(PE_ADDR) - (char *)meta->r_image.map_addr;
8f30d9
	vaddr = meta->m_opt.oh_mem.coh_image_base + meta->m_idata[idx].ih_virtual_addr;
8f30d9
8f30d9
	ch  = buf;
8f30d9
	ch += pe_output_hex_header(
8f30d9
		ch,hdr,
8f30d9
		faddr,vaddr,bits);
8f30d9
8f30d9
	ch += PE_OUTPUT(ih_import_lookup_tbl_rva);
8f30d9
	ch += PE_OUTPUT(ih_time_date_stamp);
8f30d9
	ch += PE_OUTPUT(ih_forwarder_chain);
8f30d9
	ch += PE_OUTPUT(ih_name_rva);
8f30d9
	ch += PE_OUTPUT(ih_import_addr_tbl_rva);
8f30d9
8f30d9
	ch += pe_output_hex_footer(ch);
8f30d9
0a52ca
	/* import name for all but the null header */
0a52ca
	if (idx == meta->m_stats.t_nimplibs) {
0a52ca
		(void)0;
0a52ca
0a52ca
	} else if (meta->m_idata[idx].ih_name_rva) {
0a52ca
		sprintf(
0a52ca
			hdr,
0a52ca
			"struct pe_raw_import_name [%d]",
0a52ca
			idx);
0a52ca
0a52ca
		faddr = meta->m_idata[idx].ih_name - (char *)meta->r_image.map_addr;
0a52ca
		vaddr = meta->m_idata[idx].ih_name_rva;
0a52ca
0a52ca
		ch += pe_output_hex_header(
0a52ca
			ch,hdr,
0a52ca
			faddr,vaddr,bits);
0a52ca
0a52ca
		ch += pe_output_raw_element(
0a52ca
			ch,
0a52ca
			meta->m_idata[idx].ih_name,
0a52ca
			"ih_name",0,
0a52ca
			strlen(meta->m_idata[idx].ih_name) + 1);
0a52ca
0a52ca
		ch += pe_output_hex_footer(ch);
0a52ca
	}
0a52ca
8f30d9
	*ch = 0;
8f30d9
0a52ca
	/* fdout */
8f30d9
	if (pe_dprintf(pe_driver_fdout(dctx),"%s",buf) < 0)
8f30d9
		return PERK_FILE_ERROR(dctx);
8f30d9
8f30d9
	return 0;
8f30d9
}
8f30d9
8f30d9
int pe_hdrdump_import_tbl(
8f30d9
	const struct pe_driver_ctx *	dctx,
8f30d9
	const struct pe_image_meta *	meta)
8f30d9
{
8f30d9
	int idx;
8f30d9
0a52ca
	for (idx=0; idx<=meta->m_stats.t_nimplibs; idx++)
8f30d9
		if (pe_hdrdump_import_hdr_impl(dctx,meta,idx) < 0)
8f30d9
			return PERK_NESTED_ERROR(dctx);
8f30d9
8f30d9
	return 0;
8f30d9
}