2 * PROJECT: ReactOS Kernel
3 * LICENSE: GPL - See COPYING in the top level directory
4 * FILE: ntoskrnl/fsrtl/fsrtlpc.c
5 * PURPOSE: Contains initialization and support code for the FsRtl
6 * PROGRAMMERS: Alex Ionescu (alex.ionescu@reactos.org)
9 /* INCLUDES ******************************************************************/
15 /* GLOBALS *******************************************************************/
17 PERESOURCE FsRtlPagingIoResources
;
18 ULONG FsRtlPagingIoResourceSelector
;
19 NTSTATUS NTAPI INIT_FUNCTION
FsRtlInitializeWorkerThread(VOID
);
20 extern KSEMAPHORE FsRtlpUncSemaphore
;
22 static const UCHAR LegalAnsiCharacterArray
[] =
56 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* ` ', 0x20 */
57 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `!', 0x21 */
58 FSRTL_WILD_CHARACTER
, /* `"', 0x22 */
59 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `#', 0x23 */
60 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `$', 0x24 */
61 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `%', 0x25 */
62 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `&', 0x26 */
63 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `'', 0x27 */
64 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `(', 0x28 */
65 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `)', 0x29 */
66 FSRTL_WILD_CHARACTER
, /* `*', 0x2a */
67 FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `+', 0x2b */
68 FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `,', 0x2c */
69 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `-', 0x2d */
70 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `.', 0x2e */
72 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `0', 0x30 */
73 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `1', 0x31 */
74 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `2', 0x32 */
75 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `3', 0x33 */
76 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `4', 0x34 */
77 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `5', 0x35 */
78 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `6', 0x36 */
79 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `7', 0x37 */
80 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `8', 0x38 */
81 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `9', 0x39 */
82 FSRTL_NTFS_LEGAL
, /* `:', 0x3a */
83 FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `;', 0x3b */
84 FSRTL_WILD_CHARACTER
, /* `<', 0x3c */
85 FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `=', 0x3d */
86 FSRTL_WILD_CHARACTER
, /* `>', 0x3e */
87 FSRTL_WILD_CHARACTER
, /* `?', 0x3f */
88 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `@', 0x40 */
89 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `A', 0x41 */
90 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `B', 0x42 */
91 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `C', 0x43 */
92 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `D', 0x44 */
93 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `E', 0x45 */
94 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `F', 0x46 */
95 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `G', 0x47 */
96 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `H', 0x48 */
97 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `I', 0x49 */
98 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `J', 0x4a */
99 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `K', 0x4b */
100 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `L', 0x4c */
101 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `M', 0x4d */
102 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `N', 0x4e */
103 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `O', 0x4f */
104 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `P', 0x50 */
105 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `Q', 0x51 */
106 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `R', 0x52 */
107 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `S', 0x53 */
108 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `T', 0x54 */
109 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `U', 0x55 */
110 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `V', 0x56 */
111 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `W', 0x57 */
112 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `X', 0x58 */
113 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `Y', 0x59 */
114 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `Z', 0x5a */
115 FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `[', 0x5b */
117 FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `]', 0x5d */
118 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `^', 0x5e */
119 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `_', 0x5f */
120 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* ``', 0x60 */
121 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `a', 0x61 */
122 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `b', 0x62 */
123 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `c', 0x63 */
124 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `d', 0x64 */
125 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `e', 0x65 */
126 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `f', 0x66 */
127 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `g', 0x67 */
128 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `h', 0x68 */
129 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `i', 0x69 */
130 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `j', 0x6a */
131 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `k', 0x6b */
132 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `l', 0x6c */
133 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `m', 0x6d */
134 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `n', 0x6e */
135 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `o', 0x6f */
136 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `p', 0x70 */
137 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `q', 0x71 */
138 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `r', 0x72 */
139 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `s', 0x73 */
140 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `t', 0x74 */
141 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `u', 0x75 */
142 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `v', 0x76 */
143 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `w', 0x77 */
144 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `x', 0x78 */
145 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `y', 0x79 */
146 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `z', 0x7a */
147 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `{', 0x7b */
149 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `}', 0x7d */
150 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
, /* `~', 0x7e */
151 FSRTL_FAT_LEGAL
| FSRTL_HPFS_LEGAL
| FSRTL_NTFS_LEGAL
/* 0x7f */
154 const UCHAR
* const FsRtlLegalAnsiCharacterArray
= LegalAnsiCharacterArray
;
156 /* PRIVATE FUNCTIONS *********************************************************/
161 FsRtlInitSystem(VOID
)
165 /* Initialize the list for granted locks */
166 ExInitializePagedLookasideList(&FsRtlFileLockLookasideList
,
174 FsRtlInitializeTunnels();
175 FsRtlInitializeLargeMcbs();
176 KeInitializeSemaphore(&FsRtlpUncSemaphore
, 1, MAXLONG
);
178 /* Allocate the Resource Buffer */
179 FsRtlPagingIoResources
= FsRtlAllocatePoolWithTag(NonPagedPool
,
180 FSRTL_MAX_RESOURCES
*
184 /* Initialize the Resources */
185 for (i
= 0; i
< FSRTL_MAX_RESOURCES
; i
++)
187 ExInitializeResource(&FsRtlPagingIoResources
[i
]);
190 return NT_SUCCESS(FsRtlInitializeWorkerThread());
193 /* PUBLIC FUNCTIONS **********************************************************/
196 * @name FsRtlAllocateResource
197 * @implemented NT 4.0
199 * The FsRtlAllocateResource routine returns a pre-initialized ERESOURCE
200 * for use by a File System Driver.
202 * @return A Pointer to a pre-initialized ERESOURCE.
204 * @remarks The File System Library only provides up to 16 Resources.
209 FsRtlAllocateResource(VOID
)
213 /* Return a preallocated ERESOURCE */
214 return &FsRtlPagingIoResources
[FsRtlPagingIoResourceSelector
++ %
215 FSRTL_MAX_RESOURCES
];