30 #define TAG_DEVICE_NAME 'NDsF' 31 #define TAG_DEVICE 'vDsF' 85 if (*
p ==
'(' && *(
p + 1) ==
')')
99 if (*
p ==
'(' && *(
p + 1) ==
')')
110 DeviceOpenMode = OpenMode;
121 if (
pDevice->ReferenceCount == 0)
124 for (DeviceId = 0; DeviceId <
MAX_FDS; DeviceId++)
151 if (!
FileData[DeviceId].FileFuncTable)
154 if (!
FileData[DeviceId].FileFuncTable)
157 if (!
FileData[DeviceId].FileFuncTable)
159 if (!
FileData[DeviceId].FileFuncTable)
162 #if defined(_M_IX86) || defined(_M_AMD64) 163 if (!
FileData[DeviceId].FileFuncTable)
166 if (!
FileData[DeviceId].FileFuncTable)
169 pDevice->FuncTable->Close(DeviceId);
261 ERR(
"%s\n", ErrorString);
294 cchPathLen =
min(
sizeof(FullPath)/
sizeof(
CHAR),
strlen(FullPath));
295 if (cchPathLen >=
sizeof(FullPath)/
sizeof(
CHAR))
299 cchPathLen > 0 && (FullPath[cchPathLen-1] !=
'\\' && FullPath[cchPathLen-1] !=
'/'))
307 cchPathLen > 0 && (FullPath[cchPathLen-1] ==
'\\' || FullPath[cchPathLen-1] ==
'/'))
320 return ArcOpen(FullPath, OpenMode, FileId);
345 TRACE(
"FsGetNumPathParts() Path = %s NumPathParts = %d\n",
Path,
num);
380 TRACE(
"FsGetFirstNameFromPath() Path = %s FirstName = %s\n",
Path,
Buffer);
ARC_STATUS ArcClose(ULONG FileId)
const DEVVTBL * FileFuncTable
static FILEDATA FileData[MAX_FDS]
ARC_STATUS ArcGetFileInformation(ULONG FileId, FILEINFORMATION *Information)
_In_ __drv_aliasesMem PSTRING Prefix
_In_ ULONG _In_ ULONG _In_ ULONG Length
static LIST_ENTRY DeviceListHead
ACPI_SIZE strlen(const char *String)
ULONG FsGetNumPathParts(PCSTR Path)
FORCEINLINE VOID InsertHeadList(_Inout_ PLIST_ENTRY ListHead, _Inout_ __drv_aliasesMem PLIST_ENTRY Entry)
VOID FsGetFirstNameFromPath(PCHAR Buffer, PCSTR Path)
ARC_STATUS ArcOpen(CHAR *Path, OPENMODE OpenMode, ULONG *FileId)
_Check_return_ _CRTIMP _CONST_RETURN char *__cdecl strrchr(_In_z_ const char *_Str, _In_ int _Ch)
ULONG FsGetDeviceId(ULONG FileId)
struct tagFILEDATA FILEDATA
_In_ WDFREQUEST _In_ NTSTATUS _In_ ULONG_PTR Information
const DEVVTBL * NtfsMount(ULONG DeviceId)
NTSTRSAFEAPI RtlStringCbCopyA(_Out_writes_bytes_(cbDest) _Always_(_Post_z_) NTSTRSAFE_PSTR pszDest, _In_ size_t cbDest, _In_ NTSTRSAFE_PCSTR pszSrc)
NTSTATUS FatMount(_In_ ULONG DeviceId, _In_ ULONG Unknown, _Out_ PBL_FILE_ENTRY *FileEntry)
ARC_STATUS ArcRead(ULONG FileId, VOID *Buffer, ULONG N, ULONG *Count)
_Must_inspect_result_ _In_ PWDFDEVICE_INIT _In_opt_ PCUNICODE_STRING DeviceName
VOID UiMessageBox(PCSTR Format,...)
FORCEINLINE PVOID FrLdrTempAlloc(_In_ SIZE_T Size, _In_ ULONG Tag)
VOID * FsGetDeviceSpecific(ULONG FileId)
PFLT_MESSAGE_WAITER_QUEUE CONTAINING_RECORD(Csq, DEVICE_EXTENSION, IrpQueue)) -> WaiterQ.mLock) _IRQL_raises_(DISPATCH_LEVEL) VOID NTAPI FltpAcquireMessageWaiterLock(_In_ PIO_CSQ Csq, _Out_ PKIRQL Irql)
PCWSTR FsGetServiceName(ULONG FileId)
struct _LIST_ENTRY * Flink
#define NT_SUCCESS(StatCode)
int strncmp(const char *String1, const char *String2, ACPI_SIZE Count)
const DEVVTBL * FuncTable
GLdouble GLdouble GLdouble GLdouble q
ARC_STATUS FsOpenFile(IN PCSTR FileName, IN PCSTR DefaultPath OPTIONAL, IN OPENMODE OpenMode, OUT PULONG FileId)
const DEVVTBL * FuncTable
DBG_DEFAULT_CHANNEL(FILESYSTEM)
ARC_STATUS ArcSeek(ULONG FileId, LARGE_INTEGER *Position, SEEKMODE SeekMode)
ARC_GET_FILE_INFORMATION GetFileInformation
struct _FileName FileName
PRTL_UNICODE_STRING_BUFFER Path
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
#define InitializeListHead(ListHead)
const DEVVTBL * BtrFsMount(ULONG DeviceId)
const DEVVTBL * IsoMount(ULONG DeviceId)
const DEVVTBL * PxeMount(ULONG DeviceId)
const DEVVTBL * Ext2Mount(ULONG DeviceId)
VOID FileSystemError(PCSTR ErrorString)
VOID FsSetDeviceSpecific(ULONG FileId, VOID *Specific)
#define RtlZeroMemory(Destination, Length)
#define RtlCopyMemory(Destination, Source, Length)
VOID FsRegisterDevice(CHAR *Prefix, const DEVVTBL *FuncTable)
NTSTRSAFEAPI RtlStringCbCatA(_Inout_updates_bytes_(cbDest) _Always_(_Post_z_) NTSTRSAFE_PSTR pszDest, _In_ size_t cbDest, _In_ NTSTRSAFE_PCSTR pszSrc)
PULONG MinorVersion OPTIONAL