2020-09-30 16:53:55 +02:00

221 lines
5.8 KiB
C

#include <windows.h>
#include "view.h"
#include "except.h"
#include "thread.h"
#include "dump.h"
#include "memory.h"
#include "profiler.h"
#include "filter.h"
static CRITICAL_SECTION filterCritSec;
static PMODULEFILTER pFilterHead = 0;
static PMODULEFILTER pLBFilterHead = 0;
static char *pszModules[] = {"ntdll.dll",
"kernel32.dll",
"gdi32.dll",
"user32.dll",
"shell32.dll",
"shlwapi.dll",
"msvcrt.dll",
"msvcirt.dll",
"advapi32.dll",
"ddraw.dll",
"dsound.dll",
"ole32.dll",
"rpcrt4.dll",
"oleaut32.dll",
"winmm.dll",
"comctl32.dll",
"comdlg32.dll",
"riched20.dll",
"dinput.dll",
"wdmaud.drv",
NAME_OF_DLL_TO_INJECT};
BOOL
InitializeFilterList(VOID)
{
HMODULE hTemp;
PIMAGE_NT_HEADERS pHeaders;
DWORD dwModStart;
DWORD dwModEnd;
DWORD dwCounter;
DWORD dwCount;
BOOL bResult;
InitializeCriticalSection(&filterCritSec);
dwCount = sizeof(pszModules) / sizeof(char *);
for (dwCounter = 0; dwCounter < dwCount; dwCounter++) {
//
// Build the filter list
//
hTemp = GetModuleHandleA(pszModules[dwCounter]);
if (0 == hTemp) {
bResult = AddModuleToFilterList(pszModules[dwCounter],
0,
0,
TRUE);
if (FALSE == bResult) {
return FALSE;
}
}
else {
//
// Dig out the PE information
//
pHeaders = ImageNtHeader2((PVOID)hTemp);
dwModStart = (DWORD)hTemp;
dwModEnd = dwModStart + pHeaders->OptionalHeader.SizeOfImage;
bResult = AddModuleToFilterList(pszModules[dwCounter],
dwModStart,
dwModEnd,
FALSE);
if (FALSE == bResult) {
return FALSE;
}
}
}
return TRUE;
}
BOOL
AddModuleToFilterList(CHAR *pszModuleName,
DWORD dwStartAddress,
DWORD dwEndAddress,
BOOL bLateBound)
{
PMODULEFILTER pModuleFilter;
//
// Allocate entry
//
pModuleFilter = AllocMem(sizeof(MODULEFILTER));
if (0 == pModuleFilter) {
return FALSE;
}
if (pszModuleName) {
strcpy(pModuleFilter->szModuleName, pszModuleName);
}
pModuleFilter->dwModuleStart = dwStartAddress;
pModuleFilter->dwModuleEnd = dwEndAddress;
pModuleFilter->pNextFilter = 0;
EnterCriticalSection(&filterCritSec);
if (FALSE == bLateBound) {
//
// Add DLL to the normal filter list
//
if (0 == pFilterHead) {
pFilterHead = pModuleFilter;
}
else {
pModuleFilter->pNextFilter = pFilterHead;
pFilterHead = pModuleFilter;
}
}
else {
//
// Add DLL to the late bound list
//
if (0 == pLBFilterHead) {
pLBFilterHead = pModuleFilter;
}
else {
pModuleFilter->pNextFilter = pLBFilterHead;
pLBFilterHead = pModuleFilter;
}
}
LeaveCriticalSection(&filterCritSec);
return TRUE;
}
BOOL
IsAddressFiltered(DWORD dwAddress)
{
PMODULEFILTER pModuleFilter;
EnterCriticalSection(&filterCritSec);
//
// Walk both lists and see if we have an address to filter
//
pModuleFilter = pFilterHead;
while (pModuleFilter) {
if ((dwAddress >= pModuleFilter->dwModuleStart) &&
(dwAddress <= pModuleFilter->dwModuleEnd)) {
LeaveCriticalSection(&filterCritSec);
return TRUE;
}
pModuleFilter = pModuleFilter->pNextFilter;
}
pModuleFilter = pLBFilterHead;
while (pModuleFilter) {
if ((dwAddress >= pModuleFilter->dwModuleStart) &&
(dwAddress <= pModuleFilter->dwModuleEnd)) {
LeaveCriticalSection(&filterCritSec);
return TRUE;
}
pModuleFilter = pModuleFilter->pNextFilter;
}
LeaveCriticalSection(&filterCritSec);
return FALSE;
}
VOID
RefreshFilterList(VOID)
{
PMODULEFILTER pModuleFilter;
HMODULE hTemp;
PIMAGE_NT_HEADERS pHeaders;
DWORD dwModStart;
DWORD dwModEnd;
//
// Walk the LB list and refresh the start and end module addresses
//
EnterCriticalSection(&filterCritSec);
pModuleFilter = pLBFilterHead;
while (pModuleFilter) {
//
// Grab the module base address
//
hTemp = GetModuleHandleA(pModuleFilter->szModuleName);
if (hTemp) {
//
// This module is loaded - do refresh
//
pHeaders = ImageNtHeader2((PVOID)hTemp);
dwModStart = (DWORD)hTemp;
dwModEnd = dwModStart + pHeaders->OptionalHeader.SizeOfImage;
pModuleFilter->dwModuleStart = dwModStart;
pModuleFilter->dwModuleEnd = dwModEnd;
}
pModuleFilter = pModuleFilter->pNextFilter;
}
LeaveCriticalSection(&filterCritSec);
}