/* * Copyright (C) Microsoft Corporation, 1990-1999 * nt_vdd.h * * VDD services exports and defines * */ #ifndef _NT_VDD #define _NT_VDD #if _MSC_VER > 1000 #pragma once #endif #ifdef __cplusplus extern "C" { #endif /** * IO port service prototypes and data structure definitions **/ /** Basic typedefs of VDD IO hooks **/ typedef VOID (*PFNVDD_INB) (WORD iport,BYTE * data); typedef VOID (*PFNVDD_INW) (WORD iport,WORD * data); typedef VOID (*PFNVDD_INSB) (WORD iport,BYTE * data,WORD count); typedef VOID (*PFNVDD_INSW) (WORD iport,WORD * data,WORD count); typedef VOID (*PFNVDD_OUTB) (WORD iport,BYTE data); typedef VOID (*PFNVDD_OUTW) (WORD iport,WORD data); typedef VOID (*PFNVDD_OUTSB) (WORD iport,BYTE * data,WORD count); typedef VOID (*PFNVDD_OUTSW) (WORD iport,WORD * data,WORD count); /** Array of handlers for VDD IO hooks. **/ typedef struct _VDD_IO_HANDLERS { PFNVDD_INB inb_handler; PFNVDD_INW inw_handler; PFNVDD_INSB insb_handler; PFNVDD_INSW insw_handler; PFNVDD_OUTB outb_handler; PFNVDD_OUTW outw_handler; PFNVDD_OUTSB outsb_handler; PFNVDD_OUTSW outsw_handler; } VDD_IO_HANDLERS, *PVDD_IO_HANDLERS; /** Port Range structure **/ typedef struct _VDD_IO_PORTRANGE { WORD First; WORD Last; } VDD_IO_PORTRANGE, *PVDD_IO_PORTRANGE; BOOL VDDInstallIOHook ( HANDLE hVDD, WORD cPortRange, PVDD_IO_PORTRANGE pPortRange, PVDD_IO_HANDLERS IOhandler ); VOID VDDDeInstallIOHook ( HANDLE hVdd, WORD cPortRange, PVDD_IO_PORTRANGE pPortRange ); WORD VDDReserveIrqLine ( HANDLE hVdd, WORD IrqLine ); BOOL VDDReleaseIrqLine ( HANDLE hVdd, WORD IrqLine ); /** * DMA service prototypes and data structure definitions **/ /** Buffer definition for returning DMA information **/ typedef struct _VDD_DMA_INFO { WORD addr; WORD count; WORD page; BYTE status; BYTE mode; BYTE mask; } VDD_DMA_INFO, *PVDD_DMA_INFO; /** bits for querying the DMA information **/ #define VDD_DMA_ADDR 0x01 #define VDD_DMA_COUNT 0x02 #define VDD_DMA_PAGE 0x04 #define VDD_DMA_STATUS 0x08 #define VDD_DMA_ALL VDD_DMA_ADDR | VDD_DMA_COUNT | VDD_DMA_PAGE | VDD_DMA_STATUS DWORD VDDRequestDMA ( HANDLE hVDD, WORD iChannel, PVOID Buffer, DWORD length ); BOOL VDDSetDMA ( HANDLE hVDD, WORD iChannel, WORD fDMA, PVDD_DMA_INFO Buffer ); BOOL VDDQueryDMA ( HANDLE hVDD, WORD iChannel, PVDD_DMA_INFO pDmaInfo ); /** * Memory mapped I/O service prototypes and data structure definitions **/ typedef VOID (*PVDD_MEMORY_HANDLER) (PVOID FaultAddress, ULONG RWMode); BOOL VDDInstallMemoryHook ( HANDLE hVDD, PVOID pStart, DWORD count, PVDD_MEMORY_HANDLER MemoryHandler ); BOOL VDDDeInstallMemoryHook ( HANDLE hVDD, PVOID pStart, DWORD count ); BOOL VDDAllocMem( HANDLE hVDD, PVOID Address, DWORD Size ); BOOL VDDFreeMem( HANDLE hVDD, PVOID Address, DWORD Size ); /** * Misc. service prototypes and data structure definitions **/ BOOL VDDIncludeMem( HANDLE hVDD, PVOID Address, DWORD Size ); VOID VDDTerminateVDM(); /** Basic typedefs of VDD User hooks **/ typedef VOID (*PFNVDD_UCREATE) (USHORT DosPDB); typedef VOID (*PFNVDD_UTERMINATE) (USHORT DosPDB); typedef VOID (*PFNVDD_UBLOCK) (VOID); typedef VOID (*PFNVDD_URESUME) (VOID); /** Array of handlers for VDD User hooks. **/ typedef struct _VDD_USER_HANDLERS { HANDLE hvdd; PFNVDD_UCREATE ucr_handler; PFNVDD_UTERMINATE uterm_handler; PFNVDD_UBLOCK ublock_handler; PFNVDD_URESUME uresume_handler; struct _VDD_USER_HANDLERS *next; } VDD_USER_HANDLERS, *PVDD_USER_HANDLERS; /** Function prototypes **/ BOOL VDDInstallUserHook ( HANDLE hVDD, PFNVDD_UCREATE Ucr_Handler, PFNVDD_UTERMINATE Uterm_Handler, PFNVDD_UBLOCK Ublock_handler, PFNVDD_URESUME Uresume_handler ); BOOL VDDDeInstallUserHook ( HANDLE hVdd ); VOID VDDTerminateUserHook(USHORT DosPDB); VOID VDDCreateUserHook(USHORT DosPDB); VOID VDDBlockUserHook(VOID); VOID VDDResumeUserHook(VOID); VOID VDDSimulate16(VOID); SHORT VDDAllocateDosHandle(ULONG pPDB, PVOID* ppSFT, PVOID* ppJFT); VOID VDDAssociateNtHandle(PVOID pSFT, HANDLE h32File, WORD wAccess); BOOL VDDReleaseDosHandle (ULONG pPDB, SHORT hFile); HANDLE VDDRetrieveNtHandle (ULONG pPDB, SHORT hFile, PVOID* ppSFT, PVOID* ppJFT); VOID VdmTraceEvent( USHORT Type, USHORT wData, ULONG lData ); #if DBG #define VDM_TRACE(Type, wData, lData) VdmTraceEvent(Type, wData, lData) #else #define VDM_TRACE(Type, wData, lData) TRUE #endif typedef enum { VDM_V86, VDM_PM } VDM_MODE; typedef enum { VDM_NO_ERROR, VDM_ERROR_INVALID_BUFFER_SIZE, VDM_ERROR_INVALID_FUNCTION, } VDM_ERROR_TYPE; typedef enum { VDM_GET_TICK_COUNT, VDM_GET_TIMER0_INITIAL_COUNT, VDM_GET_LAST_UPDATED_TIMER0_COUNT, VDM_LATCH_TIMER0_COUNT, VDM_SET_NEXT_TIMER0_COUNT, } VDM_INFO_TYPE; #ifndef MSW_PE #define MSW_PE 0x1 #endif #define getMODE() ((getMSW() & MSW_PE) ? VDM_PM : VDM_V86) PVOID VdmMapFlat( USHORT selector, ULONG offset, VDM_MODE mode ); #ifdef _X86_ #define VdmUnmapFlat(sel, off, buffer, mode) TRUE #define VdmFlushCache(sel, off, len, mode) TRUE #else BOOL VdmUnmapFlat( USHORT selector, ULONG offset, PVOID buffer, VDM_MODE mode ); BOOL VdmFlushCache( USHORT selector, ULONG offset, ULONG length, VDM_MODE mode ); #endif BOOL VdmParametersInfo( VDM_INFO_TYPE infotype, PVOID pBuffer, ULONG cbBufferSize ); VDM_INFO_TYPE VdmGetParametersInfoError( VOID ); #ifdef __cplusplus } #endif #endif // ifndef _NT_VDD