Fixed dumping of the import directory to ignore the directory size.

This commit is contained in:
Alexandre Julliard 2005-10-04 15:55:33 +00:00
parent c2bb910877
commit f5e49be317
1 changed files with 13 additions and 19 deletions

View File

@ -520,7 +520,6 @@ static void dump_image_thunk_data32(IMAGE_THUNK_DATA32 *il)
static void dump_dir_imported_functions(void) static void dump_dir_imported_functions(void)
{ {
IMAGE_IMPORT_DESCRIPTOR *importDesc = get_dir(IMAGE_FILE_IMPORT_DIRECTORY); IMAGE_IMPORT_DESCRIPTOR *importDesc = get_dir(IMAGE_FILE_IMPORT_DIRECTORY);
unsigned nb_imp, i;
DWORD directorySize; DWORD directorySize;
if (!importDesc) return; if (!importDesc) return;
@ -534,29 +533,21 @@ static void dump_dir_imported_functions(void)
IMAGE_OPTIONAL_HEADER32 *opt = (IMAGE_OPTIONAL_HEADER32*)&PE_nt_headers->OptionalHeader; IMAGE_OPTIONAL_HEADER32 *opt = (IMAGE_OPTIONAL_HEADER32*)&PE_nt_headers->OptionalHeader;
directorySize = opt->DataDirectory[IMAGE_FILE_IMPORT_DIRECTORY].Size; directorySize = opt->DataDirectory[IMAGE_FILE_IMPORT_DIRECTORY].Size;
} }
nb_imp = directorySize / sizeof(*importDesc);
if (!nb_imp) return;
printf("Import Table size: %08lx\n", directorySize);/* FIXME */ printf("Import Table size: %08lx\n", directorySize);/* FIXME */
for (i = 0; i < nb_imp - 1; i++) /* the last descr is set as 0 as a sentinel */ for (;;)
{ {
IMAGE_THUNK_DATA32* il; IMAGE_THUNK_DATA32* il;
if (!importDesc->Name || if (!importDesc->Name || !importDesc->FirstThunk) break;
(importDesc->u.OriginalFirstThunk == 0 && importDesc->FirstThunk == 0))
{
/* FIXME */
printf("<<<<<<<null entry\n");
break;
}
printf(" offset %08lx %s\n", Offset(importDesc), (char*)RVA(importDesc->Name, sizeof(DWORD))); printf(" offset %08lx %s\n", Offset(importDesc), (char*)RVA(importDesc->Name, sizeof(DWORD)));
printf(" Hint/Name Table: %08lX\n", (DWORD)importDesc->u.OriginalFirstThunk); printf(" Hint/Name Table: %08lX\n", (DWORD)importDesc->u.OriginalFirstThunk);
printf(" TimeDataStamp: %08lX (%s)\n", printf(" TimeDataStamp: %08lX (%s)\n",
importDesc->TimeDateStamp, get_time_str(importDesc->TimeDateStamp)); importDesc->TimeDateStamp, get_time_str(importDesc->TimeDateStamp));
printf(" ForwarderChain: %08lX\n", importDesc->ForwarderChain); printf(" ForwarderChain: %08lX\n", importDesc->ForwarderChain);
printf(" First thunk RVA: %08lX (delta: %u 0x%x)\n", printf(" First thunk RVA: %08lX\n", (DWORD)importDesc->FirstThunk);
(DWORD)importDesc->FirstThunk, -1, -1); /* FIXME */
printf(" Ordn Name\n"); printf(" Ordn Name\n");
@ -564,13 +555,16 @@ static void dump_dir_imported_functions(void)
RVA((DWORD)importDesc->u.OriginalFirstThunk, sizeof(DWORD)) : RVA((DWORD)importDesc->u.OriginalFirstThunk, sizeof(DWORD)) :
RVA((DWORD)importDesc->FirstThunk, sizeof(DWORD)); RVA((DWORD)importDesc->FirstThunk, sizeof(DWORD));
if (!il) {printf("Can't grab thunk data, going to next imported DLL\n"); continue;} if (!il)
printf("Can't grab thunk data, going to next imported DLL\n");
else
{
if(PE_nt_headers->OptionalHeader.Magic == IMAGE_NT_OPTIONAL_HDR64_MAGIC) if(PE_nt_headers->OptionalHeader.Magic == IMAGE_NT_OPTIONAL_HDR64_MAGIC)
dump_image_thunk_data64((IMAGE_THUNK_DATA64*)il); dump_image_thunk_data64((IMAGE_THUNK_DATA64*)il);
else else
dump_image_thunk_data32(il); dump_image_thunk_data32(il);
printf("\n"); printf("\n");
}
importDesc++; importDesc++;
} }
printf("\n"); printf("\n");