30#define TAG_DEVICE_NAME 'NDsF'
31#define TAG_DEVICE 'vDsF'
54#define IS_VALID_FILEID(FileId) \
55 ((ULONG)(FileId) < _countof(FileData) && FileData[(ULONG)(FileId)].FuncTable)
70#if defined(_M_IX86) || defined(_M_AMD64)
86 DbgPrint(
"\n== Dumping ARC devices ==\n");
99 " DeviceName : '%s'\n",
102 FuncTable =
pDevice->FuncTable;
103 DbgPrint(
" DevFuncTable: 0x%p (In array: 0x%p) ; Name: '%S'\n",
109 FuncTable =
pDevice->FileFuncTable;
110 DbgPrint(
" FileFuncTable: 0x%p ; Name: '%S'\n",
116 DbgPrint(
"\n== END Dumping ARC devices ==\n\n");
124 DbgPrint(
"\n== Dumping ARC files table ==\n");
138 " ParentDeviceId: %lu\n"
145 DbgPrint(
" FuncTable: 0x%p ; Name: '%S'\n",
151 DbgPrint(
"\n== END Dumping ARC files table ==\n\n");
196 if ((
p + 1) < End && *
p ==
'(' && *(
p + 1) ==
')')
213 if ((
p + 1) < End && *
p ==
'(' && *(
p + 1) ==
')')
249 DeviceOpenMode = OpenMode;
273 if (
pDevice->ReferenceCount == 0)
276 for (DeviceId = 0; ; ++DeviceId)
378 if (--
FileData[DeviceId].ReferenceCount == 0)
385 if (--
pDevice->ReferenceCount == 0)
402 if (
pDevice->DeviceId == DeviceId)
423 if (--
FileData[FileId].ReferenceCount == 0)
437 if (--
pDevice->ReferenceCount == 0)
473 ERR(
"%s\n", ErrorString);
506 cchPathLen =
min(
sizeof(FullPath)/
sizeof(
CHAR),
strlen(FullPath));
507 if (cchPathLen >=
sizeof(FullPath)/
sizeof(
CHAR))
511 cchPathLen > 0 && (FullPath[cchPathLen-1] !=
'\\' && FullPath[cchPathLen-1] !=
'/'))
519 cchPathLen > 0 && (FullPath[cchPathLen-1] ==
'\\' || FullPath[cchPathLen-1] ==
'/'))
532 return ArcOpen(FullPath, OpenMode, FileId);
557 TRACE(
"FsGetNumPathParts() Path = %s NumPathParts = %d\n",
Path,
num);
592 TRACE(
"FsGetFirstNameFromPath() Path = %s FirstName = %s\n",
Path,
Buffer);
PRTL_UNICODE_STRING_BUFFER Path
ACPI_SIZE strlen(const char *String)
int strncmp(const char *String1, const char *String2, ACPI_SIZE Count)
NTSTATUS FatMount(_In_ ULONG DeviceId, _In_ ULONG Unknown, _Out_ PBL_FILE_ENTRY *FileEntry)
#define DBG_DEFAULT_CHANNEL(ch)
const DEVVTBL * BtrFsMount(ULONG DeviceId)
const DEVVTBL * NtfsMount(ULONG DeviceId)
FORCEINLINE PVOID FrLdrTempAlloc(_In_ SIZE_T Size, _In_ ULONG Tag)
FORCEINLINE VOID FrLdrTempFree(PVOID Allocation, ULONG Tag)
VOID UiMessageBox(_In_ PCSTR Format,...)
#define IS_VALID_FILEID(FileId)
ARC_STATUS ArcGetFileInformation(ULONG FileId, FILEINFORMATION *Information)
ARC_STATUS ArcSeek(ULONG FileId, LARGE_INTEGER *Position, SEEKMODE SeekMode)
ARC_STATUS ArcOpen(CHAR *Path, OPENMODE OpenMode, ULONG *FileId)
static LIST_ENTRY DeviceListHead
PVOID FsGetDeviceSpecific(ULONG FileId)
ULONG FsGetNumPathParts(PCSTR Path)
VOID FsSetDeviceSpecific(ULONG FileId, PVOID Specific)
ARC_STATUS FsOpenFile(IN PCSTR FileName, IN PCSTR DefaultPath OPTIONAL, IN OPENMODE OpenMode, OUT PULONG FileId)
ARC_STATUS ArcClose(_In_ ULONG FileId)
VOID FileSystemError(PCSTR ErrorString)
struct tagFILEDATA FILEDATA
PCHAR NormalizeArcDeviceName(_In_ PCCH DeviceName, _Inout_ PSIZE_T Length)
Replace "()" by "(0)" in the given ARC device name, if necessary.
ULONG FsGetDeviceId(ULONG FileId)
PCWSTR FsGetServiceName(ULONG FileId)
static DEVICE * FsGetDeviceById(ULONG DeviceId)
static FILEDATA FileData[MAX_FDS]
VOID FsRegisterDevice(_In_ PCSTR DeviceName, _In_ const DEVVTBL *FuncTable)
const DEVVTBL *(* PFS_MOUNT)(ULONG DeviceId)
ARC_STATUS ArcRead(ULONG FileId, VOID *Buffer, ULONG N, ULONG *Count)
VOID FsGetFirstNameFromPath(PCHAR Buffer, PCSTR Path)
#define NT_SUCCESS(StatCode)
#define InsertHeadList(ListHead, Entry)
#define InitializeListHead(ListHead)
const DEVVTBL * Ext2Mount(ULONG DeviceId)
struct _FileName FileName
const DEVVTBL * PxeMount(ULONG DeviceId)
GLdouble GLdouble GLdouble GLdouble q
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
const DEVVTBL * IsoMount(ULONG DeviceId)
_In_ ULONG _In_ ULONG _In_ ULONG Length
NTSTRSAFEAPI RtlStringCbCatA(_Inout_updates_bytes_(cbDest) _Always_(_Post_z_) NTSTRSAFE_PSTR pszDest, _In_ size_t cbDest, _In_ NTSTRSAFE_PCSTR pszSrc)
NTSTRSAFEAPI RtlStringCbCopyA(_Out_writes_bytes_(cbDest) _Always_(_Post_z_) NTSTRSAFE_PSTR pszDest, _In_ size_t cbDest, _In_ NTSTRSAFE_PCSTR pszSrc)
_CRT_RESTORE_GCC_WARNINGS _CRT_DISABLE_GCC_WARNINGS _Check_return_ _CRTIMP _CONST_RETURN char *__cdecl strrchr(_In_z_ const char *_Str, _In_ int _Ch)
PULONG MinorVersion OPTIONAL
struct _LIST_ENTRY * Flink
ULONG DeviceId
Entry ID in FileData when the device gets referenced.
const DEVVTBL * FuncTable
Driver function table.
const DEVVTBL * FileFuncTable
Used only by mounted storage devices.
ARC_GET_FILE_INFORMATION GetFileInformation
const DEVVTBL * FuncTable
ULONG DeviceId
Parent device's ID.
#define RtlCopyMemory(Destination, Source, Length)
#define RtlZeroMemory(Destination, Length)
#define CONTAINING_RECORD(address, type, field)
_Must_inspect_result_ _In_ PWDFDEVICE_INIT _In_opt_ PCUNICODE_STRING DeviceName
_In_ WDFREQUEST _In_ NTSTATUS _In_ ULONG_PTR Information