148 lines
3.9 KiB
C
148 lines
3.9 KiB
C
|
/*++
|
|||
|
|
|||
|
Copyright (c) 1989-1994 Microsoft Corporation
|
|||
|
|
|||
|
Module Name:
|
|||
|
|
|||
|
NtDspVec.h
|
|||
|
|
|||
|
Abstract:
|
|||
|
|
|||
|
This module declares the routines used to initialize a dispatch vector. this includefile is
|
|||
|
essentially private for NT version of the fsd and fspdispatch.
|
|||
|
|
|||
|
Author:
|
|||
|
|
|||
|
Joe Linn [JoeLinn] 2-Aug-94
|
|||
|
|
|||
|
Revision History:
|
|||
|
|
|||
|
--*/
|
|||
|
|
|||
|
#ifndef _DISPVEC_
|
|||
|
#define _DISPVEC_
|
|||
|
|
|||
|
|
|||
|
//
|
|||
|
// Global structures used to dispatch to the actual routines. By having
|
|||
|
// a common dispatch we are able to consolidate handling of stuff like
|
|||
|
// dispatching to a stack overflow thread, irpcontext getting, logging, etc.
|
|||
|
// We may decide later that we
|
|||
|
// would rather save the few cycles that this takes. Eventually, all the FCBs will
|
|||
|
// have pointers to optimized dispatch tables.
|
|||
|
//
|
|||
|
|
|||
|
typedef
|
|||
|
NTSTATUS
|
|||
|
(*PRXCOMMON_ROUTINE) (
|
|||
|
IN PRX_CONTEXT RxContext
|
|||
|
);
|
|||
|
|
|||
|
typedef struct _RX_FSD_DISPATCH_VECTOR{
|
|||
|
PRXCOMMON_ROUTINE CommonRoutine;
|
|||
|
ULONG StackRequirement;
|
|||
|
} RX_FSD_DISPATCH_VECTOR, *PRX_FSD_DISPATCH_VECTOR;
|
|||
|
|
|||
|
extern RX_FSD_DISPATCH_VECTOR RxFsdDispatchVector[IRP_MJ_MAXIMUM_FUNCTION + 1];
|
|||
|
extern RX_FSD_DISPATCH_VECTOR RxDeviceFCBVector[IRP_MJ_MAXIMUM_FUNCTION + 1];
|
|||
|
|
|||
|
|
|||
|
#define DISPVECENTRY_SELECT_1(x) RxCommon##x
|
|||
|
#define DISPVECENTRY_SELECT_0(x) RxCommonDispatchProblem
|
|||
|
#define DISPVECENTRY_SELECT(x,y) DISPVECENTRY_SELECT_##x(y)
|
|||
|
#define DISPVECENTRY_NEW(IRPSUFFIX,IMPL,VEC,STACKREQ) \
|
|||
|
{DISPVECENTRY_SELECT(IMPL,VEC),STACKREQ}
|
|||
|
|
|||
|
#if (IRP_MJ_CREATE != 0x00)
|
|||
|
#error IRP_MJ_CREATE has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_CREATE_NAMED_PIPE != 0x01)
|
|||
|
#error IRP_MJ_CREATE_NAMED_PIPE has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_CLOSE != 0x02)
|
|||
|
#error IRP_MJ_CLOSE has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_READ != 0x03)
|
|||
|
#error IRP_MJ_READ has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_WRITE != 0x04)
|
|||
|
#error IRP_MJ_WRITE has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_QUERY_INFORMATION != 0x05)
|
|||
|
#error IRP_MJ_QUERY_INFORMATION has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_SET_INFORMATION != 0x06)
|
|||
|
#error IRP_MJ_SET_INFORMATION has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_QUERY_EA != 0x07)
|
|||
|
#error IRP_MJ_QUERY_EA has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_SET_EA != 0x08)
|
|||
|
#error IRP_MJ_SET_EA has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_FLUSH_BUFFERS != 0x09)
|
|||
|
#error IRP_MJ_FLUSH_BUFFERS has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_QUERY_VOLUME_INFORMATION != 0x0a)
|
|||
|
#error IRP_MJ_QUERY_VOLUME_INFORMATION has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_SET_VOLUME_INFORMATION != 0x0b)
|
|||
|
#error IRP_MJ_SET_VOLUME_INFORMATION has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_DIRECTORY_CONTROL != 0x0c)
|
|||
|
#error IRP_MJ_DIRECTORY_CONTROL has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_FILE_SYSTEM_CONTROL != 0x0d)
|
|||
|
#error IRP_MJ_FILE_SYSTEM_CONTROL has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_DEVICE_CONTROL != 0x0e)
|
|||
|
#error IRP_MJ_DEVICE_CONTROL has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_INTERNAL_DEVICE_CONTROL != 0x0f)
|
|||
|
#error IRP_MJ_INTERNAL_DEVICE_CONTROL has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_SHUTDOWN != 0x10)
|
|||
|
#error IRP_MJ_SHUTDOWN has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_LOCK_CONTROL != 0x11)
|
|||
|
#error IRP_MJ_LOCK_CONTROL has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_CLEANUP != 0x12)
|
|||
|
#error IRP_MJ_CLEANUP has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_CREATE_MAILSLOT != 0x13)
|
|||
|
#error IRP_MJ_CREATE_MAILSLOT has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_QUERY_SECURITY != 0x14)
|
|||
|
#error IRP_MJ_QUERY_SECURITY has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_SET_SECURITY != 0x15)
|
|||
|
#error IRP_MJ_SET_SECURITY has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_POWER != 0x16)
|
|||
|
#error IRP_MJ_POWER has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_SYSTEM_CONTROL != 0x17)
|
|||
|
#error IRP_MJ_SYSTEM_CONTROL has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_DEVICE_CHANGE != 0x18)
|
|||
|
#error IRP_MJ_DEVICE_CHANGE has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_QUERY_QUOTA != 0x19)
|
|||
|
#error IRP_MJ_QUERY_QUOTA has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_SET_QUOTA != 0x1a)
|
|||
|
#error IRP_MJ_SET_QUOTA has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_PNP != 0x1b)
|
|||
|
#error IRP_MJ_PNP has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_PNP_POWER != IRP_MJ_PNP)
|
|||
|
#error IRP_MJ_PNP_POWER has changed!!!
|
|||
|
#endif
|
|||
|
#if (IRP_MJ_MAXIMUM_FUNCTION != 0x1b)
|
|||
|
#error IRP_MJ_MAXIMUM_FUNCTION has changed!!!
|
|||
|
#endif
|
|||
|
|
|||
|
#endif // _DISPVEC_
|
|||
|
|