61 lines
2.6 KiB
C
61 lines
2.6 KiB
C
|
/*++
|
||
|
Copyright (c) 1989 Microsoft Corporation
|
||
|
|
||
|
Module Name:
|
||
|
fsctrl.c
|
||
|
|
||
|
Abstract:
|
||
|
This module contains the code to implement the NtFsControlFile system service for the NT I/O system.
|
||
|
|
||
|
Author:
|
||
|
Darryl E. Havens (darrylh) 16-Oct-1989
|
||
|
|
||
|
Environment:
|
||
|
Kernel mode only
|
||
|
--*/
|
||
|
|
||
|
#include "iop.h"
|
||
|
|
||
|
#ifdef ALLOC_PRAGMA
|
||
|
#pragma alloc_text(PAGE, NtFsControlFile)
|
||
|
#endif
|
||
|
|
||
|
|
||
|
NTSTATUS
|
||
|
NtFsControlFile(
|
||
|
IN HANDLE FileHandle,
|
||
|
IN HANDLE Event OPTIONAL,
|
||
|
IN PIO_APC_ROUTINE ApcRoutine OPTIONAL,
|
||
|
IN PVOID ApcContext OPTIONAL,
|
||
|
OUT PIO_STATUS_BLOCK IoStatusBlock,
|
||
|
IN ULONG IoControlCode,
|
||
|
IN PVOID InputBuffer OPTIONAL,
|
||
|
IN ULONG InputBufferLength,
|
||
|
OUT PVOID OutputBuffer OPTIONAL,
|
||
|
IN ULONG OutputBufferLength
|
||
|
)
|
||
|
/*++
|
||
|
Routine Description:
|
||
|
This service builds descriptors or MDLs for the supplied buffer(s) and passes the untyped data to the file system associated with the file handle.
|
||
|
It is up to the file system to check the input data and function IoControlCode for validity, as well as to make the appropriate access checks.
|
||
|
Arguments:
|
||
|
FileHandle - Supplies a handle to the file on which the service is being performed.
|
||
|
Event - Supplies an optional event to be set to the Signaled state when the service is complete.
|
||
|
ApcRoutine - Supplies an optional APC routine to be executed when the service is complete.
|
||
|
ApcContext - Supplies a context parameter to be passed to the ApcRoutine, if an ApcRoutine was specified.
|
||
|
IoStatusBlock - Address of the caller's I/O status block.
|
||
|
IoControlCode - Subfunction code to determine exactly what operation is being performed.
|
||
|
InputBuffer - Optionally supplies an input buffer to be passed to the file system.
|
||
|
Whether or not the buffer is actually optional is dependent on the IoControlCode.
|
||
|
InputBufferLength - Length of the InputBuffer in bytes.
|
||
|
OutputBuffer - Optionally supplies an output buffer to receive information from the file system.
|
||
|
Whether or not the buffer is actually optional is dependent on the IoControlCode.
|
||
|
OutputBufferLength - Length of the OutputBuffer in bytes.
|
||
|
Return Value:
|
||
|
The status returned is success if the control operation was properly queued to the I/O system.
|
||
|
Once the operation completes, the status can be determined by examining the Status field of the I/O status block.
|
||
|
--*/
|
||
|
{
|
||
|
// Simply invoke the common routine that implements both device and file system I/O controls.
|
||
|
return IopXxxControlFile( FileHandle, Event, ApcRoutine, ApcContext, IoStatusBlock, IoControlCode, InputBuffer, InputBufferLength, OutputBuffer, OutputBufferLength, FALSE );
|
||
|
}
|