FSCTL_OPLOCK_BREAK_ACKNOWLEDGE codice di controllo
Il codice di controllo FSCTL_OPLOCK_BREAK_ACKNOWLEDGE risponde alla notifica che un blocco opportunistico (livello 1, batch o filtro) esclusivo (oplock) in un file è stato interrotto.
Un'applicazione client invia questo codice di controllo per indicare che riconosce l'interruzione di oplock e che, se l'oplock è un blocco di livello 1 interrotto al livello 2, vuole il livello 2 oplock.
Per elaborare questo codice di controllo, un minifilter chiama FltOplockFsctrl con i parametri seguenti. Un file system o un driver di filtro legacy chiama FsRtlOplockFsctrl.
Per altre informazioni sul blocco opportunistico e sul codice di controllo FSCTL_OPLOCK_BREAK_ACKNOWLEDGE, vedere la documentazione di Microsoft Windows SDK.
Parametri
Oplock: puntatore a oggetti oplock opaco per il file.
CallbackData: solo FltOplockFsctrl . Struttura dei dati di callback (FLT_CALLBACK_DATA) per una richiesta IRP_MJ_FILE_SYSTEM_CONTROL FSCTL. Il parametro FsControlCode per l'operazione deve essere FSCTL_OPLOCK_BREAK_ACKNOWLEDGE.
Irp: solo FsRtlOplockFsctrl . IRP per una richiesta IRP_MJ_FILE_SYSTEM_CONTROL FSCTL. Il parametro FsControlCode per l'operazione deve essere FSCTL_OPLOCK_BREAK_ACKNOWLEDGE.
OpenCount: non usato con questa operazione; impostato su zero.
Blocco dello stato
FltOplockFsctrl restituisce FLT_PREOP_PENDING per questa operazione quando viene interrotto un oplock di livello 1 a livello 2 e il livello 2 è stato concesso. In caso contrario, restituisce FLT_PREOP_COMPLETE.
FsRtlOplockFsctrl restituisce uno dei valori NTSTATUS seguenti per questa operazione:
Codice | Significato |
---|---|
STATUS_SUCCESS | L'interruzione di oplock viene riconosciuta. Non vengono mantenuti altri oplock. |
STATUS_INVALID_OPLOCK_PROTOCOL | Nessun blocco è stato mantenuto da questo handle o l'interruzione di oplock non è attualmente in corso. Si tratta di un codice di errore. |
STATUS_PENDING | L'interruzione di oplock viene riconosciuta. Al ritorno, il mittente del codice di controllo FSCTL_OPLOCK_BREAK_ACKNOWLEDGE contiene un blocco di livello 2. Si tratta di un codice riuscito. |
Requisiti
Tipo di requisito | Requisito |
---|---|
Intestazione | Ntifs.h (include Ntifs.h o Fltkernel.h) |
Vedi anche
FLT_PARAMETERS per IRP_MJ_FILE_SYSTEM_CONTROL