mirror of
https://github.com/winfsp/winfsp.git
synced 2025-06-15 08:12:45 -05:00
sys: fsctl.c
This commit is contained in:
@ -143,6 +143,7 @@
|
|||||||
<ClCompile Include="..\..\src\sys\flush.c" />
|
<ClCompile Include="..\..\src\sys\flush.c" />
|
||||||
<ClCompile Include="..\..\src\sys\fsctl.c" />
|
<ClCompile Include="..\..\src\sys\fsctl.c" />
|
||||||
<ClCompile Include="..\..\src\sys\lockctl.c" />
|
<ClCompile Include="..\..\src\sys\lockctl.c" />
|
||||||
|
<ClCompile Include="..\..\src\sys\misc.c" />
|
||||||
<ClCompile Include="..\..\src\sys\read.c" />
|
<ClCompile Include="..\..\src\sys\read.c" />
|
||||||
<ClCompile Include="..\..\src\sys\resource.c" />
|
<ClCompile Include="..\..\src\sys\resource.c" />
|
||||||
<ClCompile Include="..\..\src\sys\security.c" />
|
<ClCompile Include="..\..\src\sys\security.c" />
|
||||||
|
@ -71,6 +71,9 @@
|
|||||||
<ClCompile Include="..\..\src\sys\write.c">
|
<ClCompile Include="..\..\src\sys\write.c">
|
||||||
<Filter>Source</Filter>
|
<Filter>Source</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\..\src\sys\misc.c">
|
||||||
|
<Filter>Source</Filter>
|
||||||
|
</ClCompile>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ClInclude Include="..\..\src\sys\driver.h">
|
<ClInclude Include="..\..\src\sys\driver.h">
|
||||||
|
@ -19,11 +19,13 @@ extern const __declspec(selectany) GUID FspDeviceClassGuid =
|
|||||||
/* fsctl device codes */
|
/* fsctl device codes */
|
||||||
#define FSP_FSCTL_CREATE \
|
#define FSP_FSCTL_CREATE \
|
||||||
CTL_CODE(FILE_DEVICE_FILE_SYSTEM, 0x800 + 'C', METHOD_BUFFERED, FILE_READ_DATA | FILE_WRITE_DATA)
|
CTL_CODE(FILE_DEVICE_FILE_SYSTEM, 0x800 + 'C', METHOD_BUFFERED, FILE_READ_DATA | FILE_WRITE_DATA)
|
||||||
#define FSP_FSCTL_DELETE \
|
|
||||||
CTL_CODE(FILE_DEVICE_FILE_SYSTEM, 0x800 + 'D', METHOD_BUFFERED, FILE_READ_DATA | FILE_WRITE_DATA)
|
|
||||||
|
|
||||||
/* fsvrt device codes */
|
/* fsvrt device codes */
|
||||||
|
#define FSP_FSCTL_DELETE \
|
||||||
|
CTL_CODE(FILE_DEVICE_FILE_SYSTEM, 0x800 + 'D', METHOD_BUFFERED, FILE_READ_DATA | FILE_WRITE_DATA)
|
||||||
#define FSP_FSCTL_TRANSACT \
|
#define FSP_FSCTL_TRANSACT \
|
||||||
CTL_CODE(FILE_DEVICE_FILE_SYSTEM, 0x800 + 'T', METHOD_BUFFERED, FILE_READ_DATA | FILE_WRITE_DATA)
|
CTL_CODE(FILE_DEVICE_FILE_SYSTEM, 0x800 + 'T', METHOD_BUFFERED, FILE_READ_DATA | FILE_WRITE_DATA)
|
||||||
|
|
||||||
|
#define FSP_FSCTL_CREATE_BUFFER_SIZEMAX 64
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -86,7 +86,7 @@ const char *IrpMinorFunctionSym(UCHAR MajorFunction, UCHAR MinorFunction)
|
|||||||
SYMBRC(IRP_MN_COMPLETE_MDL)
|
SYMBRC(IRP_MN_COMPLETE_MDL)
|
||||||
SYMBRC(IRP_MN_COMPLETE_MDL_DPC)
|
SYMBRC(IRP_MN_COMPLETE_MDL_DPC)
|
||||||
default:
|
default:
|
||||||
return "[Unknown]";
|
return "[IRP_MN:Unknown]";
|
||||||
}
|
}
|
||||||
case IRP_MJ_DIRECTORY_CONTROL:
|
case IRP_MJ_DIRECTORY_CONTROL:
|
||||||
switch (MinorFunction)
|
switch (MinorFunction)
|
||||||
@ -94,7 +94,7 @@ const char *IrpMinorFunctionSym(UCHAR MajorFunction, UCHAR MinorFunction)
|
|||||||
SYMBRC(IRP_MN_QUERY_DIRECTORY)
|
SYMBRC(IRP_MN_QUERY_DIRECTORY)
|
||||||
SYMBRC(IRP_MN_NOTIFY_CHANGE_DIRECTORY)
|
SYMBRC(IRP_MN_NOTIFY_CHANGE_DIRECTORY)
|
||||||
default:
|
default:
|
||||||
return "[Unknown]";
|
return "[IRP_MN:Unknown]";
|
||||||
}
|
}
|
||||||
case IRP_MJ_FILE_SYSTEM_CONTROL:
|
case IRP_MJ_FILE_SYSTEM_CONTROL:
|
||||||
switch (MinorFunction)
|
switch (MinorFunction)
|
||||||
@ -105,7 +105,7 @@ const char *IrpMinorFunctionSym(UCHAR MajorFunction, UCHAR MinorFunction)
|
|||||||
SYMBRC(IRP_MN_LOAD_FILE_SYSTEM)
|
SYMBRC(IRP_MN_LOAD_FILE_SYSTEM)
|
||||||
SYMBRC(IRP_MN_KERNEL_CALL)
|
SYMBRC(IRP_MN_KERNEL_CALL)
|
||||||
default:
|
default:
|
||||||
return "[Unknown]";
|
return "[IRP_MN:Unknown]";
|
||||||
}
|
}
|
||||||
case IRP_MJ_LOCK_CONTROL:
|
case IRP_MJ_LOCK_CONTROL:
|
||||||
switch (MinorFunction)
|
switch (MinorFunction)
|
||||||
@ -115,7 +115,7 @@ const char *IrpMinorFunctionSym(UCHAR MajorFunction, UCHAR MinorFunction)
|
|||||||
SYMBRC(IRP_MN_UNLOCK_ALL)
|
SYMBRC(IRP_MN_UNLOCK_ALL)
|
||||||
SYMBRC(IRP_MN_UNLOCK_ALL_BY_KEY)
|
SYMBRC(IRP_MN_UNLOCK_ALL_BY_KEY)
|
||||||
default:
|
default:
|
||||||
return "[Unknown]";
|
return "[IRP_MN:Unknown]";
|
||||||
}
|
}
|
||||||
case IRP_MJ_POWER:
|
case IRP_MJ_POWER:
|
||||||
switch (MinorFunction)
|
switch (MinorFunction)
|
||||||
@ -125,7 +125,7 @@ const char *IrpMinorFunctionSym(UCHAR MajorFunction, UCHAR MinorFunction)
|
|||||||
SYMBRC(IRP_MN_SET_POWER)
|
SYMBRC(IRP_MN_SET_POWER)
|
||||||
SYMBRC(IRP_MN_QUERY_POWER)
|
SYMBRC(IRP_MN_QUERY_POWER)
|
||||||
default:
|
default:
|
||||||
return "[Unknown]";
|
return "[IRP_MN:Unknown]";
|
||||||
}
|
}
|
||||||
case IRP_MJ_SYSTEM_CONTROL:
|
case IRP_MJ_SYSTEM_CONTROL:
|
||||||
switch (MinorFunction)
|
switch (MinorFunction)
|
||||||
@ -142,7 +142,7 @@ const char *IrpMinorFunctionSym(UCHAR MajorFunction, UCHAR MinorFunction)
|
|||||||
SYMBRC(IRP_MN_EXECUTE_METHOD)
|
SYMBRC(IRP_MN_EXECUTE_METHOD)
|
||||||
SYMBRC(IRP_MN_REGINFO_EX)
|
SYMBRC(IRP_MN_REGINFO_EX)
|
||||||
default:
|
default:
|
||||||
return "[Unknown]";
|
return "[IRP_MN:Unknown]";
|
||||||
}
|
}
|
||||||
case IRP_MJ_PNP:
|
case IRP_MJ_PNP:
|
||||||
switch (MinorFunction)
|
switch (MinorFunction)
|
||||||
@ -153,10 +153,22 @@ const char *IrpMinorFunctionSym(UCHAR MajorFunction, UCHAR MinorFunction)
|
|||||||
SYMBRC(IRP_MN_CANCEL_REMOVE_DEVICE)
|
SYMBRC(IRP_MN_CANCEL_REMOVE_DEVICE)
|
||||||
SYMBRC(IRP_MN_SURPRISE_REMOVAL)
|
SYMBRC(IRP_MN_SURPRISE_REMOVAL)
|
||||||
default:
|
default:
|
||||||
return "[Unknown]";
|
return "[IRP_MN:Unknown]";
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const char *IoctlCodeSym(ULONG ControlCode)
|
||||||
|
{
|
||||||
|
switch (ControlCode)
|
||||||
|
{
|
||||||
|
SYM(FSP_FSCTL_CREATE)
|
||||||
|
SYM(FSP_FSCTL_DELETE)
|
||||||
|
SYM(FSP_FSCTL_TRANSACT)
|
||||||
|
default:
|
||||||
|
return "IOCTL:Unknown";
|
||||||
|
}
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
#define WINFSP_SYS_DRIVER_H_INCLUDED
|
#define WINFSP_SYS_DRIVER_H_INCLUDED
|
||||||
|
|
||||||
#include <ntifs.h>
|
#include <ntifs.h>
|
||||||
|
#include <ntstrsafe.h>
|
||||||
#include <wdmsec.h>
|
#include <wdmsec.h>
|
||||||
#include <winfsp/fsctl.h>
|
#include <winfsp/fsctl.h>
|
||||||
|
|
||||||
@ -176,12 +177,16 @@ FAST_IO_RELEASE_FOR_MOD_WRITE FspReleaseForModWrite;
|
|||||||
FAST_IO_ACQUIRE_FOR_CCFLUSH FspAcquireForCcFlush;
|
FAST_IO_ACQUIRE_FOR_CCFLUSH FspAcquireForCcFlush;
|
||||||
FAST_IO_RELEASE_FOR_CCFLUSH FspReleaseForCcFlush;
|
FAST_IO_RELEASE_FOR_CCFLUSH FspReleaseForCcFlush;
|
||||||
|
|
||||||
|
/* misc */
|
||||||
|
NTSTATUS CreateGuid(GUID *Guid);
|
||||||
|
|
||||||
/* debug */
|
/* debug */
|
||||||
#if DBG
|
#if DBG
|
||||||
BOOLEAN HasDbgBreakPoint(const char *Function);
|
BOOLEAN HasDbgBreakPoint(const char *Function);
|
||||||
const char *NtStatusSym(NTSTATUS Status);
|
const char *NtStatusSym(NTSTATUS Status);
|
||||||
const char *IrpMajorFunctionSym(UCHAR MajorFunction);
|
const char *IrpMajorFunctionSym(UCHAR MajorFunction);
|
||||||
const char *IrpMinorFunctionSym(UCHAR MajorFunction, UCHAR MinorFunction);
|
const char *IrpMinorFunctionSym(UCHAR MajorFunction, UCHAR MinorFunction);
|
||||||
|
const char *IoctlCodeSym(ULONG ControlCode);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* extern */
|
/* extern */
|
||||||
|
126
src/sys/fsctl.c
126
src/sys/fsctl.c
@ -6,23 +6,23 @@
|
|||||||
|
|
||||||
#include <sys/driver.h>
|
#include <sys/driver.h>
|
||||||
|
|
||||||
static
|
static NTSTATUS FspFsctlCreateVolume(
|
||||||
NTSTATUS
|
PDEVICE_OBJECT DeviceObject, PIRP Irp, PIO_STACK_LOCATION IrpSp);
|
||||||
FspFsctlCreateVolume(PDEVICE_OBJECT DeviceObject, PIO_STACK_LOCATION IrpSp);
|
static NTSTATUS FspFsvolDeleteVolume(
|
||||||
static
|
PDEVICE_OBJECT DeviceObject, PIRP Irp, PIO_STACK_LOCATION IrpSp);
|
||||||
NTSTATUS
|
static NTSTATUS FspFsvolTransact(
|
||||||
FspFsctlDeleteVolume(PDEVICE_OBJECT DeviceObject, PIO_STACK_LOCATION IrpSp);
|
PDEVICE_OBJECT DeviceObject, PIRP Irp, PIO_STACK_LOCATION IrpSp);
|
||||||
static
|
static NTSTATUS FspFsctlFileSystemControl(
|
||||||
NTSTATUS
|
PDEVICE_OBJECT DeviceObject, PIRP Irp, PIO_STACK_LOCATION IrpSp);
|
||||||
FspFsvolTransact(PDEVICE_OBJECT DeviceObject, PIO_STACK_LOCATION IrpSp);
|
static NTSTATUS FspFsvrtFileSystemControl(
|
||||||
static DRIVER_DISPATCH FspFsctlFileSystemControl;
|
PDEVICE_OBJECT DeviceObject, PIRP Irp, PIO_STACK_LOCATION IrpSp);
|
||||||
static DRIVER_DISPATCH FspFsvrtFileSystemControl;
|
static NTSTATUS FspFsvolFileSystemControl(
|
||||||
static DRIVER_DISPATCH FspFsvolFileSystemControl;
|
PDEVICE_OBJECT DeviceObject, PIRP Irp, PIO_STACK_LOCATION IrpSp);
|
||||||
DRIVER_DISPATCH FspFileSystemControl;
|
DRIVER_DISPATCH FspFileSystemControl;
|
||||||
|
|
||||||
#ifdef ALLOC_PRAGMA
|
#ifdef ALLOC_PRAGMA
|
||||||
#pragma alloc_text(PAGE, FspFsctlCreateVolume)
|
#pragma alloc_text(PAGE, FspFsctlCreateVolume)
|
||||||
#pragma alloc_text(PAGE, FspFsctlDeleteVolume)
|
#pragma alloc_text(PAGE, FspFsvolDeleteVolume)
|
||||||
#pragma alloc_text(PAGE, FspFsvolTransact)
|
#pragma alloc_text(PAGE, FspFsvolTransact)
|
||||||
#pragma alloc_text(PAGE, FspFsctlFileSystemControl)
|
#pragma alloc_text(PAGE, FspFsctlFileSystemControl)
|
||||||
#pragma alloc_text(PAGE, FspFsvrtFileSystemControl)
|
#pragma alloc_text(PAGE, FspFsvrtFileSystemControl)
|
||||||
@ -30,66 +30,85 @@ DRIVER_DISPATCH FspFileSystemControl;
|
|||||||
#pragma alloc_text(PAGE, FspFileSystemControl)
|
#pragma alloc_text(PAGE, FspFileSystemControl)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static
|
static NTSTATUS FspFsctlCreateVolume(
|
||||||
NTSTATUS
|
PDEVICE_OBJECT DeviceObject, PIRP Irp, PIO_STACK_LOCATION IrpSp)
|
||||||
FspFsctlCreateVolume(PDEVICE_OBJECT DeviceObject, PIO_STACK_LOCATION IrpSp)
|
{
|
||||||
|
if (FSP_FSCTL_CREATE_BUFFER_SIZEMAX > IrpSp->Parameters.FileSystemControl.OutputBufferLength)
|
||||||
|
return STATUS_BUFFER_TOO_SMALL;
|
||||||
|
|
||||||
|
NTSTATUS Result;
|
||||||
|
|
||||||
|
GUID Guid;
|
||||||
|
Result = CreateGuid(&Guid);
|
||||||
|
if (!NT_SUCCESS(Result))
|
||||||
|
return Result;
|
||||||
|
|
||||||
|
PDEVICE_OBJECT FsvrtDeviceObject;
|
||||||
|
UNICODE_STRING DeviceSddl;
|
||||||
|
UNICODE_STRING DeviceName;
|
||||||
|
RtlInitUnicodeString(&DeviceSddl, L"" DEVICE_SDDL);
|
||||||
|
RtlInitEmptyUnicodeString(&DeviceName, Irp->AssociatedIrp.SystemBuffer, FSP_FSCTL_CREATE_BUFFER_SIZEMAX);
|
||||||
|
Result = RtlUnicodeStringPrintf(&DeviceName,
|
||||||
|
L"\\Device\\Volume{%08lx-%04x-%04x-%02x%02x-%02x%02x%02x%02x%02x%02x}",
|
||||||
|
Guid.Data1, Guid.Data2, Guid.Data3,
|
||||||
|
Guid.Data4[0], Guid.Data4[1], Guid.Data4[2], Guid.Data4[3],
|
||||||
|
Guid.Data4[4], Guid.Data4[5], Guid.Data4[6], Guid.Data4[7]);
|
||||||
|
ASSERT(NT_SUCCESS(Result));
|
||||||
|
Result = IoCreateDeviceSecure(DeviceObject->DriverObject,
|
||||||
|
sizeof(FSP_FSVRT_DEVICE_EXTENSION), &DeviceName, DeviceObject->DeviceType, 0, FALSE,
|
||||||
|
&DeviceSddl, 0,
|
||||||
|
&FsvrtDeviceObject);
|
||||||
|
if (!NT_SUCCESS(Result))
|
||||||
|
return Result;
|
||||||
|
FspDeviceExtension(FsvrtDeviceObject)->Kind = FspFsvrtDeviceExtensionKind;
|
||||||
|
Irp->IoStatus.Information = DeviceName.Length + 1;
|
||||||
|
|
||||||
|
return Result;
|
||||||
|
}
|
||||||
|
|
||||||
|
static NTSTATUS FspFsvolDeleteVolume(
|
||||||
|
PDEVICE_OBJECT DeviceObject, PIRP Irp, PIO_STACK_LOCATION IrpSp)
|
||||||
{
|
{
|
||||||
return STATUS_INVALID_DEVICE_REQUEST;
|
return STATUS_INVALID_DEVICE_REQUEST;
|
||||||
}
|
}
|
||||||
|
|
||||||
static
|
static NTSTATUS FspFsvolTransact(
|
||||||
NTSTATUS
|
PDEVICE_OBJECT DeviceObject, PIRP Irp, PIO_STACK_LOCATION IrpSp)
|
||||||
FspFsctlDeleteVolume(PDEVICE_OBJECT DeviceObject, PIO_STACK_LOCATION IrpSp)
|
|
||||||
{
|
{
|
||||||
return STATUS_INVALID_DEVICE_REQUEST;
|
return STATUS_INVALID_DEVICE_REQUEST;
|
||||||
}
|
}
|
||||||
|
|
||||||
static
|
static NTSTATUS FspFsctlFileSystemControl(
|
||||||
NTSTATUS
|
PDEVICE_OBJECT DeviceObject, PIRP Irp, PIO_STACK_LOCATION IrpSp)
|
||||||
FspFsvolTransact(PDEVICE_OBJECT DeviceObject, PIO_STACK_LOCATION IrpSp)
|
|
||||||
{
|
|
||||||
return STATUS_INVALID_DEVICE_REQUEST;
|
|
||||||
}
|
|
||||||
|
|
||||||
static
|
|
||||||
NTSTATUS
|
|
||||||
FspFsctlFileSystemControl(
|
|
||||||
_In_ PDEVICE_OBJECT DeviceObject,
|
|
||||||
_In_ PIRP Irp)
|
|
||||||
{
|
{
|
||||||
NTSTATUS Result = STATUS_INVALID_DEVICE_REQUEST;
|
NTSTATUS Result = STATUS_INVALID_DEVICE_REQUEST;
|
||||||
PIO_STACK_LOCATION IrpSp = IoGetCurrentIrpStackLocation(Irp);
|
|
||||||
switch (IrpSp->MinorFunction)
|
switch (IrpSp->MinorFunction)
|
||||||
{
|
{
|
||||||
case IRP_MN_USER_FS_REQUEST:
|
case IRP_MN_USER_FS_REQUEST:
|
||||||
switch (IrpSp->Parameters.FileSystemControl.FsControlCode)
|
switch (IrpSp->Parameters.FileSystemControl.FsControlCode)
|
||||||
{
|
{
|
||||||
case FSP_FSCTL_CREATE:
|
case FSP_FSCTL_CREATE:
|
||||||
Result = FspFsctlCreateVolume(DeviceObject, IrpSp);
|
Result = FspFsctlCreateVolume(DeviceObject, Irp, IrpSp);
|
||||||
break;
|
|
||||||
case FSP_FSCTL_DELETE:
|
|
||||||
Result = FspFsctlDeleteVolume(DeviceObject, IrpSp);
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return Result;
|
return Result;
|
||||||
}
|
}
|
||||||
|
|
||||||
static
|
static NTSTATUS FspFsvrtFileSystemControl(
|
||||||
NTSTATUS
|
PDEVICE_OBJECT DeviceObject, PIRP Irp, PIO_STACK_LOCATION IrpSp)
|
||||||
FspFsvrtFileSystemControl(
|
|
||||||
_In_ PDEVICE_OBJECT DeviceObject,
|
|
||||||
_In_ PIRP Irp)
|
|
||||||
{
|
{
|
||||||
NTSTATUS Result = STATUS_INVALID_DEVICE_REQUEST;
|
NTSTATUS Result = STATUS_INVALID_DEVICE_REQUEST;
|
||||||
PIO_STACK_LOCATION IrpSp = IoGetCurrentIrpStackLocation(Irp);
|
|
||||||
switch (IrpSp->MinorFunction)
|
switch (IrpSp->MinorFunction)
|
||||||
{
|
{
|
||||||
case IRP_MN_USER_FS_REQUEST:
|
case IRP_MN_USER_FS_REQUEST:
|
||||||
switch (IrpSp->Parameters.FileSystemControl.FsControlCode)
|
switch (IrpSp->Parameters.FileSystemControl.FsControlCode)
|
||||||
{
|
{
|
||||||
|
case FSP_FSCTL_DELETE:
|
||||||
|
Result = FspFsvolDeleteVolume(DeviceObject, Irp, IrpSp);
|
||||||
|
break;
|
||||||
case FSP_FSCTL_TRANSACT:
|
case FSP_FSCTL_TRANSACT:
|
||||||
Result = FspFsvolTransact(DeviceObject, IrpSp);
|
Result = FspFsvolTransact(DeviceObject, Irp, IrpSp);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -97,14 +116,10 @@ FspFsvrtFileSystemControl(
|
|||||||
return Result;
|
return Result;
|
||||||
}
|
}
|
||||||
|
|
||||||
static
|
static NTSTATUS FspFsvolFileSystemControl(
|
||||||
NTSTATUS
|
PDEVICE_OBJECT DeviceObject, PIRP Irp, PIO_STACK_LOCATION IrpSp)
|
||||||
FspFsvolFileSystemControl(
|
|
||||||
_In_ PDEVICE_OBJECT DeviceObject,
|
|
||||||
_In_ PIRP Irp)
|
|
||||||
{
|
{
|
||||||
NTSTATUS Result = STATUS_INVALID_DEVICE_REQUEST;
|
NTSTATUS Result = STATUS_INVALID_DEVICE_REQUEST;
|
||||||
PIO_STACK_LOCATION IrpSp = IoGetCurrentIrpStackLocation(Irp);
|
|
||||||
switch (IrpSp->MinorFunction)
|
switch (IrpSp->MinorFunction)
|
||||||
{
|
{
|
||||||
case IRP_MN_USER_FS_REQUEST:
|
case IRP_MN_USER_FS_REQUEST:
|
||||||
@ -129,14 +144,19 @@ FspFileSystemControl(
|
|||||||
switch (FspDeviceExtension(DeviceObject)->Kind)
|
switch (FspDeviceExtension(DeviceObject)->Kind)
|
||||||
{
|
{
|
||||||
case FspFsvolDeviceExtensionKind:
|
case FspFsvolDeviceExtensionKind:
|
||||||
FSP_RETURN(Result = FspFsctlFileSystemControl(DeviceObject, Irp));
|
FSP_RETURN(Result = FspFsctlFileSystemControl(DeviceObject, Irp, IrpSp));
|
||||||
case FspFsvrtDeviceExtensionKind:
|
case FspFsvrtDeviceExtensionKind:
|
||||||
FSP_RETURN(Result = FspFsvrtFileSystemControl(DeviceObject, Irp));
|
FSP_RETURN(Result = FspFsvrtFileSystemControl(DeviceObject, Irp, IrpSp));
|
||||||
case FspFsctlDeviceExtensionKind:
|
case FspFsctlDeviceExtensionKind:
|
||||||
FSP_RETURN(Result = FspFsvolFileSystemControl(DeviceObject, Irp));
|
FSP_RETURN(Result = FspFsvolFileSystemControl(DeviceObject, Irp, IrpSp));
|
||||||
default:
|
default:
|
||||||
FSP_RETURN(Result = STATUS_INVALID_DEVICE_REQUEST);
|
FSP_RETURN(Result = STATUS_INVALID_DEVICE_REQUEST);
|
||||||
}
|
}
|
||||||
|
|
||||||
FSP_LEAVE_MJ("", 0);
|
FSP_LEAVE_MJ(
|
||||||
|
"FileObject=%p%s%s",
|
||||||
|
IrpSp->FileObject,
|
||||||
|
IRP_MN_USER_FS_REQUEST == IrpSp->MinorFunction ? ", " : "",
|
||||||
|
IRP_MN_USER_FS_REQUEST == IrpSp->MinorFunction ?
|
||||||
|
IoctlCodeSym(IrpSp->Parameters.FileSystemControl.FsControlCode) : "");
|
||||||
}
|
}
|
||||||
|
24
src/sys/misc.c
Normal file
24
src/sys/misc.c
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
/**
|
||||||
|
* @file sys/misc.c
|
||||||
|
*
|
||||||
|
* @copyright 2015 Bill Zissimopoulos
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <sys/driver.h>
|
||||||
|
|
||||||
|
NTSTATUS CreateGuid(GUID *Guid);
|
||||||
|
|
||||||
|
#ifdef ALLOC_PRAGMA
|
||||||
|
#pragma alloc_text(PAGE, CreateGuid)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
NTSTATUS CreateGuid(GUID *Guid)
|
||||||
|
{
|
||||||
|
NTSTATUS Result;
|
||||||
|
int Retries = 3;
|
||||||
|
do
|
||||||
|
{
|
||||||
|
Result = ExUuidCreate(Guid);
|
||||||
|
} while (!NT_SUCCESS(Result) && 0 < --Retries);
|
||||||
|
return Result;
|
||||||
|
}
|
Reference in New Issue
Block a user