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

337 lines
8.5 KiB
C

/*++
Copyright (c) 1998 Microsoft Corporation
Module Name:
trackirp.h
Abstract:
The module associated with the header asserts Irps are handled correctly
by drivers. No IRP-major specific testing is done;
Author:
Adrian J. Oney (adriao) 20-Apr-1998
Revision History:
--*/
#ifndef _TRACKIRP_H_
#define _TRACKIRP_H_
#if DBG
extern ULONG IovpIrpTrackingSpewLevel;
#endif
#define IRP_DIAG_HAS_SURROGATE 0x02000000
#define IRP_DIAG_IS_SURROGATE 0x01000000
//#define TRACKFLAG_ACTIVE 0x00000001
#define TRACKFLAG_SURROGATE 0x00000002
#define TRACKFLAG_HAS_SURROGATE 0x00000004
#define TRACKFLAG_PROTECTEDIRP 0x00000008
#define TRACKFLAG_QUEUED_INTERNALLY 0x00000010
#define TRACKFLAG_BOGUS 0x00000020
#define TRACKFLAG_RELEASED 0x00000040
#define TRACKFLAG_SRB_MUNGED 0x00000080
#define TRACKFLAG_SWAPPED_BACK 0x00000100
#define TRACKFLAG_DIRECT_BUFFERED 0x00000200
#define TRACKFLAG_WATERMARKED 0x00100000
#define TRACKFLAG_IO_ALLOCATED 0x00200000
#define TRACKFLAG_UNWOUND_BADLY 0x00400000
#define TRACKFLAG_PASSED_AT_BAD_IRQL 0x02000000
#define TRACKFLAG_IN_TRANSIT 0x40000000
#define STACKFLAG_NO_HANDLER 0x80000000
#define STACKFLAG_REQUEST_COMPLETED 0x40000000
#define STACKFLAG_CHECK_FOR_REFERENCE 0x20000000
#define STACKFLAG_REACHED_PDO 0x10000000
#define STACKFLAG_FIRST_REQUEST 0x08000000
#define STACKFLAG_UNWOUND_PENDING 0x04000000
#define STACKFLAG_FAILURE_FORWARDED 0x02000000
#define STACKFLAG_BOGUS_IRP_TOUCHED 0x01000000
#define CALLFLAG_STACK_DATA_ALLOCATED 0x80000000
#define CALLFLAG_COMPLETED 0x40000000
#define CALLFLAG_IS_REMOVE_IRP 0x20000000
#define CALLFLAG_REMOVING_FDO_STACK_DO 0x10000000
#define CALLFLAG_OVERRIDE_STATUS 0x08000000
#define CALLFLAG_TOPMOST_IN_SLOT 0x04000000
#define CALLFLAG_MARKED_PENDING 0x02000000
#define CALLFLAG_ARRIVED_PENDING 0x01000000
#define ALLOCFLAG_PROTECTEDIRP 0x00000001
#define SESSIONFLAG_UNWOUND_INCONSISTANT 0x00000001
#define SESSIONFLAG_MARKED_INCONSISTANT 0x00000002
#define IRP_SYSTEM_RESTRICTED 0x00000001
#define IRP_BOGUS 0x00000002
#define SL_NOTCOPIED 0x10
#define IRP_ALLOCATION_MONITORED 0x80
#define STARTED_TOP_OF_STACK 1
#define FORWARDED_TO_NEXT_DO 2
#define SKIPPED_A_DO 3
#define STARTED_INSIDE_STACK 4
#define CHANGED_STACKS_AT_BOTTOM 5
#define CHANGED_STACKS_MID_STACK 6
typedef enum {
DEFERACTION_QUEUE_WORKITEM,
DEFERACTION_QUEUE_PASSIVE_TIMER,
DEFERACTION_QUEUE_DISPATCH_TIMER,
DEFERACTION_NORMAL
} DEFER_ACTION;
typedef struct _DEFERRAL_CONTEXT {
PIOV_REQUEST_PACKET IovRequestPacket;
PIO_COMPLETION_ROUTINE OriginalCompletionRoutine;
PVOID OriginalContext;
PIRP OriginalIrp;
CCHAR OriginalPriorityBoost;
PDEVICE_OBJECT DeviceObject;
PIO_STACK_LOCATION IrpSpNext;
WORK_QUEUE_ITEM WorkQueueItem;
KDPC DpcItem;
KTIMER DeferralTimer;
DEFER_ACTION DeferAction;
} DEFERRAL_CONTEXT, *PDEFERRAL_CONTEXT;
//
// These are in trackirp.c
//
VOID
FASTCALL
IovpPacketFromIrp(
IN PIRP Irp,
OUT PIOV_REQUEST_PACKET *IovPacket
);
BOOLEAN
FASTCALL
IovpCheckIrpForCriticalTracking(
IN PIRP Irp
);
VOID
FASTCALL
IovpCallDriver1(
IN PDEVICE_OBJECT DeviceObject,
IN OUT PIRP *IrpPointer,
IN OUT PIOFCALLDRIVER_STACKDATA IofCallDriverStackData OPTIONAL,
IN PVOID CallerAddress
);
VOID
FASTCALL
IovpCallDriver2(
IN PDEVICE_OBJECT DeviceObject,
IN OUT NTSTATUS *FinalStatus,
IN PIOFCALLDRIVER_STACKDATA IofCallDriverStackData OPTIONAL
);
VOID
FASTCALL
IovpCompleteRequest1(
IN PIRP Irp,
IN CCHAR PriorityBoost,
IN OUT PIOFCOMPLETEREQUEST_STACKDATA CompletionPacket
);
VOID
FASTCALL
IovpCompleteRequest2(
IN PIRP Irp,
IN OUT PIOFCOMPLETEREQUEST_STACKDATA CompletionPacket
);
VOID
FASTCALL
IovpCompleteRequest3(
IN PIRP Irp,
IN PVOID Routine,
IN OUT PIOFCOMPLETEREQUEST_STACKDATA CompletionPacket
);
VOID
FASTCALL
IovpCompleteRequest4(
IN PIRP Irp,
IN NTSTATUS ReturnedStatus,
IN OUT PIOFCOMPLETEREQUEST_STACKDATA CompletionPacket
);
VOID
FASTCALL
IovpCompleteRequest5(
IN PIRP Irp,
IN OUT PIOFCOMPLETEREQUEST_STACKDATA CompletionPacket
);
VOID
FASTCALL
IovpCompleteRequestApc(
IN PIRP Irp,
IN PVOID BestStackOffset
);
VOID
FASTCALL
IovpCancelIrp(
IN PIRP Irp,
IN OUT PBOOLEAN CancelHandled,
IN OUT PBOOLEAN ReturnValue
);
VOID
IovpExamineIrpStackForwarding(
IN OUT PIOV_REQUEST_PACKET IovPacket,
IN BOOLEAN IsNewSession,
IN ULONG ForwardMethod,
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp,
IN PVOID CallerAddress,
IN OUT PIO_STACK_LOCATION *IoCurrentStackLocation,
OUT PIO_STACK_LOCATION *IoLastStackLocation,
OUT ULONG *StackLocationsAdvanced
);
NTSTATUS
IovpSwapSurrogateIrp(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp,
IN PVOID Context
);
VOID
FASTCALL
IovpExamineDevObjForwarding(
IN PDEVICE_OBJECT DeviceBeingCalled,
IN PDEVICE_OBJECT DeviceLastCalled,
OUT PULONG ForwardingTechnique
);
VOID
FASTCALL
IovpFinalizeIrpSettings(
IN OUT PIOV_REQUEST_PACKET IrpTrackingData,
IN BOOLEAN SurrogateIrpSwapped
);
NTSTATUS
IovpInternalCompletionTrap(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp,
IN PVOID Context
);
NTSTATUS
IovpInternalDeferredCompletion(
IN PDEVICE_OBJECT DeviceObject,
IN PIRP Irp,
IN PVOID Context
);
VOID
IovpInternalCompleteAfterWait(
IN PVOID Context
);
VOID
IovpInternalCompleteAtDPC(
IN PKDPC Dpc,
IN PVOID DeferredContext,
IN PVOID SystemArgument1,
IN PVOID SystemArgument2
);
BOOLEAN
IovpAdvanceStackDownwards(
IN PIOV_STACK_LOCATION StackDataArray,
IN CCHAR CurrentLocation,
IN PIO_STACK_LOCATION IrpSp,
IN PIO_STACK_LOCATION IrpLastSp OPTIONAL,
IN ULONG LocationsAdvanced,
IN BOOLEAN IsNewRequest,
IN BOOLEAN MarkAsTaken,
OUT PIOV_STACK_LOCATION *StackLocationInfo
);
VOID
IovpBuildMiniIrpSnapshot(
IN PIRP Irp,
OUT IRP_MINI_SNAPSHOT *IrpSnapshot
);
#define SPECIALIRP_MARK_NON_TRACKABLE(Irp) { \
(Irp)->Flags |= IRPFLAG_EXAMINE_NOT_TRACKED; \
}
#define SPECIALIRP_IOF_COMPLETE_1(Irp, PriorityBoost, CompletionPacket) \
{\
IovpCompleteRequest1((Irp), (PriorityBoost), (CompletionPacket));\
}
#define SPECIALIRP_IOF_COMPLETE_2(Irp, CompletionPacket) \
{\
IovpCompleteRequest2((Irp), (CompletionPacket));\
}
#define SPECIALIRP_IOF_COMPLETE_3(Irp, Routine, CompletionPacket) \
{\
IovpCompleteRequest3((Irp), (Routine), (CompletionPacket));\
}
#define SPECIALIRP_IOF_COMPLETE_4(Irp, ReturnedStatus, CompletionPacket) \
{\
IovpCompleteRequest4((Irp), (ReturnedStatus), (CompletionPacket));\
}
#define SPECIALIRP_IOF_COMPLETE_5(Irp, CompletionPacket) \
{\
IovpCompleteRequest5((Irp), (CompletionPacket));\
}
#define SPECIALIRP_IO_CANCEL_IRP(Irp, CancelHandled, ReturnValue) \
{\
IovpCancelIrp((Irp), (CancelHandled), (ReturnValue));\
}
#define SPECIALIRP_WATERMARK_IRP(Irp, Flags) \
{\
IovUtilWatermarkIrp(Irp, Flags);\
}
#define SPECIALIRP_IOP_COMPLETE_REQUEST(Irp, StackPointer) \
{\
IovpCompleteRequestApc(Irp, StackPointer);\
}
#if DBG
#define TRACKIRP_DBGPRINT(txt,level) \
{ \
if (IovpIrpTrackingSpewLevel>(level)) { \
DbgPrint##txt ; \
}\
}
#else
#define TRACKIRP_DBGPRINT(txt,level)
#endif
#endif // _TRACKIRP_H_