/* * IMAGEHLP library * * Copyright 1998 Patrik Stridvall */ #include "winbase.h" #include "winnt.h" #include "winerror.h" #include "windef.h" #include "heap.h" #include "debugtools.h" #include "imagehlp.h" DEFAULT_DEBUG_CHANNEL(imagehlp); /*********************************************************************** * Data */ static PLOADED_IMAGE IMAGEHLP_pFirstLoadedImage=NULL; static PLOADED_IMAGE IMAGEHLP_pLastLoadedImage=NULL; static LOADED_IMAGE IMAGEHLP_EmptyLoadedImage = { NULL, /* ModuleName */ 0xffffffff, /* hFile */ NULL, /* MappedAddress */ NULL, /* FileHeader */ NULL, /* LastRvaSection */ 0, /* NumberOfSections */ NULL, /* Sections */ 1, /* Characteristics */ FALSE, /* fSystemImage */ FALSE, /* fDOSImage */ { &IMAGEHLP_EmptyLoadedImage.Links, &IMAGEHLP_EmptyLoadedImage.Links }, /* Links */ 148, /* SizeOfImage; */ }; /*********************************************************************** * EnumerateLoadedModules (IMAGEHLP.@) */ BOOL WINAPI EnumerateLoadedModules( HANDLE hProcess, PENUMLOADED_MODULES_CALLBACK EnumLoadedModulesCallback, PVOID UserContext) { FIXME("(0x%08x, %p, %p): stub\n", hProcess, EnumLoadedModulesCallback, UserContext ); SetLastError(ERROR_CALL_NOT_IMPLEMENTED); return FALSE; } /*********************************************************************** * GetTimestampForLoadedLibrary (IMAGEHLP.@) */ DWORD WINAPI GetTimestampForLoadedLibrary(HMODULE Module) { FIXME("(0x%08x): stub\n", Module); SetLastError(ERROR_CALL_NOT_IMPLEMENTED); return 0; } /*********************************************************************** * GetImageConfigInformation (IMAGEHLP.@) */ BOOL WINAPI GetImageConfigInformation( PLOADED_IMAGE LoadedImage, PIMAGE_LOAD_CONFIG_DIRECTORY ImageConfigInformation) { FIXME("(%p, %p): stub\n", LoadedImage, ImageConfigInformation ); SetLastError(ERROR_CALL_NOT_IMPLEMENTED); return FALSE; } /*********************************************************************** * GetImageUnusedHeaderBytes (IMAGEHLP.@) */ DWORD WINAPI GetImageUnusedHeaderBytes( PLOADED_IMAGE LoadedImage, LPDWORD SizeUnusedHeaderBytes) { FIXME("(%p, %p): stub\n", LoadedImage, SizeUnusedHeaderBytes ); SetLastError(ERROR_CALL_NOT_IMPLEMENTED); return 0; } /*********************************************************************** * ImageDirectoryEntryToData (IMAGEHLP.@) */ PVOID WINAPI ImageDirectoryEntryToData( PVOID Base, BOOLEAN MappedAsImage, USHORT DirectoryEntry, PULONG Size) { FIXME("(%p, %d, %hd, %p): stub\n", Base, MappedAsImage, DirectoryEntry, Size ); SetLastError(ERROR_CALL_NOT_IMPLEMENTED); return NULL; } /*********************************************************************** * ImageLoad (IMAGEHLP.@) */ PLOADED_IMAGE WINAPI ImageLoad(LPSTR DllName, LPSTR DllPath) { PLOADED_IMAGE pLoadedImage = HeapAlloc(IMAGEHLP_hHeap, 0, sizeof(LOADED_IMAGE)); return pLoadedImage; } /*********************************************************************** * ImageNtHeader (IMAGEHLP.@) */ PIMAGE_NT_HEADERS WINAPI ImageNtHeader(PVOID Base) { return (PIMAGE_NT_HEADERS) ((LPBYTE) Base + ((PIMAGE_DOS_HEADER) Base)->e_lfanew); } /*********************************************************************** * ImageRvaToSection (IMAGEHLP.@) */ PIMAGE_SECTION_HEADER WINAPI ImageRvaToSection( PIMAGE_NT_HEADERS NtHeaders, PVOID Base, ULONG Rva) { FIXME("(%p, %p, %ld): stub\n", NtHeaders, Base, Rva); SetLastError(ERROR_CALL_NOT_IMPLEMENTED); return NULL; } /*********************************************************************** * ImageRvaToVa (IMAGEHLP.@) */ PVOID WINAPI ImageRvaToVa( PIMAGE_NT_HEADERS NtHeaders, PVOID Base, ULONG Rva, PIMAGE_SECTION_HEADER *LastRvaSection) { FIXME("(%p, %p, %ld, %p): stub\n", NtHeaders, Base, Rva, LastRvaSection ); SetLastError(ERROR_CALL_NOT_IMPLEMENTED); return NULL; } /*********************************************************************** * ImageUnload (IMAGEHLP.@) */ BOOL WINAPI ImageUnload(PLOADED_IMAGE pLoadedImage) { LIST_ENTRY *pCurrent, *pFind; if(!IMAGEHLP_pFirstLoadedImage || !pLoadedImage) { /* No image loaded or null pointer */ SetLastError(ERROR_INVALID_PARAMETER); return FALSE; } pFind=&pLoadedImage->Links; pCurrent=&IMAGEHLP_pFirstLoadedImage->Links; while((pCurrent != pFind) && (pCurrent != NULL)) pCurrent = pCurrent->Flink; if(!pCurrent) { /* Not found */ SetLastError(ERROR_INVALID_PARAMETER); return FALSE; } if(pCurrent->Blink) pCurrent->Blink->Flink = pCurrent->Flink; else IMAGEHLP_pFirstLoadedImage = pCurrent->Flink?CONTAINING_RECORD( pCurrent->Flink, LOADED_IMAGE, Links):NULL; if(pCurrent->Flink) pCurrent->Flink->Blink = pCurrent->Blink; else IMAGEHLP_pLastLoadedImage = pCurrent->Blink?CONTAINING_RECORD( pCurrent->Blink, LOADED_IMAGE, Links):NULL; return FALSE; } /*********************************************************************** * MapAndLoad (IMAGEHLP.@) */ BOOL WINAPI MapAndLoad( LPSTR pszImageName, LPSTR pszDllPath, PLOADED_IMAGE pLoadedImage, BOOL bDotDll, BOOL bReadOnly) { CHAR szFileName[MAX_PATH]; HANDLE hFile = (HANDLE) NULL; HANDLE hFileMapping = (HANDLE) NULL; HMODULE hModule = (HMODULE) NULL; PIMAGE_NT_HEADERS pNtHeader = NULL; /* PathCombine(&szFileName, pszDllPath, pszImageName); */ /* PathRenameExtension(&szFileName, bDotDll?:"dll":"exe"); */ /* FIXME: Check if the file already loaded (use IMAGEHLP_pFirstLoadedImage) */ if(!(hFile = CreateFileA( szFileName, GENERIC_READ, 1, /* FIXME: FILE_SHARE_READ not defined */ NULL, OPEN_EXISTING, 0, (HANDLE) NULL))) { SetLastError(ERROR_FILE_NOT_FOUND); goto Error; } if(!(hFileMapping = CreateFileMappingA( hFile, NULL, PAGE_READONLY | SEC_COMMIT, 0, 0, NULL))) { DWORD dwLastError = GetLastError(); WARN("CreateFileMapping: Error = %ld\n", dwLastError); SetLastError(dwLastError); goto Error; } CloseHandle(hFile); hFile = (HANDLE) NULL; if(!(hModule = (HMODULE) MapViewOfFile( hFileMapping, FILE_MAP_READ, 0, 0, 0))) { DWORD dwLastError = GetLastError(); WARN("MapViewOfFile: Error = %ld\n", dwLastError); SetLastError(dwLastError); goto Error; } CloseHandle(hFileMapping); hFileMapping=(HANDLE) NULL; pLoadedImage = (PLOADED_IMAGE) HeapAlloc( IMAGEHLP_hHeap, 0, sizeof(LOADED_IMAGE) ); pNtHeader = ImageNtHeader((PVOID) hModule); pLoadedImage->ModuleName = HEAP_strdupA(IMAGEHLP_hHeap, 0, pszDllPath); /* FIXME: Correct? */ pLoadedImage->hFile = hFile; pLoadedImage->MappedAddress = (PUCHAR) hModule; pLoadedImage->FileHeader = pNtHeader; pLoadedImage->Sections = (PIMAGE_SECTION_HEADER) ((LPBYTE) &pNtHeader->OptionalHeader + pNtHeader->FileHeader.SizeOfOptionalHeader); pLoadedImage->NumberOfSections = pNtHeader->FileHeader.NumberOfSections; pLoadedImage->SizeOfImage = pNtHeader->OptionalHeader.SizeOfImage; pLoadedImage->Characteristics = pNtHeader->FileHeader.Characteristics; pLoadedImage->LastRvaSection = pLoadedImage->Sections; pLoadedImage->fSystemImage = FALSE; /* FIXME */ pLoadedImage->fDOSImage = FALSE; /* FIXME */ /* FIXME: Make thread safe */ pLoadedImage->Links.Flink = NULL; pLoadedImage->Links.Blink = &IMAGEHLP_pLastLoadedImage->Links; if(IMAGEHLP_pLastLoadedImage) IMAGEHLP_pLastLoadedImage->Links.Flink = &pLoadedImage->Links; IMAGEHLP_pLastLoadedImage = pLoadedImage; if(!IMAGEHLP_pFirstLoadedImage) IMAGEHLP_pFirstLoadedImage = pLoadedImage; return TRUE; Error: if(hModule) UnmapViewOfFile((PVOID) hModule); if(hFileMapping) CloseHandle(hFileMapping); if(hFile) CloseHandle(hFile); return FALSE; } /*********************************************************************** * SetImageConfigInformation (IMAGEHLP.@) */ BOOL WINAPI SetImageConfigInformation( PLOADED_IMAGE LoadedImage, PIMAGE_LOAD_CONFIG_DIRECTORY ImageConfigInformation) { FIXME("(%p, %p): stub\n", LoadedImage, ImageConfigInformation ); SetLastError(ERROR_CALL_NOT_IMPLEMENTED); return FALSE; } /*********************************************************************** * UnMapAndLoad (IMAGEHLP.@) */ BOOL WINAPI UnMapAndLoad(PLOADED_IMAGE LoadedImage) { FIXME("(%p): stub\n", LoadedImage); SetLastError(ERROR_CALL_NOT_IMPLEMENTED); return FALSE; }