/*
* Process Hacker -
* procedure import module
*
* Copyright (C) 2015 wj32
*
* This file is part of Process Hacker.
*
* Process Hacker is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Process Hacker is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Process Hacker. If not, see .
*/
#include
#include
PVOID PhpImportProcedure(
_Inout_ PVOID *Cache,
_Inout_ PBOOLEAN CacheValid,
_In_ PWSTR ModuleName,
_In_ PSTR ProcedureName
)
{
HMODULE module;
PVOID procedure;
if (*CacheValid)
return *Cache;
module = GetModuleHandle(ModuleName);
if (!module)
return NULL;
procedure = GetProcAddress(module, ProcedureName);
*Cache = procedure;
MemoryBarrier();
*CacheValid = TRUE;
return procedure;
}
#define PH_DEFINE_IMPORT(Module, Name) \
_##Name Name##_Import(VOID) \
{ \
static PVOID cache = NULL; \
static BOOLEAN cacheValid = FALSE; \
\
return (_##Name)PhpImportProcedure(&cache, &cacheValid, Module, #Name); \
}
PH_DEFINE_IMPORT(L"comctl32.dll", TaskDialogIndirect);
PH_DEFINE_IMPORT(L"ntdll.dll", NtQueryInformationEnlistment);
PH_DEFINE_IMPORT(L"ntdll.dll", NtQueryInformationResourceManager);
PH_DEFINE_IMPORT(L"ntdll.dll", NtQueryInformationTransaction);
PH_DEFINE_IMPORT(L"ntdll.dll", NtQueryInformationTransactionManager);
PH_DEFINE_IMPORT(L"shell32.dll", SHCreateShellItem);
PH_DEFINE_IMPORT(L"shell32.dll", SHOpenFolderAndSelectItems);
PH_DEFINE_IMPORT(L"shell32.dll", SHParseDisplayName);