mirror of
https://github.com/tnodir/fort
synced 2024-11-15 08:25:20 +00:00
Driver: Setup callbacks proxying
This commit is contained in:
parent
e814e4c809
commit
1f5a518d29
@ -23,10 +23,10 @@ SOURCES += \
|
|||||||
loader/fortdl.c \
|
loader/fortdl.c \
|
||||||
loader/fortimg.c \
|
loader/fortimg.c \
|
||||||
loader/fortmm.c \
|
loader/fortmm.c \
|
||||||
proxycb/fortpcb_def.c \
|
|
||||||
proxycb/fortpcb_drv.c \
|
proxycb/fortpcb_drv.c \
|
||||||
proxycb/fortpcb_dst.c \
|
proxycb/fortpcb_dst.c \
|
||||||
proxycb/fortpcb_src.c \
|
proxycb/fortpcb_src.c \
|
||||||
|
proxycb/fortpcb_src_dummy.c \
|
||||||
wdm/um_aux_klib.c \
|
wdm/um_aux_klib.c \
|
||||||
wdm/um_fwpmk.c \
|
wdm/um_fwpmk.c \
|
||||||
wdm/um_fwpsk.c \
|
wdm/um_fwpsk.c \
|
||||||
|
@ -4,8 +4,25 @@
|
|||||||
|
|
||||||
#include "proxycb/fortpcb_dst.h"
|
#include "proxycb/fortpcb_dst.h"
|
||||||
|
|
||||||
|
FORT_PROXYCB_INFO g_callbackInfo;
|
||||||
|
|
||||||
FORT_API FortCallbackFunc fort_callback(int id, FortCallbackFunc func)
|
FORT_API FortCallbackFunc fort_callback(int id, FortCallbackFunc func)
|
||||||
{
|
{
|
||||||
g_proxyDstCallbacks[id] = func;
|
g_callbackInfo.callbacks[id] = func;
|
||||||
return func;
|
return g_callbackInfo.src[id];
|
||||||
|
}
|
||||||
|
|
||||||
|
void fort_callback_setup(PFORT_PROXYCB_INFO cb_info)
|
||||||
|
{
|
||||||
|
fort_proxycb_dst_prepare(&g_callbackInfo);
|
||||||
|
|
||||||
|
if (cb_info == NULL) {
|
||||||
|
g_callbackInfo.src = g_callbackInfo.dst;
|
||||||
|
} else {
|
||||||
|
g_callbackInfo.src = cb_info->src;
|
||||||
|
|
||||||
|
fort_proxycb_dst_setup(&g_callbackInfo);
|
||||||
|
|
||||||
|
*cb_info = g_callbackInfo;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,8 @@
|
|||||||
|
|
||||||
#include "fortdrv.h"
|
#include "fortdrv.h"
|
||||||
|
|
||||||
|
#include "proxycb/fortpcb_def.h"
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
FORT_SYSCB_POWER = 0,
|
FORT_SYSCB_POWER = 0,
|
||||||
FORT_SYSCB_TIME,
|
FORT_SYSCB_TIME,
|
||||||
@ -18,6 +20,8 @@ typedef void (*FortCallbackFunc)(void);
|
|||||||
|
|
||||||
FORT_API FortCallbackFunc fort_callback(int id, FortCallbackFunc func);
|
FORT_API FortCallbackFunc fort_callback(int id, FortCallbackFunc func);
|
||||||
|
|
||||||
|
FORT_API void fort_callback_setup(PFORT_PROXYCB_INFO cb_info);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
} // extern "C"
|
} // extern "C"
|
||||||
#endif
|
#endif
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
|
|
||||||
#include "common/fortdef.h"
|
#include "common/fortdef.h"
|
||||||
|
|
||||||
|
#include "fortcb.h"
|
||||||
#include "fortdev.h"
|
#include "fortdev.h"
|
||||||
|
|
||||||
static NTSTATUS fort_bfe_wait(void)
|
static NTSTATUS fort_bfe_wait(void)
|
||||||
@ -62,12 +63,6 @@ static NTSTATUS fort_driver_load(PDRIVER_OBJECT driver, PUNICODE_STRING reg_path
|
|||||||
if (!NT_SUCCESS(status))
|
if (!NT_SUCCESS(status))
|
||||||
return status;
|
return status;
|
||||||
|
|
||||||
driver->MajorFunction[IRP_MJ_CREATE] = fort_device_create;
|
|
||||||
driver->MajorFunction[IRP_MJ_CLOSE] = fort_device_close;
|
|
||||||
driver->MajorFunction[IRP_MJ_CLEANUP] = fort_device_cleanup;
|
|
||||||
driver->MajorFunction[IRP_MJ_DEVICE_CONTROL] = fort_device_control;
|
|
||||||
driver->DriverUnload = fort_driver_unload;
|
|
||||||
|
|
||||||
UNICODE_STRING device_link;
|
UNICODE_STRING device_link;
|
||||||
|
|
||||||
RtlInitUnicodeString(&device_link, FORT_DOS_DEVICE_NAME);
|
RtlInitUnicodeString(&device_link, FORT_DOS_DEVICE_NAME);
|
||||||
@ -75,15 +70,24 @@ static NTSTATUS fort_driver_load(PDRIVER_OBJECT driver, PUNICODE_STRING reg_path
|
|||||||
if (!NT_SUCCESS(status))
|
if (!NT_SUCCESS(status))
|
||||||
return status;
|
return status;
|
||||||
|
|
||||||
|
driver->DriverUnload = fort_driver_unload;
|
||||||
|
driver->MajorFunction[IRP_MJ_CREATE] = fort_device_create;
|
||||||
|
driver->MajorFunction[IRP_MJ_CLOSE] = fort_device_close;
|
||||||
|
driver->MajorFunction[IRP_MJ_CLEANUP] = fort_device_cleanup;
|
||||||
|
driver->MajorFunction[IRP_MJ_DEVICE_CONTROL] = fort_device_control;
|
||||||
|
|
||||||
device_obj->Flags |= DO_BUFFERED_IO;
|
device_obj->Flags |= DO_BUFFERED_IO;
|
||||||
|
|
||||||
return fort_device_load(device_obj);
|
return fort_device_load(device_obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
NTSTATUS __declspec(dllexport) DriverCallbackEntry(PDRIVER_OBJECT driver, PUNICODE_STRING reg_path)
|
NTSTATUS __declspec(dllexport) DriverCallbackEntry(
|
||||||
|
PDRIVER_OBJECT driver, PUNICODE_STRING reg_path, PFORT_PROXYCB_INFO cb_info)
|
||||||
{
|
{
|
||||||
NTSTATUS status;
|
NTSTATUS status;
|
||||||
|
|
||||||
|
fort_callback_setup(cb_info);
|
||||||
|
|
||||||
status = fort_driver_load(driver, reg_path);
|
status = fort_driver_load(driver, reg_path);
|
||||||
|
|
||||||
if (!NT_SUCCESS(status)) {
|
if (!NT_SUCCESS(status)) {
|
||||||
@ -96,5 +100,5 @@ NTSTATUS __declspec(dllexport) DriverCallbackEntry(PDRIVER_OBJECT driver, PUNICO
|
|||||||
|
|
||||||
NTSTATUS DriverEntry(PDRIVER_OBJECT driver, PUNICODE_STRING reg_path)
|
NTSTATUS DriverEntry(PDRIVER_OBJECT driver, PUNICODE_STRING reg_path)
|
||||||
{
|
{
|
||||||
return DriverCallbackEntry(driver, reg_path);
|
return DriverCallbackEntry(driver, reg_path, NULL);
|
||||||
}
|
}
|
||||||
|
@ -66,11 +66,12 @@
|
|||||||
<FilesToPackage Include="$(TargetPath)" />
|
<FilesToPackage Include="$(TargetPath)" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
<MASM Include="proxycb\fortpcb_dst_x86.asm">
|
||||||
|
<AdditionalOptions Condition="'$(Platform)'=='Win32'">/safeseh</AdditionalOptions>
|
||||||
|
</MASM>
|
||||||
<ClCompile Include="fortdrv_amalg.c" />
|
<ClCompile Include="fortdrv_amalg.c" />
|
||||||
<ResourceCompile Include="fortdrv.rc" />
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<ClInclude Include="fortdrv.h" />
|
<ClInclude Include="fortdrv.h" />
|
||||||
|
<ResourceCompile Include="fortdrv.rc" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
||||||
<ImportGroup Label="ExtensionTargets">
|
<ImportGroup Label="ExtensionTargets">
|
||||||
|
@ -32,14 +32,18 @@ static NTSTATUS fort_loader_entry(PDRIVER_OBJECT driver, PUNICODE_STRING regPath
|
|||||||
{
|
{
|
||||||
NTSTATUS status;
|
NTSTATUS status;
|
||||||
|
|
||||||
/* Setup the proxy callbacks */
|
/* Prepare the proxy callbacks */
|
||||||
fort_proxycb_src_setup();
|
FORT_PROXYCB_INFO cbInfo;
|
||||||
|
fort_proxycb_src_prepare(&cbInfo);
|
||||||
|
|
||||||
/* Run the module entry function */
|
/* Run the module entry function */
|
||||||
status = CallModuleEntry(&g_loader.module, driver, regPath);
|
status = CallModuleEntry(&g_loader.module, driver, regPath, &cbInfo);
|
||||||
if (!NT_SUCCESS(status))
|
if (!NT_SUCCESS(status))
|
||||||
return status;
|
return status;
|
||||||
|
|
||||||
|
/* Setup the proxy callbacks */
|
||||||
|
fort_proxycb_src_setup(&cbInfo);
|
||||||
|
|
||||||
/* Proxy the driver major functions */
|
/* Proxy the driver major functions */
|
||||||
g_loader.DriverUnload = driver->DriverUnload;
|
g_loader.DriverUnload = driver->DriverUnload;
|
||||||
driver->DriverUnload = fort_loader_unload;
|
driver->DriverUnload = fort_loader_unload;
|
||||||
|
@ -21,7 +21,8 @@
|
|||||||
#define fort_nt_headers(pImage) \
|
#define fort_nt_headers(pImage) \
|
||||||
((PIMAGE_NT_HEADERS) & ((PUCHAR) (pImage))[((PIMAGE_DOS_HEADER) pImage)->e_lfanew])
|
((PIMAGE_NT_HEADERS) & ((PUCHAR) (pImage))[((PIMAGE_DOS_HEADER) pImage)->e_lfanew])
|
||||||
|
|
||||||
typedef NTSTATUS(WINAPI *DriverCallbackEntryProc)(PDRIVER_OBJECT driver, PUNICODE_STRING regPath);
|
typedef NTSTATUS(WINAPI *DriverCallbackEntryProc)(
|
||||||
|
PDRIVER_OBJECT driver, PUNICODE_STRING regPath, PFORT_PROXYCB_INFO cbInfo);
|
||||||
|
|
||||||
static NTSTATUS GetModuleInfo(PLOADEDMODULE pModule, LPCSTR name,
|
static NTSTATUS GetModuleInfo(PLOADEDMODULE pModule, LPCSTR name,
|
||||||
const PAUX_MODULE_EXTENDED_INFO modules, DWORD modulesCount)
|
const PAUX_MODULE_EXTENDED_INFO modules, DWORD modulesCount)
|
||||||
@ -391,18 +392,19 @@ FORT_API void UnloadModule(PLOADEDMODULE pModule)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
FORT_API NTSTATUS CallModuleEntry(
|
FORT_API NTSTATUS CallModuleEntry(PLOADEDMODULE pModule, PDRIVER_OBJECT driver,
|
||||||
PLOADEDMODULE pModule, PDRIVER_OBJECT driver, PUNICODE_STRING regPath)
|
PUNICODE_STRING regPath, PFORT_PROXYCB_INFO cbInfo)
|
||||||
{
|
{
|
||||||
DriverCallbackEntryProc driverEntry =
|
DriverCallbackEntryProc driverEntry =
|
||||||
(DriverCallbackEntryProc) ModuleGetProcAddress(pModule, "DriverCallbackEntry");
|
(DriverCallbackEntryProc) ModuleGetProcAddress(pModule, "DriverCallbackEntry");
|
||||||
if (driverEntry == NULL)
|
if (driverEntry == NULL)
|
||||||
return STATUS_PROCEDURE_NOT_FOUND;
|
return STATUS_PROCEDURE_NOT_FOUND;
|
||||||
|
|
||||||
DbgPrintEx(DPFLTR_IHVNETWORK_ID, DPFLTR_ERROR_LEVEL, "FORT: Loader Module: Entry Proc: %p %x\n",
|
DbgPrintEx(DPFLTR_IHVNETWORK_ID, DPFLTR_ERROR_LEVEL,
|
||||||
driverEntry, *(PDWORD) (PVOID) &driverEntry);
|
"FORT: Loader Module: Entry Proc: %p data=%x\n", driverEntry,
|
||||||
|
*(PDWORD) (PVOID) &driverEntry);
|
||||||
|
|
||||||
return driverEntry(driver, regPath);
|
return driverEntry(driver, regPath, cbInfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Retrieve address of an exported function from the loaded module. */
|
/* Retrieve address of an exported function from the loaded module. */
|
||||||
|
@ -3,6 +3,8 @@
|
|||||||
|
|
||||||
#include "fortdl.h"
|
#include "fortdl.h"
|
||||||
|
|
||||||
|
#include "../proxycb/fortpcb_def.h"
|
||||||
|
|
||||||
#if defined(__cplusplus)
|
#if defined(__cplusplus)
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
@ -16,8 +18,8 @@ FORT_API NTSTATUS LoadModuleFromMemory(PLOADEDMODULE pModule, PUCHAR lpData, DWO
|
|||||||
|
|
||||||
FORT_API void UnloadModule(PLOADEDMODULE pModule);
|
FORT_API void UnloadModule(PLOADEDMODULE pModule);
|
||||||
|
|
||||||
FORT_API NTSTATUS CallModuleEntry(
|
FORT_API NTSTATUS CallModuleEntry(PLOADEDMODULE pModule, PDRIVER_OBJECT driver,
|
||||||
PLOADEDMODULE pModule, PDRIVER_OBJECT driver, PUNICODE_STRING regPath);
|
PUNICODE_STRING regPath, PFORT_PROXYCB_INFO cbInfo);
|
||||||
|
|
||||||
FORT_API FARPROC ModuleGetProcAddress(PLOADEDMODULE pModule, LPCSTR funcName);
|
FORT_API FARPROC ModuleGetProcAddress(PLOADEDMODULE pModule, LPCSTR funcName);
|
||||||
|
|
||||||
|
@ -9,75 +9,15 @@ extern "C" {
|
|||||||
|
|
||||||
typedef void (*ProxyCallbackProc)(void);
|
typedef void (*ProxyCallbackProc)(void);
|
||||||
|
|
||||||
|
typedef struct fort_proxycb_info
|
||||||
|
{
|
||||||
|
ProxyCallbackProc *src;
|
||||||
|
ProxyCallbackProc *dst;
|
||||||
|
ProxyCallbackProc *callbacks;
|
||||||
|
} FORT_PROXYCB_INFO, *PFORT_PROXYCB_INFO;
|
||||||
|
|
||||||
#define PROXY_CALLBACKS_COUNT 64
|
#define PROXY_CALLBACKS_COUNT 64
|
||||||
|
|
||||||
#define ProxyCallbackExtern(i) extern void proxyCallback##i(void)
|
|
||||||
|
|
||||||
ProxyCallbackExtern(0);
|
|
||||||
ProxyCallbackExtern(1);
|
|
||||||
ProxyCallbackExtern(2);
|
|
||||||
ProxyCallbackExtern(3);
|
|
||||||
ProxyCallbackExtern(4);
|
|
||||||
ProxyCallbackExtern(5);
|
|
||||||
ProxyCallbackExtern(6);
|
|
||||||
ProxyCallbackExtern(7);
|
|
||||||
ProxyCallbackExtern(8);
|
|
||||||
ProxyCallbackExtern(9);
|
|
||||||
ProxyCallbackExtern(10);
|
|
||||||
ProxyCallbackExtern(11);
|
|
||||||
ProxyCallbackExtern(12);
|
|
||||||
ProxyCallbackExtern(13);
|
|
||||||
ProxyCallbackExtern(14);
|
|
||||||
ProxyCallbackExtern(15);
|
|
||||||
ProxyCallbackExtern(16);
|
|
||||||
ProxyCallbackExtern(17);
|
|
||||||
ProxyCallbackExtern(18);
|
|
||||||
ProxyCallbackExtern(19);
|
|
||||||
ProxyCallbackExtern(20);
|
|
||||||
ProxyCallbackExtern(21);
|
|
||||||
ProxyCallbackExtern(22);
|
|
||||||
ProxyCallbackExtern(23);
|
|
||||||
ProxyCallbackExtern(24);
|
|
||||||
ProxyCallbackExtern(25);
|
|
||||||
ProxyCallbackExtern(26);
|
|
||||||
ProxyCallbackExtern(27);
|
|
||||||
ProxyCallbackExtern(28);
|
|
||||||
ProxyCallbackExtern(29);
|
|
||||||
ProxyCallbackExtern(30);
|
|
||||||
ProxyCallbackExtern(31);
|
|
||||||
ProxyCallbackExtern(32);
|
|
||||||
ProxyCallbackExtern(33);
|
|
||||||
ProxyCallbackExtern(34);
|
|
||||||
ProxyCallbackExtern(35);
|
|
||||||
ProxyCallbackExtern(36);
|
|
||||||
ProxyCallbackExtern(37);
|
|
||||||
ProxyCallbackExtern(38);
|
|
||||||
ProxyCallbackExtern(39);
|
|
||||||
ProxyCallbackExtern(40);
|
|
||||||
ProxyCallbackExtern(41);
|
|
||||||
ProxyCallbackExtern(42);
|
|
||||||
ProxyCallbackExtern(43);
|
|
||||||
ProxyCallbackExtern(44);
|
|
||||||
ProxyCallbackExtern(45);
|
|
||||||
ProxyCallbackExtern(46);
|
|
||||||
ProxyCallbackExtern(47);
|
|
||||||
ProxyCallbackExtern(48);
|
|
||||||
ProxyCallbackExtern(49);
|
|
||||||
ProxyCallbackExtern(50);
|
|
||||||
ProxyCallbackExtern(51);
|
|
||||||
ProxyCallbackExtern(52);
|
|
||||||
ProxyCallbackExtern(53);
|
|
||||||
ProxyCallbackExtern(54);
|
|
||||||
ProxyCallbackExtern(55);
|
|
||||||
ProxyCallbackExtern(56);
|
|
||||||
ProxyCallbackExtern(57);
|
|
||||||
ProxyCallbackExtern(58);
|
|
||||||
ProxyCallbackExtern(59);
|
|
||||||
ProxyCallbackExtern(60);
|
|
||||||
ProxyCallbackExtern(61);
|
|
||||||
ProxyCallbackExtern(62);
|
|
||||||
ProxyCallbackExtern(63);
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
} // extern "C"
|
} // extern "C"
|
||||||
#endif
|
#endif
|
||||||
|
@ -2,10 +2,160 @@
|
|||||||
|
|
||||||
#include "fortpcb_dst.h"
|
#include "fortpcb_dst.h"
|
||||||
|
|
||||||
ProxyCallbackProc g_proxyDstCallbacks[PROXY_CALLBACKS_COUNT];
|
#ifdef _WIN64
|
||||||
|
|
||||||
FORT_API void fort_proxycb_dst_setup(void)
|
# define ProxyCallbackExtern(i) extern void proxyCallback##i(void)
|
||||||
|
|
||||||
|
ProxyCallbackExtern(0);
|
||||||
|
ProxyCallbackExtern(1);
|
||||||
|
ProxyCallbackExtern(2);
|
||||||
|
ProxyCallbackExtern(3);
|
||||||
|
ProxyCallbackExtern(4);
|
||||||
|
ProxyCallbackExtern(5);
|
||||||
|
ProxyCallbackExtern(6);
|
||||||
|
ProxyCallbackExtern(7);
|
||||||
|
ProxyCallbackExtern(8);
|
||||||
|
ProxyCallbackExtern(9);
|
||||||
|
ProxyCallbackExtern(10);
|
||||||
|
ProxyCallbackExtern(11);
|
||||||
|
ProxyCallbackExtern(12);
|
||||||
|
ProxyCallbackExtern(13);
|
||||||
|
ProxyCallbackExtern(14);
|
||||||
|
ProxyCallbackExtern(15);
|
||||||
|
ProxyCallbackExtern(16);
|
||||||
|
ProxyCallbackExtern(17);
|
||||||
|
ProxyCallbackExtern(18);
|
||||||
|
ProxyCallbackExtern(19);
|
||||||
|
ProxyCallbackExtern(20);
|
||||||
|
ProxyCallbackExtern(21);
|
||||||
|
ProxyCallbackExtern(22);
|
||||||
|
ProxyCallbackExtern(23);
|
||||||
|
ProxyCallbackExtern(24);
|
||||||
|
ProxyCallbackExtern(25);
|
||||||
|
ProxyCallbackExtern(26);
|
||||||
|
ProxyCallbackExtern(27);
|
||||||
|
ProxyCallbackExtern(28);
|
||||||
|
ProxyCallbackExtern(29);
|
||||||
|
ProxyCallbackExtern(30);
|
||||||
|
ProxyCallbackExtern(31);
|
||||||
|
ProxyCallbackExtern(32);
|
||||||
|
ProxyCallbackExtern(33);
|
||||||
|
ProxyCallbackExtern(34);
|
||||||
|
ProxyCallbackExtern(35);
|
||||||
|
ProxyCallbackExtern(36);
|
||||||
|
ProxyCallbackExtern(37);
|
||||||
|
ProxyCallbackExtern(38);
|
||||||
|
ProxyCallbackExtern(39);
|
||||||
|
ProxyCallbackExtern(40);
|
||||||
|
ProxyCallbackExtern(41);
|
||||||
|
ProxyCallbackExtern(42);
|
||||||
|
ProxyCallbackExtern(43);
|
||||||
|
ProxyCallbackExtern(44);
|
||||||
|
ProxyCallbackExtern(45);
|
||||||
|
ProxyCallbackExtern(46);
|
||||||
|
ProxyCallbackExtern(47);
|
||||||
|
ProxyCallbackExtern(48);
|
||||||
|
ProxyCallbackExtern(49);
|
||||||
|
ProxyCallbackExtern(50);
|
||||||
|
ProxyCallbackExtern(51);
|
||||||
|
ProxyCallbackExtern(52);
|
||||||
|
ProxyCallbackExtern(53);
|
||||||
|
ProxyCallbackExtern(54);
|
||||||
|
ProxyCallbackExtern(55);
|
||||||
|
ProxyCallbackExtern(56);
|
||||||
|
ProxyCallbackExtern(57);
|
||||||
|
ProxyCallbackExtern(58);
|
||||||
|
ProxyCallbackExtern(59);
|
||||||
|
ProxyCallbackExtern(60);
|
||||||
|
ProxyCallbackExtern(61);
|
||||||
|
ProxyCallbackExtern(62);
|
||||||
|
ProxyCallbackExtern(63);
|
||||||
|
|
||||||
|
static ProxyCallbackProc g_proxyDstCallbacks[PROXY_CALLBACKS_COUNT] = {
|
||||||
|
proxyCallback0,
|
||||||
|
proxyCallback1,
|
||||||
|
proxyCallback2,
|
||||||
|
proxyCallback3,
|
||||||
|
proxyCallback4,
|
||||||
|
proxyCallback5,
|
||||||
|
proxyCallback6,
|
||||||
|
proxyCallback7,
|
||||||
|
proxyCallback8,
|
||||||
|
proxyCallback9,
|
||||||
|
proxyCallback10,
|
||||||
|
proxyCallback11,
|
||||||
|
proxyCallback12,
|
||||||
|
proxyCallback13,
|
||||||
|
proxyCallback14,
|
||||||
|
proxyCallback15,
|
||||||
|
proxyCallback16,
|
||||||
|
proxyCallback17,
|
||||||
|
proxyCallback18,
|
||||||
|
proxyCallback19,
|
||||||
|
proxyCallback20,
|
||||||
|
proxyCallback21,
|
||||||
|
proxyCallback22,
|
||||||
|
proxyCallback23,
|
||||||
|
proxyCallback24,
|
||||||
|
proxyCallback25,
|
||||||
|
proxyCallback26,
|
||||||
|
proxyCallback27,
|
||||||
|
proxyCallback28,
|
||||||
|
proxyCallback29,
|
||||||
|
proxyCallback30,
|
||||||
|
proxyCallback31,
|
||||||
|
proxyCallback32,
|
||||||
|
proxyCallback33,
|
||||||
|
proxyCallback34,
|
||||||
|
proxyCallback35,
|
||||||
|
proxyCallback36,
|
||||||
|
proxyCallback37,
|
||||||
|
proxyCallback38,
|
||||||
|
proxyCallback39,
|
||||||
|
proxyCallback40,
|
||||||
|
proxyCallback41,
|
||||||
|
proxyCallback42,
|
||||||
|
proxyCallback43,
|
||||||
|
proxyCallback44,
|
||||||
|
proxyCallback45,
|
||||||
|
proxyCallback46,
|
||||||
|
proxyCallback47,
|
||||||
|
proxyCallback48,
|
||||||
|
proxyCallback49,
|
||||||
|
proxyCallback50,
|
||||||
|
proxyCallback51,
|
||||||
|
proxyCallback52,
|
||||||
|
proxyCallback53,
|
||||||
|
proxyCallback54,
|
||||||
|
proxyCallback55,
|
||||||
|
proxyCallback56,
|
||||||
|
proxyCallback57,
|
||||||
|
proxyCallback58,
|
||||||
|
proxyCallback59,
|
||||||
|
proxyCallback60,
|
||||||
|
proxyCallback61,
|
||||||
|
proxyCallback62,
|
||||||
|
proxyCallback63,
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static ProxyCallbackProc g_proxyCallbacks[PROXY_CALLBACKS_COUNT];
|
||||||
|
|
||||||
|
ProxyCallbackProc *g_proxyCallbacksPtr;
|
||||||
|
|
||||||
|
FORT_API void fort_proxycb_dst_prepare(PFORT_PROXYCB_INFO cbInfo)
|
||||||
{
|
{
|
||||||
DbgPrintEx(DPFLTR_IHVNETWORK_ID, DPFLTR_ERROR_LEVEL, "FORT: ProxyCbDst Setup: %p\n",
|
cbInfo->dst = g_proxyCallbacks;
|
||||||
&proxyCallback0);
|
cbInfo->callbacks = g_proxyCallbacks;
|
||||||
|
}
|
||||||
|
|
||||||
|
FORT_API void fort_proxycb_dst_setup(PFORT_PROXYCB_INFO cbInfo)
|
||||||
|
{
|
||||||
|
#ifdef _WIN64
|
||||||
|
cbInfo->dst = g_proxyDstCallbacks;
|
||||||
|
g_proxyCallbacksPtr = g_proxyCallbacks;
|
||||||
|
#else
|
||||||
|
Q_UNUSED(cbInfo);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
@ -7,9 +7,10 @@
|
|||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern ProxyCallbackProc g_proxyDstCallbacks[PROXY_CALLBACKS_COUNT];
|
extern ProxyCallbackProc *g_proxyCallbacksPtr;
|
||||||
|
|
||||||
FORT_API void fort_proxycb_dst_setup(void);
|
FORT_API void fort_proxycb_dst_prepare(PFORT_PROXYCB_INFO cbInfo);
|
||||||
|
FORT_API void fort_proxycb_dst_setup(PFORT_PROXYCB_INFO cbInfo);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
} // extern "C"
|
} // extern "C"
|
||||||
|
@ -3,21 +3,16 @@ ELSE
|
|||||||
.model flat, stdcall
|
.model flat, stdcall
|
||||||
ENDIF
|
ENDIF
|
||||||
|
|
||||||
.DATA
|
externdef g_proxyCallbacksPtr : far
|
||||||
IFDEF RAX
|
|
||||||
g_proxyDstCallbacks QWORD 040H dup (?)
|
|
||||||
ELSE
|
|
||||||
g_proxyDstCallbacks DWORD 040H dup (?)
|
|
||||||
ENDIF
|
|
||||||
|
|
||||||
.CODE
|
.CODE
|
||||||
|
|
||||||
ProxyCallbackProc MACRO index:REQ
|
ProxyCallbackProc MACRO index:REQ
|
||||||
IFDEF RAX
|
IFDEF RAX
|
||||||
pop rax
|
pop rax
|
||||||
jmp QWORD PTR [g_proxyDstCallbacks + index * 8]
|
jmp QWORD PTR [g_proxyCallbacksPtr + index * 8]
|
||||||
ELSE
|
ELSE
|
||||||
jmp DWORD PTR [g_proxyDstCallbacks + index * 4]
|
jmp DWORD PTR [g_proxyCallbacksPtr + index * 4]
|
||||||
ENDIF
|
ENDIF
|
||||||
ENDM
|
ENDM
|
||||||
|
|
||||||
|
@ -2,6 +2,73 @@
|
|||||||
|
|
||||||
#include "fortpcb_src.h"
|
#include "fortpcb_src.h"
|
||||||
|
|
||||||
|
#define ProxyCallbackExtern(i) extern void proxyCallback##i(void)
|
||||||
|
|
||||||
|
ProxyCallbackExtern(0);
|
||||||
|
ProxyCallbackExtern(1);
|
||||||
|
ProxyCallbackExtern(2);
|
||||||
|
ProxyCallbackExtern(3);
|
||||||
|
ProxyCallbackExtern(4);
|
||||||
|
ProxyCallbackExtern(5);
|
||||||
|
ProxyCallbackExtern(6);
|
||||||
|
ProxyCallbackExtern(7);
|
||||||
|
ProxyCallbackExtern(8);
|
||||||
|
ProxyCallbackExtern(9);
|
||||||
|
ProxyCallbackExtern(10);
|
||||||
|
ProxyCallbackExtern(11);
|
||||||
|
ProxyCallbackExtern(12);
|
||||||
|
ProxyCallbackExtern(13);
|
||||||
|
ProxyCallbackExtern(14);
|
||||||
|
ProxyCallbackExtern(15);
|
||||||
|
ProxyCallbackExtern(16);
|
||||||
|
ProxyCallbackExtern(17);
|
||||||
|
ProxyCallbackExtern(18);
|
||||||
|
ProxyCallbackExtern(19);
|
||||||
|
ProxyCallbackExtern(20);
|
||||||
|
ProxyCallbackExtern(21);
|
||||||
|
ProxyCallbackExtern(22);
|
||||||
|
ProxyCallbackExtern(23);
|
||||||
|
ProxyCallbackExtern(24);
|
||||||
|
ProxyCallbackExtern(25);
|
||||||
|
ProxyCallbackExtern(26);
|
||||||
|
ProxyCallbackExtern(27);
|
||||||
|
ProxyCallbackExtern(28);
|
||||||
|
ProxyCallbackExtern(29);
|
||||||
|
ProxyCallbackExtern(30);
|
||||||
|
ProxyCallbackExtern(31);
|
||||||
|
ProxyCallbackExtern(32);
|
||||||
|
ProxyCallbackExtern(33);
|
||||||
|
ProxyCallbackExtern(34);
|
||||||
|
ProxyCallbackExtern(35);
|
||||||
|
ProxyCallbackExtern(36);
|
||||||
|
ProxyCallbackExtern(37);
|
||||||
|
ProxyCallbackExtern(38);
|
||||||
|
ProxyCallbackExtern(39);
|
||||||
|
ProxyCallbackExtern(40);
|
||||||
|
ProxyCallbackExtern(41);
|
||||||
|
ProxyCallbackExtern(42);
|
||||||
|
ProxyCallbackExtern(43);
|
||||||
|
ProxyCallbackExtern(44);
|
||||||
|
ProxyCallbackExtern(45);
|
||||||
|
ProxyCallbackExtern(46);
|
||||||
|
ProxyCallbackExtern(47);
|
||||||
|
ProxyCallbackExtern(48);
|
||||||
|
ProxyCallbackExtern(49);
|
||||||
|
ProxyCallbackExtern(50);
|
||||||
|
ProxyCallbackExtern(51);
|
||||||
|
ProxyCallbackExtern(52);
|
||||||
|
ProxyCallbackExtern(53);
|
||||||
|
ProxyCallbackExtern(54);
|
||||||
|
ProxyCallbackExtern(55);
|
||||||
|
ProxyCallbackExtern(56);
|
||||||
|
ProxyCallbackExtern(57);
|
||||||
|
ProxyCallbackExtern(58);
|
||||||
|
ProxyCallbackExtern(59);
|
||||||
|
ProxyCallbackExtern(60);
|
||||||
|
ProxyCallbackExtern(61);
|
||||||
|
ProxyCallbackExtern(62);
|
||||||
|
ProxyCallbackExtern(63);
|
||||||
|
|
||||||
static ProxyCallbackProc g_proxySrcCallbacks[PROXY_CALLBACKS_COUNT] = {
|
static ProxyCallbackProc g_proxySrcCallbacks[PROXY_CALLBACKS_COUNT] = {
|
||||||
proxyCallback0,
|
proxyCallback0,
|
||||||
proxyCallback1,
|
proxyCallback1,
|
||||||
@ -69,8 +136,14 @@ static ProxyCallbackProc g_proxySrcCallbacks[PROXY_CALLBACKS_COUNT] = {
|
|||||||
proxyCallback63,
|
proxyCallback63,
|
||||||
};
|
};
|
||||||
|
|
||||||
FORT_API void fort_proxycb_src_setup(void)
|
ProxyCallbackProc *g_proxyDstCallbacksPtr;
|
||||||
|
|
||||||
|
FORT_API void fort_proxycb_src_prepare(PFORT_PROXYCB_INFO cbInfo)
|
||||||
{
|
{
|
||||||
DbgPrintEx(DPFLTR_IHVNETWORK_ID, DPFLTR_ERROR_LEVEL, "FORT: ProxyCbSrc Setup: %p\n",
|
cbInfo->src = g_proxySrcCallbacks;
|
||||||
&proxyCallback0);
|
}
|
||||||
|
|
||||||
|
FORT_API void fort_proxycb_src_setup(PFORT_PROXYCB_INFO cbInfo)
|
||||||
|
{
|
||||||
|
g_proxyDstCallbacksPtr = cbInfo->dst;
|
||||||
}
|
}
|
||||||
|
@ -7,7 +7,10 @@
|
|||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
FORT_API void fort_proxycb_src_setup(void);
|
extern ProxyCallbackProc *g_proxyDstCallbacksPtr;
|
||||||
|
|
||||||
|
FORT_API void fort_proxycb_src_prepare(PFORT_PROXYCB_INFO cbInfo);
|
||||||
|
FORT_API void fort_proxycb_src_setup(PFORT_PROXYCB_INFO cbInfo);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
} // extern "C"
|
} // extern "C"
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/* Fort Firewall Driver Loader: Proxy Callbacks: Dummy */
|
/* Fort Firewall Driver Loader: Proxy Callbacks: Source Dummy */
|
||||||
|
|
||||||
#include "fortpcb_def.h"
|
#include "fortpcb_src.h"
|
||||||
|
|
||||||
ProxyCallbackProc g_proxyDstProcs[PROXY_CALLBACKS_COUNT];
|
ProxyCallbackProc g_proxyDstProcs[PROXY_CALLBACKS_COUNT];
|
||||||
|
|
@ -3,22 +3,17 @@ ELSE
|
|||||||
.model flat, stdcall
|
.model flat, stdcall
|
||||||
ENDIF
|
ENDIF
|
||||||
|
|
||||||
.DATA
|
externdef g_proxyDstCallbacksPtr : far
|
||||||
IFDEF RAX
|
|
||||||
g_proxyDstProcs QWORD 040H dup (?)
|
|
||||||
ELSE
|
|
||||||
g_proxyDstProcs DWORD 040H dup (?)
|
|
||||||
ENDIF
|
|
||||||
|
|
||||||
.CODE
|
.CODE
|
||||||
|
|
||||||
ProxyCallbackProc MACRO index:REQ
|
ProxyCallbackProc MACRO index:REQ
|
||||||
IFDEF RAX
|
IFDEF RAX
|
||||||
push rax
|
push rax
|
||||||
mov rax, [g_proxyDstProcs + index * 8]
|
mov rax, [g_proxyDstCallbacksPtr + index * 8]
|
||||||
jmp rax
|
jmp rax
|
||||||
ELSE
|
ELSE
|
||||||
jmp DWORD PTR [g_proxyDstProcs + index * 4]
|
jmp DWORD PTR [g_proxyDstCallbacksPtr + index * 4]
|
||||||
ENDIF
|
ENDIF
|
||||||
ENDM
|
ENDM
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user