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

213 lines
7.5 KiB
C

/*++ BUILD Version: 0001
*
* WOW v1.0
*
* Copyright (c) 2002, Microsoft Corporation
*
* DpmTbls.h
* Builds the Dynamic Patch Module global dispatch tables
*
* History:
* Created 01-10-2002 by cmjones
*
* NOTE:
* 1. This instantiates the memory for DpmFamTbls[] & DpmFamModuleSets[] in
* v86\monitor\i386\thread.c
* by that file.
* 2. If you add to or change this, you must rebuild ntvdm.exe & wow32.dll!!
* 3. To add new families, follow the instructions for each "!!!EDIT THIS !!!"
* section below.
*
--*/
#include "vdm.h"
#define DPMFAMTBLS() (((PVDM_TIB)(NtCurrentTeb()->Vdm))->pDpmFamTbls)
// 1. !!! EDIT THIS !!!
// - for both VDM and/or WOW!!!
//
// Add the include file for each family here.
#include "dpmf_fio.h"
#include "dpmf_prf.h"
#include "dpmf_reg.h"
#include "dpmf_ntd.h"
#ifndef _DPMTBLS_H_COMMON_
#define _DPMTBLS_H_COMMON_
typedef struct _tagDpmModuleSets {
const char *DpmFamilyType; // Type of DPM patch module.dll (see below)
const char *ApiModuleName; // Name of system.dll patched api's belong to
const char **ApiNames; // Array of ptrs to API names we are hooking
} DPMMODULESETS, *PDPMMODULESETS;
// Type prototypes for calling the family table init & destroy functions
// in the various dpmfxxx.dll's.
typedef PFAMILY_TABLE (*LPDPMINIT)(PFAMILY_TABLE, HMODULE, PVOID, PVOID, LPWSTR, PDPMMODULESETS);
typedef PFAMILY_TABLE (*LPDPMDESTROY)(PFAMILY_TABLE, PFAMILY_TABLE);
// 2. !!! EDIT THIS !!!
// Add a description for any new associations you add.
//
// DpmFamilyType's:
// This tells the DPM loader which DPM family to associate your dpm .dll with.
// Current associations:
// DPMFIO - built from dpmf_fio.h
// DPMNTD - built from dpmf_ntd.h
// DPMPRF - built from dpmf_prf.h
// DPMREG - built from dpmf_reg.h
// These are strings used in the dbu.xml with the WOWCF2_DPM_PATCHES app compat
// flag. For example:
// <FLAG NAME="WOWCF2_DPM_PATCHES" COMMAND_LINE="DPMFIO=dpmffio.dll;DPMPRF=dpmprf.dll;DPMREG=dpmfreg.dll"/>
// where the .dll specified is the .dll you build with the associated
// dpmf_xxx.h file shown above.
typedef struct _tagCMDLNPARMS {
int argc; // number of ';' delimited parameters in the command_line
char **argv; // array of vectors pointing to each item in command_line
DWORD dwFlag; // App compat flag associated with these parameters
} CMDLNPARMS, *PCMDLNPARMS;
void BuildGlobalDpmStuffForWow(PFAMILY_TABLE *, PDPMMODULESETS *);
void InitTaskDpmSupport(int,
PFAMILY_TABLE *,
PCMDLNPARMS,
PVOID,
PVOID,
LPWSTR,
LPWSTR,
LPWSTR);
VOID FreeTaskDpmSupport(PFAMILY_TABLE *, int, PFAMILY_TABLE *);
void InitGlobalDpmTables(PFAMILY_TABLE *, int);
PVOID GetDpmAddress(PVOID lpAddress);
PCMDLNPARMS InitVdmSdbInfo(LPCSTR, DWORD *, int *);
VOID FreeCmdLnParmStructs(PCMDLNPARMS, int);
BOOL IsDpmEnabledForThisTask(void);
#define MAX_APP_NAME 31+1
// 3.Vdm. !!! EDIT THIS !!!
// -- add any new VDM familes to this list
//
// NOTE: If you update this list you must update all of the following:
// gDpmVdmFamTbls[]
// gDpmWowFamTbls[]
// gDpmVdmModuleSets[]
// gDpmWowModuleSets[]
enum VdmFamilies {FIO_FAM=0,
NTD_FAM,
enum_last_VDM_fam}; // this should always be last
#define NUM_VDM_FAMILIES_HOOKED enum_last_VDM_fam
// 4.Wow. !!! EDIT THIS !!!
/// -- add any new WOW Families to this list
//
// NOTE: If you update this list you must update gDpmWowFamTbls[] &
// gDpmWowModuleSets[] below.
enum WowFamilies {REG_FAM=enum_last_VDM_fam,
PRF_FAM,
enum_last_WOW_fam}; // this should always be last
#define NUM_WOW_FAMILIES_HOOKED (enum_last_WOW_fam)
// Note: The WOW families & module sets get appended on the end of the VDM
// families & module sets for WOW.
#endif // _DPMTBLS_H_COMMON_
// 5.Common. !!! EDIT THIS !!!
//
// Add a DPMMODULESETS struct for each family created.
// If you add something to this list, be sure to add the new moduleset to the
// appropriate modulesets below.
#ifdef _DPM_COMMON_ // For both VDM & WOW
const DPMMODULESETS FioModSet = {"DPMFIO", "kernel32.dll", DpmFioStrs};
const DPMMODULESETS NtdModSet = {"DPMNTD", "ntdll.dll", DpmNtdStrs};
#ifdef _WDPM_C_ // For WOW only
const DPMMODULESETS RegModSet = {"DPMREG", "advapi32.dll", DpmRegStrs};
const DPMMODULESETS PrfModSet = {"DPMPRF", "kernel32.dll", DpmPrfStrs};
#endif // _WDPM_C_
#endif // _DPM_COMMON_
#ifdef _VDPM_C_
//
// THIS SECTION IS FOR VDM FAMILIES ONLY!!!!
//
// VDM Patches (Possibly callable by WOW!)
// The following two arrays become part of v86\monitor\i386\thread.c through
// this inclusion.
// 6.Vdm. !!! EDIT THIS !!!
// -- For VDM Families only!!!
//
// Add the family defined at the end of each VDM dpmf_xxx.h file included above.
// Families added to this list must be in the same order as enum VdmFamilies{}
// above. If you add something to this list you must also add it to the
// gDpmWowFamTbls[] list below.
const PFAMILY_TABLE gDpmVdmFamTbls[] = {&DpmFioFam,
&DpmNtdFam };
// 7.Vdm. !!! EDIT THIS !!!
// -- For VDM Families only!!!
//
// Add each DPMMODULESETS struct created above.
// list.
// Names added to this list must be in the same order as enum VdmFamilies{}
// above. If you add something to this list you must also add it to the
// gDpmWowModuleSets[] list below.
const PDPMMODULESETS gDpmVdmModuleSets[] = {(const PDPMMODULESETS)&FioModSet,
(const PDPMMODULESETS)&NtdModSet};
// END VDM ONLY SECTION!!!!
#endif // _VDPM_C_
#ifdef _WDPM_C_
//
// THIS SECTION IS FOR WOW FAMILIES!!!!
//
// WOW exclusive Patches
// The following two arrays become part of mvdm\wow32\wdpm.c through
// this inclusion.
// 6.Wow. !!! EDIT THIS !!!
// -- For WOW Families only!!!
//
// Add the family defined at the end of each WOW dpmf_xxx.h file included above.
// Families added to this list must be in the same order as enum WowFamilies{}
// above. All VDM familes added to this list must be at the head of the list
// and be in the same order as gDpmVdmFamTbls[].
const PFAMILY_TABLE gDpmWowFamTbls[] = {&DpmFioFam,
&DpmNtdFam,
&DpmRegFam,
&DpmPrfFam };
// 7.Wow. !!! EDIT THIS !!!
// -- For WOW Families only!!!
//
// Add each DPMMODULESETS struct created above.
// list.
// Families added to this list must be in the same order as enum WowFamilies{}
// above. All VDM familes added to this list must be at the head of the list
// and be in the same order as gDpmVdmModuleSets[].
const PDPMMODULESETS gDpmWowModuleSets[] = {(const PDPMMODULESETS)&FioModSet,
(const PDPMMODULESETS)&NtdModSet,
(const PDPMMODULESETS)&RegModSet,
(const PDPMMODULESETS)&PrfModSet};
// END WOW ONLY SECTION!!!!
#endif // _WDPM_C_