Commit 43d14fd8 authored by Paul Gofman's avatar Paul Gofman Committed by Alexandre Julliard

kernelbase: Use LdrGetDllFullName() in GetModuleFileNameW().

parent 39a35490
...@@ -298,9 +298,9 @@ DWORD WINAPI DECLSPEC_HOTPATCH GetModuleFileNameA( HMODULE module, LPSTR filenam ...@@ -298,9 +298,9 @@ DWORD WINAPI DECLSPEC_HOTPATCH GetModuleFileNameA( HMODULE module, LPSTR filenam
DWORD WINAPI DECLSPEC_HOTPATCH GetModuleFileNameW( HMODULE module, LPWSTR filename, DWORD size ) DWORD WINAPI DECLSPEC_HOTPATCH GetModuleFileNameW( HMODULE module, LPWSTR filename, DWORD size )
{ {
ULONG len = 0; ULONG len = 0;
ULONG_PTR magic;
LDR_DATA_TABLE_ENTRY *pldr;
WIN16_SUBSYSTEM_TIB *win16_tib; WIN16_SUBSYSTEM_TIB *win16_tib;
UNICODE_STRING name;
NTSTATUS status;
if (!module && ((win16_tib = NtCurrentTeb()->Tib.SubSystemTib)) && win16_tib->exe_name) if (!module && ((win16_tib = NtCurrentTeb()->Tib.SubSystemTib)) && win16_tib->exe_name)
{ {
...@@ -310,22 +310,11 @@ DWORD WINAPI DECLSPEC_HOTPATCH GetModuleFileNameW( HMODULE module, LPWSTR filena ...@@ -310,22 +310,11 @@ DWORD WINAPI DECLSPEC_HOTPATCH GetModuleFileNameW( HMODULE module, LPWSTR filena
goto done; goto done;
} }
LdrLockLoaderLock( 0, NULL, &magic ); name.Buffer = filename;
name.MaximumLength = size * sizeof(WCHAR);
if (!module) module = NtCurrentTeb()->Peb->ImageBaseAddress; status = LdrGetDllFullName( module, &name );
if (set_ntstatus( LdrFindEntryForAddress( module, &pldr ))) if (!status || status == STATUS_BUFFER_TOO_SMALL) len = name.Length / sizeof(WCHAR);
{ SetLastError( RtlNtStatusToDosError( status ));
len = min( size, pldr->FullDllName.Length / sizeof(WCHAR) );
memcpy( filename, pldr->FullDllName.Buffer, len * sizeof(WCHAR) );
if (len < size)
{
filename[len] = 0;
SetLastError( 0 );
}
else SetLastError( ERROR_INSUFFICIENT_BUFFER );
}
LdrUnlockLoaderLock( 0, magic );
done: done:
TRACE( "%s\n", debugstr_wn(filename, len) ); TRACE( "%s\n", debugstr_wn(filename, len) );
return len; return len;
......
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