xref: /reactos/drivers/filesystems/ext2/src/debug.c (revision c2c66aff)
1 /*
2  * COPYRIGHT:        See COPYRIGHT.TXT
3  * PROJECT:          Ext2 File System Driver for WinNT/2K/XP
4  * FILE:             Debug.c
5  * PROGRAMMER:       Matt Wu <mattwu@163.com>
6  * HOMEPAGE:         http://www.ext2fsd.com
7  * UPDATE HISTORY:
8  */
9 
10 /* INCLUDES **************************************************************/
11 
12 #include "stdarg.h"
13 #include "ext2fs.h"
14 
15 /* GLOBALS ***************************************************************/
16 
17 #if EXT2_DEBUG
18 
19 #define SYSTEM_PROCESS_NAME "System"
20 
21 extern PEXT2_GLOBAL Ext2Global;
22 
23 ULONG   DebugFilter = DL_DEFAULT;
24 
25 ULONG  ProcessNameOffset = 0;
26 
27 /* DEFINITIONS ***********************************************************/
28 
29 
30 /* Static Definitions ****************************************************/
31 
32 static PUCHAR IrpMjStrings[] = {
33     "IRP_MJ_CREATE",
34     "IRP_MJ_CREATE_NAMED_PIPE",
35     "IRP_MJ_CLOSE",
36     "IRP_MJ_READ",
37     "IRP_MJ_WRITE",
38     "IRP_MJ_QUERY_INFORMATION",
39     "IRP_MJ_SET_INFORMATION",
40     "IRP_MJ_QUERY_EA",
41     "IRP_MJ_SET_EA",
42     "IRP_MJ_FLUSH_BUFFERS",
43     "IRP_MJ_QUERY_VOLUME_INFORMATION",
44     "IRP_MJ_SET_VOLUME_INFORMATION",
45     "IRP_MJ_DIRECTORY_CONTROL",
46     "IRP_MJ_FILE_SYSTEM_CONTROL",
47     "IRP_MJ_DEVICE_CONTROL",
48     "IRP_MJ_INTERNAL_DEVICE_CONTROL",
49     "IRP_MJ_SHUTDOWN",
50     "IRP_MJ_LOCK_CONTROL",
51     "IRP_MJ_CLEANUP",
52     "IRP_MJ_CREATE_MAILSLOT",
53     "IRP_MJ_QUERY_SECURITY",
54     "IRP_MJ_SET_SECURITY",
55     "IRP_MJ_POWER",
56     "IRP_MJ_SYSTEM_CONTROL",
57     "IRP_MJ_DEVICE_CHANGE",
58     "IRP_MJ_QUERY_QUOTA",
59     "IRP_MJ_SET_QUOTA",
60     "IRP_MJ_PNP"
61 };
62 
63 static PUCHAR FileInformationClassStrings[] = {
64     "Unknown FileInformationClass 0",
65     "FileDirectoryInformation",
66     "FileFullDirectoryInformation",
67     "FileBothDirectoryInformation",
68     "FileBasicInformation",
69     "FileStandardInformation",
70     "FileInternalInformation",
71     "FileEaInformation",
72     "FileAccessInformation",
73     "FileNameInformation",
74     "FileRenameInformation",
75     "FileLinkInformation",
76     "FileNamesInformation",
77     "FileDispositionInformation",
78     "FilePositionInformation",
79     "FileFullEaInformation",
80     "FileModeInformation",
81     "FileAlignmentInformation",
82     "FileAllInformation",
83     "FileAllocationInformation",
84     "FileEndOfFileInformation",
85     "FileAlternateNameInformation",
86     "FileStreamInformation",
87     "FilePipeInformation",
88     "FilePipeLocalInformation",
89     "FilePipeRemoteInformation",
90     "FileMailslotQueryInformation",
91     "FileMailslotSetInformation",
92     "FileCompressionInformation",
93     "FileObjectIdInformation",
94     "FileCompletionInformation",
95     "FileMoveClusterInformation",
96     "FileQuotaInformation",
97     "FileReparsePointInformation",
98     "FileNetworkOpenInformation",
99     "FileAttributeTagInformation",
100     "FileTrackingInformation"
101 };
102 
103 static PUCHAR FsInformationClassStrings[] = {
104     "Unknown FsInformationClass 0",
105     "FileFsVolumeInformation",
106     "FileFsLabelInformation",
107     "FileFsSizeInformation",
108     "FileFsDeviceInformation",
109     "FileFsAttributeInformation",
110     "FileFsControlInformation",
111     "FileFsFullSizeInformation",
112     "FileFsObjectIdInformation"
113 };
114 
115 /*
116  * Ext2Printf
117  *   This function is variable-argument, level-sensitive debug print routine.
118  *   If the specified debug level for the print statement is lower or equal
119  *   to the current debug level, the message will be printed.
120  *
121  * Arguments:
122  *   DebugMessage - Variable argument ascii c string
123  *
124  * Return Value:
125  *   N/A
126  *
127  * NOTES:
128  *   N/A
129  */
130 
131 #define DBG_BUF_LEN 0x100
132 VOID
Ext2Printf(PCHAR DebugMessage,...)133 Ext2Printf(
134     PCHAR DebugMessage,
135     ...
136 )
137 {
138     va_list             ap;
139     LARGE_INTEGER       CurrentTime;
140     TIME_FIELDS         TimeFields;
141     CHAR                Buffer[DBG_BUF_LEN];
142     ULONG               i;
143 
144     RtlZeroMemory(Buffer, DBG_BUF_LEN);
145     va_start(ap, DebugMessage);
146 
147     KeQuerySystemTime( &CurrentTime);
148     RtlTimeToTimeFields(&CurrentTime, &TimeFields);
149     _vsnprintf(&Buffer[0], DBG_BUF_LEN, DebugMessage, ap);
150 
151     DbgPrint(DRIVER_NAME":~%d: %2.2d:%2.2d:%2.2d:%3.3d %8.8x:   %s",
152              KeGetCurrentProcessorNumber(),
153              TimeFields.Hour, TimeFields.Minute,
154              TimeFields.Second, TimeFields.Milliseconds,
155              PsGetCurrentThread(), Buffer);
156 
157     va_end(ap);
158 }
159 
160 VOID
Ext2NiPrintf(PCHAR DebugMessage,...)161 Ext2NiPrintf(
162     PCHAR DebugMessage,
163     ...
164 )
165 {
166     va_list             ap;
167     LARGE_INTEGER       CurrentTime;
168     TIME_FIELDS         TimeFields;
169     CHAR                Buffer[0x100];
170     ULONG               i;
171 
172     va_start(ap, DebugMessage);
173 
174     KeQuerySystemTime( &CurrentTime);
175     RtlTimeToTimeFields(&CurrentTime, &TimeFields);
176     _vsnprintf(&Buffer[0], 0x100, DebugMessage, ap);
177 
178     DbgPrint(DRIVER_NAME":~%d: %2.2d:%2.2d:%2.2d:%3.3d %8.8x: %s",
179              KeGetCurrentProcessorNumber(),
180              TimeFields.Hour, TimeFields.Minute,
181              TimeFields.Second, TimeFields.Milliseconds,
182              PsGetCurrentThread(), Buffer);
183 
184     va_end(ap);
185 
186 } // Ext2NiPrintf()
187 
188 ULONG
Ext2GetProcessNameOffset(VOID)189 Ext2GetProcessNameOffset ( VOID )
190 {
191     PEPROCESS   Process;
192     ULONG       i;
193 
194     Process = PsGetCurrentProcess();
195 
196     for (i = 0; i < PAGE_SIZE; i++) {
197         if (!strncmp(
198                     SYSTEM_PROCESS_NAME,
199                     (PCHAR) Process + i,
200                     strlen(SYSTEM_PROCESS_NAME)
201                 )) {
202 
203             return i;
204         }
205     }
206 
207     DEBUG(DL_ERR, ( ": *** FsdGetProcessNameOffset failed ***\n"));
208 
209     return 0;
210 }
211 
212 
213 VOID
Ext2DbgPrintCall(IN PDEVICE_OBJECT DeviceObject,IN PIRP Irp)214 Ext2DbgPrintCall (IN PDEVICE_OBJECT   DeviceObject,
215                   IN PIRP             Irp )
216 {
217     PIO_STACK_LOCATION      IoStackLocation;
218     PFILE_OBJECT            FileObject;
219     PWCHAR                  FileName;
220     PEXT2_FCB               Fcb;
221     FILE_INFORMATION_CLASS  FileInformationClass;
222     FS_INFORMATION_CLASS    FsInformationClass;
223 
224     IoStackLocation = IoGetCurrentIrpStackLocation(Irp);
225 
226     FileObject = IoStackLocation->FileObject;
227 
228     FileName = L"Unknown";
229 
230     if (DeviceObject == Ext2Global->DiskdevObject) {
231 
232         FileName = DEVICE_NAME;
233 
234     } else if (DeviceObject == Ext2Global->CdromdevObject) {
235 
236         FileName = CDROM_NAME;
237 
238     } else if (FileObject && FileObject->FsContext) {
239 
240         Fcb = (PEXT2_FCB) FileObject->FsContext;
241 
242         if (Fcb->Identifier.Type == EXT2VCB)  {
243             FileName = L"\\Volume";
244         } else if (Fcb->Identifier.Type == EXT2FCB && Fcb->Mcb->FullName.Buffer) {
245             FileName = Fcb->Mcb->FullName.Buffer;
246         }
247     }
248 
249     switch (IoStackLocation->MajorFunction) {
250 
251     case IRP_MJ_CREATE:
252 
253         FileName = NULL;
254 
255         if (DeviceObject == Ext2Global->DiskdevObject) {
256             FileName = DEVICE_NAME;
257         } else if (DeviceObject == Ext2Global->CdromdevObject) {
258             FileName = CDROM_NAME;
259         } else if (IoStackLocation->FileObject->FileName.Length == 0) {
260             FileName = L"\\Volume";
261         }
262 
263         if (FileName) {
264             DEBUGNI(DL_FUN, ("%s %s %S\n",
265                              Ext2GetCurrentProcessName(),
266                              IrpMjStrings[IoStackLocation->MajorFunction],
267                              FileName
268                             ));
269         } else if (IoStackLocation->FileObject->FileName.Buffer) {
270             DEBUGNI(DL_FUN, ("%s %s %S\n",
271                              Ext2GetCurrentProcessName(),
272                              IrpMjStrings[IoStackLocation->MajorFunction],
273                              IoStackLocation->FileObject->FileName.Buffer
274                             ));
275         } else {
276             DEBUGNI(DL_FUN, ("%s %s %s\n",
277                              Ext2GetCurrentProcessName(),
278                              IrpMjStrings[IoStackLocation->MajorFunction],
279                              "Unknown"
280                             ));
281         }
282 
283         break;
284 
285     case IRP_MJ_CLOSE:
286 
287         DEBUGNI(DL_FUN, ("%s %s %S\n",
288                          Ext2GetCurrentProcessName(),
289                          IrpMjStrings[IoStackLocation->MajorFunction],
290                          FileName
291                         ));
292 
293         break;
294 
295     case IRP_MJ_READ:
296 
297         if (IoStackLocation->MinorFunction & IRP_MN_COMPLETE) {
298             DEBUGNI(DL_FUN, ("%s %s %S IRP_MN_COMPLETE\n",
299                              Ext2GetCurrentProcessName(),
300                              IrpMjStrings[IoStackLocation->MajorFunction],
301                              FileName
302                             ));
303         } else {
304             DEBUGNI(DL_FUN, ("%s %s %S Offset: %I64xh Length: %xh %s%s%s%s%s%s\n",
305                              Ext2GetCurrentProcessName(),
306                              IrpMjStrings[IoStackLocation->MajorFunction],
307                              FileName,
308                              IoStackLocation->Parameters.Read.ByteOffset.QuadPart,
309                              IoStackLocation->Parameters.Read.Length,
310                              (IoStackLocation->MinorFunction & IRP_MN_DPC ? "IRP_MN_DPC " : " "),
311                              (IoStackLocation->MinorFunction & IRP_MN_MDL ? "IRP_MN_MDL " : " "),
312                              (IoStackLocation->MinorFunction & IRP_MN_COMPRESSED ? "IRP_MN_COMPRESSED " : " "),
313                              (Irp->Flags & IRP_PAGING_IO ? "IRP_PAGING_IO " : " "),
314                              (Irp->Flags & IRP_NOCACHE ? "IRP_NOCACHE " : " "),
315                              (FileObject->Flags & FO_SYNCHRONOUS_IO ? "FO_SYNCHRONOUS_IO " : " ")
316                             ));
317         }
318 
319         break;
320 
321     case IRP_MJ_WRITE:
322 
323         if (IoStackLocation->MinorFunction & IRP_MN_COMPLETE)  {
324             DEBUGNI(DL_FUN, ("%s %s %S IRP_MN_COMPLETE\n",
325                              Ext2GetCurrentProcessName(),
326                              IrpMjStrings[IoStackLocation->MajorFunction],
327                              FileName
328                             ));
329         } else {
330             DEBUGNI(DL_FUN, ("%s %s %S Offset: %I64xh Length: %xh %s%s%s%s%s%s\n",
331                              Ext2GetCurrentProcessName(),
332                              IrpMjStrings[IoStackLocation->MajorFunction],
333                              FileName,
334                              IoStackLocation->Parameters.Read.ByteOffset.QuadPart,
335                              IoStackLocation->Parameters.Read.Length,
336                              (IoStackLocation->MinorFunction & IRP_MN_DPC ? "IRP_MN_DPC " : " "),
337                              (IoStackLocation->MinorFunction & IRP_MN_MDL ? "IRP_MN_MDL " : " "),
338                              (IoStackLocation->MinorFunction & IRP_MN_COMPRESSED ? "IRP_MN_COMPRESSED " : " "),
339                              (Irp->Flags & IRP_PAGING_IO ? "IRP_PAGING_IO " : " "),
340                              (Irp->Flags & IRP_NOCACHE ? "IRP_NOCACHE " : " "),
341                              (FileObject->Flags & FO_SYNCHRONOUS_IO ? "FO_SYNCHRONOUS_IO " : " ")
342                             ));
343         }
344 
345         break;
346 
347     case IRP_MJ_QUERY_INFORMATION:
348 
349         FileInformationClass =
350             IoStackLocation->Parameters.QueryFile.FileInformationClass;
351 
352         if (FileInformationClass <= FileMaximumInformation) {
353             DEBUGNI(DL_FUN, ("%s %s %S %s\n",
354                              Ext2GetCurrentProcessName(),
355                              IrpMjStrings[IoStackLocation->MajorFunction],
356                              FileName,
357                              FileInformationClassStrings[FileInformationClass]
358                             ));
359         } else {
360             DEBUGNI(DL_FUN, ("%s %s %S Unknown FileInformationClass %u\n",
361                              Ext2GetCurrentProcessName(),
362                              IrpMjStrings[IoStackLocation->MajorFunction],
363                              FileName,
364                              FileInformationClass
365                             ));
366         }
367 
368         break;
369 
370     case IRP_MJ_SET_INFORMATION:
371 
372         FileInformationClass =
373             IoStackLocation->Parameters.SetFile.FileInformationClass;
374 
375         if (FileInformationClass <= FileMaximumInformation) {
376             DEBUGNI(DL_FUN, ("%s %s %S %s\n",
377                              Ext2GetCurrentProcessName(),
378                              IrpMjStrings[IoStackLocation->MajorFunction],
379                              FileName,
380                              FileInformationClassStrings[FileInformationClass]
381                             ));
382         } else {
383             DEBUGNI(DL_FUN, ("%s %s %S Unknown FileInformationClass %u\n",
384                              Ext2GetCurrentProcessName(),
385                              IrpMjStrings[IoStackLocation->MajorFunction],
386                              FileName,
387                              FileInformationClass
388                             ));
389         }
390 
391         break;
392 
393     case IRP_MJ_QUERY_VOLUME_INFORMATION:
394 
395         FsInformationClass =
396             IoStackLocation->Parameters.QueryVolume.FsInformationClass;
397 
398         if (FsInformationClass <= FileFsMaximumInformation) {
399             DEBUGNI(DL_FUN, ("%s %s %S %s\n",
400                              Ext2GetCurrentProcessName(),
401                              IrpMjStrings[IoStackLocation->MajorFunction],
402                              FileName,
403                              FsInformationClassStrings[FsInformationClass]
404                             ));
405         } else {
406             DEBUGNI(DL_FUN, ("%s %s %S Unknown FsInformationClass %u\n",
407                              Ext2GetCurrentProcessName(),
408                              IrpMjStrings[IoStackLocation->MajorFunction],
409                              FileName,
410                              FsInformationClass
411                             ));
412         }
413 
414         break;
415 
416     case IRP_MJ_DIRECTORY_CONTROL:
417 
418         if (IoStackLocation->MinorFunction & IRP_MN_QUERY_DIRECTORY) {
419 
420 #ifndef _GNU_NTIFS_
421             FileInformationClass =
422                 IoStackLocation->Parameters.QueryDirectory.FileInformationClass;
423 #else
424             FileInformationClass = ((PEXTENDED_IO_STACK_LOCATION)
425                                     IoStackLocation)->Parameters.QueryDirectory.FileInformationClass;
426 #endif
427 
428             if (FileInformationClass <= FileMaximumInformation) {
429                 DEBUGNI(DL_FUN, ("%s %s %S %s\n",
430                                  Ext2GetCurrentProcessName(),
431                                  IrpMjStrings[IoStackLocation->MajorFunction],
432                                  FileName,
433                                  FileInformationClassStrings[FileInformationClass]
434                                 ));
435 
436                 if (
437 #ifndef _GNU_NTIFS_
438                     IoStackLocation->Parameters.QueryDirectory.FileName
439 #else
440                     ((PEXTENDED_IO_STACK_LOCATION)
441                      IoStackLocation)->Parameters.QueryDirectory.FileName
442 #endif
443                 ) {
444 #ifndef _GNU_NTIFS_
445                     DEBUGNI(DL_FUN, ("%s FileName: %.*S FileIndex: %x %s%s%s\n",
446                                      Ext2GetCurrentProcessName(),
447 
448                                      IoStackLocation->Parameters.QueryDirectory.FileName->Length / 2,
449                                      IoStackLocation->Parameters.QueryDirectory.FileName->Buffer,
450                                      IoStackLocation->Parameters.QueryDirectory.FileIndex,
451                                      (IoStackLocation->Flags & SL_RESTART_SCAN ? "SL_RESTART_SCAN " : ""),
452                                      (IoStackLocation->Flags & SL_RETURN_SINGLE_ENTRY ? "SL_RETURN_SINGLE_ENTRY " : ""),
453                                      ((IoStackLocation->Flags & SL_INDEX_SPECIFIED) ? "SL_INDEX_SPECIFIED " : "")
454                                     ));
455 
456 #else
457                     DEBUGNI(DL_FUN, ("%s FileName: %.*S FileIndex: %x %s%s%s\n",
458                                      Ext2GetCurrentProcessName(),
459 
460                                      ((PEXTENDED_IO_STACK_LOCATION)
461                                       IoStackLocation)->Parameters.QueryDirectory.FileName->Length / 2,
462                                      ((PEXTENDED_IO_STACK_LOCATION)
463                                       IoStackLocation)->Parameters.QueryDirectory.FileName->Buffer,
464                                      ((PEXTENDED_IO_STACK_LOCATION)
465                                       IoStackLocation)->Parameters.QueryDirectory.FileIndex,
466                                      (IoStackLocation->Flags & SL_RESTART_SCAN ? "SL_RESTART_SCAN " : ""),
467                                      (IoStackLocation->Flags & SL_RETURN_SINGLE_ENTRY ? "SL_RETURN_SINGLE_ENTRY " : ""),
468                                      ((IoStackLocation->Flags & SL_INDEX_SPECIFIED) ? "SL_INDEX_SPECIFIED " : "")
469                                     ));
470 #endif
471                 } else {
472 #ifndef _GNU_NTIFS_
473                     DEBUGNI(DL_FUN, ("%s FileName: FileIndex: %#x %s%s%s\n",
474                                      Ext2GetCurrentProcessName(),
475                                      IoStackLocation->Parameters.QueryDirectory.FileIndex,
476                                      (IoStackLocation->Flags & SL_RESTART_SCAN ? "SL_RESTART_SCAN " : ""),
477                                      (IoStackLocation->Flags & SL_RETURN_SINGLE_ENTRY ? "SL_RETURN_SINGLE_ENTRY " : ""),
478                                      (IoStackLocation->Flags & SL_INDEX_SPECIFIED ? "SL_INDEX_SPECIFIED " : "")
479                                     ));
480 #else
481                     DEBUGNI(DL_FUN, ("%s FileName: FileIndex: %#x %s%s%s\n",
482                                      Ext2GetCurrentProcessName(),
483                                      ((PEXTENDED_IO_STACK_LOCATION)
484                                       IoStackLocation)->Parameters.QueryDirectory.FileIndex,
485                                      (IoStackLocation->Flags & SL_RESTART_SCAN ? "SL_RESTART_SCAN " : ""),
486                                      (IoStackLocation->Flags & SL_RETURN_SINGLE_ENTRY ? "SL_RETURN_SINGLE_ENTRY " : ""),
487                                      (IoStackLocation->Flags & SL_INDEX_SPECIFIED ? "SL_INDEX_SPECIFIED " : "")
488                                     ));
489 #endif
490                 }
491             } else {
492                 DEBUGNI(DL_FUN, ("%s %s %S Unknown FileInformationClass %u\n",
493                                  Ext2GetCurrentProcessName(),
494                                  IrpMjStrings[IoStackLocation->MajorFunction],
495                                  FileName,
496                                  FileInformationClass
497                                 ));
498             }
499         } else if (IoStackLocation->MinorFunction & IRP_MN_NOTIFY_CHANGE_DIRECTORY) {
500             DEBUGNI(DL_FUN, ("%s %s %S IRP_MN_NOTIFY_CHANGE_DIRECTORY\n",
501                              Ext2GetCurrentProcessName(),
502                              IrpMjStrings[IoStackLocation->MajorFunction],
503                              FileName
504                             ));
505         } else {
506             DEBUGNI(DL_FUN, ("%s %s %S Unknown minor function %#x\n",
507                              Ext2GetCurrentProcessName(),
508                              IrpMjStrings[IoStackLocation->MajorFunction],
509                              FileName,
510                              IoStackLocation->MinorFunction
511                             ));
512         }
513 
514         break;
515 
516     case IRP_MJ_FILE_SYSTEM_CONTROL:
517 
518         if (IoStackLocation->MinorFunction == IRP_MN_USER_FS_REQUEST) {
519 #ifndef _GNU_NTIFS_
520             DEBUGNI(DL_FUN, ( "%s %s %S IRP_MN_USER_FS_REQUEST FsControlCode: %#x\n",
521                               Ext2GetCurrentProcessName(),
522                               IrpMjStrings[IoStackLocation->MajorFunction],
523                               FileName,
524                               IoStackLocation->Parameters.FileSystemControl.FsControlCode
525                             ));
526 #else
527             DEBUGNI(DL_FUN, ("%s %s %S IRP_MN_USER_FS_REQUEST FsControlCode: %#x\n",
528                              Ext2GetCurrentProcessName(),
529                              IrpMjStrings[IoStackLocation->MajorFunction],
530                              FileName,
531                              ((PEXTENDED_IO_STACK_LOCATION)
532                               IoStackLocation)->Parameters.FileSystemControl.FsControlCode
533                             ));
534 #endif
535         } else if (IoStackLocation->MinorFunction == IRP_MN_MOUNT_VOLUME) {
536             DEBUGNI(DL_FUN, ("%s %s %S IRP_MN_MOUNT_VOLUME DeviceObject: %#x\n",
537                              Ext2GetCurrentProcessName(),
538                              IrpMjStrings[IoStackLocation->MajorFunction],
539                              FileName,
540                              IoStackLocation->Parameters.MountVolume.DeviceObject
541                             ));
542         } else if (IoStackLocation->MinorFunction == IRP_MN_VERIFY_VOLUME) {
543             DEBUGNI(DL_FUN, ("%s %s %S IRP_MN_VERIFY_VOLUME DeviceObject: %#x\n",
544                              Ext2GetCurrentProcessName(),
545                              IrpMjStrings[IoStackLocation->MajorFunction],
546                              FileName,
547                              IoStackLocation->Parameters.VerifyVolume.DeviceObject
548                             ));
549         } else if (IoStackLocation->MinorFunction == IRP_MN_LOAD_FILE_SYSTEM) {
550             DEBUGNI(DL_FUN, ("%s %s %S IRP_MN_LOAD_FILE_SYSTEM\n",
551                              Ext2GetCurrentProcessName(),
552                              IrpMjStrings[IoStackLocation->MajorFunction],
553                              FileName
554                             ));
555         }
556 #if (_WIN32_WINNT >= 0x0500)
557         else if (IoStackLocation->MinorFunction == IRP_MN_KERNEL_CALL) {
558             DEBUGNI(DL_FUN, ("%s %s %S IRP_MN_KERNEL_CALL\n",
559                              Ext2GetCurrentProcessName(),
560                              IrpMjStrings[IoStackLocation->MajorFunction],
561                              FileName
562                             ));
563         }
564 #endif // (_WIN32_WINNT >= 0x0500)
565         else {
566             DEBUGNI(DL_FUN, ("%s %s %S Unknown minor function %#x\n",
567                              Ext2GetCurrentProcessName(),
568                              IrpMjStrings[IoStackLocation->MajorFunction],
569                              FileName,
570                              IoStackLocation->MinorFunction
571                             ));
572         }
573 
574         break;
575 
576     case IRP_MJ_DEVICE_CONTROL:
577 
578         DEBUGNI(DL_FUN, ("%s %s %S IoControlCode: %#x\n",
579                          Ext2GetCurrentProcessName(),
580                          IrpMjStrings[IoStackLocation->MajorFunction],
581                          FileName,
582                          IoStackLocation->Parameters.DeviceIoControl.IoControlCode
583                         ));
584 
585         break;
586 
587     case IRP_MJ_LOCK_CONTROL:
588 
589         if (IoStackLocation->MinorFunction & IRP_MN_LOCK) {
590 #ifndef _GNU_NTIFS_
591             DEBUGNI(DL_FUN, ("%s %s %S IRP_MN_LOCK Offset: %I64xh Length: %I64xh Key: %u %s%s\n",
592                              Ext2GetCurrentProcessName(),
593                              IrpMjStrings[IoStackLocation->MajorFunction],
594                              FileName,
595                              IoStackLocation->Parameters.LockControl.ByteOffset.QuadPart,
596                              IoStackLocation->Parameters.LockControl.Length->QuadPart,
597                              IoStackLocation->Parameters.LockControl.Key,
598                              (IoStackLocation->Flags & SL_FAIL_IMMEDIATELY ? "SL_FAIL_IMMEDIATELY " : ""),
599                              (IoStackLocation->Flags & SL_EXCLUSIVE_LOCK ? "SL_EXCLUSIVE_LOCK " : "")
600                             ));
601 #else
602             DEBUGNI(DL_FUN, ("%s %s %S IRP_MN_LOCK Offset: %I64xh Length: %I64xh Key: %u %s%s\n",
603                              Ext2GetCurrentProcessName(),
604                              IrpMjStrings[IoStackLocation->MajorFunction],
605                              FileName,
606                              ((PEXTENDED_IO_STACK_LOCATION)
607                               IoStackLocation)->Parameters.LockControl.ByteOffset.QuadPart,
608                              ((PEXTENDED_IO_STACK_LOCATION)
609                               IoStackLocation)->Parameters.LockControl.Length->QuadPart,
610                              ((PEXTENDED_IO_STACK_LOCATION)
611                               IoStackLocation)->Parameters.LockControl.Key,
612                              (IoStackLocation->Flags & SL_FAIL_IMMEDIATELY ? "SL_FAIL_IMMEDIATELY " : ""),
613                              (IoStackLocation->Flags & SL_EXCLUSIVE_LOCK ? "SL_EXCLUSIVE_LOCK " : "")
614                             ));
615 #endif
616         } else if (IoStackLocation->MinorFunction & IRP_MN_UNLOCK_SINGLE) {
617 #ifndef _GNU_NTIFS_
618             DEBUGNI(DL_FUN, ("%s %s %S IRP_MN_UNLOCK_SINGLE Offset: %I64xh Length: %I64xh Key: %u\n",
619                              Ext2GetCurrentProcessName(),
620                              IrpMjStrings[IoStackLocation->MajorFunction],
621                              FileName,
622                              IoStackLocation->Parameters.LockControl.ByteOffset.QuadPart,
623                              IoStackLocation->Parameters.LockControl.Length->QuadPart,
624                              IoStackLocation->Parameters.LockControl.Key
625                             ));
626 #else
627             DEBUGNI(DL_FUN, ("%s %s %S IRP_MN_UNLOCK_SINGLE Offset: %I64xh Length: %I64xh Key: %u\n",
628                              Ext2GetCurrentProcessName(),
629                              IrpMjStrings[IoStackLocation->MajorFunction],
630                              FileName,
631                              ((PEXTENDED_IO_STACK_LOCATION)
632                               IoStackLocation)->Parameters.LockControl.ByteOffset.QuadPart,
633                              ((PEXTENDED_IO_STACK_LOCATION)
634                               IoStackLocation)->Parameters.LockControl.Length->QuadPart,
635                              ((PEXTENDED_IO_STACK_LOCATION)
636                               IoStackLocation)->Parameters.LockControl.Key
637                             ));
638 #endif
639         } else if (IoStackLocation->MinorFunction & IRP_MN_UNLOCK_ALL) {
640             DEBUGNI(DL_FUN, ("%s %s %S IRP_MN_UNLOCK_ALL\n",
641                              Ext2GetCurrentProcessName(),
642                              IrpMjStrings[IoStackLocation->MajorFunction],
643                              FileName
644                             ));
645         } else if (IoStackLocation->MinorFunction & IRP_MN_UNLOCK_ALL_BY_KEY) {
646 #ifndef _GNU_NTIFS_
647             DEBUGNI(DL_FUN, ("%s %s %S IRP_MN_UNLOCK_ALL_BY_KEY Key: %u\n",
648                              Ext2GetCurrentProcessName(),
649                              IrpMjStrings[IoStackLocation->MajorFunction],
650                              FileName,
651                              IoStackLocation->Parameters.LockControl.Key
652                             ));
653 #else
654             DEBUGNI(DL_FUN, ("%s %s %S IRP_MN_UNLOCK_ALL_BY_KEY Key: %u\n",
655                              Ext2GetCurrentProcessName(),
656                              IrpMjStrings[IoStackLocation->MajorFunction],
657                              FileName,
658                              ((PEXTENDED_IO_STACK_LOCATION)
659                               IoStackLocation)->Parameters.LockControl.Key
660                             ));
661 #endif
662         } else {
663             DEBUGNI(DL_FUN, ("%s %s %S Unknown minor function %#x\n",
664                              Ext2GetCurrentProcessName(),
665                              IrpMjStrings[IoStackLocation->MajorFunction],
666                              FileName,
667                              IoStackLocation->MinorFunction
668                             ));
669         }
670 
671         break;
672 
673     case IRP_MJ_CLEANUP:
674 
675         DEBUGNI(DL_FUN, ("%s %s %S\n",
676                          Ext2GetCurrentProcessName(),
677                          IrpMjStrings[IoStackLocation->MajorFunction],
678                          FileName
679                         ));
680 
681         break;
682 
683     case IRP_MJ_SHUTDOWN:
684 
685         DEBUGNI(DL_FUN, ("%s %s %S\n",
686                          Ext2GetCurrentProcessName(),
687                          IrpMjStrings[IoStackLocation->MajorFunction],
688                          FileName
689                         ));
690 
691         break;
692 
693 #if (_WIN32_WINNT >= 0x0500)
694     case IRP_MJ_PNP:
695 
696         DEBUGNI(DL_FUN, ( "%s %s %S\n",
697                           Ext2GetCurrentProcessName(),
698                           IrpMjStrings[IoStackLocation->MajorFunction],
699                           FileName
700                         ));
701         break;
702 #endif // (_WIN32_WINNT >= 0x0500)
703 
704     default:
705 
706         DEBUGNI(DL_FUN, ("%s %s %S\n",
707                          Ext2GetCurrentProcessName(),
708                          IrpMjStrings[IoStackLocation->MajorFunction],
709                          FileName
710                         ));
711     }
712 }
713 
714 VOID
Ext2DbgPrintComplete(IN PIRP Irp,IN BOOLEAN bPrint)715 Ext2DbgPrintComplete (IN PIRP Irp, IN BOOLEAN bPrint)
716 {
717     PIO_STACK_LOCATION IoStackLocation;
718 
719     if (!Irp)
720         return;
721 
722     if (Irp->IoStatus.Status != STATUS_SUCCESS) {
723 
724         IoStackLocation = IoGetCurrentIrpStackLocation(Irp);
725 
726         if (bPrint) {
727             DEBUGNI(DL_FUN, ("%s %s Status: %s (%#x).\n",
728                              Ext2GetCurrentProcessName(),
729                              IrpMjStrings[IoStackLocation->MajorFunction],
730                              Ext2NtStatusToString(Irp->IoStatus.Status),
731                              Irp->IoStatus.Status
732                             ));
733         }
734     }
735 }
736 
737 PUCHAR
Ext2NtStatusToString(IN NTSTATUS Status)738 Ext2NtStatusToString ( IN NTSTATUS Status )
739 {
740     switch (Status) {
741 
742     case 0x00000000:
743         return "STATUS_SUCCESS";
744     case 0x00000001:
745         return "STATUS_WAIT_1";
746     case 0x00000002:
747         return "STATUS_WAIT_2";
748     case 0x00000003:
749         return "STATUS_WAIT_3";
750     case 0x0000003F:
751         return "STATUS_WAIT_63";
752     case 0x00000080:
753         return "STATUS_ABANDONED_WAIT_0";
754     case 0x000000BF:
755         return "STATUS_ABANDONED_WAIT_63";
756     case 0x000000C0:
757         return "STATUS_USER_APC";
758     case 0x00000100:
759         return "STATUS_KERNEL_APC";
760     case 0x00000101:
761         return "STATUS_ALERTED";
762     case 0x00000102:
763         return "STATUS_TIMEOUT";
764     case 0x00000103:
765         return "STATUS_PENDING";
766     case 0x00000104:
767         return "STATUS_REPARSE";
768     case 0x00000105:
769         return "STATUS_MORE_ENTRIES";
770     case 0x00000106:
771         return "STATUS_NOT_ALL_ASSIGNED";
772     case 0x00000107:
773         return "STATUS_SOME_NOT_MAPPED";
774     case 0x00000108:
775         return "STATUS_OPLOCK_BREAK_IN_PROGRESS";
776     case 0x00000109:
777         return "STATUS_VOLUME_MOUNTED";
778     case 0x0000010A:
779         return "STATUS_RXACT_COMMITTED";
780     case 0x0000010B:
781         return "STATUS_NOTIFY_CLEANUP";
782     case 0x0000010C:
783         return "STATUS_NOTIFY_ENUM_DIR";
784     case 0x0000010D:
785         return "STATUS_NO_QUOTAS_FOR_ACCOUNT";
786     case 0x0000010E:
787         return "STATUS_PRIMARY_TRANSPORT_CONNECT_FAILED";
788     case 0x00000110:
789         return "STATUS_PAGE_FAULT_TRANSITION";
790     case 0x00000111:
791         return "STATUS_PAGE_FAULT_DEMAND_ZERO";
792     case 0x00000112:
793         return "STATUS_PAGE_FAULT_COPY_ON_WRITE";
794     case 0x00000113:
795         return "STATUS_PAGE_FAULT_GUARD_PAGE";
796     case 0x00000114:
797         return "STATUS_PAGE_FAULT_PAGING_FILE";
798     case 0x00000115:
799         return "STATUS_CACHE_PAGE_LOCKED";
800     case 0x00000116:
801         return "STATUS_CRASH_DUMP";
802     case 0x00000117:
803         return "STATUS_BUFFER_ALL_ZEROS";
804     case 0x00000118:
805         return "STATUS_REPARSE_OBJECT";
806     case 0x00000119:
807         return "STATUS_RESOURCE_REQUIREMENTS_CHANGED";
808     case 0x00000120:
809         return "STATUS_TRANSLATION_COMPLETE";
810     case 0x00000121:
811         return "STATUS_DS_MEMBERSHIP_EVALUATED_LOCALLY";
812     case 0x00010001:
813         return "DBG_EXCEPTION_HANDLED";
814     case 0x00010002:
815         return "DBG_CONTINUE";
816     case 0x40000000:
817         return "STATUS_OBJECT_NAME_EXISTS";
818     case 0x40000001:
819         return "STATUS_THREAD_WAS_SUSPENDED";
820     case 0x40000002:
821         return "STATUS_WORKING_SET_LIMIT_RANGE";
822     case 0x40000003:
823         return "STATUS_IMAGE_NOT_AT_BASE";
824     case 0x40000004:
825         return "STATUS_RXACT_STATE_CREATED";
826     case 0x40000005:
827         return "STATUS_SEGMENT_NOTIFICATION";
828     case 0x40000006:
829         return "STATUS_LOCAL_USER_SESSION_KEY";
830     case 0x40000007:
831         return "STATUS_BAD_CURRENT_DIRECTORY";
832     case 0x40000008:
833         return "STATUS_SERIAL_MORE_WRITES";
834     case 0x40000009:
835         return "STATUS_REGISTRY_RECOVERED";
836     case 0x4000000A:
837         return "STATUS_FT_READ_RECOVERY_FROM_BACKUP";
838     case 0x4000000B:
839         return "STATUS_FT_WRITE_RECOVERY";
840     case 0x4000000C:
841         return "STATUS_SERIAL_COUNTER_TIMEOUT";
842     case 0x4000000D:
843         return "STATUS_NULL_LM_PASSWORD";
844     case 0x4000000E:
845         return "STATUS_IMAGE_MACHINE_TYPE_MISMATCH";
846     case 0x4000000F:
847         return "STATUS_RECEIVE_PARTIAL";
848     case 0x40000010:
849         return "STATUS_RECEIVE_EXPEDITED";
850     case 0x40000011:
851         return "STATUS_RECEIVE_PARTIAL_EXPEDITED";
852     case 0x40000012:
853         return "STATUS_EVENT_DONE";
854     case 0x40000013:
855         return "STATUS_EVENT_PENDING";
856     case 0x40000014:
857         return "STATUS_CHECKING_FILE_SYSTEM";
858     case 0x40000015:
859         return "STATUS_FATAL_APP_EXIT";
860     case 0x40000016:
861         return "STATUS_PREDEFINED_HANDLE";
862     case 0x40000017:
863         return "STATUS_WAS_UNLOCKED";
864     case 0x40000018:
865         return "STATUS_SERVICE_NOTIFICATION";
866     case 0x40000019:
867         return "STATUS_WAS_LOCKED";
868     case 0x4000001A:
869         return "STATUS_LOG_HARD_ERROR";
870     case 0x4000001B:
871         return "STATUS_ALREADY_WIN32";
872     case 0x4000001C:
873         return "STATUS_WX86_UNSIMULATE";
874     case 0x4000001D:
875         return "STATUS_WX86_CONTINUE";
876     case 0x4000001E:
877         return "STATUS_WX86_SINGLE_STEP";
878     case 0x4000001F:
879         return "STATUS_WX86_BREAKPOINT";
880     case 0x40000020:
881         return "STATUS_WX86_EXCEPTION_CONTINUE";
882     case 0x40000021:
883         return "STATUS_WX86_EXCEPTION_LASTCHANCE";
884     case 0x40000022:
885         return "STATUS_WX86_EXCEPTION_CHAIN";
886     case 0x40000023:
887         return "STATUS_IMAGE_MACHINE_TYPE_MISMATCH_EXE";
888     case 0x40000024:
889         return "STATUS_NO_YIELD_PERFORMED";
890     case 0x40000025:
891         return "STATUS_TIMER_RESUME_IGNORED";
892     case 0x40000026:
893         return "STATUS_ARBITRATION_UNHANDLED";
894     case 0x40000027:
895         return "STATUS_CARDBUS_NOT_SUPPORTED";
896     case 0x40000028:
897         return "STATUS_WX86_CREATEWX86TIB";
898     case 0x40000029:
899         return "STATUS_MP_PROCESSOR_MISMATCH";
900     case 0x40010001:
901         return "DBG_REPLY_LATER";
902     case 0x40010002:
903         return "DBG_UNABLE_TO_PROVIDE_HANDLE";
904     case 0x40010003:
905         return "DBG_TERMINATE_THREAD";
906     case 0x40010004:
907         return "DBG_TERMINATE_PROCESS";
908     case 0x40010005:
909         return "DBG_CONTROL_C";
910     case 0x40010006:
911         return "DBG_PRINTEXCEPTION_C";
912     case 0x40010007:
913         return "DBG_RIPEXCEPTION";
914     case 0x40010008:
915         return "DBG_CONTROL_BREAK";
916     case 0x80000001:
917         return "STATUS_GUARD_PAGE_VIOLATION";
918     case 0x80000002:
919         return "STATUS_DATATYPE_MISALIGNMENT";
920     case 0x80000003:
921         return "STATUS_BREAKPOINT";
922     case 0x80000004:
923         return "STATUS_SINGLE_STEP";
924     case 0x80000005:
925         return "STATUS_BUFFER_OVERFLOW";
926     case 0x80000006:
927         return "STATUS_NO_MORE_FILES";
928     case 0x80000007:
929         return "STATUS_WAKE_SYSTEM_DEBUGGER";
930     case 0x8000000A:
931         return "STATUS_HANDLES_CLOSED";
932     case 0x8000000B:
933         return "STATUS_NO_INHERITANCE";
934     case 0x8000000C:
935         return "STATUS_GUID_SUBSTITUTION_MADE";
936     case 0x8000000D:
937         return "STATUS_PARTIAL_COPY";
938     case 0x8000000E:
939         return "STATUS_DEVICE_PAPER_EMPTY";
940     case 0x8000000F:
941         return "STATUS_DEVICE_POWERED_OFF";
942     case 0x80000010:
943         return "STATUS_DEVICE_OFF_LINE";
944     case 0x80000011:
945         return "STATUS_DEVICE_BUSY";
946     case 0x80000012:
947         return "STATUS_NO_MORE_EAS";
948     case 0x80000013:
949         return "STATUS_INVALID_EA_NAME";
950     case 0x80000014:
951         return "STATUS_EA_LIST_INCONSISTENT";
952     case 0x80000015:
953         return "STATUS_INVALID_EA_FLAG";
954     case 0x80000016:
955         return "STATUS_VERIFY_REQUIRED";
956     case 0x80000017:
957         return "STATUS_EXTRANEOUS_INFORMATION";
958     case 0x80000018:
959         return "STATUS_RXACT_COMMIT_NECESSARY";
960     case 0x8000001A:
961         return "STATUS_NO_MORE_ENTRIES";
962     case 0x8000001B:
963         return "STATUS_FILEMARK_DETECTED";
964     case 0x8000001C:
965         return "STATUS_MEDIA_CHANGED";
966     case 0x8000001D:
967         return "STATUS_BUS_RESET";
968     case 0x8000001E:
969         return "STATUS_END_OF_MEDIA";
970     case 0x8000001F:
971         return "STATUS_BEGINNING_OF_MEDIA";
972     case 0x80000020:
973         return "STATUS_MEDIA_CHECK";
974     case 0x80000021:
975         return "STATUS_SETMARK_DETECTED";
976     case 0x80000022:
977         return "STATUS_NO_DATA_DETECTED";
978     case 0x80000023:
979         return "STATUS_REDIRECTOR_HAS_OPEN_HANDLES";
980     case 0x80000024:
981         return "STATUS_SERVER_HAS_OPEN_HANDLES";
982     case 0x80000025:
983         return "STATUS_ALREADY_DISCONNECTED";
984     case 0x80000026:
985         return "STATUS_LONGJUMP";
986     case 0x80010001:
987         return "DBG_EXCEPTION_NOT_HANDLED";
988     case 0xC0000001:
989         return "STATUS_UNSUCCESSFUL";
990     case 0xC0000002:
991         return "STATUS_NOT_IMPLEMENTED";
992     case 0xC0000003:
993         return "STATUS_INVALID_INFO_CLASS";
994     case 0xC0000004:
995         return "STATUS_INFO_LENGTH_MISMATCH";
996     case 0xC0000005:
997         return "STATUS_ACCESS_VIOLATION";
998     case 0xC0000006:
999         return "STATUS_IN_PAGE_ERROR";
1000     case 0xC0000007:
1001         return "STATUS_PAGEFILE_QUOTA";
1002     case 0xC0000008:
1003         return "STATUS_INVALID_HANDLE";
1004     case 0xC0000009:
1005         return "STATUS_BAD_INITIAL_STACK";
1006     case 0xC000000A:
1007         return "STATUS_BAD_INITIAL_PC";
1008     case 0xC000000B:
1009         return "STATUS_INVALID_CID";
1010     case 0xC000000C:
1011         return "STATUS_TIMER_NOT_CANCELED";
1012     case 0xC000000D:
1013         return "STATUS_INVALID_PARAMETER";
1014     case 0xC000000E:
1015         return "STATUS_NO_SUCH_DEVICE";
1016     case 0xC000000F:
1017         return "STATUS_NO_SUCH_FILE";
1018     case 0xC0000010:
1019         return "STATUS_INVALID_DEVICE_REQUEST";
1020     case 0xC0000011:
1021         return "STATUS_END_OF_FILE";
1022     case 0xC0000012:
1023         return "STATUS_WRONG_VOLUME";
1024     case 0xC0000013:
1025         return "STATUS_NO_MEDIA_IN_DEVICE";
1026     case 0xC0000014:
1027         return "STATUS_UNRECOGNIZED_MEDIA";
1028     case 0xC0000015:
1029         return "STATUS_NONEXISTENT_SECTOR";
1030     case 0xC0000016:
1031         return "STATUS_MORE_PROCESSING_REQUIRED";
1032     case 0xC0000017:
1033         return "STATUS_NO_MEMORY";
1034     case 0xC0000018:
1035         return "STATUS_CONFLICTING_ADDRESSES";
1036     case 0xC0000019:
1037         return "STATUS_NOT_MAPPED_VIEW";
1038     case 0xC000001A:
1039         return "STATUS_UNABLE_TO_FREE_VM";
1040     case 0xC000001B:
1041         return "STATUS_UNABLE_TO_DELETE_SECTION";
1042     case 0xC000001C:
1043         return "STATUS_INVALID_SYSTEM_SERVICE";
1044     case 0xC000001D:
1045         return "STATUS_ILLEGAL_INSTRUCTION";
1046     case 0xC000001E:
1047         return "STATUS_INVALID_LOCK_SEQUENCE";
1048     case 0xC000001F:
1049         return "STATUS_INVALID_VIEW_SIZE";
1050     case 0xC0000020:
1051         return "STATUS_INVALID_FILE_FOR_SECTION";
1052     case 0xC0000021:
1053         return "STATUS_ALREADY_COMMITTED";
1054     case 0xC0000022:
1055         return "STATUS_ACCESS_DENIED";
1056     case 0xC0000023:
1057         return "STATUS_BUFFER_TOO_SMALL";
1058     case 0xC0000024:
1059         return "STATUS_OBJECT_TYPE_MISMATCH";
1060     case 0xC0000025:
1061         return "STATUS_NONCONTINUABLE_EXCEPTION";
1062     case 0xC0000026:
1063         return "STATUS_INVALID_DISPOSITION";
1064     case 0xC0000027:
1065         return "STATUS_UNWIND";
1066     case 0xC0000028:
1067         return "STATUS_BAD_STACK";
1068     case 0xC0000029:
1069         return "STATUS_INVALID_UNWIND_TARGET";
1070     case 0xC000002A:
1071         return "STATUS_NOT_LOCKED";
1072     case 0xC000002B:
1073         return "STATUS_PARITY_ERROR";
1074     case 0xC000002C:
1075         return "STATUS_UNABLE_TO_DECOMMIT_VM";
1076     case 0xC000002D:
1077         return "STATUS_NOT_COMMITTED";
1078     case 0xC000002E:
1079         return "STATUS_INVALID_PORT_ATTRIBUTES";
1080     case 0xC000002F:
1081         return "STATUS_PORT_MESSAGE_TOO_LONG";
1082     case 0xC0000030:
1083         return "STATUS_INVALID_PARAMETER_MIX";
1084     case 0xC0000031:
1085         return "STATUS_INVALID_QUOTA_LOWER";
1086     case 0xC0000032:
1087         return "STATUS_DISK_CORRUPT_ERROR";
1088     case 0xC0000033:
1089         return "STATUS_OBJECT_NAME_INVALID";
1090     case 0xC0000034:
1091         return "STATUS_OBJECT_NAME_NOT_FOUND";
1092     case 0xC0000035:
1093         return "STATUS_OBJECT_NAME_COLLISION";
1094     case 0xC0000037:
1095         return "STATUS_PORT_DISCONNECTED";
1096     case 0xC0000038:
1097         return "STATUS_DEVICE_ALREADY_ATTACHED";
1098     case 0xC0000039:
1099         return "STATUS_OBJECT_PATH_INVALID";
1100     case 0xC000003A:
1101         return "STATUS_OBJECT_PATH_NOT_FOUND";
1102     case 0xC000003B:
1103         return "STATUS_OBJECT_PATH_SYNTAX_BAD";
1104     case 0xC000003C:
1105         return "STATUS_DATA_OVERRUN";
1106     case 0xC000003D:
1107         return "STATUS_DATA_LATE_ERROR";
1108     case 0xC000003E:
1109         return "STATUS_DATA_ERROR";
1110     case 0xC000003F:
1111         return "STATUS_CRC_ERROR";
1112     case 0xC0000040:
1113         return "STATUS_SECTION_TOO_BIG";
1114     case 0xC0000041:
1115         return "STATUS_PORT_CONNECTION_REFUSED";
1116     case 0xC0000042:
1117         return "STATUS_INVALID_PORT_HANDLE";
1118     case 0xC0000043:
1119         return "STATUS_SHARING_VIOLATION";
1120     case 0xC0000044:
1121         return "STATUS_QUOTA_EXCEEDED";
1122     case 0xC0000045:
1123         return "STATUS_INVALID_PAGE_PROTECTION";
1124     case 0xC0000046:
1125         return "STATUS_MUTANT_NOT_OWNED";
1126     case 0xC0000047:
1127         return "STATUS_SEMAPHORE_LIMIT_EXCEEDED";
1128     case 0xC0000048:
1129         return "STATUS_PORT_ALREADY_SET";
1130     case 0xC0000049:
1131         return "STATUS_SECTION_NOT_IMAGE";
1132     case 0xC000004A:
1133         return "STATUS_SUSPEND_COUNT_EXCEEDED";
1134     case 0xC000004B:
1135         return "STATUS_THREAD_IS_TERMINATING";
1136     case 0xC000004C:
1137         return "STATUS_BAD_WORKING_SET_LIMIT";
1138     case 0xC000004D:
1139         return "STATUS_INCOMPATIBLE_FILE_MAP";
1140     case 0xC000004E:
1141         return "STATUS_SECTION_PROTECTION";
1142     case 0xC000004F:
1143         return "STATUS_EAS_NOT_SUPPORTED";
1144     case 0xC0000050:
1145         return "STATUS_EA_TOO_LARGE";
1146     case 0xC0000051:
1147         return "STATUS_NONEXISTENT_EA_ENTRY";
1148     case 0xC0000052:
1149         return "STATUS_NO_EAS_ON_FILE";
1150     case 0xC0000053:
1151         return "STATUS_EA_CORRUPT_ERROR";
1152     case 0xC0000054:
1153         return "STATUS_FILE_LOCK_CONFLICT";
1154     case 0xC0000055:
1155         return "STATUS_LOCK_NOT_GRANTED";
1156     case 0xC0000056:
1157         return "STATUS_DELETE_PENDING";
1158     case 0xC0000057:
1159         return "STATUS_CTL_FILE_NOT_SUPPORTED";
1160     case 0xC0000058:
1161         return "STATUS_UNKNOWN_REVISION";
1162     case 0xC0000059:
1163         return "STATUS_REVISION_MISMATCH";
1164     case 0xC000005A:
1165         return "STATUS_INVALID_OWNER";
1166     case 0xC000005B:
1167         return "STATUS_INVALID_PRIMARY_GROUP";
1168     case 0xC000005C:
1169         return "STATUS_NO_IMPERSONATION_TOKEN";
1170     case 0xC000005D:
1171         return "STATUS_CANT_DISABLE_MANDATORY";
1172     case 0xC000005E:
1173         return "STATUS_NO_LOGON_SERVERS";
1174     case 0xC000005F:
1175         return "STATUS_NO_SUCH_LOGON_SESSION";
1176     case 0xC0000060:
1177         return "STATUS_NO_SUCH_PRIVILEGE";
1178     case 0xC0000061:
1179         return "STATUS_PRIVILEGE_NOT_HELD";
1180     case 0xC0000062:
1181         return "STATUS_INVALID_ACCOUNT_NAME";
1182     case 0xC0000063:
1183         return "STATUS_USER_EXISTS";
1184     case 0xC0000064:
1185         return "STATUS_NO_SUCH_USER";
1186     case 0xC0000065:
1187         return "STATUS_GROUP_EXISTS";
1188     case 0xC0000066:
1189         return "STATUS_NO_SUCH_GROUP";
1190     case 0xC0000067:
1191         return "STATUS_MEMBER_IN_GROUP";
1192     case 0xC0000068:
1193         return "STATUS_MEMBER_NOT_IN_GROUP";
1194     case 0xC0000069:
1195         return "STATUS_LAST_ADMIN";
1196     case 0xC000006A:
1197         return "STATUS_WRONG_PASSWORD";
1198     case 0xC000006B:
1199         return "STATUS_ILL_FORMED_PASSWORD";
1200     case 0xC000006C:
1201         return "STATUS_PASSWORD_RESTRICTION";
1202     case 0xC000006D:
1203         return "STATUS_LOGON_FAILURE";
1204     case 0xC000006E:
1205         return "STATUS_ACCOUNT_RESTRICTION";
1206     case 0xC000006F:
1207         return "STATUS_INVALID_LOGON_HOURS";
1208     case 0xC0000070:
1209         return "STATUS_INVALID_WORKSTATION";
1210     case 0xC0000071:
1211         return "STATUS_PASSWORD_EXPIRED";
1212     case 0xC0000072:
1213         return "STATUS_ACCOUNT_DISABLED";
1214     case 0xC0000073:
1215         return "STATUS_NONE_MAPPED";
1216     case 0xC0000074:
1217         return "STATUS_TOO_MANY_LUIDS_REQUESTED";
1218     case 0xC0000075:
1219         return "STATUS_LUIDS_EXHAUSTED";
1220     case 0xC0000076:
1221         return "STATUS_INVALID_SUB_AUTHORITY";
1222     case 0xC0000077:
1223         return "STATUS_INVALID_ACL";
1224     case 0xC0000078:
1225         return "STATUS_INVALID_SID";
1226     case 0xC0000079:
1227         return "STATUS_INVALID_SECURITY_DESCR";
1228     case 0xC000007A:
1229         return "STATUS_PROCEDURE_NOT_FOUND";
1230     case 0xC000007B:
1231         return "STATUS_INVALID_IMAGE_FORMAT";
1232     case 0xC000007C:
1233         return "STATUS_NO_TOKEN";
1234     case 0xC000007D:
1235         return "STATUS_BAD_INHERITANCE_ACL";
1236     case 0xC000007E:
1237         return "STATUS_RANGE_NOT_LOCKED";
1238     case 0xC000007F:
1239         return "STATUS_DISK_FULL";
1240     case 0xC0000080:
1241         return "STATUS_SERVER_DISABLED";
1242     case 0xC0000081:
1243         return "STATUS_SERVER_NOT_DISABLED";
1244     case 0xC0000082:
1245         return "STATUS_TOO_MANY_GUIDS_REQUESTED";
1246     case 0xC0000083:
1247         return "STATUS_GUIDS_EXHAUSTED";
1248     case 0xC0000084:
1249         return "STATUS_INVALID_ID_AUTHORITY";
1250     case 0xC0000085:
1251         return "STATUS_AGENTS_EXHAUSTED";
1252     case 0xC0000086:
1253         return "STATUS_INVALID_VOLUME_LABEL";
1254     case 0xC0000087:
1255         return "STATUS_SECTION_NOT_EXTENDED";
1256     case 0xC0000088:
1257         return "STATUS_NOT_MAPPED_DATA";
1258     case 0xC0000089:
1259         return "STATUS_RESOURCE_DATA_NOT_FOUND";
1260     case 0xC000008A:
1261         return "STATUS_RESOURCE_TYPE_NOT_FOUND";
1262     case 0xC000008B:
1263         return "STATUS_RESOURCE_NAME_NOT_FOUND";
1264     case 0xC000008C:
1265         return "STATUS_ARRAY_BOUNDS_EXCEEDED";
1266     case 0xC000008D:
1267         return "STATUS_FLOAT_DENORMAL_OPERAND";
1268     case 0xC000008E:
1269         return "STATUS_FLOAT_DIVIDE_BY_ZERO";
1270     case 0xC000008F:
1271         return "STATUS_FLOAT_INEXACT_RESULT";
1272     case 0xC0000090:
1273         return "STATUS_FLOAT_INVALID_OPERATION";
1274     case 0xC0000091:
1275         return "STATUS_FLOAT_OVERFLOW";
1276     case 0xC0000092:
1277         return "STATUS_FLOAT_STACK_CHECK";
1278     case 0xC0000093:
1279         return "STATUS_FLOAT_UNDERFLOW";
1280     case 0xC0000094:
1281         return "STATUS_INTEGER_DIVIDE_BY_ZERO";
1282     case 0xC0000095:
1283         return "STATUS_INTEGER_OVERFLOW";
1284     case 0xC0000096:
1285         return "STATUS_PRIVILEGED_INSTRUCTION";
1286     case 0xC0000097:
1287         return "STATUS_TOO_MANY_PAGING_FILES";
1288     case 0xC0000098:
1289         return "STATUS_FILE_INVALID";
1290     case 0xC0000099:
1291         return "STATUS_ALLOTTED_SPACE_EXCEEDED";
1292     case 0xC000009A:
1293         return "STATUS_INSUFFICIENT_RESOURCES";
1294     case 0xC000009B:
1295         return "STATUS_DFS_EXIT_PATH_FOUND";
1296     case 0xC000009C:
1297         return "STATUS_DEVICE_DATA_ERROR";
1298     case 0xC000009D:
1299         return "STATUS_DEVICE_NOT_CONNECTED";
1300     case 0xC000009E:
1301         return "STATUS_DEVICE_POWER_FAILURE";
1302     case 0xC000009F:
1303         return "STATUS_FREE_VM_NOT_AT_BASE";
1304     case 0xC00000A0:
1305         return "STATUS_MEMORY_NOT_ALLOCATED";
1306     case 0xC00000A1:
1307         return "STATUS_WORKING_SET_QUOTA";
1308     case 0xC00000A2:
1309         return "STATUS_MEDIA_WRITE_PROTECTED";
1310     case 0xC00000A3:
1311         return "STATUS_DEVICE_NOT_READY";
1312     case 0xC00000A4:
1313         return "STATUS_INVALID_GROUP_ATTRIBUTES";
1314     case 0xC00000A5:
1315         return "STATUS_BAD_IMPERSONATION_LEVEL";
1316     case 0xC00000A6:
1317         return "STATUS_CANT_OPEN_ANONYMOUS";
1318     case 0xC00000A7:
1319         return "STATUS_BAD_VALIDATION_CLASS";
1320     case 0xC00000A8:
1321         return "STATUS_BAD_TOKEN_TYPE";
1322     case 0xC00000A9:
1323         return "STATUS_BAD_MASTER_BOOT_RECORD";
1324     case 0xC00000AA:
1325         return "STATUS_INSTRUCTION_MISALIGNMENT";
1326     case 0xC00000AB:
1327         return "STATUS_INSTANCE_NOT_AVAILABLE";
1328     case 0xC00000AC:
1329         return "STATUS_PIPE_NOT_AVAILABLE";
1330     case 0xC00000AD:
1331         return "STATUS_INVALID_PIPE_STATE";
1332     case 0xC00000AE:
1333         return "STATUS_PIPE_BUSY";
1334     case 0xC00000AF:
1335         return "STATUS_ILLEGAL_FUNCTION";
1336     case 0xC00000B0:
1337         return "STATUS_PIPE_DISCONNECTED";
1338     case 0xC00000B1:
1339         return "STATUS_PIPE_CLOSING";
1340     case 0xC00000B2:
1341         return "STATUS_PIPE_CONNECTED";
1342     case 0xC00000B3:
1343         return "STATUS_PIPE_LISTENING";
1344     case 0xC00000B4:
1345         return "STATUS_INVALID_READ_MODE";
1346     case 0xC00000B5:
1347         return "STATUS_IO_TIMEOUT";
1348     case 0xC00000B6:
1349         return "STATUS_FILE_FORCED_CLOSED";
1350     case 0xC00000B7:
1351         return "STATUS_PROFILING_NOT_STARTED";
1352     case 0xC00000B8:
1353         return "STATUS_PROFILING_NOT_STOPPED";
1354     case 0xC00000B9:
1355         return "STATUS_COULD_NOT_INTERPRET";
1356     case 0xC00000BA:
1357         return "STATUS_FILE_IS_A_DIRECTORY";
1358     case 0xC00000BB:
1359         return "STATUS_NOT_SUPPORTED";
1360     case 0xC00000BC:
1361         return "STATUS_REMOTE_NOT_LISTENING";
1362     case 0xC00000BD:
1363         return "STATUS_DUPLICATE_NAME";
1364     case 0xC00000BE:
1365         return "STATUS_BAD_NETWORK_PATH";
1366     case 0xC00000BF:
1367         return "STATUS_NETWORK_BUSY";
1368     case 0xC00000C0:
1369         return "STATUS_DEVICE_DOES_NOT_EXIST";
1370     case 0xC00000C1:
1371         return "STATUS_TOO_MANY_COMMANDS";
1372     case 0xC00000C2:
1373         return "STATUS_ADAPTER_HARDWARE_ERROR";
1374     case 0xC00000C3:
1375         return "STATUS_INVALID_NETWORK_RESPONSE";
1376     case 0xC00000C4:
1377         return "STATUS_UNEXPECTED_NETWORK_ERROR";
1378     case 0xC00000C5:
1379         return "STATUS_BAD_REMOTE_ADAPTER";
1380     case 0xC00000C6:
1381         return "STATUS_PRINT_QUEUE_FULL";
1382     case 0xC00000C7:
1383         return "STATUS_NO_SPOOL_SPACE";
1384     case 0xC00000C8:
1385         return "STATUS_PRINT_CANCELLED";
1386     case 0xC00000C9:
1387         return "STATUS_NETWORK_NAME_DELETED";
1388     case 0xC00000CA:
1389         return "STATUS_NETWORK_ACCESS_DENIED";
1390     case 0xC00000CB:
1391         return "STATUS_BAD_DEVICE_TYPE";
1392     case 0xC00000CC:
1393         return "STATUS_BAD_NETWORK_NAME";
1394     case 0xC00000CD:
1395         return "STATUS_TOO_MANY_NAMES";
1396     case 0xC00000CE:
1397         return "STATUS_TOO_MANY_SESSIONS";
1398     case 0xC00000CF:
1399         return "STATUS_SHARING_PAUSED";
1400     case 0xC00000D0:
1401         return "STATUS_REQUEST_NOT_ACCEPTED";
1402     case 0xC00000D1:
1403         return "STATUS_REDIRECTOR_PAUSED";
1404     case 0xC00000D2:
1405         return "STATUS_NET_WRITE_FAULT";
1406     case 0xC00000D3:
1407         return "STATUS_PROFILING_AT_LIMIT";
1408     case 0xC00000D4:
1409         return "STATUS_NOT_SAME_DEVICE";
1410     case 0xC00000D5:
1411         return "STATUS_FILE_RENAMED";
1412     case 0xC00000D6:
1413         return "STATUS_VIRTUAL_CIRCUIT_CLOSED";
1414     case 0xC00000D7:
1415         return "STATUS_NO_SECURITY_ON_OBJECT";
1416     case 0xC00000D8:
1417         return "STATUS_CANT_WAIT";
1418     case 0xC00000D9:
1419         return "STATUS_PIPE_EMPTY";
1420     case 0xC00000DA:
1421         return "STATUS_CANT_ACCESS_DOMAIN_INFO";
1422     case 0xC00000DB:
1423         return "STATUS_CANT_TERMINATE_SELF";
1424     case 0xC00000DC:
1425         return "STATUS_INVALID_SERVER_STATE";
1426     case 0xC00000DD:
1427         return "STATUS_INVALID_DOMAIN_STATE";
1428     case 0xC00000DE:
1429         return "STATUS_INVALID_DOMAIN_ROLE";
1430     case 0xC00000DF:
1431         return "STATUS_NO_SUCH_DOMAIN";
1432     case 0xC00000E0:
1433         return "STATUS_DOMAIN_EXISTS";
1434     case 0xC00000E1:
1435         return "STATUS_DOMAIN_LIMIT_EXCEEDED";
1436     case 0xC00000E2:
1437         return "STATUS_OPLOCK_NOT_GRANTED";
1438     case 0xC00000E3:
1439         return "STATUS_INVALID_OPLOCK_PROTOCOL";
1440     case 0xC00000E4:
1441         return "STATUS_INTERNAL_DB_CORRUPTION";
1442     case 0xC00000E5:
1443         return "STATUS_INTERNAL_ERROR";
1444     case 0xC00000E6:
1445         return "STATUS_GENERIC_NOT_MAPPED";
1446     case 0xC00000E7:
1447         return "STATUS_BAD_DESCRIPTOR_FORMAT";
1448     case 0xC00000E8:
1449         return "STATUS_INVALID_USER_BUFFER";
1450     case 0xC00000E9:
1451         return "STATUS_UNEXPECTED_IO_ERROR";
1452     case 0xC00000EA:
1453         return "STATUS_UNEXPECTED_MM_CREATE_ERR";
1454     case 0xC00000EB:
1455         return "STATUS_UNEXPECTED_MM_MAP_ERROR";
1456     case 0xC00000EC:
1457         return "STATUS_UNEXPECTED_MM_EXTEND_ERR";
1458     case 0xC00000ED:
1459         return "STATUS_NOT_LOGON_PROCESS";
1460     case 0xC00000EE:
1461         return "STATUS_LOGON_SESSION_EXISTS";
1462     case 0xC00000EF:
1463         return "STATUS_INVALID_PARAMETER_1";
1464     case 0xC00000F0:
1465         return "STATUS_INVALID_PARAMETER_2";
1466     case 0xC00000F1:
1467         return "STATUS_INVALID_PARAMETER_3";
1468     case 0xC00000F2:
1469         return "STATUS_INVALID_PARAMETER_4";
1470     case 0xC00000F3:
1471         return "STATUS_INVALID_PARAMETER_5";
1472     case 0xC00000F4:
1473         return "STATUS_INVALID_PARAMETER_6";
1474     case 0xC00000F5:
1475         return "STATUS_INVALID_PARAMETER_7";
1476     case 0xC00000F6:
1477         return "STATUS_INVALID_PARAMETER_8";
1478     case 0xC00000F7:
1479         return "STATUS_INVALID_PARAMETER_9";
1480     case 0xC00000F8:
1481         return "STATUS_INVALID_PARAMETER_10";
1482     case 0xC00000F9:
1483         return "STATUS_INVALID_PARAMETER_11";
1484     case 0xC00000FA:
1485         return "STATUS_INVALID_PARAMETER_12";
1486     case 0xC00000FB:
1487         return "STATUS_REDIRECTOR_NOT_STARTED";
1488     case 0xC00000FC:
1489         return "STATUS_REDIRECTOR_STARTED";
1490     case 0xC00000FD:
1491         return "STATUS_STACK_OVERFLOW";
1492     case 0xC00000FE:
1493         return "STATUS_NO_SUCH_PACKAGE";
1494     case 0xC00000FF:
1495         return "STATUS_BAD_FUNCTION_TABLE";
1496     case 0xC0000100:
1497         return "STATUS_VARIABLE_NOT_FOUND";
1498     case 0xC0000101:
1499         return "STATUS_DIRECTORY_NOT_EMPTY";
1500     case 0xC0000102:
1501         return "STATUS_FILE_CORRUPT_ERROR";
1502     case 0xC0000103:
1503         return "STATUS_NOT_A_DIRECTORY";
1504     case 0xC0000104:
1505         return "STATUS_BAD_LOGON_SESSION_STATE";
1506     case 0xC0000105:
1507         return "STATUS_LOGON_SESSION_COLLISION";
1508     case 0xC0000106:
1509         return "STATUS_NAME_TOO_LONG";
1510     case 0xC0000107:
1511         return "STATUS_FILES_OPEN";
1512     case 0xC0000108:
1513         return "STATUS_CONNECTION_IN_USE";
1514     case 0xC0000109:
1515         return "STATUS_MESSAGE_NOT_FOUND";
1516     case 0xC000010A:
1517         return "STATUS_PROCESS_IS_TERMINATING";
1518     case 0xC000010B:
1519         return "STATUS_INVALID_LOGON_TYPE";
1520     case 0xC000010C:
1521         return "STATUS_NO_GUID_TRANSLATION";
1522     case 0xC000010D:
1523         return "STATUS_CANNOT_IMPERSONATE";
1524     case 0xC000010E:
1525         return "STATUS_IMAGE_ALREADY_LOADED";
1526     case 0xC000010F:
1527         return "STATUS_ABIOS_NOT_PRESENT";
1528     case 0xC0000110:
1529         return "STATUS_ABIOS_LID_NOT_EXIST";
1530     case 0xC0000111:
1531         return "STATUS_ABIOS_LID_ALREADY_OWNED";
1532     case 0xC0000112:
1533         return "STATUS_ABIOS_NOT_LID_OWNER";
1534     case 0xC0000113:
1535         return "STATUS_ABIOS_INVALID_COMMAND";
1536     case 0xC0000114:
1537         return "STATUS_ABIOS_INVALID_LID";
1538     case 0xC0000115:
1539         return "STATUS_ABIOS_SELECTOR_NOT_AVAILABLE";
1540     case 0xC0000116:
1541         return "STATUS_ABIOS_INVALID_SELECTOR";
1542     case 0xC0000117:
1543         return "STATUS_NO_LDT";
1544     case 0xC0000118:
1545         return "STATUS_INVALID_LDT_SIZE";
1546     case 0xC0000119:
1547         return "STATUS_INVALID_LDT_OFFSET";
1548     case 0xC000011A:
1549         return "STATUS_INVALID_LDT_DESCRIPTOR";
1550     case 0xC000011B:
1551         return "STATUS_INVALID_IMAGE_NE_FORMAT";
1552     case 0xC000011C:
1553         return "STATUS_RXACT_INVALID_STATE";
1554     case 0xC000011D:
1555         return "STATUS_RXACT_COMMIT_FAILURE";
1556     case 0xC000011E:
1557         return "STATUS_MAPPED_FILE_SIZE_ZERO";
1558     case 0xC000011F:
1559         return "STATUS_TOO_MANY_OPENED_FILES";
1560     case 0xC0000120:
1561         return "STATUS_CANCELLED";
1562     case 0xC0000121:
1563         return "STATUS_CANNOT_DELETE";
1564     case 0xC0000122:
1565         return "STATUS_INVALID_COMPUTER_NAME";
1566     case 0xC0000123:
1567         return "STATUS_FILE_DELETED";
1568     case 0xC0000124:
1569         return "STATUS_SPECIAL_ACCOUNT";
1570     case 0xC0000125:
1571         return "STATUS_SPECIAL_GROUP";
1572     case 0xC0000126:
1573         return "STATUS_SPECIAL_USER";
1574     case 0xC0000127:
1575         return "STATUS_MEMBERS_PRIMARY_GROUP";
1576     case 0xC0000128:
1577         return "STATUS_FILE_CLOSED";
1578     case 0xC0000129:
1579         return "STATUS_TOO_MANY_THREADS";
1580     case 0xC000012A:
1581         return "STATUS_THREAD_NOT_IN_PROCESS";
1582     case 0xC000012B:
1583         return "STATUS_TOKEN_ALREADY_IN_USE";
1584     case 0xC000012C:
1585         return "STATUS_PAGEFILE_QUOTA_EXCEEDED";
1586     case 0xC000012D:
1587         return "STATUS_COMMITMENT_LIMIT";
1588     case 0xC000012E:
1589         return "STATUS_INVALID_IMAGE_LE_FORMAT";
1590     case 0xC000012F:
1591         return "STATUS_INVALID_IMAGE_NOT_MZ";
1592     case 0xC0000130:
1593         return "STATUS_INVALID_IMAGE_PROTECT";
1594     case 0xC0000131:
1595         return "STATUS_INVALID_IMAGE_WIN_16";
1596     case 0xC0000132:
1597         return "STATUS_LOGON_SERVER_CONFLICT";
1598     case 0xC0000133:
1599         return "STATUS_TIME_DIFFERENCE_AT_DC";
1600     case 0xC0000134:
1601         return "STATUS_SYNCHRONIZATION_REQUIRED";
1602     case 0xC0000135:
1603         return "STATUS_DLL_NOT_FOUND";
1604     case 0xC0000136:
1605         return "STATUS_OPEN_FAILED";
1606     case 0xC0000137:
1607         return "STATUS_IO_PRIVILEGE_FAILED";
1608     case 0xC0000138:
1609         return "STATUS_ORDINAL_NOT_FOUND";
1610     case 0xC0000139:
1611         return "STATUS_ENTRYPOINT_NOT_FOUND";
1612     case 0xC000013A:
1613         return "STATUS_CONTROL_C_EXIT";
1614     case 0xC000013B:
1615         return "STATUS_LOCAL_DISCONNECT";
1616     case 0xC000013C:
1617         return "STATUS_REMOTE_DISCONNECT";
1618     case 0xC000013D:
1619         return "STATUS_REMOTE_RESOURCES";
1620     case 0xC000013E:
1621         return "STATUS_LINK_FAILED";
1622     case 0xC000013F:
1623         return "STATUS_LINK_TIMEOUT";
1624     case 0xC0000140:
1625         return "STATUS_INVALID_CONNECTION";
1626     case 0xC0000141:
1627         return "STATUS_INVALID_ADDRESS";
1628     case 0xC0000142:
1629         return "STATUS_DLL_INIT_FAILED";
1630     case 0xC0000143:
1631         return "STATUS_MISSING_SYSTEMFILE";
1632     case 0xC0000144:
1633         return "STATUS_UNHANDLED_EXCEPTION";
1634     case 0xC0000145:
1635         return "STATUS_APP_INIT_FAILURE";
1636     case 0xC0000146:
1637         return "STATUS_PAGEFILE_CREATE_FAILED";
1638     case 0xC0000147:
1639         return "STATUS_NO_PAGEFILE";
1640     case 0xC0000148:
1641         return "STATUS_INVALID_LEVEL";
1642     case 0xC0000149:
1643         return "STATUS_WRONG_PASSWORD_CORE";
1644     case 0xC000014A:
1645         return "STATUS_ILLEGAL_FLOAT_CONTEXT";
1646     case 0xC000014B:
1647         return "STATUS_PIPE_BROKEN";
1648     case 0xC000014C:
1649         return "STATUS_REGISTRY_CORRUPT";
1650     case 0xC000014D:
1651         return "STATUS_REGISTRY_IO_FAILED";
1652     case 0xC000014E:
1653         return "STATUS_NO_EVENT_PAIR";
1654     case 0xC000014F:
1655         return "STATUS_UNRECOGNIZED_VOLUME";
1656     case 0xC0000150:
1657         return "STATUS_SERIAL_NO_DEVICE_INITED";
1658     case 0xC0000151:
1659         return "STATUS_NO_SUCH_ALIAS";
1660     case 0xC0000152:
1661         return "STATUS_MEMBER_NOT_IN_ALIAS";
1662     case 0xC0000153:
1663         return "STATUS_MEMBER_IN_ALIAS";
1664     case 0xC0000154:
1665         return "STATUS_ALIAS_EXISTS";
1666     case 0xC0000155:
1667         return "STATUS_LOGON_NOT_GRANTED";
1668     case 0xC0000156:
1669         return "STATUS_TOO_MANY_SECRETS";
1670     case 0xC0000157:
1671         return "STATUS_SECRET_TOO_LONG";
1672     case 0xC0000158:
1673         return "STATUS_INTERNAL_DB_ERROR";
1674     case 0xC0000159:
1675         return "STATUS_FULLSCREEN_MODE";
1676     case 0xC000015A:
1677         return "STATUS_TOO_MANY_CONTEXT_IDS";
1678     case 0xC000015B:
1679         return "STATUS_LOGON_TYPE_NOT_GRANTED";
1680     case 0xC000015C:
1681         return "STATUS_NOT_REGISTRY_FILE";
1682     case 0xC000015D:
1683         return "STATUS_NT_CROSS_ENCRYPTION_REQUIRED";
1684     case 0xC000015E:
1685         return "STATUS_DOMAIN_CTRLR_CONFIG_ERROR";
1686     case 0xC000015F:
1687         return "STATUS_FT_MISSING_MEMBER";
1688     case 0xC0000160:
1689         return "STATUS_ILL_FORMED_SERVICE_ENTRY";
1690     case 0xC0000161:
1691         return "STATUS_ILLEGAL_CHARACTER";
1692     case 0xC0000162:
1693         return "STATUS_UNMAPPABLE_CHARACTER";
1694     case 0xC0000163:
1695         return "STATUS_UNDEFINED_CHARACTER";
1696     case 0xC0000164:
1697         return "STATUS_FLOPPY_VOLUME";
1698     case 0xC0000165:
1699         return "STATUS_FLOPPY_ID_MARK_NOT_FOUND";
1700     case 0xC0000166:
1701         return "STATUS_FLOPPY_WRONG_CYLINDER";
1702     case 0xC0000167:
1703         return "STATUS_FLOPPY_UNKNOWN_ERROR";
1704     case 0xC0000168:
1705         return "STATUS_FLOPPY_BAD_REGISTERS";
1706     case 0xC0000169:
1707         return "STATUS_DISK_RECALIBRATE_FAILED";
1708     case 0xC000016A:
1709         return "STATUS_DISK_OPERATION_FAILED";
1710     case 0xC000016B:
1711         return "STATUS_DISK_RESET_FAILED";
1712     case 0xC000016C:
1713         return "STATUS_SHARED_IRQ_BUSY";
1714     case 0xC000016D:
1715         return "STATUS_FT_ORPHANING";
1716     case 0xC000016E:
1717         return "STATUS_BIOS_FAILED_TO_CONNECT_INTERRUPT";
1718     case 0xC0000172:
1719         return "STATUS_PARTITION_FAILURE";
1720     case 0xC0000173:
1721         return "STATUS_INVALID_BLOCK_LENGTH";
1722     case 0xC0000174:
1723         return "STATUS_DEVICE_NOT_PARTITIONED";
1724     case 0xC0000175:
1725         return "STATUS_UNABLE_TO_LOCK_MEDIA";
1726     case 0xC0000176:
1727         return "STATUS_UNABLE_TO_UNLOAD_MEDIA";
1728     case 0xC0000177:
1729         return "STATUS_EOM_OVERFLOW";
1730     case 0xC0000178:
1731         return "STATUS_NO_MEDIA";
1732     case 0xC000017A:
1733         return "STATUS_NO_SUCH_MEMBER";
1734     case 0xC000017B:
1735         return "STATUS_INVALID_MEMBER";
1736     case 0xC000017C:
1737         return "STATUS_KEY_DELETED";
1738     case 0xC000017D:
1739         return "STATUS_NO_LOG_SPACE";
1740     case 0xC000017E:
1741         return "STATUS_TOO_MANY_SIDS";
1742     case 0xC000017F:
1743         return "STATUS_LM_CROSS_ENCRYPTION_REQUIRED";
1744     case 0xC0000180:
1745         return "STATUS_KEY_HAS_CHILDREN";
1746     case 0xC0000181:
1747         return "STATUS_CHILD_MUST_BE_VOLATILE";
1748     case 0xC0000182:
1749         return "STATUS_DEVICE_CONFIGURATION_ERROR";
1750     case 0xC0000183:
1751         return "STATUS_DRIVER_INTERNAL_ERROR";
1752     case 0xC0000184:
1753         return "STATUS_INVALID_DEVICE_STATE";
1754     case 0xC0000185:
1755         return "STATUS_IO_DEVICE_ERROR";
1756     case 0xC0000186:
1757         return "STATUS_DEVICE_PROTOCOL_ERROR";
1758     case 0xC0000187:
1759         return "STATUS_BACKUP_CONTROLLER";
1760     case 0xC0000188:
1761         return "STATUS_LOG_FILE_FULL";
1762     case 0xC0000189:
1763         return "STATUS_TOO_LATE";
1764     case 0xC000018A:
1765         return "STATUS_NO_TRUST_LSA_SECRET";
1766     case 0xC000018B:
1767         return "STATUS_NO_TRUST_SAM_ACCOUNT";
1768     case 0xC000018C:
1769         return "STATUS_TRUSTED_DOMAIN_FAILURE";
1770     case 0xC000018D:
1771         return "STATUS_TRUSTED_RELATIONSHIP_FAILURE";
1772     case 0xC000018E:
1773         return "STATUS_EVENTLOG_FILE_CORRUPT";
1774     case 0xC000018F:
1775         return "STATUS_EVENTLOG_CANT_START";
1776     case 0xC0000190:
1777         return "STATUS_TRUST_FAILURE";
1778     case 0xC0000191:
1779         return "STATUS_MUTANT_LIMIT_EXCEEDED";
1780     case 0xC0000192:
1781         return "STATUS_NETLOGON_NOT_STARTED";
1782     case 0xC0000193:
1783         return "STATUS_ACCOUNT_EXPIRED";
1784     case 0xC0000194:
1785         return "STATUS_POSSIBLE_DEADLOCK";
1786     case 0xC0000195:
1787         return "STATUS_NETWORK_CREDENTIAL_CONFLICT";
1788     case 0xC0000196:
1789         return "STATUS_REMOTE_SESSION_LIMIT";
1790     case 0xC0000197:
1791         return "STATUS_EVENTLOG_FILE_CHANGED";
1792     case 0xC0000198:
1793         return "STATUS_NOLOGON_INTERDOMAIN_TRUST_ACCOUNT";
1794     case 0xC0000199:
1795         return "STATUS_NOLOGON_WORKSTATION_TRUST_ACCOUNT";
1796     case 0xC000019A:
1797         return "STATUS_NOLOGON_SERVER_TRUST_ACCOUNT";
1798     case 0xC000019B:
1799         return "STATUS_DOMAIN_TRUST_INCONSISTENT";
1800     case 0xC000019C:
1801         return "STATUS_FS_DRIVER_REQUIRED";
1802     case 0xC0000202:
1803         return "STATUS_NO_USER_SESSION_KEY";
1804     case 0xC0000203:
1805         return "STATUS_USER_SESSION_DELETED";
1806     case 0xC0000204:
1807         return "STATUS_RESOURCE_LANG_NOT_FOUND";
1808     case 0xC0000205:
1809         return "STATUS_INSUFF_SERVER_RESOURCES";
1810     case 0xC0000206:
1811         return "STATUS_INVALID_BUFFER_SIZE";
1812     case 0xC0000207:
1813         return "STATUS_INVALID_ADDRESS_COMPONENT";
1814     case 0xC0000208:
1815         return "STATUS_INVALID_ADDRESS_WILDCARD";
1816     case 0xC0000209:
1817         return "STATUS_TOO_MANY_ADDRESSES";
1818     case 0xC000020A:
1819         return "STATUS_ADDRESS_ALREADY_EXISTS";
1820     case 0xC000020B:
1821         return "STATUS_ADDRESS_CLOSED";
1822     case 0xC000020C:
1823         return "STATUS_CONNECTION_DISCONNECTED";
1824     case 0xC000020D:
1825         return "STATUS_CONNECTION_RESET";
1826     case 0xC000020E:
1827         return "STATUS_TOO_MANY_NODES";
1828     case 0xC000020F:
1829         return "STATUS_TRANSACTION_ABORTED";
1830     case 0xC0000210:
1831         return "STATUS_TRANSACTION_TIMED_OUT";
1832     case 0xC0000211:
1833         return "STATUS_TRANSACTION_NO_RELEASE";
1834     case 0xC0000212:
1835         return "STATUS_TRANSACTION_NO_MATCH";
1836     case 0xC0000213:
1837         return "STATUS_TRANSACTION_RESPONDED";
1838     case 0xC0000214:
1839         return "STATUS_TRANSACTION_INVALID_ID";
1840     case 0xC0000215:
1841         return "STATUS_TRANSACTION_INVALID_TYPE";
1842     case 0xC0000216:
1843         return "STATUS_NOT_SERVER_SESSION";
1844     case 0xC0000217:
1845         return "STATUS_NOT_CLIENT_SESSION";
1846     case 0xC0000218:
1847         return "STATUS_CANNOT_LOAD_REGISTRY_FILE";
1848     case 0xC0000219:
1849         return "STATUS_DEBUG_ATTACH_FAILED";
1850     case 0xC000021A:
1851         return "STATUS_SYSTEM_PROCESS_TERMINATED";
1852     case 0xC000021B:
1853         return "STATUS_DATA_NOT_ACCEPTED";
1854     case 0xC000021C:
1855         return "STATUS_NO_BROWSER_SERVERS_FOUND";
1856     case 0xC000021D:
1857         return "STATUS_VDM_HARD_ERROR";
1858     case 0xC000021E:
1859         return "STATUS_DRIVER_CANCEL_TIMEOUT";
1860     case 0xC000021F:
1861         return "STATUS_REPLY_MESSAGE_MISMATCH";
1862     case 0xC0000220:
1863         return "STATUS_MAPPED_ALIGNMENT";
1864     case 0xC0000221:
1865         return "STATUS_IMAGE_CHECKSUM_MISMATCH";
1866     case 0xC0000222:
1867         return "STATUS_LOST_WRITEBEHIND_DATA";
1868     case 0xC0000223:
1869         return "STATUS_CLIENT_SERVER_PARAMETERS_INVALID";
1870     case 0xC0000224:
1871         return "STATUS_PASSWORD_MUST_CHANGE";
1872     case 0xC0000225:
1873         return "STATUS_NOT_FOUND";
1874     case 0xC0000226:
1875         return "STATUS_NOT_TINY_STREAM";
1876     case 0xC0000227:
1877         return "STATUS_RECOVERY_FAILURE";
1878     case 0xC0000228:
1879         return "STATUS_STACK_OVERFLOW_READ";
1880     case 0xC0000229:
1881         return "STATUS_FAIL_CHECK";
1882     case 0xC000022A:
1883         return "STATUS_DUPLICATE_OBJECTID";
1884     case 0xC000022B:
1885         return "STATUS_OBJECTID_EXISTS";
1886     case 0xC000022C:
1887         return "STATUS_CONVERT_TO_LARGE";
1888     case 0xC000022D:
1889         return "STATUS_RETRY";
1890     case 0xC000022E:
1891         return "STATUS_FOUND_OUT_OF_SCOPE";
1892     case 0xC000022F:
1893         return "STATUS_ALLOCATE_BUCKET";
1894     case 0xC0000230:
1895         return "STATUS_PROPSET_NOT_FOUND";
1896     case 0xC0000231:
1897         return "STATUS_MARSHALL_OVERFLOW";
1898     case 0xC0000232:
1899         return "STATUS_INVALID_VARIANT";
1900     case 0xC0000233:
1901         return "STATUS_DOMAIN_CONTROLLER_NOT_FOUND";
1902     case 0xC0000234:
1903         return "STATUS_ACCOUNT_LOCKED_OUT";
1904     case 0xC0000235:
1905         return "STATUS_HANDLE_NOT_CLOSABLE";
1906     case 0xC0000236:
1907         return "STATUS_CONNECTION_REFUSED";
1908     case 0xC0000237:
1909         return "STATUS_GRACEFUL_DISCONNECT";
1910     case 0xC0000238:
1911         return "STATUS_ADDRESS_ALREADY_ASSOCIATED";
1912     case 0xC0000239:
1913         return "STATUS_ADDRESS_NOT_ASSOCIATED";
1914     case 0xC000023A:
1915         return "STATUS_CONNECTION_INVALID";
1916     case 0xC000023B:
1917         return "STATUS_CONNECTION_ACTIVE";
1918     case 0xC000023C:
1919         return "STATUS_NETWORK_UNREACHABLE";
1920     case 0xC000023D:
1921         return "STATUS_HOST_UNREACHABLE";
1922     case 0xC000023E:
1923         return "STATUS_PROTOCOL_UNREACHABLE";
1924     case 0xC000023F:
1925         return "STATUS_PORT_UNREACHABLE";
1926     case 0xC0000240:
1927         return "STATUS_REQUEST_ABORTED";
1928     case 0xC0000241:
1929         return "STATUS_CONNECTION_ABORTED";
1930     case 0xC0000242:
1931         return "STATUS_BAD_COMPRESSION_BUFFER";
1932     case 0xC0000243:
1933         return "STATUS_USER_MAPPED_FILE";
1934     case 0xC0000244:
1935         return "STATUS_AUDIT_FAILED";
1936     case 0xC0000245:
1937         return "STATUS_TIMER_RESOLUTION_NOT_SET";
1938     case 0xC0000246:
1939         return "STATUS_CONNECTION_COUNT_LIMIT";
1940     case 0xC0000247:
1941         return "STATUS_LOGIN_TIME_RESTRICTION";
1942     case 0xC0000248:
1943         return "STATUS_LOGIN_WKSTA_RESTRICTION";
1944     case 0xC0000249:
1945         return "STATUS_IMAGE_MP_UP_MISMATCH";
1946     case 0xC0000250:
1947         return "STATUS_INSUFFICIENT_LOGON_INFO";
1948     case 0xC0000251:
1949         return "STATUS_BAD_DLL_ENTRYPOINT";
1950     case 0xC0000252:
1951         return "STATUS_BAD_SERVICE_ENTRYPOINT";
1952     case 0xC0000253:
1953         return "STATUS_LPC_REPLY_LOST";
1954     case 0xC0000254:
1955         return "STATUS_IP_ADDRESS_CONFLICT1";
1956     case 0xC0000255:
1957         return "STATUS_IP_ADDRESS_CONFLICT2";
1958     case 0xC0000256:
1959         return "STATUS_REGISTRY_QUOTA_LIMIT";
1960     case 0xC0000257:
1961         return "STATUS_PATH_NOT_COVERED";
1962     case 0xC0000258:
1963         return "STATUS_NO_CALLBACK_ACTIVE";
1964     case 0xC0000259:
1965         return "STATUS_LICENSE_QUOTA_EXCEEDED";
1966     case 0xC000025A:
1967         return "STATUS_PWD_TOO_SHORT";
1968     case 0xC000025B:
1969         return "STATUS_PWD_TOO_RECENT";
1970     case 0xC000025C:
1971         return "STATUS_PWD_HISTORY_CONFLICT";
1972     case 0xC000025E:
1973         return "STATUS_PLUGPLAY_NO_DEVICE";
1974     case 0xC000025F:
1975         return "STATUS_UNSUPPORTED_COMPRESSION";
1976     case 0xC0000260:
1977         return "STATUS_INVALID_HW_PROFILE";
1978     case 0xC0000261:
1979         return "STATUS_INVALID_PLUGPLAY_DEVICE_PATH";
1980     case 0xC0000262:
1981         return "STATUS_DRIVER_ORDINAL_NOT_FOUND";
1982     case 0xC0000263:
1983         return "STATUS_DRIVER_ENTRYPOINT_NOT_FOUND";
1984     case 0xC0000264:
1985         return "STATUS_RESOURCE_NOT_OWNED";
1986     case 0xC0000265:
1987         return "STATUS_TOO_MANY_LINKS";
1988     case 0xC0000266:
1989         return "STATUS_QUOTA_LIST_INCONSISTENT";
1990     case 0xC0000267:
1991         return "STATUS_FILE_IS_OFFLINE";
1992     case 0xC0000268:
1993         return "STATUS_EVALUATION_EXPIRATION";
1994     case 0xC0000269:
1995         return "STATUS_ILLEGAL_DLL_RELOCATION";
1996     case 0xC000026A:
1997         return "STATUS_LICENSE_VIOLATION";
1998     case 0xC000026B:
1999         return "STATUS_DLL_INIT_FAILED_LOGOFF";
2000     case 0xC000026C:
2001         return "STATUS_DRIVER_UNABLE_TO_LOAD";
2002     case 0xC000026D:
2003         return "STATUS_DFS_UNAVAILABLE";
2004     case 0xC000026E:
2005         return "STATUS_VOLUME_DISMOUNTED";
2006     case 0xC000026F:
2007         return "STATUS_WX86_INTERNAL_ERROR";
2008     case 0xC0000270:
2009         return "STATUS_WX86_FLOAT_STACK_CHECK";
2010     case 0xC0000271:
2011         return "STATUS_VALIDATE_CONTINUE";
2012     case 0xC0000272:
2013         return "STATUS_NO_MATCH";
2014     case 0xC0000273:
2015         return "STATUS_NO_MORE_MATCHES";
2016     case 0xC0000275:
2017         return "STATUS_NOT_A_REPARSE_POINT";
2018     case 0xC0000276:
2019         return "STATUS_IO_REPARSE_TAG_INVALID";
2020     case 0xC0000277:
2021         return "STATUS_IO_REPARSE_TAG_MISMATCH";
2022     case 0xC0000278:
2023         return "STATUS_IO_REPARSE_DATA_INVALID";
2024     case 0xC0000279:
2025         return "STATUS_IO_REPARSE_TAG_NOT_HANDLED";
2026     case 0xC0000280:
2027         return "STATUS_REPARSE_POINT_NOT_RESOLVED";
2028     case 0xC0000281:
2029         return "STATUS_DIRECTORY_IS_A_REPARSE_POINT";
2030     case 0xC0000282:
2031         return "STATUS_RANGE_LIST_CONFLICT";
2032     case 0xC0000283:
2033         return "STATUS_SOURCE_ELEMENT_EMPTY";
2034     case 0xC0000284:
2035         return "STATUS_DESTINATION_ELEMENT_FULL";
2036     case 0xC0000285:
2037         return "STATUS_ILLEGAL_ELEMENT_ADDRESS";
2038     case 0xC0000286:
2039         return "STATUS_MAGAZINE_NOT_PRESENT";
2040     case 0xC0000287:
2041         return "STATUS_REINITIALIZATION_NEEDED";
2042     case 0x80000288:
2043         return "STATUS_DEVICE_REQUIRES_CLEANING";
2044     case 0x80000289:
2045         return "STATUS_DEVICE_DOOR_OPEN";
2046     case 0xC000028A:
2047         return "STATUS_ENCRYPTION_FAILED";
2048     case 0xC000028B:
2049         return "STATUS_DECRYPTION_FAILED";
2050     case 0xC000028C:
2051         return "STATUS_RANGE_NOT_FOUND";
2052     case 0xC000028D:
2053         return "STATUS_NO_RECOVERY_POLICY";
2054     case 0xC000028E:
2055         return "STATUS_NO_EFS";
2056     case 0xC000028F:
2057         return "STATUS_WRONG_EFS";
2058     case 0xC0000290:
2059         return "STATUS_NO_USER_KEYS";
2060     case 0xC0000291:
2061         return "STATUS_FILE_NOT_ENCRYPTED";
2062     case 0xC0000292:
2063         return "STATUS_NOT_EXPORT_FORMAT";
2064     case 0xC0000293:
2065         return "STATUS_FILE_ENCRYPTED";
2066     case 0x40000294:
2067         return "STATUS_WAKE_SYSTEM";
2068     case 0xC0000295:
2069         return "STATUS_WMI_GUID_NOT_FOUND";
2070     case 0xC0000296:
2071         return "STATUS_WMI_INSTANCE_NOT_FOUND";
2072     case 0xC0000297:
2073         return "STATUS_WMI_ITEMID_NOT_FOUND";
2074     case 0xC0000298:
2075         return "STATUS_WMI_TRY_AGAIN";
2076     case 0xC0000299:
2077         return "STATUS_SHARED_POLICY";
2078     case 0xC000029A:
2079         return "STATUS_POLICY_OBJECT_NOT_FOUND";
2080     case 0xC000029B:
2081         return "STATUS_POLICY_ONLY_IN_DS";
2082     case 0xC000029C:
2083         return "STATUS_VOLUME_NOT_UPGRADED";
2084     case 0xC000029D:
2085         return "STATUS_REMOTE_STORAGE_NOT_ACTIVE";
2086     case 0xC000029E:
2087         return "STATUS_REMOTE_STORAGE_MEDIA_ERROR";
2088     case 0xC000029F:
2089         return "STATUS_NO_TRACKING_SERVICE";
2090     case 0xC00002A0:
2091         return "STATUS_SERVER_SID_MISMATCH";
2092     case 0xC00002A1:
2093         return "STATUS_DS_NO_ATTRIBUTE_OR_VALUE";
2094     case 0xC00002A2:
2095         return "STATUS_DS_INVALID_ATTRIBUTE_SYNTAX";
2096     case 0xC00002A3:
2097         return "STATUS_DS_ATTRIBUTE_TYPE_UNDEFINED";
2098     case 0xC00002A4:
2099         return "STATUS_DS_ATTRIBUTE_OR_VALUE_EXISTS";
2100     case 0xC00002A5:
2101         return "STATUS_DS_BUSY";
2102     case 0xC00002A6:
2103         return "STATUS_DS_UNAVAILABLE";
2104     case 0xC00002A7:
2105         return "STATUS_DS_NO_RIDS_ALLOCATED";
2106     case 0xC00002A8:
2107         return "STATUS_DS_NO_MORE_RIDS";
2108     case 0xC00002A9:
2109         return "STATUS_DS_INCORRECT_ROLE_OWNER";
2110     case 0xC00002AA:
2111         return "STATUS_DS_RIDMGR_INIT_ERROR";
2112     case 0xC00002AB:
2113         return "STATUS_DS_OBJ_CLASS_VIOLATION";
2114     case 0xC00002AC:
2115         return "STATUS_DS_CANT_ON_NON_LEAF";
2116     case 0xC00002AD:
2117         return "STATUS_DS_CANT_ON_RDN";
2118     case 0xC00002AE:
2119         return "STATUS_DS_CANT_MOD_OBJ_CLASS";
2120     case 0xC00002AF:
2121         return "STATUS_DS_CROSS_DOM_MOVE_FAILED";
2122     case 0xC00002B0:
2123         return "STATUS_DS_GC_NOT_AVAILABLE";
2124     case 0xC00002B1:
2125         return "STATUS_DIRECTORY_SERVICE_REQUIRED";
2126     case 0xC00002B2:
2127         return "STATUS_REPARSE_ATTRIBUTE_CONFLICT";
2128     case 0xC00002B3:
2129         return "STATUS_CANT_ENABLE_DENY_ONLY";
2130     case 0xC00002B4:
2131         return "STATUS_FLOAT_MULTIPLE_FAULTS";
2132     case 0xC00002B5:
2133         return "STATUS_FLOAT_MULTIPLE_TRAPS";
2134     case 0xC00002B6:
2135         return "STATUS_DEVICE_REMOVED";
2136     case 0xC00002B7:
2137         return "STATUS_JOURNAL_DELETE_IN_PROGRESS";
2138     case 0xC00002B8:
2139         return "STATUS_JOURNAL_NOT_ACTIVE";
2140     case 0xC00002B9:
2141         return "STATUS_NOINTERFACE";
2142     case 0xC00002C1:
2143         return "STATUS_DS_ADMIN_LIMIT_EXCEEDED";
2144     case 0xC00002C2:
2145         return "STATUS_DRIVER_FAILED_SLEEP";
2146     case 0xC00002C3:
2147         return "STATUS_MUTUAL_AUTHENTICATION_FAILED";
2148     case 0xC00002C4:
2149         return "STATUS_CORRUPT_SYSTEM_FILE";
2150     case 0xC00002C5:
2151         return "STATUS_DATATYPE_MISALIGNMENT_ERROR";
2152     case 0xC00002C6:
2153         return "STATUS_WMI_READ_ONLY";
2154     case 0xC00002C7:
2155         return "STATUS_WMI_SET_FAILURE";
2156     case 0xC00002C8:
2157         return "STATUS_COMMITMENT_MINIMUM";
2158     case 0xC00002C9:
2159         return "STATUS_REG_NAT_CONSUMPTION";
2160     case 0xC00002CA:
2161         return "STATUS_TRANSPORT_FULL";
2162     case 0xC00002CB:
2163         return "STATUS_DS_SAM_INIT_FAILURE";
2164     case 0xC00002CC:
2165         return "STATUS_ONLY_IF_CONNECTED";
2166     case 0xC00002CD:
2167         return "STATUS_DS_SENSITIVE_GROUP_VIOLATION";
2168     case 0xC00002CE:
2169         return "STATUS_PNP_RESTART_ENUMERATION";
2170     case 0xC00002CF:
2171         return "STATUS_JOURNAL_ENTRY_DELETED";
2172     case 0xC00002D0:
2173         return "STATUS_DS_CANT_MOD_PRIMARYGROUPID";
2174     case 0xC00002D1:
2175         return "STATUS_SYSTEM_IMAGE_BAD_SIGNATURE";
2176     case 0xC00002D2:
2177         return "STATUS_PNP_REBOOT_REQUIRED";
2178     case 0xC00002D3:
2179         return "STATUS_POWER_STATE_INVALID";
2180     case 0xC00002D4:
2181         return "STATUS_DS_INVALID_GROUP_TYPE";
2182     case 0xC00002D5:
2183         return "STATUS_DS_NO_NEST_GLOBALGROUP_IN_MIXEDDOMAIN";
2184     case 0xC00002D6:
2185         return "STATUS_DS_NO_NEST_LOCALGROUP_IN_MIXEDDOMAIN";
2186     case 0xC00002D7:
2187         return "STATUS_DS_GLOBAL_CANT_HAVE_LOCAL_MEMBER";
2188     case 0xC00002D8:
2189         return "STATUS_DS_GLOBAL_CANT_HAVE_UNIVERSAL_MEMBER";
2190     case 0xC00002D9:
2191         return "STATUS_DS_UNIVERSAL_CANT_HAVE_LOCAL_MEMBER";
2192     case 0xC00002DA:
2193         return "STATUS_DS_GLOBAL_CANT_HAVE_CROSSDOMAIN_MEMBER";
2194     case 0xC00002DB:
2195         return "STATUS_DS_LOCAL_CANT_HAVE_CROSSDOMAIN_LOCAL_MEMBER";
2196     case 0xC00002DC:
2197         return "STATUS_DS_HAVE_PRIMARY_MEMBERS";
2198     case 0xC00002DD:
2199         return "STATUS_WMI_NOT_SUPPORTED";
2200     case 0xC00002DE:
2201         return "STATUS_INSUFFICIENT_POWER";
2202     case 0xC00002DF:
2203         return "STATUS_SAM_NEED_BOOTKEY_PASSWORD";
2204     case 0xC00002E0:
2205         return "STATUS_SAM_NEED_BOOTKEY_FLOPPY";
2206     case 0xC00002E1:
2207         return "STATUS_DS_CANT_START";
2208     case 0xC00002E2:
2209         return "STATUS_DS_INIT_FAILURE";
2210     case 0xC00002E3:
2211         return "STATUS_SAM_INIT_FAILURE";
2212     case 0xC00002E4:
2213         return "STATUS_DS_GC_REQUIRED";
2214     case 0xC00002E5:
2215         return "STATUS_DS_LOCAL_MEMBER_OF_LOCAL_ONLY";
2216     case 0xC00002E6:
2217         return "STATUS_DS_NO_FPO_IN_UNIVERSAL_GROUPS";
2218     case 0xC00002E7:
2219         return "STATUS_DS_MACHINE_ACCOUNT_QUOTA_EXCEEDED";
2220     case 0xC00002E8:
2221         return "STATUS_MULTIPLE_FAULT_VIOLATION";
2222     case 0xC0000300:
2223         return "STATUS_NOT_SUPPORTED_ON_SBS";
2224     case 0xC0009898:
2225         return "STATUS_WOW_ASSERTION";
2226     case 0xC0010001:
2227         return "DBG_NO_STATE_CHANGE";
2228     case 0xC0010002:
2229         return "DBG_APP_NOT_IDLE";
2230     case 0xC0020001:
2231         return "RPC_NT_INVALID_STRING_BINDING";
2232     case 0xC0020002:
2233         return "RPC_NT_WRONG_KIND_OF_BINDING";
2234     case 0xC0020003:
2235         return "RPC_NT_INVALID_BINDING";
2236     case 0xC0020004:
2237         return "RPC_NT_PROTSEQ_NOT_SUPPORTED";
2238     case 0xC0020005:
2239         return "RPC_NT_INVALID_RPC_PROTSEQ";
2240     case 0xC0020006:
2241         return "RPC_NT_INVALID_STRING_UUID";
2242     case 0xC0020007:
2243         return "RPC_NT_INVALID_ENDPOINT_FORMAT";
2244     case 0xC0020008:
2245         return "RPC_NT_INVALID_NET_ADDR";
2246     case 0xC0020009:
2247         return "RPC_NT_NO_ENDPOINT_FOUND";
2248     case 0xC002000A:
2249         return "RPC_NT_INVALID_TIMEOUT";
2250     case 0xC002000B:
2251         return "RPC_NT_OBJECT_NOT_FOUND";
2252     case 0xC002000C:
2253         return "RPC_NT_ALREADY_REGISTERED";
2254     case 0xC002000D:
2255         return "RPC_NT_TYPE_ALREADY_REGISTERED";
2256     case 0xC002000E:
2257         return "RPC_NT_ALREADY_LISTENING";
2258     case 0xC002000F:
2259         return "RPC_NT_NO_PROTSEQS_REGISTERED";
2260     case 0xC0020010:
2261         return "RPC_NT_NOT_LISTENING";
2262     case 0xC0020011:
2263         return "RPC_NT_UNKNOWN_MGR_TYPE";
2264     case 0xC0020012:
2265         return "RPC_NT_UNKNOWN_IF";
2266     case 0xC0020013:
2267         return "RPC_NT_NO_BINDINGS";
2268     case 0xC0020014:
2269         return "RPC_NT_NO_PROTSEQS";
2270     case 0xC0020015:
2271         return "RPC_NT_CANT_CREATE_ENDPOINT";
2272     case 0xC0020016:
2273         return "RPC_NT_OUT_OF_RESOURCES";
2274     case 0xC0020017:
2275         return "RPC_NT_SERVER_UNAVAILABLE";
2276     case 0xC0020018:
2277         return "RPC_NT_SERVER_TOO_BUSY";
2278     case 0xC0020019:
2279         return "RPC_NT_INVALID_NETWORK_OPTIONS";
2280     case 0xC002001A:
2281         return "RPC_NT_NO_CALL_ACTIVE";
2282     case 0xC002001B:
2283         return "RPC_NT_CALL_FAILED";
2284     case 0xC002001C:
2285         return "RPC_NT_CALL_FAILED_DNE";
2286     case 0xC002001D:
2287         return "RPC_NT_PROTOCOL_ERROR";
2288     case 0xC002001F:
2289         return "RPC_NT_UNSUPPORTED_TRANS_SYN";
2290     case 0xC0020021:
2291         return "RPC_NT_UNSUPPORTED_TYPE";
2292     case 0xC0020022:
2293         return "RPC_NT_INVALID_TAG";
2294     case 0xC0020023:
2295         return "RPC_NT_INVALID_BOUND";
2296     case 0xC0020024:
2297         return "RPC_NT_NO_ENTRY_NAME";
2298     case 0xC0020025:
2299         return "RPC_NT_INVALID_NAME_SYNTAX";
2300     case 0xC0020026:
2301         return "RPC_NT_UNSUPPORTED_NAME_SYNTAX";
2302     case 0xC0020028:
2303         return "RPC_NT_UUID_NO_ADDRESS";
2304     case 0xC0020029:
2305         return "RPC_NT_DUPLICATE_ENDPOINT";
2306     case 0xC002002A:
2307         return "RPC_NT_UNKNOWN_AUTHN_TYPE";
2308     case 0xC002002B:
2309         return "RPC_NT_MAX_CALLS_TOO_SMALL";
2310     case 0xC002002C:
2311         return "RPC_NT_STRING_TOO_LONG";
2312     case 0xC002002D:
2313         return "RPC_NT_PROTSEQ_NOT_FOUND";
2314     case 0xC002002E:
2315         return "RPC_NT_PROCNUM_OUT_OF_RANGE";
2316     case 0xC002002F:
2317         return "RPC_NT_BINDING_HAS_NO_AUTH";
2318     case 0xC0020030:
2319         return "RPC_NT_UNKNOWN_AUTHN_SERVICE";
2320     case 0xC0020031:
2321         return "RPC_NT_UNKNOWN_AUTHN_LEVEL";
2322     case 0xC0020032:
2323         return "RPC_NT_INVALID_AUTH_IDENTITY";
2324     case 0xC0020033:
2325         return "RPC_NT_UNKNOWN_AUTHZ_SERVICE";
2326     case 0xC0020034:
2327         return "EPT_NT_INVALID_ENTRY";
2328     case 0xC0020035:
2329         return "EPT_NT_CANT_PERFORM_OP";
2330     case 0xC0020036:
2331         return "EPT_NT_NOT_REGISTERED";
2332     case 0xC0020037:
2333         return "RPC_NT_NOTHING_TO_EXPORT";
2334     case 0xC0020038:
2335         return "RPC_NT_INCOMPLETE_NAME";
2336     case 0xC0020039:
2337         return "RPC_NT_INVALID_VERS_OPTION";
2338     case 0xC002003A:
2339         return "RPC_NT_NO_MORE_MEMBERS";
2340     case 0xC002003B:
2341         return "RPC_NT_NOT_ALL_OBJS_UNEXPORTED";
2342     case 0xC002003C:
2343         return "RPC_NT_INTERFACE_NOT_FOUND";
2344     case 0xC002003D:
2345         return "RPC_NT_ENTRY_ALREADY_EXISTS";
2346     case 0xC002003E:
2347         return "RPC_NT_ENTRY_NOT_FOUND";
2348     case 0xC002003F:
2349         return "RPC_NT_NAME_SERVICE_UNAVAILABLE";
2350     case 0xC0020040:
2351         return "RPC_NT_INVALID_NAF_ID";
2352     case 0xC0020041:
2353         return "RPC_NT_CANNOT_SUPPORT";
2354     case 0xC0020042:
2355         return "RPC_NT_NO_CONTEXT_AVAILABLE";
2356     case 0xC0020043:
2357         return "RPC_NT_INTERNAL_ERROR";
2358     case 0xC0020044:
2359         return "RPC_NT_ZERO_DIVIDE";
2360     case 0xC0020045:
2361         return "RPC_NT_ADDRESS_ERROR";
2362     case 0xC0020046:
2363         return "RPC_NT_FP_DIV_ZERO";
2364     case 0xC0020047:
2365         return "RPC_NT_FP_UNDERFLOW";
2366     case 0xC0020048:
2367         return "RPC_NT_FP_OVERFLOW";
2368     case 0xC0030001:
2369         return "RPC_NT_NO_MORE_ENTRIES";
2370     case 0xC0030002:
2371         return "RPC_NT_SS_CHAR_TRANS_OPEN_FAIL";
2372     case 0xC0030003:
2373         return "RPC_NT_SS_CHAR_TRANS_SHORT_FILE";
2374     case 0xC0030004:
2375         return "RPC_NT_SS_IN_NULL_CONTEXT";
2376     case 0xC0030005:
2377         return "RPC_NT_SS_CONTEXT_MISMATCH";
2378     case 0xC0030006:
2379         return "RPC_NT_SS_CONTEXT_DAMAGED";
2380     case 0xC0030007:
2381         return "RPC_NT_SS_HANDLES_MISMATCH";
2382     case 0xC0030008:
2383         return "RPC_NT_SS_CANNOT_GET_CALL_HANDLE";
2384     case 0xC0030009:
2385         return "RPC_NT_NULL_REF_POINTER";
2386     case 0xC003000A:
2387         return "RPC_NT_ENUM_VALUE_OUT_OF_RANGE";
2388     case 0xC003000B:
2389         return "RPC_NT_BYTE_COUNT_TOO_SMALL";
2390     case 0xC003000C:
2391         return "RPC_NT_BAD_STUB_DATA";
2392     case 0xC0020049:
2393         return "RPC_NT_CALL_IN_PROGRESS";
2394     case 0xC002004A:
2395         return "RPC_NT_NO_MORE_BINDINGS";
2396     case 0xC002004B:
2397         return "RPC_NT_GROUP_MEMBER_NOT_FOUND";
2398     case 0xC002004C:
2399         return "EPT_NT_CANT_CREATE";
2400     case 0xC002004D:
2401         return "RPC_NT_INVALID_OBJECT";
2402     case 0xC002004F:
2403         return "RPC_NT_NO_INTERFACES";
2404     case 0xC0020050:
2405         return "RPC_NT_CALL_CANCELLED";
2406     case 0xC0020051:
2407         return "RPC_NT_BINDING_INCOMPLETE";
2408     case 0xC0020052:
2409         return "RPC_NT_COMM_FAILURE";
2410     case 0xC0020053:
2411         return "RPC_NT_UNSUPPORTED_AUTHN_LEVEL";
2412     case 0xC0020054:
2413         return "RPC_NT_NO_PRINC_NAME";
2414     case 0xC0020055:
2415         return "RPC_NT_NOT_RPC_ERROR";
2416     case 0x40020056:
2417         return "RPC_NT_UUID_LOCAL_ONLY";
2418     case 0xC0020057:
2419         return "RPC_NT_SEC_PKG_ERROR";
2420     case 0xC0020058:
2421         return "RPC_NT_NOT_CANCELLED";
2422     case 0xC0030059:
2423         return "RPC_NT_INVALID_ES_ACTION";
2424     case 0xC003005A:
2425         return "RPC_NT_WRONG_ES_VERSION";
2426     case 0xC003005B:
2427         return "RPC_NT_WRONG_STUB_VERSION";
2428     case 0xC003005C:
2429         return "RPC_NT_INVALID_PIPE_OBJECT";
2430     case 0xC003005D:
2431         return "RPC_NT_INVALID_PIPE_OPERATION";
2432     case 0xC003005E:
2433         return "RPC_NT_WRONG_PIPE_VERSION";
2434     case 0xC003005F:
2435         return "RPC_NT_PIPE_CLOSED";
2436     case 0xC0030060:
2437         return "RPC_NT_PIPE_DISCIPLINE_ERROR";
2438     case 0xC0030061:
2439         return "RPC_NT_PIPE_EMPTY";
2440     case 0xC0020062:
2441         return "RPC_NT_INVALID_ASYNC_HANDLE";
2442     case 0xC0020063:
2443         return "RPC_NT_INVALID_ASYNC_CALL";
2444     case 0x400200AF:
2445         return "RPC_NT_SEND_INCOMPLETE";
2446     case 0xC0140001:
2447         return "STATUS_ACPI_INVALID_OPCODE";
2448     case 0xC0140002:
2449         return "STATUS_ACPI_STACK_OVERFLOW";
2450     case 0xC0140003:
2451         return "STATUS_ACPI_ASSERT_FAILED";
2452     case 0xC0140004:
2453         return "STATUS_ACPI_INVALID_INDEX";
2454     case 0xC0140005:
2455         return "STATUS_ACPI_INVALID_ARGUMENT";
2456     case 0xC0140006:
2457         return "STATUS_ACPI_FATAL";
2458     case 0xC0140007:
2459         return "STATUS_ACPI_INVALID_SUPERNAME";
2460     case 0xC0140008:
2461         return "STATUS_ACPI_INVALID_ARGTYPE";
2462     case 0xC0140009:
2463         return "STATUS_ACPI_INVALID_OBJTYPE";
2464     case 0xC014000A:
2465         return "STATUS_ACPI_INVALID_TARGETTYPE";
2466     case 0xC014000B:
2467         return "STATUS_ACPI_INCORRECT_ARGUMENT_COUNT";
2468     case 0xC014000C:
2469         return "STATUS_ACPI_ADDRESS_NOT_MAPPED";
2470     case 0xC014000D:
2471         return "STATUS_ACPI_INVALID_EVENTTYPE";
2472     case 0xC014000E:
2473         return "STATUS_ACPI_HANDLER_COLLISION";
2474     case 0xC014000F:
2475         return "STATUS_ACPI_INVALID_DATA";
2476     case 0xC0140010:
2477         return "STATUS_ACPI_INVALID_REGION";
2478     case 0xC0140011:
2479         return "STATUS_ACPI_INVALID_ACCESS_SIZE";
2480     case 0xC0140012:
2481         return "STATUS_ACPI_ACQUIRE_GLOBAL_LOCK";
2482     case 0xC0140013:
2483         return "STATUS_ACPI_ALREADY_INITIALIZED";
2484     case 0xC0140014:
2485         return "STATUS_ACPI_NOT_INITIALIZED";
2486     case 0xC0140015:
2487         return "STATUS_ACPI_INVALID_MUTEX_LEVEL";
2488     case 0xC0140016:
2489         return "STATUS_ACPI_MUTEX_NOT_OWNED";
2490     case 0xC0140017:
2491         return "STATUS_ACPI_MUTEX_NOT_OWNER";
2492     case 0xC0140018:
2493         return "STATUS_ACPI_RS_ACCESS";
2494     case 0xC0140019:
2495         return "STATUS_ACPI_INVALID_TABLE";
2496     case 0xC0140020:
2497         return "STATUS_ACPI_REG_HANDLER_FAILED";
2498     case 0xC0140021:
2499         return "STATUS_ACPI_POWER_REQUEST_FAILED";
2500     case 0xC00A0001:
2501         return "STATUS_CTX_WINSTATION_NAME_INVALID";
2502     case 0xC00A0002:
2503         return "STATUS_CTX_INVALID_PD";
2504     case 0xC00A0003:
2505         return "STATUS_CTX_PD_NOT_FOUND";
2506     case 0x400A0004:
2507         return "STATUS_CTX_CDM_CONNECT";
2508     case 0x400A0005:
2509         return "STATUS_CTX_CDM_DISCONNECT";
2510     case 0xC00A0006:
2511         return "STATUS_CTX_CLOSE_PENDING";
2512     case 0xC00A0007:
2513         return "STATUS_CTX_NO_OUTBUF";
2514     case 0xC00A0008:
2515         return "STATUS_CTX_MODEM_INF_NOT_FOUND";
2516     case 0xC00A0009:
2517         return "STATUS_CTX_INVALID_MODEMNAME";
2518     case 0xC00A000A:
2519         return "STATUS_CTX_RESPONSE_ERROR";
2520     case 0xC00A000B:
2521         return "STATUS_CTX_MODEM_RESPONSE_TIMEOUT";
2522     case 0xC00A000C:
2523         return "STATUS_CTX_MODEM_RESPONSE_NO_CARRIER";
2524     case 0xC00A000D:
2525         return "STATUS_CTX_MODEM_RESPONSE_NO_DIALTONE";
2526     case 0xC00A000E:
2527         return "STATUS_CTX_MODEM_RESPONSE_BUSY";
2528     case 0xC00A000F:
2529         return "STATUS_CTX_MODEM_RESPONSE_VOICE";
2530     case 0xC00A0010:
2531         return "STATUS_CTX_TD_ERROR";
2532     case 0xC00A0012:
2533         return "STATUS_CTX_LICENSE_CLIENT_INVALID";
2534     case 0xC00A0013:
2535         return "STATUS_CTX_LICENSE_NOT_AVAILABLE";
2536     case 0xC00A0014:
2537         return "STATUS_CTX_LICENSE_EXPIRED";
2538     case 0xC00A0015:
2539         return "STATUS_CTX_WINSTATION_NOT_FOUND";
2540     case 0xC00A0016:
2541         return "STATUS_CTX_WINSTATION_NAME_COLLISION";
2542     case 0xC00A0017:
2543         return "STATUS_CTX_WINSTATION_BUSY";
2544     case 0xC00A0018:
2545         return "STATUS_CTX_BAD_VIDEO_MODE";
2546     case 0xC00A0022:
2547         return "STATUS_CTX_GRAPHICS_INVALID";
2548     case 0xC00A0024:
2549         return "STATUS_CTX_NOT_CONSOLE";
2550     case 0xC00A0026:
2551         return "STATUS_CTX_CLIENT_QUERY_TIMEOUT";
2552     case 0xC00A0027:
2553         return "STATUS_CTX_CONSOLE_DISCONNECT";
2554     case 0xC00A0028:
2555         return "STATUS_CTX_CONSOLE_CONNECT";
2556     case 0xC00A002A:
2557         return "STATUS_CTX_SHADOW_DENIED";
2558     case 0xC00A002B:
2559         return "STATUS_CTX_WINSTATION_ACCESS_DENIED";
2560     case 0xC00A002E:
2561         return "STATUS_CTX_INVALID_WD";
2562     case 0xC00A002F:
2563         return "STATUS_CTX_WD_NOT_FOUND";
2564     case 0xC00A0030:
2565         return "STATUS_CTX_SHADOW_INVALID";
2566     case 0xC00A0031:
2567         return "STATUS_CTX_SHADOW_DISABLED";
2568     case 0xC00A0032:
2569         return "STATUS_RDP_PROTOCOL_ERROR";
2570     case 0xC00A0033:
2571         return "STATUS_CTX_CLIENT_LICENSE_NOT_SET";
2572     case 0xC00A0034:
2573         return "STATUS_CTX_CLIENT_LICENSE_IN_USE";
2574     case 0xC0040035:
2575         return "STATUS_PNP_BAD_MPS_TABLE";
2576     case 0xC0040036:
2577         return "STATUS_PNP_TRANSLATION_FAILED";
2578     case 0xC0040037:
2579         return "STATUS_PNP_IRQ_TRANSLATION_FAILED";
2580     default:
2581         return "STATUS_UNKNOWN";
2582     }
2583 }
2584 
2585 
2586 /* avoid stack overflow for dead symlinks */
2587 
2588 VOID
Ext2TraceMcb(PCHAR fn,USHORT lc,USHORT add,PEXT2_MCB Mcb)2589 Ext2TraceMcb(PCHAR fn, USHORT lc, USHORT add, PEXT2_MCB Mcb) {
2590     int i;
2591     CHAR _space[33];
2592 
2593     _snprintf(&_space[0], 32, "%s:%d:", fn, lc);
2594     _space[32] = 0;
2595     i = strlen(_space);
2596     while (i < 32) {
2597         _space[i++] = ' ';
2598         _space[i]=0;
2599     }
2600     if (add) {
2601         Ext2ReferXcb(&Mcb->Refercount);
2602         DEBUG(DL_RES,   ("%s +%2u %wZ (%p)\n", _space, (Mcb->Refercount - 1), &Mcb->FullName, Mcb));
2603     } else {
2604         Ext2DerefXcb(&Mcb->Refercount);
2605         DEBUG(DL_RES, ("%s -%2u %wZ (%p)\n", _space, Mcb->Refercount, &Mcb->FullName, Mcb));
2606     }
2607 }
2608 
2609 KSPIN_LOCK  Ext2MemoryLock;
2610 ULONGLONG   Ext2TotalMemorySize = 0;
2611 ULONG       Ext2TotalAllocates = 0;
2612 
2613 PVOID
Ext2AllocatePool(IN POOL_TYPE PoolType,IN SIZE_T NumberOfBytes,IN ULONG Tag)2614 Ext2AllocatePool(
2615     IN POOL_TYPE PoolType,
2616     IN SIZE_T NumberOfBytes,
2617     IN ULONG Tag
2618 )
2619 {
2620     PUCHAR  Buffer =  ExAllocatePoolWithTag(
2621                           PoolType,
2622                           0x20 + NumberOfBytes,
2623                           Tag);
2624     if (Buffer) {
2625         KIRQL   Irql = 0;
2626         PULONG  Data = (PULONG)Buffer;
2627         Data[0] = (ULONG)NumberOfBytes;
2628         Data[1] = (ULONG)NumberOfBytes + 0x20;
2629         memset(Buffer + 0x08, 'S', 8);
2630         memset(Buffer + 0x10 + NumberOfBytes, 'E', 0x10);
2631         Buffer += 0x10;
2632         KeAcquireSpinLock(&Ext2MemoryLock, &Irql);
2633         Ext2TotalMemorySize = Ext2TotalMemorySize + NumberOfBytes;
2634         Ext2TotalAllocates += 1;
2635         KeReleaseSpinLock(&Ext2MemoryLock, Irql);
2636     }
2637 
2638     return Buffer;
2639 }
2640 
2641 VOID
Ext2FreePool(IN PVOID P,IN ULONG Tag)2642 Ext2FreePool(
2643     IN PVOID P,
2644     IN ULONG Tag
2645 )
2646 {
2647     PUCHAR  Buffer = (PUCHAR)P;
2648     PULONG  Data;
2649     ULONG   NumberOfBytes, i;
2650     KIRQL   Irql;
2651 
2652     Buffer -= 0x10;
2653     Data = (PULONG)(Buffer);
2654     NumberOfBytes = Data[0];
2655     if (Data[1] != NumberOfBytes + 0x20) {
2656         DbgBreak();
2657         return;
2658     }
2659     for (i=0x08; i < 0x10; i++) {
2660         if (Buffer[i] != 'S') {
2661             DbgBreak();
2662         }
2663         Buffer[i] = '-';
2664     }
2665     for (i=0; i < 0x10; i++) {
2666         if (Buffer[i + NumberOfBytes + 0x10] != 'E') {
2667             DbgBreak();
2668             return;
2669         }
2670         Buffer[i + NumberOfBytes + 0x10] = '-';
2671     }
2672 
2673     KeAcquireSpinLock(&Ext2MemoryLock, &Irql);
2674     Ext2TotalMemorySize = Ext2TotalMemorySize - NumberOfBytes;
2675     Ext2TotalAllocates -= 1;
2676     KeReleaseSpinLock(&Ext2MemoryLock, Irql);
2677 
2678     ExFreePoolWithTag(Buffer, Tag);
2679 }
2680 
2681 #else  // EXT2_DEBUG
2682 
2683 PVOID
Ext2AllocatePool(IN POOL_TYPE PoolType,IN SIZE_T NumberOfBytes,IN ULONG Tag)2684 Ext2AllocatePool(
2685     IN POOL_TYPE PoolType,
2686     IN SIZE_T NumberOfBytes,
2687     IN ULONG Tag
2688 )
2689 {
2690     return ExAllocatePoolWithTag(
2691                PoolType,
2692                NumberOfBytes,
2693                Tag);
2694 }
2695 
2696 VOID
Ext2FreePool(IN PVOID P,IN ULONG Tag)2697 Ext2FreePool(
2698     IN PVOID P,
2699     IN ULONG Tag
2700 )
2701 {
2702     ExFreePoolWithTag(P, Tag);
2703 }
2704 
2705 #endif // !EXT2_DEBUG
2706