FSCTL_OPLOCK_BREAK_ACKNOWLEDGE控制代码
FSCTL_OPLOCK_BREAK_ACKNOWLEDGE控制代码会响应一个通知,指出文件中的 oplock) (oplock 的独占 (级别 1、批处理或筛选器) 机会锁已损坏。
客户端应用程序发送此控制代码以指示它确认了 oplock 中断,并且如果 oplock 是已中断到级别 2 的 1 级 oplock,则它确实需要 2 级 oplock。
为了处理此控制代码,微筛选器使用以下参数调用 FltOplockFsctrl 。 文件系统或旧版筛选器驱动程序调用 FsRtlOplockFsctrl。
有关机会锁定和FSCTL_OPLOCK_BREAK_ACKNOWLEDGE控制代码的详细信息,请参阅Microsoft Windows SDK文档。
参数
Oplock:文件的不透明不锁定对象指针。
CallbackData:仅限 FltOplockFsctrl 。 IRP_MJ_FILE_SYSTEM_CONTROL FSCTL 请求的回调数据 (FLT_CALLBACK_DATA) 结构。 必须FSCTL_OPLOCK_BREAK_ACKNOWLEDGE操作的 FsControlCode 参数。
Irp:仅限 FsRtlOplockFsctrl 。 IRP_MJ_FILE_SYSTEM_CONTROL FSCTL 请求的 IRP。 必须FSCTL_OPLOCK_BREAK_ACKNOWLEDGE操作的 FsControlCode 参数。
OpenCount:不与此操作一起使用;设置为零。
状态块
当级别 1 oplock 中断到级别 2 并且已授予级别 2 oplock 时,FltOplockFsctrl 将返回此操作的FLT_PREOP_PENDING。 否则,它将返回FLT_PREOP_COMPLETE。
FsRtlOplockFsctrl 为此操作返回以下 NTSTATUS 值之一:
代码 | 含义 |
---|---|
STATUS_SUCCESS | 确认了 oplock 中断。 不保留剩余的 oplock。 |
STATUS_INVALID_OPLOCK_PROTOCOL | 此句柄未持有 oplock,或者当前未进行 oplock 中断。 这是错误代码。 |
STATUS_PENDING | 确认了 oplock 中断。 返回时, FSCTL_OPLOCK_BREAK_ACKNOWLEDGE 控制代码的发送方持有 2 级 oplock。 这是一个成功代码。 |
要求
要求类型 | 要求 |
---|---|
标头 | Ntifs.h (包括 Ntifs.h 或 Fltkernel.h) |
另请参阅
IRP_MJ_FILE_SYSTEM_CONTROL 的 FLT_PARAMETERS