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

307 lines
7.3 KiB
C

/*
* MMDEVLDR.H - The main include file for the DevLoader
*
* Version 4.00
*
* Copyright (c) 1994-1998 Microsoft Corporation
*
*/
#ifdef _WIN32 /* ;BeginInternal */
#define MMDEVLDR_IOCTL_GETVERSION 0
#define MMDEVLDR_IOCTL_LINPAGELOCK 1
#define MMDEVLDR_IOCTL_LINPAGEUNLOCK 2
#define MMDEVLDR_IOCTL_RING0THREADHANDLE 3
#define MMDEVLDR_IOCTL_QUEUEAPC 4
#define MMDEVLDR_IOCTL_GETCHANGENOTIFYPTR 5
#define MMDEVLDR_IOCTL_CLOSEVXDHANDLE 6
#define MMDEVLDR_IOCTL_PAGEALLOCATE 7
#define MMDEVLDR_IOCTL_PAGEFREE 8
#define MMDEVLDR_IOCTL_GETDEVICESTATUS 9
#define MM_DEVSTATUS_ERROR 0
#define MM_DEVSTATUS_STARTED 1
#define MM_DEVSTATUS_UNKNOWNPROB 2
#define MM_DEVSTATUS_DISABLED 3
typedef struct tagLOCKUNLOCKPARMS
{
DWORD dwStartPage;
DWORD dwPageCount;
DWORD fdwOperation;
} LOCKUNLOCKPARMS;
typedef struct tagQUEUEAPCPARMS
{
DWORD fnCallback;
DWORD dwUser;
DWORD hRing0Thd;
} QUEUEAPCPARMS;
typedef struct tagPAGEALLOCATEPARMS
{
DWORD dwFlags;
DWORD dwPageCount;
} PAGEALLOCATEPARMS;
typedef struct tagPAGEALLOCATERETURN
{
VOID * lpvBase;
DWORD hMem;
DWORD dwPageCount;
DWORD dwPhysBase;
} PAGEALLOCATERETURN;
#endif
#ifdef MMDEVLDR_VXD
#define MM_STOP 0
#define MM_START 1
#define MM_MMDEVLDR_UP 3
#define MM_REMOVE 4
#define CONFIG_QUERYSTART 0x01000
#define MAXLEN 256
typedef struct tagMMDEVNODE
{
DEVNODE dn ;
DWORD dwDevStatus ;
VMMLIST hlDrivers ;
BOOL IsWDMDriver ;
} MMDEVNODE, *PMMDEVNODE ;
typedef struct tagMMDRVNODE
{
CMCONFIGHANDLER pConfigHandler ;
DWORD dwRefData ;
} MMDRVNODE, *PMMDRVNODE ;
//
// macros
//
#define SIZEOF_ARRAY(ar) (sizeof(ar)/sizeof((ar)[0]))
#if defined(DEBUG_RETAIL) || defined(DEBUG)
#define DBG_TRACE(strings) {\
_Debug_Printf_Service( "MMDEVLDR: "); \
_Debug_Printf_Service##strings; \
_Debug_Printf_Service("\n");}
#ifdef DEBUG
#define DBG_ERROR(strings) {\
_Debug_Printf_Service( "MMDEVLDR ERROR: "); \
_Debug_Printf_Service##strings; \
_Debug_Printf_Service("\n");\
{_asm int 3}}
#else
#define DBG_ERROR(strings) {\
_Debug_Printf_Service( "MMDEVLDR ERROR: "); \
_Debug_Printf_Service##strings; \
_Debug_Printf_Service("\n");}
#endif
#else
#define DBG_TRACE(strings)
#define DBG_ERROR(strings)
#endif
#ifdef DEBUG
#define DPF( strings ) _Debug_Printf_Service##strings;
void __cdecl _my_assert(void *, void *, unsigned);
#define ASSERT(exp) (void)( (exp) || (_my_assert(#exp, __FILE__, __LINE__), 0) )
#else
#define DPF( strings )
#define ASSERT( exp )
#endif
#define QUOTE(x) #x
#define QQUOTE(y) QUOTE(y)
#define REMIND(str) __FILE__ "(" QQUOTE(__LINE__) ") : " str
//
// internal function prototypes
//
void MMDEVLDR_Call_MMSystem(DEVNODE dnDevNode, DWORD fLoad);
void MMDEVLDR_CheckForMMSystem(void);
DWORD StringLen(PCHAR psz);
PCHAR StringCopy(PCHAR pszDst, PCHAR pszSrc);
PCHAR StringCat(PCHAR pszDst, PCHAR pszSrc);
#pragma warning (disable:4035) // turn off no return code warning
PSTR VXDINLINE Get_Environment_String
(
PSTR pszName
)
{
_asm push esi
_asm mov esi, pszName
VMMCall( Get_Environment_String ) ;
_asm mov eax, edx
_asm pop esi
}
#pragma warning (default:4035) // turn on no return code warning
BOOL _InitGlobalEnvironment() ;
VOID MMDEVLDR_SetEnvironmentString
(
PSTR pszName,
PSTR pszValue
) ;
BOOL MMDEVLDR_GetEnvironmentString
(
PSTR pszName,
PSTR pszValue,
UINT uBufSize
) ;
VOID MMDEVLDR_RemoveEnvironmentString
(
PSTR pszName
) ;
VOID MMDEVLDR_AddEnvironmentString
(
PSTR pszName,
PSTR pszValue
) ;
#else /* ;EndInternal */
#define Multimedia_OEM_ID 0x0440 // ; MS Reserved OEM # 34
#define MMDEVLDR_DEVICE_ID Multimedia_OEM_ID + 10 //;MMDEVLDR's device ID
#ifdef Begin_Service_Table // define only if vmm.h is included
#define MMDEVLDR_Service Declare_Service
#pragma warning (disable:4003) // turn off not enough params warning
//MACROS
Begin_Service_Table(MMDEVLDR)
MMDEVLDR_Service (MMDEVLDR_Register_Device_Driver, LOCAL)
MMDEVLDR_Service (MMDEVLDR_SetDevicePresence)
MMDEVLDR_Service (MMDEVLDR_SetEnvironmentString)
MMDEVLDR_Service (MMDEVLDR_GetEnvironmentString)
MMDEVLDR_Service (MMDEVLDR_RemoveEnvironmentString)
MMDEVLDR_Service (MMDEVLDR_AddEnvironmentString)
End_Service_Table(MMDEVLDR)
//ENDMACROS
#pragma warning (default:4003) // turn on not enough params warning
#pragma warning (disable:4035) // turn off no return code warning
VOID VXDINLINE MMDEVLDR_Register_Device_Driver
(
DEVNODE dnDevNode,
DWORD fnConfigHandler,
DWORD dwUserData
)
{
_asm push ebx
_asm mov eax,dnDevNode
_asm mov ebx,fnConfigHandler
_asm mov ecx,dwUserData
Touch_Register(edx)
VxDCall(MMDEVLDR_Register_Device_Driver);
_asm pop ebx
}
VOID VXDINLINE MMDEVLDR_SetDevicePresence
(
DEVNODE dn,
PCHAR pszReg,
BOOL fPresent
)
{
_asm push fPresent
_asm push pszReg
_asm push dn
Touch_Register(eax)
Touch_Register(ecx)
Touch_Register(edx)
VxDCall(MMDEVLDR_SetDevicePresence);
_asm add esp, 3*4
} ;
VOID VXDINLINE MMDEVLDR_SetEnvironmentString
(
PCHAR pszName,
PCHAR pszValue
)
{
_asm push pszValue
_asm push pszName
Touch_Register(eax)
Touch_Register(ecx)
Touch_Register(edx)
VxDCall(MMDEVLDR_SetEnvironmentString);
_asm add esp, 2*4
} ;
BOOL VXDINLINE MMDEVLDR_GetEnvironmentString
(
PCHAR pszName,
PCHAR pszValue,
UINT uBufSize
)
{
_asm push uBufSize
_asm push pszValue
_asm push pszName
Touch_Register(eax)
Touch_Register(ecx)
Touch_Register(edx)
VxDCall(MMDEVLDR_GetEnvironmentString);
_asm add esp, 3*4
} ;
VOID VXDINLINE MMDEVLDR_RemoveEnvironmentString
(
PCHAR pszName
)
{
_asm push pszName
Touch_Register(eax)
Touch_Register(ecx)
Touch_Register(edx)
VxDCall(MMDEVLDR_RemoveEnvironmentString);
_asm add esp, 4
} ;
VOID VXDINLINE MMDEVLDR_AddEnvironmentString
(
PCHAR pszName,
PCHAR pszValue
)
{
_asm push pszValue
_asm push pszName
Touch_Register(eax)
Touch_Register(ecx)
Touch_Register(edx)
VxDCall(MMDEVLDR_AddEnvironmentString);
_asm add esp, 2*4
} ;
#pragma warning (disable:4035) // turn on no return code warning
#endif // Begin_Service_Table
#endif /* ;Internal */