Commit f63f8bc2 authored by Marcus Meissner's avatar Marcus Meissner Committed by Alexandre Julliard

Detection of the end of imports with Characteristics 0 fail for Borland

programs (which seem to have always characteristics 0). Changed to algorithm to something a bit more intelligent.
parent fa5f56fc
...@@ -220,7 +220,7 @@ DWORD fixup_imports (PDB32 *process,WINE_MODREF *wm) ...@@ -220,7 +220,7 @@ DWORD fixup_imports (PDB32 *process,WINE_MODREF *wm)
WINE_MODREF *xwm; WINE_MODREF *xwm;
PE_MODREF *pem; PE_MODREF *pem;
unsigned int load_addr = wm->module; unsigned int load_addr = wm->module;
int i; int i,characteristics_detection=1;
char *modname; char *modname;
assert(wm->type==MODULE32_PE); assert(wm->type==MODULE32_PE);
...@@ -238,8 +238,17 @@ DWORD fixup_imports (PDB32 *process,WINE_MODREF *wm) ...@@ -238,8 +238,17 @@ DWORD fixup_imports (PDB32 *process,WINE_MODREF *wm)
if (!pe_imp) if (!pe_imp)
ERR(win32, "no import directory????\n"); ERR(win32, "no import directory????\n");
for (i = 0; pe_imp->Name && pe_imp->u.Characteristics; pe_imp++) /* We assume that we have at least one import with !0 characteristics and
* detect broken imports with all characteristsics 0 (notably Borland) and
* switch the detection off for them.
*/
for (i = 0; pe_imp->Name ; pe_imp++) {
if (!i && !pe_imp->u.Characteristics)
characteristics_detection = 0;
if (characteristics_detection && !pe_imp->u.Characteristics)
break;
i++; i++;
}
/* Allocate module dependency list */ /* Allocate module dependency list */
wm->nDeps = i; wm->nDeps = i;
...@@ -249,12 +258,15 @@ DWORD fixup_imports (PDB32 *process,WINE_MODREF *wm) ...@@ -249,12 +258,15 @@ DWORD fixup_imports (PDB32 *process,WINE_MODREF *wm)
* added to the modref list of the process. * added to the modref list of the process.
*/ */
for (i = 0, pe_imp = pem->pe_import; pe_imp->Name && pe_imp->u.Characteristics; pe_imp++) { for (i = 0, pe_imp = pem->pe_import; pe_imp->Name ; pe_imp++) {
HMODULE32 hImpModule; HMODULE32 hImpModule;
IMAGE_IMPORT_BY_NAME *pe_name; IMAGE_IMPORT_BY_NAME *pe_name;
PIMAGE_THUNK_DATA import_list,thunk_list; PIMAGE_THUNK_DATA import_list,thunk_list;
char *name = (char *) RVA(pe_imp->Name); char *name = (char *) RVA(pe_imp->Name);
if (characteristics_detection && !pe_imp->u.Characteristics)
break;
/* don't use MODULE_Load, Win32 creates new task differently */ /* don't use MODULE_Load, Win32 creates new task differently */
hImpModule = MODULE_LoadLibraryEx32A( name, process, 0, 0 ); hImpModule = MODULE_LoadLibraryEx32A( name, process, 0, 0 );
if (!hImpModule) { if (!hImpModule) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment