Commit 4cbf118d authored by Alexandre Julliard's avatar Alexandre Julliard

Check for a valid module before attempting to read the export

directory in LdrGetProcedureAddress.
parent 220edd52
...@@ -1181,8 +1181,10 @@ NTSTATUS WINAPI LdrGetProcedureAddress(HMODULE module, const ANSI_STRING *name, ...@@ -1181,8 +1181,10 @@ NTSTATUS WINAPI LdrGetProcedureAddress(HMODULE module, const ANSI_STRING *name,
RtlEnterCriticalSection( &loader_section ); RtlEnterCriticalSection( &loader_section );
if ((exports = RtlImageDirectoryEntryToData( module, TRUE, /* check if the module itself is invalid to return the proper error */
IMAGE_DIRECTORY_ENTRY_EXPORT, &exp_size ))) if (!get_modref( module )) ret = STATUS_DLL_NOT_FOUND;
else if ((exports = RtlImageDirectoryEntryToData( module, TRUE,
IMAGE_DIRECTORY_ENTRY_EXPORT, &exp_size )))
{ {
void *proc = name ? find_named_export( module, exports, exp_size, name->Buffer, -1 ) void *proc = name ? find_named_export( module, exports, exp_size, name->Buffer, -1 )
: find_ordinal_export( module, exports, exp_size, ord - exports->Base ); : find_ordinal_export( module, exports, exp_size, ord - exports->Base );
...@@ -1192,11 +1194,6 @@ NTSTATUS WINAPI LdrGetProcedureAddress(HMODULE module, const ANSI_STRING *name, ...@@ -1192,11 +1194,6 @@ NTSTATUS WINAPI LdrGetProcedureAddress(HMODULE module, const ANSI_STRING *name,
ret = STATUS_SUCCESS; ret = STATUS_SUCCESS;
} }
} }
else
{
/* check if the module itself is invalid to return the proper error */
if (!get_modref( module )) ret = STATUS_DLL_NOT_FOUND;
}
RtlLeaveCriticalSection( &loader_section ); RtlLeaveCriticalSection( &loader_section );
return ret; return ret;
......
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