summaryrefslogtreecommitdiffhomepage
path: root/src/output
diff options
context:
space:
mode:
authormidipix <writeonce@midipix.org>2015-11-21 22:40:50 -0500
committermidipix <writeonce@midipix.org>2016-11-10 23:35:25 -0500
commitab024a80297e6c3ea6a7a0d77b5a8d51800ba203 (patch)
treef7532f2d695c929d4ca2bc1d17253f61d306920b /src/output
parenta3de1cabbe842d10d38f6b6ba24ee44cf15c5dac (diff)
downloadperk-ab024a80297e6c3ea6a7a0d77b5a8d51800ba203.tar.bz2
perk-ab024a80297e6c3ea6a7a0d77b5a8d51800ba203.tar.xz
driver integration 3/9: adjust prototype of pe_output_export_symbols().
Diffstat (limited to 'src/output')
-rw-r--r--src/output/pe_output_export_symbols.c22
1 files changed, 20 insertions, 2 deletions
diff --git a/src/output/pe_output_export_symbols.c b/src/output/pe_output_export_symbols.c
index 099b540..fde10c5 100644
--- a/src/output/pe_output_export_symbols.c
+++ b/src/output/pe_output_export_symbols.c
@@ -6,13 +6,28 @@
#include <perk/perk.h>
-int pe_output_export_symbols (const struct pe_image_meta * m, uint32_t flags, FILE * f)
+int pe_output_export_symbols (const struct pe_image_meta * m, const struct pe_common_ctx * cctx, FILE * f)
{
uint32_t offset;
uint32_t * symrva;
+ int fdout;
int i;
- if (!m->hedata) return 0;
+ if (!m->hedata)
+ return 0;
+ else if (f)
+ fdout = -1;
+ else if (!cctx)
+ return -1;
+ else if (cctx->fdout < 0) {
+ f = stdout;
+ fdout = -1;
+ } else if ((fdout = dup(cctx->fdout)) < 0)
+ return -1;
+ else if (!(f = fdopen(fdout,"a"))) {
+ close(fdout);
+ return -1;
+ }
offset = m->hedata->virtual_addr - m->hedata->ptr_to_raw_data;
symrva = (uint32_t *)((uintptr_t)m->image.addr + (m->edata.name_ptr_rva - offset));
@@ -20,5 +35,8 @@ int pe_output_export_symbols (const struct pe_image_meta * m, uint32_t flags, FI
for (i=0; i<m->edata.num_of_name_ptrs; i++)
fprintf(f,"%s\n",(char *)((uintptr_t)m->image.addr + symrva[i] - offset));
+ if (fdout >= 0)
+ fclose(f);
+
return 0;
}