2005-02-02 23:07:33 +00:00
|
|
|
/*
|
|
|
|
* COPYRIGHT: See COPYING in the top level directory
|
|
|
|
* PROJECT: ReactOS kernel
|
|
|
|
* FILE: lib/rossym/frommem.c
|
|
|
|
* PURPOSE: Creating rossym info from an in-memory image
|
2007-10-19 23:21:45 +00:00
|
|
|
*
|
2005-02-02 23:07:33 +00:00
|
|
|
* PROGRAMMERS: Ge van Geldorp (gvg@reactos.com)
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define NTOSAPI
|
2014-02-04 10:47:12 +00:00
|
|
|
#include <ntdef.h>
|
2005-02-02 23:07:33 +00:00
|
|
|
#include <reactos/rossym.h>
|
|
|
|
#include "rossympriv.h"
|
2008-12-01 15:12:23 +00:00
|
|
|
#include <ntimage.h>
|
2005-02-02 23:07:33 +00:00
|
|
|
|
|
|
|
#define NDEBUG
|
|
|
|
#include <debug.h>
|
|
|
|
|
|
|
|
BOOLEAN
|
|
|
|
RosSymCreateFromMem(PVOID ImageStart, ULONG_PTR ImageSize, PROSSYM_INFO *RosSymInfo)
|
|
|
|
{
|
|
|
|
PIMAGE_DOS_HEADER DosHeader;
|
|
|
|
PIMAGE_NT_HEADERS NtHeaders;
|
|
|
|
PIMAGE_SECTION_HEADER SectionHeader;
|
2007-11-23 13:39:31 +00:00
|
|
|
ULONG SectionIndex;
|
|
|
|
BOOLEAN RosSymSectionFound = FALSE;
|
|
|
|
CHAR SectionName[IMAGE_SIZEOF_SHORT_NAME];
|
2005-02-02 23:07:33 +00:00
|
|
|
|
|
|
|
/* Check if MZ header is valid */
|
|
|
|
DosHeader = (PIMAGE_DOS_HEADER) ImageStart;
|
|
|
|
if (ImageSize < sizeof(IMAGE_DOS_HEADER)
|
|
|
|
|| ! ROSSYM_IS_VALID_DOS_HEADER(DosHeader))
|
|
|
|
{
|
|
|
|
DPRINT1("Image doesn't have a valid DOS header\n");
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Locate NT header */
|
|
|
|
NtHeaders = (PIMAGE_NT_HEADERS)((char *) ImageStart + DosHeader->e_lfanew);
|
|
|
|
if (ImageSize < DosHeader->e_lfanew + sizeof(IMAGE_NT_HEADERS)
|
|
|
|
|| ! ROSSYM_IS_VALID_NT_HEADERS(NtHeaders))
|
|
|
|
{
|
|
|
|
DPRINT1("Image doesn't have a valid PE header\n");
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Search for the section header */
|
|
|
|
SectionHeader = IMAGE_FIRST_SECTION(NtHeaders);
|
2005-07-05 22:35:29 +00:00
|
|
|
if (ImageSize < (ULONG_PTR)((char *) (SectionHeader + NtHeaders->FileHeader.NumberOfSections)
|
|
|
|
- (char *) ImageStart))
|
2005-02-02 23:07:33 +00:00
|
|
|
{
|
|
|
|
DPRINT1("Image doesn't have valid section headers\n");
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
strncpy(SectionName, ROSSYM_SECTION_NAME, IMAGE_SIZEOF_SHORT_NAME);
|
|
|
|
for (SectionIndex = 0; SectionIndex < NtHeaders->FileHeader.NumberOfSections; SectionIndex++)
|
|
|
|
{
|
|
|
|
if (0 == memcmp(SectionName, SectionHeader->Name, IMAGE_SIZEOF_SHORT_NAME))
|
|
|
|
{
|
2007-11-23 13:39:31 +00:00
|
|
|
RosSymSectionFound = TRUE;
|
2005-02-02 23:07:33 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
SectionHeader++;
|
|
|
|
}
|
2007-11-23 13:39:31 +00:00
|
|
|
|
|
|
|
if (!RosSymSectionFound)
|
2005-02-02 23:07:33 +00:00
|
|
|
{
|
|
|
|
DPRINT("No %s section found\n", ROSSYM_SECTION_NAME);
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Locate the section itself */
|
|
|
|
if (ImageSize < SectionHeader->PointerToRawData + SectionHeader->SizeOfRawData
|
|
|
|
|| SectionHeader->SizeOfRawData < sizeof(ROSSYM_HEADER))
|
|
|
|
{
|
2007-11-20 10:17:34 +00:00
|
|
|
DPRINT("Invalid %s section\n", ROSSYM_SECTION_NAME);
|
2005-02-02 23:07:33 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2007-11-23 13:39:31 +00:00
|
|
|
if (SectionHeader->VirtualAddress + SectionHeader->Misc.VirtualSize > ImageSize)
|
|
|
|
{
|
|
|
|
DPRINT("Bad %s section virtual size!\n", ROSSYM_SECTION_NAME);
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2005-02-02 23:07:33 +00:00
|
|
|
/* Load it */
|
2007-06-28 09:26:05 +00:00
|
|
|
return RosSymCreateFromRaw((char *) ImageStart + SectionHeader->VirtualAddress,
|
2005-02-02 23:07:33 +00:00
|
|
|
SectionHeader->SizeOfRawData, RosSymInfo);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* EOF */
|