Commit 9e1c48b8 authored by Alexandre Julliard's avatar Alexandre Julliard

Clear the remainder of the page when mapping a section whose size on

disk is not a full page multiple. Temporarily commented out the VirtualFree call in PE_UnloadLibrary.
parent 00d5d77d
...@@ -481,6 +481,7 @@ HMODULE PE_LoadImage( HANDLE hFile, LPCSTR filename, WORD *version ) ...@@ -481,6 +481,7 @@ HMODULE PE_LoadImage( HANDLE hFile, LPCSTR filename, WORD *version )
DWORD load_addr = 0, aoep, reloc = 0; DWORD load_addr = 0, aoep, reloc = 0;
struct get_read_fd_request *req = get_req_buffer(); struct get_read_fd_request *req = get_req_buffer();
int unix_handle = -1; int unix_handle = -1;
int page_size = VIRTUAL_GetPageSize();
/* Retrieve file size */ /* Retrieve file size */
if ( GetFileInformationByHandle( hFile, &bhfi ) ) if ( GetFileInformationByHandle( hFile, &bhfi ) )
...@@ -658,7 +659,7 @@ HMODULE PE_LoadImage( HANDLE hFile, LPCSTR filename, WORD *version ) ...@@ -658,7 +659,7 @@ HMODULE PE_LoadImage( HANDLE hFile, LPCSTR filename, WORD *version )
/* Map the header */ /* Map the header */
if (FILE_dommap( unix_handle, (void *)load_addr, 0, nt->OptionalHeader.SizeOfHeaders, if (FILE_dommap( unix_handle, (void *)load_addr, 0, nt->OptionalHeader.SizeOfHeaders,
0, 0, PROT_EXEC | PROT_WRITE | PROT_READ, 0, 0, PROT_EXEC | PROT_WRITE | PROT_READ,
MAP_PRIVATE | MAP_FIXED ) != load_addr) MAP_PRIVATE | MAP_FIXED ) != (void*)load_addr)
{ {
ERR_(win32)( "Critical Error: failed to map PE header to necessary address.\n"); ERR_(win32)( "Critical Error: failed to map PE header to necessary address.\n");
goto error; goto error;
...@@ -668,19 +669,30 @@ HMODULE PE_LoadImage( HANDLE hFile, LPCSTR filename, WORD *version ) ...@@ -668,19 +669,30 @@ HMODULE PE_LoadImage( HANDLE hFile, LPCSTR filename, WORD *version )
pe_sec = PE_SECTIONS( hModule ); pe_sec = PE_SECTIONS( hModule );
for (i = 0; i < nt->FileHeader.NumberOfSections; i++, pe_sec++) for (i = 0; i < nt->FileHeader.NumberOfSections; i++, pe_sec++)
{ {
if (!pe_sec->SizeOfRawData) continue; if (!pe_sec->SizeOfRawData || !pe_sec->PointerToRawData) continue;
TRACE("%s: mmaping section %s at %p off %lx\n", TRACE("%s: mmaping section %s at %p off %lx size %lx/%lx\n",
filename, pe_sec->Name, (void*)RVA(pe_sec->VirtualAddress), filename, pe_sec->Name, (void*)RVA(pe_sec->VirtualAddress),
pe_sec->PointerToRawData); pe_sec->PointerToRawData, pe_sec->SizeOfRawData, pe_sec->Misc.VirtualSize );
if (FILE_dommap( unix_handle, (void*)RVA(pe_sec->VirtualAddress), if (FILE_dommap( unix_handle, (void*)RVA(pe_sec->VirtualAddress),
0, min(pe_sec->Misc.VirtualSize, pe_sec->SizeOfRawData), 0, pe_sec->SizeOfRawData, 0, pe_sec->PointerToRawData,
0, pe_sec->PointerToRawData, PROT_EXEC | PROT_WRITE | PROT_READ, PROT_EXEC | PROT_WRITE | PROT_READ,
MAP_PRIVATE | MAP_FIXED ) != (void*)RVA(pe_sec->VirtualAddress)) MAP_PRIVATE | MAP_FIXED ) != (void*)RVA(pe_sec->VirtualAddress))
{ {
/* We failed to map to the right place (huh?) */ /* We failed to map to the right place (huh?) */
ERR_(win32)( "Critical Error: failed to map PE section to necessary address.\n"); ERR_(win32)( "Critical Error: failed to map PE section to necessary address.\n");
goto error; goto error;
} }
if ((pe_sec->SizeOfRawData < pe_sec->Misc.VirtualSize) &&
(pe_sec->SizeOfRawData & (page_size-1)))
{
DWORD end = (pe_sec->SizeOfRawData & ~(page_size-1)) + page_size;
if (end > pe_sec->Misc.VirtualSize) end = pe_sec->Misc.VirtualSize;
TRACE("clearing %p - %p\n",
RVA(pe_sec->VirtualAddress) + pe_sec->SizeOfRawData,
RVA(pe_sec->VirtualAddress) + end );
memset( (char*)RVA(pe_sec->VirtualAddress) + pe_sec->SizeOfRawData, 0,
end - pe_sec->SizeOfRawData );
}
} }
/* Perform base relocation, if necessary */ /* Perform base relocation, if necessary */
...@@ -965,7 +977,7 @@ WINE_MODREF *PE_LoadLibraryExA (LPCSTR name, DWORD flags) ...@@ -965,7 +977,7 @@ WINE_MODREF *PE_LoadLibraryExA (LPCSTR name, DWORD flags)
void PE_UnloadLibrary(WINE_MODREF *wm) void PE_UnloadLibrary(WINE_MODREF *wm)
{ {
TRACE(" unloading %s\n", wm->filename); TRACE(" unloading %s\n", wm->filename);
VirtualFree( (LPVOID)wm->module, 0, MEM_RELEASE ); /* VirtualFree( (LPVOID)wm->module, 0, MEM_RELEASE ); */ /* FIXME */
HeapFree( GetProcessHeap(), 0, wm->filename ); HeapFree( GetProcessHeap(), 0, wm->filename );
HeapFree( GetProcessHeap(), 0, wm->short_filename ); HeapFree( GetProcessHeap(), 0, wm->short_filename );
HeapFree( GetProcessHeap(), 0, wm ); HeapFree( GetProcessHeap(), 0, wm );
......
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