FLT_PARAMETERS für IRP_MJ_MDL_WRITE_COMPLETE Union
Der folgende FLT_PARAMETERS Unionsmember wird verwendet, wenn FLT_IO_PARAMETER_BLOCK.MajorFunction IRP_MJ_MDL_WRITE_COMPLETE ist.
Syntax
typedef union _FLT_PARAMETERS {
... ;
struct {
LARGE_INTEGER FileOffset;
PMDL MdlChain;
} MdlWriteComplete;
... ;
} FLT_PARAMETERS, *PFLT_PARAMETERS;
Member
MdlWriteComplete: Struktur, die die folgenden Mitglieder enthält.
FileOffset: Byte wird innerhalb der zwischengespeicherten Datei gestartet.
MdlChain: Zeiger auf eine Variable, die einen Zeiger auf eine Kette von einer oder mehreren Memory Descriptor Lists (MDL) erhält, die die Seiten beschreiben, die die Daten enthalten, die in die Cachedatei geschrieben werden sollen.
Hinweise
IRP_MJ_MDL_WRITE_COMPLETE ist ein schneller E/A-Vorgang. Es funktioniert genauso wie IRP_MJ_WRITE + IRP_MN_COMPLETE_MDLL mit Ausnahme des folgenden Unterschieds:
- Der IRP-basierte Vorgang richtet die Zwischenspeicherung für die Datei ein, wenn er noch nicht zwischengespeichert wird, bevor die MDL-Arbeit ausgeführt wird.
- Der schnelle E/A-Vorgang schlägt fehl, wenn die Datei noch nicht zwischengespeichert ist.
Die FLT_PARAMETERS-Struktur für IRP_MJ_MDL_WRITE_COMPLETE-Vorgänge enthält die Parameter für einen schnellen E/A-MdlWriteComplete-Vorgang. Dieser Vorgang wird durch Rückrufdaten-Struktur (FLT_CALLBACK_DATA) mit den Parametern des Vorgangs in der FLT_IO_PARAMETER_BLOCK-Struktur dargestellt, auf die Iopb verweist.
Wenn bei einer schnellen E/A-IRP_MJ_MDL_WRITE_COMPLETE-Anforderung ein Fehler auftritt, bestimmt der Aussteller der E/A, wie die Anforderung erneut ausgeführt werden soll. Die Anforderung kann beispielsweise mit IRP_MJ_WRITE + IRP_MN_COMPLETE_MDL als IRP-basierten Vorgang neu bereitgestellt werden.
Anforderungen
Anforderungstyp | Anforderung |
---|---|
Header | Fltkernel.h (einschließlich Fltkernel.h) |