2009-10-12 03:35:35 +00:00
|
|
|
/*
|
|
|
|
* PROJECT: ReactOS Kernel
|
|
|
|
* LICENSE: GPL - See COPYING in the top level directory
|
|
|
|
* FILE: ntoskrnl/fsrtl/oplock.c
|
|
|
|
* PURPOSE: Provides an Opportunistic Lock for file system drivers.
|
|
|
|
* PROGRAMMERS: None.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* INCLUDES ******************************************************************/
|
|
|
|
|
|
|
|
#include <ntoskrnl.h>
|
|
|
|
#define NDEBUG
|
|
|
|
#include <debug.h>
|
|
|
|
|
|
|
|
/* PUBLIC FUNCTIONS **********************************************************/
|
|
|
|
|
|
|
|
/*++
|
|
|
|
* @name FsRtlCheckOplock
|
|
|
|
* @unimplemented
|
|
|
|
*
|
|
|
|
* FILLME
|
|
|
|
*
|
|
|
|
* @param Oplock
|
|
|
|
* FILLME
|
|
|
|
*
|
|
|
|
* @param Irp
|
|
|
|
* FILLME
|
|
|
|
*
|
|
|
|
* @param Context
|
|
|
|
* FILLME
|
|
|
|
*
|
|
|
|
* @param CompletionRoutine
|
|
|
|
* FILLME
|
|
|
|
*
|
|
|
|
* @param PostIrpRoutine
|
|
|
|
* FILLME
|
|
|
|
*
|
|
|
|
* @return None
|
|
|
|
*
|
|
|
|
* @remarks None
|
|
|
|
*
|
|
|
|
*--*/
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
FsRtlCheckOplock(IN POPLOCK Oplock,
|
|
|
|
IN PIRP Irp,
|
|
|
|
IN PVOID Context,
|
|
|
|
IN POPLOCK_WAIT_COMPLETE_ROUTINE CompletionRoutine OPTIONAL,
|
|
|
|
IN POPLOCK_FS_PREPOST_IRP PostIrpRoutine OPTIONAL)
|
|
|
|
{
|
|
|
|
/* Unimplemented */
|
2015-09-29 16:28:59 +00:00
|
|
|
UNIMPLEMENTED;
|
2015-10-30 18:54:16 +00:00
|
|
|
return STATUS_SUCCESS;
|
2009-10-12 03:35:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*++
|
|
|
|
* @name FsRtlCurrentBatchOplock
|
|
|
|
* @unimplemented
|
|
|
|
*
|
|
|
|
* FILLME
|
|
|
|
*
|
|
|
|
* @param Oplock
|
|
|
|
* FILLME
|
|
|
|
*
|
|
|
|
* @return None
|
|
|
|
*
|
|
|
|
* @remarks None
|
|
|
|
*
|
|
|
|
*--*/
|
|
|
|
BOOLEAN
|
|
|
|
NTAPI
|
|
|
|
FsRtlCurrentBatchOplock(IN POPLOCK Oplock)
|
|
|
|
{
|
|
|
|
/* Unimplemented */
|
2015-09-29 16:28:59 +00:00
|
|
|
UNIMPLEMENTED;
|
2009-10-12 03:35:35 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*++
|
|
|
|
* @name FsRtlInitializeOplock
|
2015-09-29 16:28:59 +00:00
|
|
|
* @implemented
|
2009-10-12 03:35:35 +00:00
|
|
|
*
|
|
|
|
* FILLME
|
|
|
|
*
|
|
|
|
* @param Oplock
|
|
|
|
* FILLME
|
|
|
|
*
|
|
|
|
* @return None
|
|
|
|
*
|
|
|
|
* @remarks None
|
|
|
|
*
|
|
|
|
*--*/
|
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
FsRtlInitializeOplock(IN OUT POPLOCK Oplock)
|
|
|
|
{
|
2015-09-29 16:28:59 +00:00
|
|
|
PAGED_CODE();
|
2009-10-12 03:35:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*++
|
|
|
|
* @name FsRtlOplockFsctrl
|
|
|
|
* @unimplemented
|
|
|
|
*
|
|
|
|
* FILLME
|
|
|
|
*
|
|
|
|
* @param Oplock
|
|
|
|
* FILLME
|
|
|
|
*
|
|
|
|
* @param Irp
|
|
|
|
* FILLME
|
|
|
|
*
|
|
|
|
* @param OpenCount
|
|
|
|
* FILLME
|
|
|
|
*
|
|
|
|
* @return None
|
|
|
|
*
|
|
|
|
* @remarks None
|
|
|
|
*
|
|
|
|
*--*/
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
FsRtlOplockFsctrl(IN POPLOCK Oplock,
|
|
|
|
IN PIRP Irp,
|
|
|
|
IN ULONG OpenCount)
|
|
|
|
{
|
|
|
|
/* Unimplemented */
|
2015-09-29 16:28:59 +00:00
|
|
|
UNIMPLEMENTED;
|
2009-10-12 03:35:35 +00:00
|
|
|
return STATUS_NOT_IMPLEMENTED;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*++
|
|
|
|
* @name FsRtlOplockIsFastIoPossible
|
|
|
|
* @unimplemented
|
|
|
|
*
|
|
|
|
* FILLME
|
|
|
|
*
|
|
|
|
* @param Oplock
|
|
|
|
* FILLME
|
|
|
|
*
|
|
|
|
* @return None
|
|
|
|
*
|
|
|
|
* @remarks None
|
|
|
|
*
|
|
|
|
*--*/
|
|
|
|
BOOLEAN
|
|
|
|
NTAPI
|
|
|
|
FsRtlOplockIsFastIoPossible(IN POPLOCK Oplock)
|
|
|
|
{
|
2014-11-13 20:11:00 +00:00
|
|
|
UNIMPLEMENTED;
|
2015-10-30 18:54:16 +00:00
|
|
|
return TRUE;
|
2009-10-12 03:35:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*++
|
|
|
|
* @name FsRtlUninitializeOplock
|
|
|
|
* @unimplemented
|
|
|
|
*
|
|
|
|
* FILLME
|
|
|
|
*
|
|
|
|
* @param Oplock
|
|
|
|
* FILLME
|
|
|
|
*
|
|
|
|
* @return None
|
|
|
|
*
|
|
|
|
* @remarks None
|
|
|
|
*
|
|
|
|
*--*/
|
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
FsRtlUninitializeOplock(IN POPLOCK Oplock)
|
|
|
|
{
|
2014-11-13 20:11:00 +00:00
|
|
|
UNIMPLEMENTED;
|
2009-10-12 03:35:35 +00:00
|
|
|
}
|
|
|
|
|