mirror of
https://github.com/winfsp/winfsp.git
synced 2025-04-23 00:43:00 -05:00
dll: FSP_FILE_SYSTEM::DispatcherResult
This commit is contained in:
parent
422d4ccc79
commit
dd259ad45c
@ -22,8 +22,8 @@
|
|||||||
#include <winfsp/fsctl.h>
|
#include <winfsp/fsctl.h>
|
||||||
|
|
||||||
typedef struct _FSP_FILE_SYSTEM FSP_FILE_SYSTEM;
|
typedef struct _FSP_FILE_SYSTEM FSP_FILE_SYSTEM;
|
||||||
typedef NTSTATUS FSP_FILE_SYSTEM_DISPATCHER(FSP_FILE_SYSTEM *, FSP_FSCTL_TRANSACT_REQ *);
|
typedef VOID FSP_FILE_SYSTEM_DISPATCHER(FSP_FILE_SYSTEM *, FSP_FSCTL_TRANSACT_REQ *);
|
||||||
typedef VOID FSP_FILE_SYSTEM_OPERATION(FSP_FILE_SYSTEM *, FSP_FSCTL_TRANSACT_REQ *);
|
typedef NTSTATUS FSP_FILE_SYSTEM_OPERATION(FSP_FILE_SYSTEM *, FSP_FSCTL_TRANSACT_REQ *);
|
||||||
typedef struct _FSP_FILE_SYSTEM
|
typedef struct _FSP_FILE_SYSTEM
|
||||||
{
|
{
|
||||||
UINT16 Version;
|
UINT16 Version;
|
||||||
@ -31,6 +31,7 @@ typedef struct _FSP_FILE_SYSTEM
|
|||||||
HANDLE VolumeHandle;
|
HANDLE VolumeHandle;
|
||||||
PVOID UserContext;
|
PVOID UserContext;
|
||||||
FSP_FILE_SYSTEM_DISPATCHER *Dispatcher;
|
FSP_FILE_SYSTEM_DISPATCHER *Dispatcher;
|
||||||
|
NTSTATUS DispatcherResult;
|
||||||
FSP_FILE_SYSTEM_OPERATION *Operations[FspFsctlTransactKindCount];
|
FSP_FILE_SYSTEM_OPERATION *Operations[FspFsctlTransactKindCount];
|
||||||
} FSP_FILE_SYSTEM;
|
} FSP_FILE_SYSTEM;
|
||||||
|
|
||||||
@ -40,11 +41,26 @@ FSP_API NTSTATUS FspFileSystemCreate(PWSTR DevicePath,
|
|||||||
FSP_FILE_SYSTEM **PFileSystem);
|
FSP_FILE_SYSTEM **PFileSystem);
|
||||||
FSP_API VOID FspFileSystemDelete(FSP_FILE_SYSTEM *FileSystem);
|
FSP_API VOID FspFileSystemDelete(FSP_FILE_SYSTEM *FileSystem);
|
||||||
FSP_API NTSTATUS FspFileSystemLoop(FSP_FILE_SYSTEM *FileSystem);
|
FSP_API NTSTATUS FspFileSystemLoop(FSP_FILE_SYSTEM *FileSystem);
|
||||||
FSP_API NTSTATUS FspFileSystemDirectDispatcher(FSP_FILE_SYSTEM *FileSystem,
|
FSP_API VOID FspFileSystemDirectDispatcher(FSP_FILE_SYSTEM *FileSystem,
|
||||||
FSP_FSCTL_TRANSACT_REQ *Request);
|
FSP_FSCTL_TRANSACT_REQ *Request);
|
||||||
FSP_API NTSTATUS FspFileSystemPoolDispatcher(FSP_FILE_SYSTEM *FileSystem,
|
FSP_API VOID FspFileSystemPoolDispatcher(FSP_FILE_SYSTEM *FileSystem,
|
||||||
FSP_FSCTL_TRANSACT_REQ *Request);
|
FSP_FSCTL_TRANSACT_REQ *Request);
|
||||||
|
|
||||||
|
static VOID FspFileSystemGetDispatcherResult(FSP_FILE_SYSTEM *FileSystem,
|
||||||
|
NTSTATUS *PDispatcherResult)
|
||||||
|
{
|
||||||
|
/* 32-bit reads are atomic */
|
||||||
|
*PDispatcherResult = FileSystem->DispatcherResult;
|
||||||
|
MemoryBarrier();
|
||||||
|
}
|
||||||
|
static VOID FspFileSystemSetDispatcherResult(FSP_FILE_SYSTEM *FileSystem,
|
||||||
|
NTSTATUS DispatcherResult)
|
||||||
|
{
|
||||||
|
if (NT_SUCCESS(DispatcherResult))
|
||||||
|
return;
|
||||||
|
InterlockedCompareExchange(&FileSystem->DispatcherResult, DispatcherResult, 0);
|
||||||
|
}
|
||||||
|
|
||||||
FSP_API NTSTATUS FspSendResponse(FSP_FILE_SYSTEM *FileSystem,
|
FSP_API NTSTATUS FspSendResponse(FSP_FILE_SYSTEM *FileSystem,
|
||||||
FSP_FSCTL_TRANSACT_RSP *Response);
|
FSP_FSCTL_TRANSACT_RSP *Response);
|
||||||
FSP_API NTSTATUS FspSendResponseWithStatus(FSP_FILE_SYSTEM *FileSystem,
|
FSP_API NTSTATUS FspSendResponseWithStatus(FSP_FILE_SYSTEM *FileSystem,
|
||||||
|
@ -75,7 +75,9 @@ FSP_API NTSTATUS FspFileSystemLoop(FSP_FILE_SYSTEM *FileSystem)
|
|||||||
if (0 == NextRequest)
|
if (0 == NextRequest)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
Result = FileSystem->Dispatcher(FileSystem, Request);
|
FileSystem->Dispatcher(FileSystem, Request);
|
||||||
|
|
||||||
|
FspFileSystemGetDispatcherResult(FileSystem, &Result);
|
||||||
if (!NT_SUCCESS(Result))
|
if (!NT_SUCCESS(Result))
|
||||||
goto exit;
|
goto exit;
|
||||||
|
|
||||||
@ -89,50 +91,61 @@ exit:
|
|||||||
return Result;
|
return Result;
|
||||||
}
|
}
|
||||||
|
|
||||||
FSP_API NTSTATUS FspFileSystemDirectDispatcher(FSP_FILE_SYSTEM *FileSystem,
|
FSP_API VOID FspFileSystemDirectDispatcher(FSP_FILE_SYSTEM *FileSystem,
|
||||||
FSP_FSCTL_TRANSACT_REQ *Request)
|
FSP_FSCTL_TRANSACT_REQ *Request)
|
||||||
{
|
{
|
||||||
if (FspFsctlTransactKindCount <= Request->Kind || 0 == FileSystem->Operations[Request->Kind])
|
NTSTATUS DispatcherResult;
|
||||||
return FspSendResponseWithStatus(FileSystem, Request, STATUS_INVALID_DEVICE_REQUEST);
|
|
||||||
|
|
||||||
FileSystem->Operations[Request->Kind](FileSystem, Request);
|
if (FspFsctlTransactKindCount <= Request->Kind || 0 == FileSystem->Operations[Request->Kind])
|
||||||
return STATUS_SUCCESS;
|
DispatcherResult = FspSendResponseWithStatus(FileSystem, Request, STATUS_INVALID_DEVICE_REQUEST);
|
||||||
|
else
|
||||||
|
DispatcherResult = FileSystem->Operations[Request->Kind](FileSystem, Request);
|
||||||
|
|
||||||
|
FspFileSystemSetDispatcherResult(FileSystem, DispatcherResult);
|
||||||
}
|
}
|
||||||
|
|
||||||
static DWORD WINAPI FspFileSystemPoolDispatcherWorker(PVOID Param)
|
static DWORD WINAPI FspFileSystemPoolDispatcherWorker(PVOID Param)
|
||||||
{
|
{
|
||||||
|
NTSTATUS DispatcherResult;
|
||||||
FSP_DISPATCHER_WORK_ITEM *WorkItem = Param;
|
FSP_DISPATCHER_WORK_ITEM *WorkItem = Param;
|
||||||
FSP_FSCTL_TRANSACT_REQ *Request = (PVOID)WorkItem->RequestBuf;
|
FSP_FSCTL_TRANSACT_REQ *Request = (PVOID)WorkItem->RequestBuf;
|
||||||
|
|
||||||
WorkItem->FileSystem->Operations[Request->Kind](WorkItem->FileSystem, Request);
|
DispatcherResult = WorkItem->FileSystem->Operations[Request->Kind](WorkItem->FileSystem, Request);
|
||||||
MemFree(WorkItem);
|
MemFree(WorkItem);
|
||||||
|
|
||||||
|
FspFileSystemSetDispatcherResult(WorkItem->FileSystem, DispatcherResult);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
FSP_API NTSTATUS FspFileSystemPoolDispatcher(FSP_FILE_SYSTEM *FileSystem,
|
FSP_API VOID FspFileSystemPoolDispatcher(FSP_FILE_SYSTEM *FileSystem,
|
||||||
FSP_FSCTL_TRANSACT_REQ *Request)
|
FSP_FSCTL_TRANSACT_REQ *Request)
|
||||||
{
|
{
|
||||||
if (FspFsctlTransactKindCount <= Request->Kind || 0 == FileSystem->Operations[Request->Kind])
|
NTSTATUS DispatcherResult;
|
||||||
return FspSendResponseWithStatus(FileSystem, Request, STATUS_INVALID_DEVICE_REQUEST);
|
|
||||||
|
|
||||||
|
if (FspFsctlTransactKindCount <= Request->Kind || 0 == FileSystem->Operations[Request->Kind])
|
||||||
|
DispatcherResult = FspSendResponseWithStatus(FileSystem, Request, STATUS_INVALID_DEVICE_REQUEST);
|
||||||
|
else
|
||||||
|
{
|
||||||
FSP_DISPATCHER_WORK_ITEM *WorkItem = MemAlloc(sizeof *WorkItem + Request->Size);
|
FSP_DISPATCHER_WORK_ITEM *WorkItem = MemAlloc(sizeof *WorkItem + Request->Size);
|
||||||
if (0 == WorkItem)
|
if (0 == WorkItem)
|
||||||
return STATUS_INSUFFICIENT_RESOURCES;
|
DispatcherResult = STATUS_INSUFFICIENT_RESOURCES;
|
||||||
|
else
|
||||||
|
{
|
||||||
WorkItem->FileSystem = FileSystem;
|
WorkItem->FileSystem = FileSystem;
|
||||||
memcpy(WorkItem->RequestBuf, Request, Request->Size);
|
memcpy(WorkItem->RequestBuf, Request, Request->Size);
|
||||||
|
|
||||||
BOOLEAN Success = QueueUserWorkItem(
|
if (QueueUserWorkItem(FspFileSystemPoolDispatcherWorker, WorkItem, WT_EXECUTEDEFAULT))
|
||||||
FspFileSystemPoolDispatcherWorker, WorkItem, WT_EXECUTEDEFAULT);
|
DispatcherResult = STATUS_SUCCESS;
|
||||||
if (!Success)
|
else
|
||||||
{
|
{
|
||||||
NTSTATUS Result0 = FspNtStatusFromWin32(GetLastError());
|
DispatcherResult = FspNtStatusFromWin32(GetLastError());
|
||||||
MemFree(WorkItem);
|
MemFree(WorkItem);
|
||||||
return Result0;
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return STATUS_SUCCESS;
|
FspFileSystemSetDispatcherResult(FileSystem, DispatcherResult);
|
||||||
}
|
}
|
||||||
|
|
||||||
FSP_API NTSTATUS FspSendResponse(FSP_FILE_SYSTEM *FileSystem,
|
FSP_API NTSTATUS FspSendResponse(FSP_FILE_SYSTEM *FileSystem,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user