Source code of Windows XP (NT5)
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
/*++
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
Revision History:
--*/
#include "iomgr.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 ); }
|