1 /*
2  * Copyright (C) Andrew Tridgell 1995-1999
3  *
4  * This software may be distributed either under the terms of the
5  * BSD-style license that accompanies tcpdump or the GNU GPL version 2
6  * or later
7  */
8 
9 #include <sys/cdefs.h>
10 #ifndef lint
11 __RCSID("$NetBSD: smbutil.c,v 1.9 2024/09/02 16:15:33 christos Exp $");
12 #endif
13 
14 #include <config.h>
15 
16 #include "netdissect-stdinc.h"
17 
18 #include <stdio.h>
19 #include <stdlib.h>
20 #include <string.h>
21 
22 #include "netdissect-ctype.h"
23 
24 #include "netdissect.h"
25 #include "extract.h"
26 #include "smb.h"
27 
28 static int stringlen_is_set;
29 static uint32_t stringlen;
30 extern const u_char *startbuf;
31 
32 /*
33  * Reset SMB state.
34  */
35 void
smb_reset(void)36 smb_reset(void)
37 {
38     stringlen_is_set = 0;
39     stringlen = 0;
40 }
41 
42 /*
43  * interpret a 32 bit dos packed date/time to some parameters
44  */
45 static void
interpret_dos_date(uint32_t date,struct tm * tp)46 interpret_dos_date(uint32_t date, struct tm *tp)
47 {
48     uint32_t p0, p1, p2, p3;
49 
50     p0 = date & 0xFF;
51     p1 = ((date & 0xFF00) >> 8) & 0xFF;
52     p2 = ((date & 0xFF0000) >> 16) & 0xFF;
53     p3 = ((date & 0xFF000000) >> 24) & 0xFF;
54 
55     tp->tm_sec = 2 * (p0 & 0x1F);
56     tp->tm_min = ((p0 >> 5) & 0xFF) + ((p1 & 0x7) << 3);
57     tp->tm_hour = (p1 >> 3) & 0xFF;
58     tp->tm_mday = (p2 & 0x1F);
59     tp->tm_mon = ((p2 >> 5) & 0xFF) + ((p3 & 0x1) << 3) - 1;
60     tp->tm_year = ((p3 >> 1) & 0xFF) + 80;
61 }
62 
63 /*
64  * common portion:
65  * create a unix date from a dos date
66  */
67 static time_t
int_unix_date(uint32_t dos_date)68 int_unix_date(uint32_t dos_date)
69 {
70     struct tm t;
71 
72     if (dos_date == 0)
73           return(0);
74 
75     interpret_dos_date(dos_date, &t);
76     t.tm_wday = 1;
77     t.tm_yday = 1;
78     t.tm_isdst = 0;
79 
80     return (mktime(&t));
81 }
82 
83 /*
84  * create a unix date from a dos date
85  * in network byte order
86  */
87 static time_t
make_unix_date(netdissect_options * ndo,const u_char * date_ptr)88 make_unix_date(netdissect_options *ndo, const u_char *date_ptr)
89 {
90     uint32_t dos_date = 0;
91 
92     dos_date = GET_LE_U_4(date_ptr);
93 
94     return int_unix_date(dos_date);
95 }
96 
97 /*
98  * create a unix date from a dos date
99  * in halfword-swapped network byte order!
100  */
101 static time_t
make_unix_date2(netdissect_options * ndo,const u_char * date_ptr)102 make_unix_date2(netdissect_options *ndo, const u_char *date_ptr)
103 {
104     uint32_t x, x2;
105 
106     x = GET_LE_U_4(date_ptr);
107     x2 = ((x & 0xFFFF) << 16) | ((x & 0xFFFF0000) >> 16);
108     return int_unix_date(x2);
109 }
110 
111 /*
112  * interpret an 8 byte "filetime" structure to a time_t
113  * It's originally in "100ns units since jan 1st 1601"
114  */
115 static time_t
interpret_long_date(netdissect_options * ndo,const u_char * p)116 interpret_long_date(netdissect_options *ndo, const u_char *p)
117 {
118     double d;
119     time_t ret;
120 
121     /* this gives us seconds since jan 1st 1601 (approx) */
122     d = (GET_LE_U_4(p + 4) * 256.0 + GET_U_1(p + 3)) * (1.0e-7 * (1 << 24));
123 
124     /* now adjust by 369 years to make the secs since 1970 */
125     d -= 369.0 * 365.25 * 24 * 60 * 60;
126 
127     /* and a fudge factor as we got it wrong by a few days */
128     d += (3 * 24 * 60 * 60 + 6 * 60 * 60 + 2);
129 
130     if (d < 0)
131           return(0);
132 
133     ret = (time_t)d;
134 
135     return(ret);
136 }
137 
138 /*
139  * interpret the weird netbios "name". Return the name type, or -1 if
140  * we run past the end of the buffer
141  */
142 static int
name_interpret(netdissect_options * ndo,const u_char * in,const u_char * maxbuf,char * out)143 name_interpret(netdissect_options *ndo,
144                const u_char *in, const u_char *maxbuf, char *out)
145 {
146     int ret;
147     u_int len;
148 
149     if (in >= maxbuf)
150           return(-1);         /* name goes past the end of the buffer */
151     len = GET_U_1(in) / 2;
152     in++;
153 
154     *out=0;
155 
156     if (len > 30 || len == 0)
157           return(0);
158 
159     while (len) {
160           ND_TCHECK_2(in);
161           if (in + 1 >= maxbuf)
162               return(-1);     /* name goes past the end of the buffer */
163           if (GET_U_1(in) < 'A' || GET_U_1(in) > 'P' ||
164               GET_U_1(in + 1) < 'A' || GET_U_1(in + 1) > 'P') {
165               *out = 0;
166               return(0);
167           }
168           *out = ((GET_U_1(in) - 'A') << 4) + (GET_U_1(in + 1) - 'A');
169           in += 2;
170           out++;
171           len--;
172     }
173     *out = 0;
174     ret = out[-1];
175 
176     return(ret);
177 
178 trunc:
179     return(-1);
180 }
181 
182 /*
183  * find a pointer to a netbios name
184  */
185 static const u_char *
name_ptr(netdissect_options * ndo,const u_char * buf,u_int ofs,const u_char * maxbuf)186 name_ptr(netdissect_options *ndo,
187          const u_char *buf, u_int ofs, const u_char *maxbuf)
188 {
189     const u_char *p;
190     u_char c;
191 
192     p = buf + ofs;
193     if (p >= maxbuf)
194           return(NULL);       /* name goes past the end of the buffer */
195 
196     c = GET_U_1(p);
197 
198     /* XXX - this should use the same code that the DNS dissector does */
199     if ((c & 0xC0) == 0xC0) {
200           uint16_t l;
201 
202           ND_TCHECK_2(p);
203           if ((p + 1) >= maxbuf)
204               return(NULL);   /* name goes past the end of the buffer */
205           l = GET_BE_U_2(p) & 0x3FFF;
206           if (l == 0) {
207               /* We have a pointer that points to itself. */
208               return(NULL);
209           }
210           p = buf + l;
211           if (p >= maxbuf)
212               return(NULL);   /* name goes past the end of the buffer */
213           ND_TCHECK_1(p);
214     }
215     return(p);
216 
217 trunc:
218     return(NULL);   /* name goes past the end of the buffer */
219 }
220 
221 /*
222  * extract a netbios name from a buf
223  */
224 static int
name_extract(netdissect_options * ndo,const u_char * buf,u_int ofs,const u_char * maxbuf,char * name)225 name_extract(netdissect_options *ndo,
226              const u_char *buf, u_int ofs, const u_char *maxbuf, char *name)
227 {
228     const u_char *p = name_ptr(ndo, buf, ofs, maxbuf);
229     if (p == NULL)
230           return(-1);         /* error (probably name going past end of buffer) */
231     name[0] = '\0';
232     return(name_interpret(ndo, p, maxbuf, name));
233 }
234 
235 
236 /*
237  * return the total storage length of a mangled name
238  */
239 static int
name_len(netdissect_options * ndo,const u_char * s,const u_char * maxbuf)240 name_len(netdissect_options *ndo,
241          const u_char *s, const u_char *maxbuf)
242 {
243     const u_char *s0 = s;
244     unsigned char c;
245 
246     if (s >= maxbuf)
247           return(-1);         /* name goes past the end of the buffer */
248     c = GET_U_1(s);
249     if ((c & 0xC0) == 0xC0)
250           return(2);
251     while (GET_U_1(s)) {
252           if (s >= maxbuf)
253               return(-1);     /* name goes past the end of the buffer */
254           s += GET_U_1(s) + 1;
255           ND_TCHECK_1(s);
256     }
257     return(ND_BYTES_BETWEEN(s0, s) + 1);
258 
259 trunc:
260     return(-1);     /* name goes past the end of the buffer */
261 }
262 
263 static void
print_asc(netdissect_options * ndo,const u_char * buf,u_int len)264 print_asc(netdissect_options *ndo,
265           const u_char *buf, u_int len)
266 {
267     u_int i;
268     for (i = 0; i < len; i++)
269         fn_print_char(ndo, GET_U_1(buf + i));
270 }
271 
272 static const char *
name_type_str(int name_type)273 name_type_str(int name_type)
274 {
275     const char *f = NULL;
276 
277     switch (name_type) {
278     case 0:    f = "Workstation"; break;
279     case 0x03: f = "Client?"; break;
280     case 0x20: f = "Server"; break;
281     case 0x1d: f = "Master Browser"; break;
282     case 0x1b: f = "Domain Controller"; break;
283     case 0x1e: f = "Browser Server"; break;
284     default:   f = "Unknown"; break;
285     }
286     return(f);
287 }
288 
289 void
smb_data_print(netdissect_options * ndo,const u_char * buf,u_int len)290 smb_data_print(netdissect_options *ndo, const u_char *buf, u_int len)
291 {
292     u_int i = 0;
293 
294     if (len == 0)
295           return;
296     ND_PRINT("[%03X] ", i);
297     for (i = 0; i < len; /*nothing*/) {
298           ND_PRINT("%02X ", GET_U_1(buf + i) & 0xff);
299           i++;
300           if (i%8 == 0)
301               ND_PRINT(" ");
302           if (i % 16 == 0) {
303               print_asc(ndo, buf + i - 16, 8);
304               ND_PRINT(" ");
305               print_asc(ndo, buf + i - 8, 8);
306               ND_PRINT("\n");
307               if (i < len)
308                     ND_PRINT("[%03X] ", i);
309           }
310     }
311     if (i % 16) {
312           int n;
313 
314           n = 16 - (i % 16);
315           ND_PRINT(" ");
316           if (n>8)
317               ND_PRINT(" ");
318           while (n--)
319               ND_PRINT("   ");
320 
321           n = ND_MIN(8, i % 16);
322           print_asc(ndo, buf + i - (i % 16), n);
323           ND_PRINT(" ");
324           n = (i % 16) - n;
325           if (n > 0)
326               print_asc(ndo, buf + i - n, n);
327           ND_PRINT("\n");
328     }
329 }
330 
331 
332 static void
write_bits(netdissect_options * ndo,unsigned int val,const char * fmt)333 write_bits(netdissect_options *ndo,
334            unsigned int val, const char *fmt)
335 {
336     const char *p = fmt;
337     u_int i = 0;
338 
339     while ((p = strchr(fmt, '|'))) {
340           u_int l = ND_BYTES_BETWEEN(fmt, p);
341           if (l && (val & (1 << i)))
342               ND_PRINT("%.*s ", (int)l, fmt);
343           fmt = p + 1;
344           i++;
345     }
346 }
347 
348 /* convert a UCS-2 string into an ASCII string */
349 #define MAX_UNISTR_SIZE       1000
350 static const u_char *
unistr(netdissect_options * ndo,char (* buf)[MAX_UNISTR_SIZE+1],const u_char * s,uint32_t strsize,int is_null_terminated,int use_unicode)351 unistr(netdissect_options *ndo, char (*buf)[MAX_UNISTR_SIZE+1],
352        const u_char *s, uint32_t strsize, int is_null_terminated,
353        int use_unicode)
354 {
355     u_int c;
356     size_t l = 0;
357     const u_char *sp;
358 
359     if (use_unicode) {
360           /*
361            * Skip padding that puts the string on an even boundary.
362            */
363           if (((s - startbuf) % 2) != 0) {
364               ND_TCHECK_1(s);
365               s++;
366           }
367     }
368     if (is_null_terminated) {
369           /*
370            * Null-terminated string.
371            * Find the length, counting the terminating NUL.
372            */
373           strsize = 0;
374           sp = s;
375           if (!use_unicode) {
376               for (;;) {
377                     c = GET_U_1(sp);
378                     sp++;
379                     strsize++;
380                     if (c == '\0')
381                         break;
382               }
383           } else {
384               for (;;) {
385                     c = GET_LE_U_2(sp);
386                     sp += 2;
387                     strsize += 2;
388                     if (c == '\0')
389                         break;
390               }
391           }
392     }
393     if (!use_unicode) {
394           while (strsize != 0) {
395               c = GET_U_1(s);
396               s++;
397               strsize--;
398               if (c == 0) {
399                     /*
400                      * Even counted strings may have embedded null
401                      * terminators, so quit here, and skip past
402                      * the rest of the data.
403                      *
404                      * Make sure, however, that the rest of the data
405                      * is there, so we don't overflow the buffer when
406                      * skipping past it.
407                      */
408                     ND_TCHECK_LEN(s, strsize);
409                     s += strsize;
410                     strsize = 0;
411                     break;
412               }
413               if (l < MAX_UNISTR_SIZE) {
414                     if (ND_ASCII_ISPRINT(c)) {
415                         /* It's a printable ASCII character */
416                         (*buf)[l] = (char)c;
417                     } else {
418                         /* It's a non-ASCII character or a non-printable ASCII character */
419                         (*buf)[l] = '.';
420                     }
421                     l++;
422               }
423           }
424     } else {
425           while (strsize > 1) {
426               c = GET_LE_U_2(s);
427               s += 2;
428               strsize -= 2;
429               if (c == 0) {
430                     /*
431                      * Even counted strings may have embedded null
432                      * terminators, so quit here, and skip past
433                      * the rest of the data.
434                      *
435                      * Make sure, however, that the rest of the data
436                      * is there, so we don't overflow the buffer when
437                      * skipping past it.
438                      */
439                     ND_TCHECK_LEN(s, strsize);
440                     s += strsize;
441                     strsize = 0;
442                     break;
443               }
444               if (l < MAX_UNISTR_SIZE) {
445                     if (ND_ASCII_ISPRINT(c)) {
446                         /* It's a printable ASCII character */
447                         (*buf)[l] = (char)c;
448                     } else {
449                         /* It's a non-ASCII character or a non-printable ASCII character */
450                         (*buf)[l] = '.';
451                     }
452                     l++;
453               }
454           }
455           if (strsize == 1) {
456               /* We have half of a code point; skip past it */
457               ND_TCHECK_1(s);
458               s++;
459           }
460     }
461     (*buf)[l] = 0;
462     return s;
463 
464 trunc:
465     (*buf)[l] = 0;
466     return NULL;
467 }
468 
469 static const u_char *
smb_fdata1(netdissect_options * ndo,const u_char * buf,const char * fmt,const u_char * maxbuf,int unicodestr)470 smb_fdata1(netdissect_options *ndo,
471            const u_char *buf, const char *fmt, const u_char *maxbuf,
472            int unicodestr)
473 {
474     int reverse = 0;
475     const char *attrib_fmt = "READONLY|HIDDEN|SYSTEM|VOLUME|DIR|ARCHIVE|";
476     char strbuf[MAX_UNISTR_SIZE+1];
477 
478     while (*fmt && buf<maxbuf) {
479           switch (*fmt) {
480           case 'a':
481               write_bits(ndo, GET_U_1(buf), attrib_fmt);
482               buf++;
483               fmt++;
484               break;
485 
486           case 'A':
487               write_bits(ndo, GET_LE_U_2(buf), attrib_fmt);
488               buf += 2;
489               fmt++;
490               break;
491 
492           case '{':
493             {
494               char bitfmt[128];
495               char *p;
496               u_int l;
497 
498               p = strchr(++fmt, '}');
499               l = ND_BYTES_BETWEEN(fmt, p);
500 
501               if (l > sizeof(bitfmt) - 1)
502                     l = sizeof(bitfmt)-1;
503 
504               strncpy(bitfmt, fmt, l);
505               bitfmt[l] = '\0';
506               fmt = p + 1;
507               write_bits(ndo, GET_U_1(buf), bitfmt);
508               buf++;
509               break;
510             }
511 
512           case 'P':
513             {
514               int l = atoi(fmt + 1);
515               ND_TCHECK_LEN(buf, l);
516               buf += l;
517               fmt++;
518               while (ND_ASCII_ISDIGIT(*fmt))
519                     fmt++;
520               break;
521             }
522           case 'r':
523               reverse = !reverse;
524               fmt++;
525               break;
526           case 'b':
527             {
528               unsigned int x;
529               x = GET_U_1(buf);
530               ND_PRINT("%u (0x%x)", x, x);
531               buf += 1;
532               fmt++;
533               break;
534             }
535           case 'd':
536             {
537               int x;
538               x = reverse ? GET_BE_S_2(buf) :
539                                 GET_LE_S_2(buf);
540               ND_PRINT("%d (0x%x)", x, x);
541               buf += 2;
542               fmt++;
543               break;
544             }
545           case 'D':
546             {
547               int x;
548               x = reverse ? GET_BE_S_4(buf) :
549                                 GET_LE_S_4(buf);
550               ND_PRINT("%d (0x%x)", x, x);
551               buf += 4;
552               fmt++;
553               break;
554             }
555           case 'L':
556             {
557               uint64_t x;
558               x = reverse ? GET_BE_U_8(buf) :
559                                 GET_LE_U_8(buf);
560               ND_PRINT("%" PRIu64 " (0x%" PRIx64 ")", x, x);
561               buf += 8;
562               fmt++;
563               break;
564             }
565           case 'u':
566             {
567               unsigned int x;
568               x = reverse ? GET_BE_U_2(buf) :
569                                 GET_LE_U_2(buf);
570               ND_PRINT("%u (0x%x)", x, x);
571               buf += 2;
572               fmt++;
573               break;
574             }
575           case 'U':
576             {
577               unsigned int x;
578               x = reverse ? GET_BE_U_4(buf) :
579                                 GET_LE_U_4(buf);
580               ND_PRINT("%u (0x%x)", x, x);
581               buf += 4;
582               fmt++;
583               break;
584             }
585           case 'M':
586             {
587               /* Weird mixed-endian length values in 64-bit locks */
588               uint32_t x1, x2;
589               uint64_t x;
590               ND_TCHECK_8(buf);
591               x1 = reverse ? GET_BE_U_4(buf) :
592                                  GET_LE_U_4(buf);
593               x2 = reverse ? GET_BE_U_4(buf + 4) :
594                                  GET_LE_U_4(buf + 4);
595               x = (((uint64_t)x1) << 32) | x2;
596               ND_PRINT("%" PRIu64 " (0x%" PRIx64 ")", x, x);
597               buf += 8;
598               fmt++;
599               break;
600             }
601           case 'B':
602             {
603               unsigned int x;
604               x = GET_U_1(buf);
605               ND_PRINT("0x%X", x);
606               buf += 1;
607               fmt++;
608               break;
609             }
610           case 'w':
611             {
612               unsigned int x;
613               x = reverse ? GET_BE_U_2(buf) :
614                                 GET_LE_U_2(buf);
615               ND_PRINT("0x%X", x);
616               buf += 2;
617               fmt++;
618               break;
619             }
620           case 'W':
621             {
622               unsigned int x;
623               x = reverse ? GET_BE_U_4(buf) :
624                                 GET_LE_U_4(buf);
625               ND_PRINT("0x%X", x);
626               buf += 4;
627               fmt++;
628               break;
629             }
630           case 'l':
631             {
632               fmt++;
633               switch (*fmt) {
634 
635               case 'b':
636                     stringlen = GET_U_1(buf);
637                     stringlen_is_set = 1;
638                     ND_PRINT("%u", stringlen);
639                     buf += 1;
640                     break;
641 
642               case 'd':
643               case 'u':
644                     stringlen = reverse ? GET_BE_U_2(buf) :
645                                               GET_LE_U_2(buf);
646                     stringlen_is_set = 1;
647                     ND_PRINT("%u", stringlen);
648                     buf += 2;
649                     break;
650 
651               case 'D':
652               case 'U':
653                     stringlen = reverse ? GET_BE_U_4(buf) :
654                                               GET_LE_U_4(buf);
655                     stringlen_is_set = 1;
656                     ND_PRINT("%u", stringlen);
657                     buf += 4;
658                     break;
659               }
660               fmt++;
661               break;
662             }
663           case 'S':
664           case 'R': /* like 'S', but always ASCII */
665             {
666               /*XXX unistr() */
667               buf = unistr(ndo, &strbuf, buf, 0, 1, (*fmt == 'R') ? 0 : unicodestr);
668               ND_PRINT("%s", strbuf);
669               if (buf == NULL)
670                     goto trunc;
671               fmt++;
672               break;
673             }
674           case 'Z':
675           case 'Y': /* like 'Z', but always ASCII */
676             {
677               if (GET_U_1(buf) != 4 && GET_U_1(buf) != 2) {
678                     ND_PRINT("Error! ASCIIZ buffer of type %u", GET_U_1(buf));
679                     return maxbuf;      /* give up */
680               }
681               buf = unistr(ndo, &strbuf, buf + 1, 0, 1, (*fmt == 'Y') ? 0 : unicodestr);
682               ND_PRINT("%s", strbuf);
683               if (buf == NULL)
684                     goto trunc;
685               fmt++;
686               break;
687             }
688           case 's':
689             {
690               int l = atoi(fmt + 1);
691               ND_TCHECK_LEN(buf, l);
692               ND_PRINT("%-*.*s", l, l, buf);
693               buf += l;
694               fmt++;
695               while (ND_ASCII_ISDIGIT(*fmt))
696                     fmt++;
697               break;
698             }
699           case 'c':
700             {
701             if (!stringlen_is_set) {
702                 ND_PRINT("{stringlen not set}");
703                 goto trunc;
704             }
705               ND_TCHECK_LEN(buf, stringlen);
706               ND_PRINT("%-*.*s", (int)stringlen, (int)stringlen, buf);
707               buf += stringlen;
708               fmt++;
709               while (ND_ASCII_ISDIGIT(*fmt))
710                     fmt++;
711               break;
712             }
713           case 'C':
714             {
715             if (!stringlen_is_set) {
716                 ND_PRINT("{stringlen not set}");
717                 goto trunc;
718             }
719               buf = unistr(ndo, &strbuf, buf, stringlen, 0, unicodestr);
720               ND_PRINT("%s", strbuf);
721               if (buf == NULL)
722                     goto trunc;
723               fmt++;
724               break;
725             }
726           case 'h':
727             {
728               int l = atoi(fmt + 1);
729               ND_TCHECK_LEN(buf, l);
730               while (l--) {
731                     ND_PRINT("%02x", GET_U_1(buf));
732                     buf++;
733               }
734               fmt++;
735               while (ND_ASCII_ISDIGIT(*fmt))
736                     fmt++;
737               break;
738             }
739           case 'n':
740             {
741               int t = atoi(fmt+1);
742               char nbuf[255];
743               int name_type;
744               int len;
745 
746               switch (t) {
747               case 1:
748                     name_type = name_extract(ndo, startbuf,
749                                          ND_BYTES_BETWEEN(startbuf, buf),
750                                          maxbuf, nbuf);
751                     if (name_type < 0)
752                         goto trunc;
753                     len = name_len(ndo, buf, maxbuf);
754                     if (len < 0)
755                         goto trunc;
756                     buf += len;
757                     ND_PRINT("%-15.15s NameType=0x%02X (%s)", nbuf, name_type,
758                         name_type_str(name_type));
759                     break;
760               case 2:
761                     name_type = GET_U_1(buf + 15);
762                     ND_PRINT("%-15.15s NameType=0x%02X (%s)", buf, name_type,
763                         name_type_str(name_type));
764                     buf += 16;
765                     break;
766               }
767               fmt++;
768               while (ND_ASCII_ISDIGIT(*fmt))
769                     fmt++;
770               break;
771             }
772           case 'T':
773             {
774               time_t t;
775               const char *tstring;
776               char buffer[sizeof("Www Mmm dd hh:mm:ss yyyyy")];
777               uint32_t x;
778 
779               switch (atoi(fmt + 1)) {
780               case 1:
781                     x = GET_LE_U_4(buf);
782                     if (x == 0 || x == 0xFFFFFFFF)
783                         t = 0;
784                     else
785                         t = make_unix_date(ndo, buf);
786                     buf += 4;
787                     break;
788               case 2:
789                     x = GET_LE_U_4(buf);
790                     if (x == 0 || x == 0xFFFFFFFF)
791                         t = 0;
792                     else
793                         t = make_unix_date2(ndo, buf);
794                     buf += 4;
795                     break;
796               case 3:
797                     ND_TCHECK_8(buf);
798                     t = interpret_long_date(ndo, buf);
799                     buf += 8;
800                     break;
801               default:
802                     t = 0;
803                     break;
804               }
805               if (t != 0) {
806                     tstring = nd_format_time(buffer, sizeof(buffer), "%Y-%m-%d %T",
807                                                    localtime(&t));
808               } else
809                     tstring = "NULL";
810               ND_PRINT("%s\n", tstring);
811               fmt++;
812               while (ND_ASCII_ISDIGIT(*fmt))
813                     fmt++;
814               break;
815             }
816           default:
817               ND_PRINT("%c", *fmt);
818               fmt++;
819               break;
820           }
821     }
822 
823     if (buf >= maxbuf && *fmt)
824           ND_PRINT("END OF BUFFER\n");
825 
826     return(buf);
827 
828 trunc:
829     nd_print_trunc(ndo);
830     return(NULL);
831 }
832 
833 const u_char *
smb_fdata(netdissect_options * ndo,const u_char * buf,const char * fmt,const u_char * maxbuf,int unicodestr)834 smb_fdata(netdissect_options *ndo,
835           const u_char *buf, const char *fmt, const u_char *maxbuf,
836           int unicodestr)
837 {
838     static int depth = 0;
839     char s[128];
840     char *p;
841 
842     while (*fmt) {
843           switch (*fmt) {
844           case '*':
845               /*
846                * List of multiple instances of something described by the
847                * remainder of the string (which may itself include a list
848                * of multiple instances of something, so we recurse).
849                */
850               fmt++;
851               while (buf < maxbuf) {
852                     const u_char *buf2;
853                     depth++;
854                     /*
855                      * In order to avoid stack exhaustion recurse at most 10
856                      * levels; that "should not happen", as no SMB structure
857                      * should be nested *that* deeply, and we thus shouldn't
858                      * have format strings with that level of nesting.
859                      */
860                     if (depth == 10) {
861                               ND_PRINT("(too many nested levels, not recursing)");
862                               buf2 = buf;
863                     } else
864                               buf2 = smb_fdata(ndo, buf, fmt, maxbuf, unicodestr);
865                     depth--;
866                     if (buf2 == NULL)
867                         return(NULL);
868                     if (buf2 == buf)
869                         return(buf);
870                     buf = buf2;
871               }
872               return(buf);
873 
874           case '|':
875               /*
876                * Just do a bounds check.
877                */
878               fmt++;
879               if (buf >= maxbuf)
880                     return(buf);
881               break;
882 
883           case '%':
884               /*
885                * XXX - unused?
886                */
887               fmt++;
888               buf = maxbuf;
889               break;
890 
891           case '#':
892               /*
893                * Done?
894                */
895               fmt++;
896               return(buf);
897               break;
898 
899           case '[':
900               /*
901                * Format of an item, enclosed in square brackets; dissect
902                * the item with smb_fdata1().
903                */
904               fmt++;
905               if (buf >= maxbuf)
906                     return(buf);
907               memset(s, 0, sizeof(s));
908               p = strchr(fmt, ']');
909               if ((size_t)(p - fmt + 1) > sizeof(s)) {
910                     /* overrun */
911                     return(buf);
912               }
913               strncpy(s, fmt, p - fmt);
914               s[p - fmt] = '\0';
915               fmt = p + 1;
916               buf = smb_fdata1(ndo, buf, s, maxbuf, unicodestr);
917               if (buf == NULL) {
918                     /*
919                      * Truncated.
920                      * Is the next character a newline?
921                      * If so, print it before quitting, so we don't
922                      * get stuff in the middle of the line.
923                      */
924                     if (*fmt == '\n')
925                         ND_PRINT("\n");
926                     return(NULL);
927               }
928               break;
929 
930           default:
931               /*
932                * Not a formatting character, so just print it.
933                */
934               ND_PRINT("%c", *fmt);
935               fmt++;
936               break;
937           }
938     }
939     if (!depth && buf < maxbuf) {
940           u_int len = ND_BYTES_BETWEEN(buf, maxbuf);
941           ND_PRINT("Data: (%u bytes)\n", len);
942           smb_data_print(ndo, buf, len);
943           return(buf + len);
944     }
945     return(buf);
946 }
947 
948 typedef struct {
949     const char *name;
950     int code;
951     const char *message;
952 } err_code_struct;
953 
954 /* DOS Error Messages */
955 static const err_code_struct dos_msgs[] = {
956     { "ERRbadfunc", 1, "Invalid function." },
957     { "ERRbadfile", 2, "File not found." },
958     { "ERRbadpath", 3, "Directory invalid." },
959     { "ERRnofids", 4, "No file descriptors available" },
960     { "ERRnoaccess", 5, "Access denied." },
961     { "ERRbadfid", 6, "Invalid file handle." },
962     { "ERRbadmcb", 7, "Memory control blocks destroyed." },
963     { "ERRnomem", 8, "Insufficient server memory to perform the requested function." },
964     { "ERRbadmem", 9, "Invalid memory block address." },
965     { "ERRbadenv", 10, "Invalid environment." },
966     { "ERRbadformat", 11, "Invalid format." },
967     { "ERRbadaccess", 12, "Invalid open mode." },
968     { "ERRbaddata", 13, "Invalid data." },
969     { "ERR", 14, "reserved." },
970     { "ERRbaddrive", 15, "Invalid drive specified." },
971     { "ERRremcd", 16, "A Delete Directory request attempted to remove the server's current directory." },
972     { "ERRdiffdevice", 17, "Not same device." },
973     { "ERRnofiles", 18, "A File Search command can find no more files matching the specified criteria." },
974     { "ERRbadshare", 32, "The sharing mode specified for an Open conflicts with existing FIDs on the file." },
975     { "ERRlock", 33, "A Lock request conflicted with an existing lock or specified an invalid mode, or an Unlock requested attempted to remove a lock held by another process." },
976     { "ERRfilexists", 80, "The file named in a Create Directory, Make New File or Link request already exists." },
977     { "ERRbadpipe", 230, "Pipe invalid." },
978     { "ERRpipebusy", 231, "All instances of the requested pipe are busy." },
979     { "ERRpipeclosing", 232, "Pipe close in progress." },
980     { "ERRnotconnected", 233, "No process on other end of pipe." },
981     { "ERRmoredata", 234, "There is more data to be returned." },
982     { NULL, -1, NULL }
983  };
984 
985 /* Server Error Messages */
986 static const err_code_struct server_msgs[] = {
987     { "ERRerror", 1, "Non-specific error code." },
988     { "ERRbadpw", 2, "Bad password - name/password pair in a Tree Connect or Session Setup are invalid." },
989     { "ERRbadtype", 3, "reserved." },
990     { "ERRaccess", 4, "The requester does not have the necessary access rights within the specified context for the requested function. The context is defined by the TID or the UID." },
991     { "ERRinvnid", 5, "The tree ID (TID) specified in a command was invalid." },
992     { "ERRinvnetname", 6, "Invalid network name in tree connect." },
993     { "ERRinvdevice", 7, "Invalid device - printer request made to non-printer connection or non-printer request made to printer connection." },
994     { "ERRqfull", 49, "Print queue full (files) -- returned by open print file." },
995     { "ERRqtoobig", 50, "Print queue full -- no space." },
996     { "ERRqeof", 51, "EOF on print queue dump." },
997     { "ERRinvpfid", 52, "Invalid print file FID." },
998     { "ERRsmbcmd", 64, "The server did not recognize the command received." },
999     { "ERRsrverror", 65, "The server encountered an internal error, e.g., system file unavailable." },
1000     { "ERRfilespecs", 67, "The file handle (FID) and pathname parameters contained an invalid combination of values." },
1001     { "ERRreserved", 68, "reserved." },
1002     { "ERRbadpermits", 69, "The access permissions specified for a file or directory are not a valid combination.  The server cannot set the requested attribute." },
1003     { "ERRreserved", 70, "reserved." },
1004     { "ERRsetattrmode", 71, "The attribute mode in the Set File Attribute request is invalid." },
1005     { "ERRpaused", 81, "Server is paused." },
1006     { "ERRmsgoff", 82, "Not receiving messages." },
1007     { "ERRnoroom", 83, "No room to buffer message." },
1008     { "ERRrmuns", 87, "Too many remote user names." },
1009     { "ERRtimeout", 88, "Operation timed out." },
1010     { "ERRnoresource", 89, "No resources currently available for request." },
1011     { "ERRtoomanyuids", 90, "Too many UIDs active on this session." },
1012     { "ERRbaduid", 91, "The UID is not known as a valid ID on this session." },
1013     { "ERRusempx", 250, "Temp unable to support Raw, use MPX mode." },
1014     { "ERRusestd", 251, "Temp unable to support Raw, use standard read/write." },
1015     { "ERRcontmpx", 252, "Continue in MPX mode." },
1016     { "ERRreserved", 253, "reserved." },
1017     { "ERRreserved", 254, "reserved." },
1018     { "ERRnosupport", 0xFFFF, "Function not supported." },
1019     { NULL, -1, NULL }
1020 };
1021 
1022 /* Hard Error Messages */
1023 static const err_code_struct hard_msgs[] = {
1024     { "ERRnowrite", 19, "Attempt to write on write-protected diskette." },
1025     { "ERRbadunit", 20, "Unknown unit." },
1026     { "ERRnotready", 21, "Drive not ready." },
1027     { "ERRbadcmd", 22, "Unknown command." },
1028     { "ERRdata", 23, "Data error (CRC)." },
1029     { "ERRbadreq", 24, "Bad request structure length." },
1030     { "ERRseek", 25 , "Seek error." },
1031     { "ERRbadmedia", 26, "Unknown media type." },
1032     { "ERRbadsector", 27, "Sector not found." },
1033     { "ERRnopaper", 28, "Printer out of paper." },
1034     { "ERRwrite", 29, "Write fault." },
1035     { "ERRread", 30, "Read fault." },
1036     { "ERRgeneral", 31, "General failure." },
1037     { "ERRbadshare", 32, "A open conflicts with an existing open." },
1038     { "ERRlock", 33, "A Lock request conflicted with an existing lock or specified an invalid mode, or an Unlock requested attempted to remove a lock held by another process." },
1039     { "ERRwrongdisk", 34, "The wrong disk was found in a drive." },
1040     { "ERRFCBUnavail", 35, "No FCBs are available to process request." },
1041     { "ERRsharebufexc", 36, "A sharing buffer has been exceeded." },
1042     { NULL, -1, NULL }
1043 };
1044 
1045 static const struct {
1046     int code;
1047     const char *class;
1048     const err_code_struct *err_msgs;
1049 } err_classes[] = {
1050     { 0, "SUCCESS", NULL },
1051     { 0x01, "ERRDOS", dos_msgs },
1052     { 0x02, "ERRSRV", server_msgs },
1053     { 0x03, "ERRHRD", hard_msgs },
1054     { 0x04, "ERRXOS", NULL },
1055     { 0xE1, "ERRRMX1", NULL },
1056     { 0xE2, "ERRRMX2", NULL },
1057     { 0xE3, "ERRRMX3", NULL },
1058     { 0xFF, "ERRCMD", NULL },
1059     { -1, NULL, NULL }
1060 };
1061 
1062 /*
1063  * return a SMB error string from a SMB buffer
1064  */
1065 const char *
smb_errstr(int class,int num)1066 smb_errstr(int class, int num)
1067 {
1068     static char ret[128];
1069     int i, j;
1070 
1071     ret[0] = 0;
1072 
1073     for (i = 0; err_classes[i].class; i++)
1074           if (err_classes[i].code == class) {
1075               if (err_classes[i].err_msgs) {
1076                     const err_code_struct *err = err_classes[i].err_msgs;
1077                     for (j = 0; err[j].name; j++)
1078                         if (num == err[j].code) {
1079                               snprintf(ret, sizeof(ret), "%s - %s (%s)",
1080                                   err_classes[i].class, err[j].name, err[j].message);
1081                               return ret;
1082                         }
1083               }
1084 
1085               snprintf(ret, sizeof(ret), "%s - %d", err_classes[i].class, num);
1086               return ret;
1087           }
1088 
1089     snprintf(ret, sizeof(ret), "ERROR: Unknown error (%d,%d)", class, num);
1090     return(ret);
1091 }
1092 
1093 typedef struct {
1094     uint32_t code;
1095     const char *name;
1096 } nt_err_code_struct;
1097 
1098 /*
1099  * NT Error codes
1100  */
1101 static const nt_err_code_struct nt_errors[] = {
1102   { 0x00000000, "STATUS_SUCCESS" },
1103   { 0x00000000, "STATUS_WAIT_0" },
1104   { 0x00000001, "STATUS_WAIT_1" },
1105   { 0x00000002, "STATUS_WAIT_2" },
1106   { 0x00000003, "STATUS_WAIT_3" },
1107   { 0x0000003F, "STATUS_WAIT_63" },
1108   { 0x00000080, "STATUS_ABANDONED" },
1109   { 0x00000080, "STATUS_ABANDONED_WAIT_0" },
1110   { 0x000000BF, "STATUS_ABANDONED_WAIT_63" },
1111   { 0x000000C0, "STATUS_USER_APC" },
1112   { 0x00000100, "STATUS_KERNEL_APC" },
1113   { 0x00000101, "STATUS_ALERTED" },
1114   { 0x00000102, "STATUS_TIMEOUT" },
1115   { 0x00000103, "STATUS_PENDING" },
1116   { 0x00000104, "STATUS_REPARSE" },
1117   { 0x00000105, "STATUS_MORE_ENTRIES" },
1118   { 0x00000106, "STATUS_NOT_ALL_ASSIGNED" },
1119   { 0x00000107, "STATUS_SOME_NOT_MAPPED" },
1120   { 0x00000108, "STATUS_OPLOCK_BREAK_IN_PROGRESS" },
1121   { 0x00000109, "STATUS_VOLUME_MOUNTED" },
1122   { 0x0000010A, "STATUS_RXACT_COMMITTED" },
1123   { 0x0000010B, "STATUS_NOTIFY_CLEANUP" },
1124   { 0x0000010C, "STATUS_NOTIFY_ENUM_DIR" },
1125   { 0x0000010D, "STATUS_NO_QUOTAS_FOR_ACCOUNT" },
1126   { 0x0000010E, "STATUS_PRIMARY_TRANSPORT_CONNECT_FAILED" },
1127   { 0x00000110, "STATUS_PAGE_FAULT_TRANSITION" },
1128   { 0x00000111, "STATUS_PAGE_FAULT_DEMAND_ZERO" },
1129   { 0x00000112, "STATUS_PAGE_FAULT_COPY_ON_WRITE" },
1130   { 0x00000113, "STATUS_PAGE_FAULT_GUARD_PAGE" },
1131   { 0x00000114, "STATUS_PAGE_FAULT_PAGING_FILE" },
1132   { 0x00000115, "STATUS_CACHE_PAGE_LOCKED" },
1133   { 0x00000116, "STATUS_CRASH_DUMP" },
1134   { 0x00000117, "STATUS_BUFFER_ALL_ZEROS" },
1135   { 0x00000118, "STATUS_REPARSE_OBJECT" },
1136   { 0x0000045C, "STATUS_NO_SHUTDOWN_IN_PROGRESS" },
1137   { 0x40000000, "STATUS_OBJECT_NAME_EXISTS" },
1138   { 0x40000001, "STATUS_THREAD_WAS_SUSPENDED" },
1139   { 0x40000002, "STATUS_WORKING_SET_LIMIT_RANGE" },
1140   { 0x40000003, "STATUS_IMAGE_NOT_AT_BASE" },
1141   { 0x40000004, "STATUS_RXACT_STATE_CREATED" },
1142   { 0x40000005, "STATUS_SEGMENT_NOTIFICATION" },
1143   { 0x40000006, "STATUS_LOCAL_USER_SESSION_KEY" },
1144   { 0x40000007, "STATUS_BAD_CURRENT_DIRECTORY" },
1145   { 0x40000008, "STATUS_SERIAL_MORE_WRITES" },
1146   { 0x40000009, "STATUS_REGISTRY_RECOVERED" },
1147   { 0x4000000A, "STATUS_FT_READ_RECOVERY_FROM_BACKUP" },
1148   { 0x4000000B, "STATUS_FT_WRITE_RECOVERY" },
1149   { 0x4000000C, "STATUS_SERIAL_COUNTER_TIMEOUT" },
1150   { 0x4000000D, "STATUS_NULL_LM_PASSWORD" },
1151   { 0x4000000E, "STATUS_IMAGE_MACHINE_TYPE_MISMATCH" },
1152   { 0x4000000F, "STATUS_RECEIVE_PARTIAL" },
1153   { 0x40000010, "STATUS_RECEIVE_EXPEDITED" },
1154   { 0x40000011, "STATUS_RECEIVE_PARTIAL_EXPEDITED" },
1155   { 0x40000012, "STATUS_EVENT_DONE" },
1156   { 0x40000013, "STATUS_EVENT_PENDING" },
1157   { 0x40000014, "STATUS_CHECKING_FILE_SYSTEM" },
1158   { 0x40000015, "STATUS_FATAL_APP_EXIT" },
1159   { 0x40000016, "STATUS_PREDEFINED_HANDLE" },
1160   { 0x40000017, "STATUS_WAS_UNLOCKED" },
1161   { 0x40000018, "STATUS_SERVICE_NOTIFICATION" },
1162   { 0x40000019, "STATUS_WAS_LOCKED" },
1163   { 0x4000001A, "STATUS_LOG_HARD_ERROR" },
1164   { 0x4000001B, "STATUS_ALREADY_WIN32" },
1165   { 0x4000001C, "STATUS_WX86_UNSIMULATE" },
1166   { 0x4000001D, "STATUS_WX86_CONTINUE" },
1167   { 0x4000001E, "STATUS_WX86_SINGLE_STEP" },
1168   { 0x4000001F, "STATUS_WX86_BREAKPOINT" },
1169   { 0x40000020, "STATUS_WX86_EXCEPTION_CONTINUE" },
1170   { 0x40000021, "STATUS_WX86_EXCEPTION_LASTCHANCE" },
1171   { 0x40000022, "STATUS_WX86_EXCEPTION_CHAIN" },
1172   { 0x40000023, "STATUS_IMAGE_MACHINE_TYPE_MISMATCH_EXE" },
1173   { 0x40000024, "STATUS_NO_YIELD_PERFORMED" },
1174   { 0x40000025, "STATUS_TIMER_RESUME_IGNORED" },
1175   { 0x80000001, "STATUS_GUARD_PAGE_VIOLATION" },
1176   { 0x80000002, "STATUS_DATATYPE_MISALIGNMENT" },
1177   { 0x80000003, "STATUS_BREAKPOINT" },
1178   { 0x80000004, "STATUS_SINGLE_STEP" },
1179   { 0x80000005, "STATUS_BUFFER_OVERFLOW" },
1180   { 0x80000006, "STATUS_NO_MORE_FILES" },
1181   { 0x80000007, "STATUS_WAKE_SYSTEM_DEBUGGER" },
1182   { 0x8000000A, "STATUS_HANDLES_CLOSED" },
1183   { 0x8000000B, "STATUS_NO_INHERITANCE" },
1184   { 0x8000000C, "STATUS_GUID_SUBSTITUTION_MADE" },
1185   { 0x8000000D, "STATUS_PARTIAL_COPY" },
1186   { 0x8000000E, "STATUS_DEVICE_PAPER_EMPTY" },
1187   { 0x8000000F, "STATUS_DEVICE_POWERED_OFF" },
1188   { 0x80000010, "STATUS_DEVICE_OFF_LINE" },
1189   { 0x80000011, "STATUS_DEVICE_BUSY" },
1190   { 0x80000012, "STATUS_NO_MORE_EAS" },
1191   { 0x80000013, "STATUS_INVALID_EA_NAME" },
1192   { 0x80000014, "STATUS_EA_LIST_INCONSISTENT" },
1193   { 0x80000015, "STATUS_INVALID_EA_FLAG" },
1194   { 0x80000016, "STATUS_VERIFY_REQUIRED" },
1195   { 0x80000017, "STATUS_EXTRANEOUS_INFORMATION" },
1196   { 0x80000018, "STATUS_RXACT_COMMIT_NECESSARY" },
1197   { 0x8000001A, "STATUS_NO_MORE_ENTRIES" },
1198   { 0x8000001B, "STATUS_FILEMARK_DETECTED" },
1199   { 0x8000001C, "STATUS_MEDIA_CHANGED" },
1200   { 0x8000001D, "STATUS_BUS_RESET" },
1201   { 0x8000001E, "STATUS_END_OF_MEDIA" },
1202   { 0x8000001F, "STATUS_BEGINNING_OF_MEDIA" },
1203   { 0x80000020, "STATUS_MEDIA_CHECK" },
1204   { 0x80000021, "STATUS_SETMARK_DETECTED" },
1205   { 0x80000022, "STATUS_NO_DATA_DETECTED" },
1206   { 0x80000023, "STATUS_REDIRECTOR_HAS_OPEN_HANDLES" },
1207   { 0x80000024, "STATUS_SERVER_HAS_OPEN_HANDLES" },
1208   { 0x80000025, "STATUS_ALREADY_DISCONNECTED" },
1209   { 0x80000026, "STATUS_LONGJUMP" },
1210   { 0x80040111, "MAPI_E_LOGON_FAILED" },
1211   { 0x80090300, "SEC_E_INSUFFICIENT_MEMORY" },
1212   { 0x80090301, "SEC_E_INVALID_HANDLE" },
1213   { 0x80090302, "SEC_E_UNSUPPORTED_FUNCTION" },
1214   { 0x8009030B, "SEC_E_NO_IMPERSONATION" },
1215   { 0x8009030D, "SEC_E_UNKNOWN_CREDENTIALS" },
1216   { 0x8009030E, "SEC_E_NO_CREDENTIALS" },
1217   { 0x8009030F, "SEC_E_MESSAGE_ALTERED" },
1218   { 0x80090310, "SEC_E_OUT_OF_SEQUENCE" },
1219   { 0x80090311, "SEC_E_NO_AUTHENTICATING_AUTHORITY" },
1220   { 0xC0000001, "STATUS_UNSUCCESSFUL" },
1221   { 0xC0000002, "STATUS_NOT_IMPLEMENTED" },
1222   { 0xC0000003, "STATUS_INVALID_INFO_CLASS" },
1223   { 0xC0000004, "STATUS_INFO_LENGTH_MISMATCH" },
1224   { 0xC0000005, "STATUS_ACCESS_VIOLATION" },
1225   { 0xC0000006, "STATUS_IN_PAGE_ERROR" },
1226   { 0xC0000007, "STATUS_PAGEFILE_QUOTA" },
1227   { 0xC0000008, "STATUS_INVALID_HANDLE" },
1228   { 0xC0000009, "STATUS_BAD_INITIAL_STACK" },
1229   { 0xC000000A, "STATUS_BAD_INITIAL_PC" },
1230   { 0xC000000B, "STATUS_INVALID_CID" },
1231   { 0xC000000C, "STATUS_TIMER_NOT_CANCELED" },
1232   { 0xC000000D, "STATUS_INVALID_PARAMETER" },
1233   { 0xC000000E, "STATUS_NO_SUCH_DEVICE" },
1234   { 0xC000000F, "STATUS_NO_SUCH_FILE" },
1235   { 0xC0000010, "STATUS_INVALID_DEVICE_REQUEST" },
1236   { 0xC0000011, "STATUS_END_OF_FILE" },
1237   { 0xC0000012, "STATUS_WRONG_VOLUME" },
1238   { 0xC0000013, "STATUS_NO_MEDIA_IN_DEVICE" },
1239   { 0xC0000014, "STATUS_UNRECOGNIZED_MEDIA" },
1240   { 0xC0000015, "STATUS_NONEXISTENT_SECTOR" },
1241   { 0xC0000016, "STATUS_MORE_PROCESSING_REQUIRED" },
1242   { 0xC0000017, "STATUS_NO_MEMORY" },
1243   { 0xC0000018, "STATUS_CONFLICTING_ADDRESSES" },
1244   { 0xC0000019, "STATUS_NOT_MAPPED_VIEW" },
1245   { 0xC000001A, "STATUS_UNABLE_TO_FREE_VM" },
1246   { 0xC000001B, "STATUS_UNABLE_TO_DELETE_SECTION" },
1247   { 0xC000001C, "STATUS_INVALID_SYSTEM_SERVICE" },
1248   { 0xC000001D, "STATUS_ILLEGAL_INSTRUCTION" },
1249   { 0xC000001E, "STATUS_INVALID_LOCK_SEQUENCE" },
1250   { 0xC000001F, "STATUS_INVALID_VIEW_SIZE" },
1251   { 0xC0000020, "STATUS_INVALID_FILE_FOR_SECTION" },
1252   { 0xC0000021, "STATUS_ALREADY_COMMITTED" },
1253   { 0xC0000022, "STATUS_ACCESS_DENIED" },
1254   { 0xC0000023, "STATUS_BUFFER_TOO_SMALL" },
1255   { 0xC0000024, "STATUS_OBJECT_TYPE_MISMATCH" },
1256   { 0xC0000025, "STATUS_NONCONTINUABLE_EXCEPTION" },
1257   { 0xC0000026, "STATUS_INVALID_DISPOSITION" },
1258   { 0xC0000027, "STATUS_UNWIND" },
1259   { 0xC0000028, "STATUS_BAD_STACK" },
1260   { 0xC0000029, "STATUS_INVALID_UNWIND_TARGET" },
1261   { 0xC000002A, "STATUS_NOT_LOCKED" },
1262   { 0xC000002B, "STATUS_PARITY_ERROR" },
1263   { 0xC000002C, "STATUS_UNABLE_TO_DECOMMIT_VM" },
1264   { 0xC000002D, "STATUS_NOT_COMMITTED" },
1265   { 0xC000002E, "STATUS_INVALID_PORT_ATTRIBUTES" },
1266   { 0xC000002F, "STATUS_PORT_MESSAGE_TOO_LONG" },
1267   { 0xC0000030, "STATUS_INVALID_PARAMETER_MIX" },
1268   { 0xC0000031, "STATUS_INVALID_QUOTA_LOWER" },
1269   { 0xC0000032, "STATUS_DISK_CORRUPT_ERROR" },
1270   { 0xC0000033, "STATUS_OBJECT_NAME_INVALID" },
1271   { 0xC0000034, "STATUS_OBJECT_NAME_NOT_FOUND" },
1272   { 0xC0000035, "STATUS_OBJECT_NAME_COLLISION" },
1273   { 0xC0000037, "STATUS_PORT_DISCONNECTED" },
1274   { 0xC0000038, "STATUS_DEVICE_ALREADY_ATTACHED" },
1275   { 0xC0000039, "STATUS_OBJECT_PATH_INVALID" },
1276   { 0xC000003A, "STATUS_OBJECT_PATH_NOT_FOUND" },
1277   { 0xC000003B, "STATUS_OBJECT_PATH_SYNTAX_BAD" },
1278   { 0xC000003C, "STATUS_DATA_OVERRUN" },
1279   { 0xC000003D, "STATUS_DATA_LATE_ERROR" },
1280   { 0xC000003E, "STATUS_DATA_ERROR" },
1281   { 0xC000003F, "STATUS_CRC_ERROR" },
1282   { 0xC0000040, "STATUS_SECTION_TOO_BIG" },
1283   { 0xC0000041, "STATUS_PORT_CONNECTION_REFUSED" },
1284   { 0xC0000042, "STATUS_INVALID_PORT_HANDLE" },
1285   { 0xC0000043, "STATUS_SHARING_VIOLATION" },
1286   { 0xC0000044, "STATUS_QUOTA_EXCEEDED" },
1287   { 0xC0000045, "STATUS_INVALID_PAGE_PROTECTION" },
1288   { 0xC0000046, "STATUS_MUTANT_NOT_OWNED" },
1289   { 0xC0000047, "STATUS_SEMAPHORE_LIMIT_EXCEEDED" },
1290   { 0xC0000048, "STATUS_PORT_ALREADY_SET" },
1291   { 0xC0000049, "STATUS_SECTION_NOT_IMAGE" },
1292   { 0xC000004A, "STATUS_SUSPEND_COUNT_EXCEEDED" },
1293   { 0xC000004B, "STATUS_THREAD_IS_TERMINATING" },
1294   { 0xC000004C, "STATUS_BAD_WORKING_SET_LIMIT" },
1295   { 0xC000004D, "STATUS_INCOMPATIBLE_FILE_MAP" },
1296   { 0xC000004E, "STATUS_SECTION_PROTECTION" },
1297   { 0xC000004F, "STATUS_EAS_NOT_SUPPORTED" },
1298   { 0xC0000050, "STATUS_EA_TOO_LARGE" },
1299   { 0xC0000051, "STATUS_NONEXISTENT_EA_ENTRY" },
1300   { 0xC0000052, "STATUS_NO_EAS_ON_FILE" },
1301   { 0xC0000053, "STATUS_EA_CORRUPT_ERROR" },
1302   { 0xC0000054, "STATUS_FILE_LOCK_CONFLICT" },
1303   { 0xC0000055, "STATUS_LOCK_NOT_GRANTED" },
1304   { 0xC0000056, "STATUS_DELETE_PENDING" },
1305   { 0xC0000057, "STATUS_CTL_FILE_NOT_SUPPORTED" },
1306   { 0xC0000058, "STATUS_UNKNOWN_REVISION" },
1307   { 0xC0000059, "STATUS_REVISION_MISMATCH" },
1308   { 0xC000005A, "STATUS_INVALID_OWNER" },
1309   { 0xC000005B, "STATUS_INVALID_PRIMARY_GROUP" },
1310   { 0xC000005C, "STATUS_NO_IMPERSONATION_TOKEN" },
1311   { 0xC000005D, "STATUS_CANT_DISABLE_MANDATORY" },
1312   { 0xC000005E, "STATUS_NO_LOGON_SERVERS" },
1313   { 0xC000005F, "STATUS_NO_SUCH_LOGON_SESSION" },
1314   { 0xC0000060, "STATUS_NO_SUCH_PRIVILEGE" },
1315   { 0xC0000061, "STATUS_PRIVILEGE_NOT_HELD" },
1316   { 0xC0000062, "STATUS_INVALID_ACCOUNT_NAME" },
1317   { 0xC0000063, "STATUS_USER_EXISTS" },
1318   { 0xC0000064, "STATUS_NO_SUCH_USER" },
1319   { 0xC0000065, "STATUS_GROUP_EXISTS" },
1320   { 0xC0000066, "STATUS_NO_SUCH_GROUP" },
1321   { 0xC0000067, "STATUS_MEMBER_IN_GROUP" },
1322   { 0xC0000068, "STATUS_MEMBER_NOT_IN_GROUP" },
1323   { 0xC0000069, "STATUS_LAST_ADMIN" },
1324   { 0xC000006A, "STATUS_WRONG_PASSWORD" },
1325   { 0xC000006B, "STATUS_ILL_FORMED_PASSWORD" },
1326   { 0xC000006C, "STATUS_PASSWORD_RESTRICTION" },
1327   { 0xC000006D, "STATUS_LOGON_FAILURE" },
1328   { 0xC000006E, "STATUS_ACCOUNT_RESTRICTION" },
1329   { 0xC000006F, "STATUS_INVALID_LOGON_HOURS" },
1330   { 0xC0000070, "STATUS_INVALID_WORKSTATION" },
1331   { 0xC0000071, "STATUS_PASSWORD_EXPIRED" },
1332   { 0xC0000072, "STATUS_ACCOUNT_DISABLED" },
1333   { 0xC0000073, "STATUS_NONE_MAPPED" },
1334   { 0xC0000074, "STATUS_TOO_MANY_LUIDS_REQUESTED" },
1335   { 0xC0000075, "STATUS_LUIDS_EXHAUSTED" },
1336   { 0xC0000076, "STATUS_INVALID_SUB_AUTHORITY" },
1337   { 0xC0000077, "STATUS_INVALID_ACL" },
1338   { 0xC0000078, "STATUS_INVALID_SID" },
1339   { 0xC0000079, "STATUS_INVALID_SECURITY_DESCR" },
1340   { 0xC000007A, "STATUS_PROCEDURE_NOT_FOUND" },
1341   { 0xC000007B, "STATUS_INVALID_IMAGE_FORMAT" },
1342   { 0xC000007C, "STATUS_NO_TOKEN" },
1343   { 0xC000007D, "STATUS_BAD_INHERITANCE_ACL" },
1344   { 0xC000007E, "STATUS_RANGE_NOT_LOCKED" },
1345   { 0xC000007F, "STATUS_DISK_FULL" },
1346   { 0xC0000080, "STATUS_SERVER_DISABLED" },
1347   { 0xC0000081, "STATUS_SERVER_NOT_DISABLED" },
1348   { 0xC0000082, "STATUS_TOO_MANY_GUIDS_REQUESTED" },
1349   { 0xC0000083, "STATUS_GUIDS_EXHAUSTED" },
1350   { 0xC0000084, "STATUS_INVALID_ID_AUTHORITY" },
1351   { 0xC0000085, "STATUS_AGENTS_EXHAUSTED" },
1352   { 0xC0000086, "STATUS_INVALID_VOLUME_LABEL" },
1353   { 0xC0000087, "STATUS_SECTION_NOT_EXTENDED" },
1354   { 0xC0000088, "STATUS_NOT_MAPPED_DATA" },
1355   { 0xC0000089, "STATUS_RESOURCE_DATA_NOT_FOUND" },
1356   { 0xC000008A, "STATUS_RESOURCE_TYPE_NOT_FOUND" },
1357   { 0xC000008B, "STATUS_RESOURCE_NAME_NOT_FOUND" },
1358   { 0xC000008C, "STATUS_ARRAY_BOUNDS_EXCEEDED" },
1359   { 0xC000008D, "STATUS_FLOAT_DENORMAL_OPERAND" },
1360   { 0xC000008E, "STATUS_FLOAT_DIVIDE_BY_ZERO" },
1361   { 0xC000008F, "STATUS_FLOAT_INEXACT_RESULT" },
1362   { 0xC0000090, "STATUS_FLOAT_INVALID_OPERATION" },
1363   { 0xC0000091, "STATUS_FLOAT_OVERFLOW" },
1364   { 0xC0000092, "STATUS_FLOAT_STACK_CHECK" },
1365   { 0xC0000093, "STATUS_FLOAT_UNDERFLOW" },
1366   { 0xC0000094, "STATUS_INTEGER_DIVIDE_BY_ZERO" },
1367   { 0xC0000095, "STATUS_INTEGER_OVERFLOW" },
1368   { 0xC0000096, "STATUS_PRIVILEGED_INSTRUCTION" },
1369   { 0xC0000097, "STATUS_TOO_MANY_PAGING_FILES" },
1370   { 0xC0000098, "STATUS_FILE_INVALID" },
1371   { 0xC0000099, "STATUS_ALLOTTED_SPACE_EXCEEDED" },
1372   { 0xC000009A, "STATUS_INSUFFICIENT_RESOURCES" },
1373   { 0xC000009B, "STATUS_DFS_EXIT_PATH_FOUND" },
1374   { 0xC000009C, "STATUS_DEVICE_DATA_ERROR" },
1375   { 0xC000009D, "STATUS_DEVICE_NOT_CONNECTED" },
1376   { 0xC000009E, "STATUS_DEVICE_POWER_FAILURE" },
1377   { 0xC000009F, "STATUS_FREE_VM_NOT_AT_BASE" },
1378   { 0xC00000A0, "STATUS_MEMORY_NOT_ALLOCATED" },
1379   { 0xC00000A1, "STATUS_WORKING_SET_QUOTA" },
1380   { 0xC00000A2, "STATUS_MEDIA_WRITE_PROTECTED" },
1381   { 0xC00000A3, "STATUS_DEVICE_NOT_READY" },
1382   { 0xC00000A4, "STATUS_INVALID_GROUP_ATTRIBUTES" },
1383   { 0xC00000A5, "STATUS_BAD_IMPERSONATION_LEVEL" },
1384   { 0xC00000A6, "STATUS_CANT_OPEN_ANONYMOUS" },
1385   { 0xC00000A7, "STATUS_BAD_VALIDATION_CLASS" },
1386   { 0xC00000A8, "STATUS_BAD_TOKEN_TYPE" },
1387   { 0xC00000A9, "STATUS_BAD_MASTER_BOOT_RECORD" },
1388   { 0xC00000AA, "STATUS_INSTRUCTION_MISALIGNMENT" },
1389   { 0xC00000AB, "STATUS_INSTANCE_NOT_AVAILABLE" },
1390   { 0xC00000AC, "STATUS_PIPE_NOT_AVAILABLE" },
1391   { 0xC00000AD, "STATUS_INVALID_PIPE_STATE" },
1392   { 0xC00000AE, "STATUS_PIPE_BUSY" },
1393   { 0xC00000AF, "STATUS_ILLEGAL_FUNCTION" },
1394   { 0xC00000B0, "STATUS_PIPE_DISCONNECTED" },
1395   { 0xC00000B1, "STATUS_PIPE_CLOSING" },
1396   { 0xC00000B2, "STATUS_PIPE_CONNECTED" },
1397   { 0xC00000B3, "STATUS_PIPE_LISTENING" },
1398   { 0xC00000B4, "STATUS_INVALID_READ_MODE" },
1399   { 0xC00000B5, "STATUS_IO_TIMEOUT" },
1400   { 0xC00000B6, "STATUS_FILE_FORCED_CLOSED" },
1401   { 0xC00000B7, "STATUS_PROFILING_NOT_STARTED" },
1402   { 0xC00000B8, "STATUS_PROFILING_NOT_STOPPED" },
1403   { 0xC00000B9, "STATUS_COULD_NOT_INTERPRET" },
1404   { 0xC00000BA, "STATUS_FILE_IS_A_DIRECTORY" },
1405   { 0xC00000BB, "STATUS_NOT_SUPPORTED" },
1406   { 0xC00000BC, "STATUS_REMOTE_NOT_LISTENING" },
1407   { 0xC00000BD, "STATUS_DUPLICATE_NAME" },
1408   { 0xC00000BE, "STATUS_BAD_NETWORK_PATH" },
1409   { 0xC00000BF, "STATUS_NETWORK_BUSY" },
1410   { 0xC00000C0, "STATUS_DEVICE_DOES_NOT_EXIST" },
1411   { 0xC00000C1, "STATUS_TOO_MANY_COMMANDS" },
1412   { 0xC00000C2, "STATUS_ADAPTER_HARDWARE_ERROR" },
1413   { 0xC00000C3, "STATUS_INVALID_NETWORK_RESPONSE" },
1414   { 0xC00000C4, "STATUS_UNEXPECTED_NETWORK_ERROR" },
1415   { 0xC00000C5, "STATUS_BAD_REMOTE_ADAPTER" },
1416   { 0xC00000C6, "STATUS_PRINT_QUEUE_FULL" },
1417   { 0xC00000C7, "STATUS_NO_SPOOL_SPACE" },
1418   { 0xC00000C8, "STATUS_PRINT_CANCELLED" },
1419   { 0xC00000C9, "STATUS_NETWORK_NAME_DELETED" },
1420   { 0xC00000CA, "STATUS_NETWORK_ACCESS_DENIED" },
1421   { 0xC00000CB, "STATUS_BAD_DEVICE_TYPE" },
1422   { 0xC00000CC, "STATUS_BAD_NETWORK_NAME" },
1423   { 0xC00000CD, "STATUS_TOO_MANY_NAMES" },
1424   { 0xC00000CE, "STATUS_TOO_MANY_SESSIONS" },
1425   { 0xC00000CF, "STATUS_SHARING_PAUSED" },
1426   { 0xC00000D0, "STATUS_REQUEST_NOT_ACCEPTED" },
1427   { 0xC00000D1, "STATUS_REDIRECTOR_PAUSED" },
1428   { 0xC00000D2, "STATUS_NET_WRITE_FAULT" },
1429   { 0xC00000D3, "STATUS_PROFILING_AT_LIMIT" },
1430   { 0xC00000D4, "STATUS_NOT_SAME_DEVICE" },
1431   { 0xC00000D5, "STATUS_FILE_RENAMED" },
1432   { 0xC00000D6, "STATUS_VIRTUAL_CIRCUIT_CLOSED" },
1433   { 0xC00000D7, "STATUS_NO_SECURITY_ON_OBJECT" },
1434   { 0xC00000D8, "STATUS_CANT_WAIT" },
1435   { 0xC00000D9, "STATUS_PIPE_EMPTY" },
1436   { 0xC00000DA, "STATUS_CANT_ACCESS_DOMAIN_INFO" },
1437   { 0xC00000DB, "STATUS_CANT_TERMINATE_SELF" },
1438   { 0xC00000DC, "STATUS_INVALID_SERVER_STATE" },
1439   { 0xC00000DD, "STATUS_INVALID_DOMAIN_STATE" },
1440   { 0xC00000DE, "STATUS_INVALID_DOMAIN_ROLE" },
1441   { 0xC00000DF, "STATUS_NO_SUCH_DOMAIN" },
1442   { 0xC00000E0, "STATUS_DOMAIN_EXISTS" },
1443   { 0xC00000E1, "STATUS_DOMAIN_LIMIT_EXCEEDED" },
1444   { 0xC00000E2, "STATUS_OPLOCK_NOT_GRANTED" },
1445   { 0xC00000E3, "STATUS_INVALID_OPLOCK_PROTOCOL" },
1446   { 0xC00000E4, "STATUS_INTERNAL_DB_CORRUPTION" },
1447   { 0xC00000E5, "STATUS_INTERNAL_ERROR" },
1448   { 0xC00000E6, "STATUS_GENERIC_NOT_MAPPED" },
1449   { 0xC00000E7, "STATUS_BAD_DESCRIPTOR_FORMAT" },
1450   { 0xC00000E8, "STATUS_INVALID_USER_BUFFER" },
1451   { 0xC00000E9, "STATUS_UNEXPECTED_IO_ERROR" },
1452   { 0xC00000EA, "STATUS_UNEXPECTED_MM_CREATE_ERR" },
1453   { 0xC00000EB, "STATUS_UNEXPECTED_MM_MAP_ERROR" },
1454   { 0xC00000EC, "STATUS_UNEXPECTED_MM_EXTEND_ERR" },
1455   { 0xC00000ED, "STATUS_NOT_LOGON_PROCESS" },
1456   { 0xC00000EE, "STATUS_LOGON_SESSION_EXISTS" },
1457   { 0xC00000EF, "STATUS_INVALID_PARAMETER_1" },
1458   { 0xC00000F0, "STATUS_INVALID_PARAMETER_2" },
1459   { 0xC00000F1, "STATUS_INVALID_PARAMETER_3" },
1460   { 0xC00000F2, "STATUS_INVALID_PARAMETER_4" },
1461   { 0xC00000F3, "STATUS_INVALID_PARAMETER_5" },
1462   { 0xC00000F4, "STATUS_INVALID_PARAMETER_6" },
1463   { 0xC00000F5, "STATUS_INVALID_PARAMETER_7" },
1464   { 0xC00000F6, "STATUS_INVALID_PARAMETER_8" },
1465   { 0xC00000F7, "STATUS_INVALID_PARAMETER_9" },
1466   { 0xC00000F8, "STATUS_INVALID_PARAMETER_10" },
1467   { 0xC00000F9, "STATUS_INVALID_PARAMETER_11" },
1468   { 0xC00000FA, "STATUS_INVALID_PARAMETER_12" },
1469   { 0xC00000FB, "STATUS_REDIRECTOR_NOT_STARTED" },
1470   { 0xC00000FC, "STATUS_REDIRECTOR_STARTED" },
1471   { 0xC00000FD, "STATUS_STACK_OVERFLOW" },
1472   { 0xC00000FE, "STATUS_NO_SUCH_PACKAGE" },
1473   { 0xC00000FF, "STATUS_BAD_FUNCTION_TABLE" },
1474   { 0xC0000100, "STATUS_VARIABLE_NOT_FOUND" },
1475   { 0xC0000101, "STATUS_DIRECTORY_NOT_EMPTY" },
1476   { 0xC0000102, "STATUS_FILE_CORRUPT_ERROR" },
1477   { 0xC0000103, "STATUS_NOT_A_DIRECTORY" },
1478   { 0xC0000104, "STATUS_BAD_LOGON_SESSION_STATE" },
1479   { 0xC0000105, "STATUS_LOGON_SESSION_COLLISION" },
1480   { 0xC0000106, "STATUS_NAME_TOO_LONG" },
1481   { 0xC0000107, "STATUS_FILES_OPEN" },
1482   { 0xC0000108, "STATUS_CONNECTION_IN_USE" },
1483   { 0xC0000109, "STATUS_MESSAGE_NOT_FOUND" },
1484   { 0xC000010A, "STATUS_PROCESS_IS_TERMINATING" },
1485   { 0xC000010B, "STATUS_INVALID_LOGON_TYPE" },
1486   { 0xC000010C, "STATUS_NO_GUID_TRANSLATION" },
1487   { 0xC000010D, "STATUS_CANNOT_IMPERSONATE" },
1488   { 0xC000010E, "STATUS_IMAGE_ALREADY_LOADED" },
1489   { 0xC000010F, "STATUS_ABIOS_NOT_PRESENT" },
1490   { 0xC0000110, "STATUS_ABIOS_LID_NOT_EXIST" },
1491   { 0xC0000111, "STATUS_ABIOS_LID_ALREADY_OWNED" },
1492   { 0xC0000112, "STATUS_ABIOS_NOT_LID_OWNER" },
1493   { 0xC0000113, "STATUS_ABIOS_INVALID_COMMAND" },
1494   { 0xC0000114, "STATUS_ABIOS_INVALID_LID" },
1495   { 0xC0000115, "STATUS_ABIOS_SELECTOR_NOT_AVAILABLE" },
1496   { 0xC0000116, "STATUS_ABIOS_INVALID_SELECTOR" },
1497   { 0xC0000117, "STATUS_NO_LDT" },
1498   { 0xC0000118, "STATUS_INVALID_LDT_SIZE" },
1499   { 0xC0000119, "STATUS_INVALID_LDT_OFFSET" },
1500   { 0xC000011A, "STATUS_INVALID_LDT_DESCRIPTOR" },
1501   { 0xC000011B, "STATUS_INVALID_IMAGE_NE_FORMAT" },
1502   { 0xC000011C, "STATUS_RXACT_INVALID_STATE" },
1503   { 0xC000011D, "STATUS_RXACT_COMMIT_FAILURE" },
1504   { 0xC000011E, "STATUS_MAPPED_FILE_SIZE_ZERO" },
1505   { 0xC000011F, "STATUS_TOO_MANY_OPENED_FILES" },
1506   { 0xC0000120, "STATUS_CANCELLED" },
1507   { 0xC0000121, "STATUS_CANNOT_DELETE" },
1508   { 0xC0000122, "STATUS_INVALID_COMPUTER_NAME" },
1509   { 0xC0000123, "STATUS_FILE_DELETED" },
1510   { 0xC0000124, "STATUS_SPECIAL_ACCOUNT" },
1511   { 0xC0000125, "STATUS_SPECIAL_GROUP" },
1512   { 0xC0000126, "STATUS_SPECIAL_USER" },
1513   { 0xC0000127, "STATUS_MEMBERS_PRIMARY_GROUP" },
1514   { 0xC0000128, "STATUS_FILE_CLOSED" },
1515   { 0xC0000129, "STATUS_TOO_MANY_THREADS" },
1516   { 0xC000012A, "STATUS_THREAD_NOT_IN_PROCESS" },
1517   { 0xC000012B, "STATUS_TOKEN_ALREADY_IN_USE" },
1518   { 0xC000012C, "STATUS_PAGEFILE_QUOTA_EXCEEDED" },
1519   { 0xC000012D, "STATUS_COMMITMENT_LIMIT" },
1520   { 0xC000012E, "STATUS_INVALID_IMAGE_LE_FORMAT" },
1521   { 0xC000012F, "STATUS_INVALID_IMAGE_NOT_MZ" },
1522   { 0xC0000130, "STATUS_INVALID_IMAGE_PROTECT" },
1523   { 0xC0000131, "STATUS_INVALID_IMAGE_WIN_16" },
1524   { 0xC0000132, "STATUS_LOGON_SERVER_CONFLICT" },
1525   { 0xC0000133, "STATUS_TIME_DIFFERENCE_AT_DC" },
1526   { 0xC0000134, "STATUS_SYNCHRONIZATION_REQUIRED" },
1527   { 0xC0000135, "STATUS_DLL_NOT_FOUND" },
1528   { 0xC0000136, "STATUS_OPEN_FAILED" },
1529   { 0xC0000137, "STATUS_IO_PRIVILEGE_FAILED" },
1530   { 0xC0000138, "STATUS_ORDINAL_NOT_FOUND" },
1531   { 0xC0000139, "STATUS_ENTRYPOINT_NOT_FOUND" },
1532   { 0xC000013A, "STATUS_CONTROL_C_EXIT" },
1533   { 0xC000013B, "STATUS_LOCAL_DISCONNECT" },
1534   { 0xC000013C, "STATUS_REMOTE_DISCONNECT" },
1535   { 0xC000013D, "STATUS_REMOTE_RESOURCES" },
1536   { 0xC000013E, "STATUS_LINK_FAILED" },
1537   { 0xC000013F, "STATUS_LINK_TIMEOUT" },
1538   { 0xC0000140, "STATUS_INVALID_CONNECTION" },
1539   { 0xC0000141, "STATUS_INVALID_ADDRESS" },
1540   { 0xC0000142, "STATUS_DLL_INIT_FAILED" },
1541   { 0xC0000143, "STATUS_MISSING_SYSTEMFILE" },
1542   { 0xC0000144, "STATUS_UNHANDLED_EXCEPTION" },
1543   { 0xC0000145, "STATUS_APP_INIT_FAILURE" },
1544   { 0xC0000146, "STATUS_PAGEFILE_CREATE_FAILED" },
1545   { 0xC0000147, "STATUS_NO_PAGEFILE" },
1546   { 0xC0000148, "STATUS_INVALID_LEVEL" },
1547   { 0xC0000149, "STATUS_WRONG_PASSWORD_CORE" },
1548   { 0xC000014A, "STATUS_ILLEGAL_FLOAT_CONTEXT" },
1549   { 0xC000014B, "STATUS_PIPE_BROKEN" },
1550   { 0xC000014C, "STATUS_REGISTRY_CORRUPT" },
1551   { 0xC000014D, "STATUS_REGISTRY_IO_FAILED" },
1552   { 0xC000014E, "STATUS_NO_EVENT_PAIR" },
1553   { 0xC000014F, "STATUS_UNRECOGNIZED_VOLUME" },
1554   { 0xC0000150, "STATUS_SERIAL_NO_DEVICE_INITED" },
1555   { 0xC0000151, "STATUS_NO_SUCH_ALIAS" },
1556   { 0xC0000152, "STATUS_MEMBER_NOT_IN_ALIAS" },
1557   { 0xC0000153, "STATUS_MEMBER_IN_ALIAS" },
1558   { 0xC0000154, "STATUS_ALIAS_EXISTS" },
1559   { 0xC0000155, "STATUS_LOGON_NOT_GRANTED" },
1560   { 0xC0000156, "STATUS_TOO_MANY_SECRETS" },
1561   { 0xC0000157, "STATUS_SECRET_TOO_LONG" },
1562   { 0xC0000158, "STATUS_INTERNAL_DB_ERROR" },
1563   { 0xC0000159, "STATUS_FULLSCREEN_MODE" },
1564   { 0xC000015A, "STATUS_TOO_MANY_CONTEXT_IDS" },
1565   { 0xC000015B, "STATUS_LOGON_TYPE_NOT_GRANTED" },
1566   { 0xC000015C, "STATUS_NOT_REGISTRY_FILE" },
1567   { 0xC000015D, "STATUS_NT_CROSS_ENCRYPTION_REQUIRED" },
1568   { 0xC000015E, "STATUS_DOMAIN_CTRLR_CONFIG_ERROR" },
1569   { 0xC000015F, "STATUS_FT_MISSING_MEMBER" },
1570   { 0xC0000160, "STATUS_ILL_FORMED_SERVICE_ENTRY" },
1571   { 0xC0000161, "STATUS_ILLEGAL_CHARACTER" },
1572   { 0xC0000162, "STATUS_UNMAPPABLE_CHARACTER" },
1573   { 0xC0000163, "STATUS_UNDEFINED_CHARACTER" },
1574   { 0xC0000164, "STATUS_FLOPPY_VOLUME" },
1575   { 0xC0000165, "STATUS_FLOPPY_ID_MARK_NOT_FOUND" },
1576   { 0xC0000166, "STATUS_FLOPPY_WRONG_CYLINDER" },
1577   { 0xC0000167, "STATUS_FLOPPY_UNKNOWN_ERROR" },
1578   { 0xC0000168, "STATUS_FLOPPY_BAD_REGISTERS" },
1579   { 0xC0000169, "STATUS_DISK_RECALIBRATE_FAILED" },
1580   { 0xC000016A, "STATUS_DISK_OPERATION_FAILED" },
1581   { 0xC000016B, "STATUS_DISK_RESET_FAILED" },
1582   { 0xC000016C, "STATUS_SHARED_IRQ_BUSY" },
1583   { 0xC000016D, "STATUS_FT_ORPHANING" },
1584   { 0xC000016E, "STATUS_BIOS_FAILED_TO_CONNECT_INTERRUPT" },
1585   { 0xC0000172, "STATUS_PARTITION_FAILURE" },
1586   { 0xC0000173, "STATUS_INVALID_BLOCK_LENGTH" },
1587   { 0xC0000174, "STATUS_DEVICE_NOT_PARTITIONED" },
1588   { 0xC0000175, "STATUS_UNABLE_TO_LOCK_MEDIA" },
1589   { 0xC0000176, "STATUS_UNABLE_TO_UNLOAD_MEDIA" },
1590   { 0xC0000177, "STATUS_EOM_OVERFLOW" },
1591   { 0xC0000178, "STATUS_NO_MEDIA" },
1592   { 0xC000017A, "STATUS_NO_SUCH_MEMBER" },
1593   { 0xC000017B, "STATUS_INVALID_MEMBER" },
1594   { 0xC000017C, "STATUS_KEY_DELETED" },
1595   { 0xC000017D, "STATUS_NO_LOG_SPACE" },
1596   { 0xC000017E, "STATUS_TOO_MANY_SIDS" },
1597   { 0xC000017F, "STATUS_LM_CROSS_ENCRYPTION_REQUIRED" },
1598   { 0xC0000180, "STATUS_KEY_HAS_CHILDREN" },
1599   { 0xC0000181, "STATUS_CHILD_MUST_BE_VOLATILE" },
1600   { 0xC0000182, "STATUS_DEVICE_CONFIGURATION_ERROR" },
1601   { 0xC0000183, "STATUS_DRIVER_INTERNAL_ERROR" },
1602   { 0xC0000184, "STATUS_INVALID_DEVICE_STATE" },
1603   { 0xC0000185, "STATUS_IO_DEVICE_ERROR" },
1604   { 0xC0000186, "STATUS_DEVICE_PROTOCOL_ERROR" },
1605   { 0xC0000187, "STATUS_BACKUP_CONTROLLER" },
1606   { 0xC0000188, "STATUS_LOG_FILE_FULL" },
1607   { 0xC0000189, "STATUS_TOO_LATE" },
1608   { 0xC000018A, "STATUS_NO_TRUST_LSA_SECRET" },
1609   { 0xC000018B, "STATUS_NO_TRUST_SAM_ACCOUNT" },
1610   { 0xC000018C, "STATUS_TRUSTED_DOMAIN_FAILURE" },
1611   { 0xC000018D, "STATUS_TRUSTED_RELATIONSHIP_FAILURE" },
1612   { 0xC000018E, "STATUS_EVENTLOG_FILE_CORRUPT" },
1613   { 0xC000018F, "STATUS_EVENTLOG_CANT_START" },
1614   { 0xC0000190, "STATUS_TRUST_FAILURE" },
1615   { 0xC0000191, "STATUS_MUTANT_LIMIT_EXCEEDED" },
1616   { 0xC0000192, "STATUS_NETLOGON_NOT_STARTED" },
1617   { 0xC0000193, "STATUS_ACCOUNT_EXPIRED" },
1618   { 0xC0000194, "STATUS_POSSIBLE_DEADLOCK" },
1619   { 0xC0000195, "STATUS_NETWORK_CREDENTIAL_CONFLICT" },
1620   { 0xC0000196, "STATUS_REMOTE_SESSION_LIMIT" },
1621   { 0xC0000197, "STATUS_EVENTLOG_FILE_CHANGED" },
1622   { 0xC0000198, "STATUS_NOLOGON_INTERDOMAIN_TRUST_ACCOUNT" },
1623   { 0xC0000199, "STATUS_NOLOGON_WORKSTATION_TRUST_ACCOUNT" },
1624   { 0xC000019A, "STATUS_NOLOGON_SERVER_TRUST_ACCOUNT" },
1625   { 0xC000019B, "STATUS_DOMAIN_TRUST_INCONSISTENT" },
1626   { 0xC000019C, "STATUS_FS_DRIVER_REQUIRED" },
1627   { 0xC0000202, "STATUS_NO_USER_SESSION_KEY" },
1628   { 0xC0000203, "STATUS_USER_SESSION_DELETED" },
1629   { 0xC0000204, "STATUS_RESOURCE_LANG_NOT_FOUND" },
1630   { 0xC0000205, "STATUS_INSUFF_SERVER_RESOURCES" },
1631   { 0xC0000206, "STATUS_INVALID_BUFFER_SIZE" },
1632   { 0xC0000207, "STATUS_INVALID_ADDRESS_COMPONENT" },
1633   { 0xC0000208, "STATUS_INVALID_ADDRESS_WILDCARD" },
1634   { 0xC0000209, "STATUS_TOO_MANY_ADDRESSES" },
1635   { 0xC000020A, "STATUS_ADDRESS_ALREADY_EXISTS" },
1636   { 0xC000020B, "STATUS_ADDRESS_CLOSED" },
1637   { 0xC000020C, "STATUS_CONNECTION_DISCONNECTED" },
1638   { 0xC000020D, "STATUS_CONNECTION_RESET" },
1639   { 0xC000020E, "STATUS_TOO_MANY_NODES" },
1640   { 0xC000020F, "STATUS_TRANSACTION_ABORTED" },
1641   { 0xC0000210, "STATUS_TRANSACTION_TIMED_OUT" },
1642   { 0xC0000211, "STATUS_TRANSACTION_NO_RELEASE" },
1643   { 0xC0000212, "STATUS_TRANSACTION_NO_MATCH" },
1644   { 0xC0000213, "STATUS_TRANSACTION_RESPONDED" },
1645   { 0xC0000214, "STATUS_TRANSACTION_INVALID_ID" },
1646   { 0xC0000215, "STATUS_TRANSACTION_INVALID_TYPE" },
1647   { 0xC0000216, "STATUS_NOT_SERVER_SESSION" },
1648   { 0xC0000217, "STATUS_NOT_CLIENT_SESSION" },
1649   { 0xC0000218, "STATUS_CANNOT_LOAD_REGISTRY_FILE" },
1650   { 0xC0000219, "STATUS_DEBUG_ATTACH_FAILED" },
1651   { 0xC000021A, "STATUS_SYSTEM_PROCESS_TERMINATED" },
1652   { 0xC000021B, "STATUS_DATA_NOT_ACCEPTED" },
1653   { 0xC000021C, "STATUS_NO_BROWSER_SERVERS_FOUND" },
1654   { 0xC000021D, "STATUS_VDM_HARD_ERROR" },
1655   { 0xC000021E, "STATUS_DRIVER_CANCEL_TIMEOUT" },
1656   { 0xC000021F, "STATUS_REPLY_MESSAGE_MISMATCH" },
1657   { 0xC0000220, "STATUS_MAPPED_ALIGNMENT" },
1658   { 0xC0000221, "STATUS_IMAGE_CHECKSUM_MISMATCH" },
1659   { 0xC0000222, "STATUS_LOST_WRITEBEHIND_DATA" },
1660   { 0xC0000223, "STATUS_CLIENT_SERVER_PARAMETERS_INVALID" },
1661   { 0xC0000224, "STATUS_PASSWORD_MUST_CHANGE" },
1662   { 0xC0000225, "STATUS_NOT_FOUND" },
1663   { 0xC0000226, "STATUS_NOT_TINY_STREAM" },
1664   { 0xC0000227, "STATUS_RECOVERY_FAILURE" },
1665   { 0xC0000228, "STATUS_STACK_OVERFLOW_READ" },
1666   { 0xC0000229, "STATUS_FAIL_CHECK" },
1667   { 0xC000022A, "STATUS_DUPLICATE_OBJECTID" },
1668   { 0xC000022B, "STATUS_OBJECTID_EXISTS" },
1669   { 0xC000022C, "STATUS_CONVERT_TO_LARGE" },
1670   { 0xC000022D, "STATUS_RETRY" },
1671   { 0xC000022E, "STATUS_FOUND_OUT_OF_SCOPE" },
1672   { 0xC000022F, "STATUS_ALLOCATE_BUCKET" },
1673   { 0xC0000230, "STATUS_PROPSET_NOT_FOUND" },
1674   { 0xC0000231, "STATUS_MARSHALL_OVERFLOW" },
1675   { 0xC0000232, "STATUS_INVALID_VARIANT" },
1676   { 0xC0000233, "STATUS_DOMAIN_CONTROLLER_NOT_FOUND" },
1677   { 0xC0000234, "STATUS_ACCOUNT_LOCKED_OUT" },
1678   { 0xC0000235, "STATUS_HANDLE_NOT_CLOSABLE" },
1679   { 0xC0000236, "STATUS_CONNECTION_REFUSED" },
1680   { 0xC0000237, "STATUS_GRACEFUL_DISCONNECT" },
1681   { 0xC0000238, "STATUS_ADDRESS_ALREADY_ASSOCIATED" },
1682   { 0xC0000239, "STATUS_ADDRESS_NOT_ASSOCIATED" },
1683   { 0xC000023A, "STATUS_CONNECTION_INVALID" },
1684   { 0xC000023B, "STATUS_CONNECTION_ACTIVE" },
1685   { 0xC000023C, "STATUS_NETWORK_UNREACHABLE" },
1686   { 0xC000023D, "STATUS_HOST_UNREACHABLE" },
1687   { 0xC000023E, "STATUS_PROTOCOL_UNREACHABLE" },
1688   { 0xC000023F, "STATUS_PORT_UNREACHABLE" },
1689   { 0xC0000240, "STATUS_REQUEST_ABORTED" },
1690   { 0xC0000241, "STATUS_CONNECTION_ABORTED" },
1691   { 0xC0000242, "STATUS_BAD_COMPRESSION_BUFFER" },
1692   { 0xC0000243, "STATUS_USER_MAPPED_FILE" },
1693   { 0xC0000244, "STATUS_AUDIT_FAILED" },
1694   { 0xC0000245, "STATUS_TIMER_RESOLUTION_NOT_SET" },
1695   { 0xC0000246, "STATUS_CONNECTION_COUNT_LIMIT" },
1696   { 0xC0000247, "STATUS_LOGIN_TIME_RESTRICTION" },
1697   { 0xC0000248, "STATUS_LOGIN_WKSTA_RESTRICTION" },
1698   { 0xC0000249, "STATUS_IMAGE_MP_UP_MISMATCH" },
1699   { 0xC0000250, "STATUS_INSUFFICIENT_LOGON_INFO" },
1700   { 0xC0000251, "STATUS_BAD_DLL_ENTRYPOINT" },
1701   { 0xC0000252, "STATUS_BAD_SERVICE_ENTRYPOINT" },
1702   { 0xC0000253, "STATUS_LPC_REPLY_LOST" },
1703   { 0xC0000254, "STATUS_IP_ADDRESS_CONFLICT1" },
1704   { 0xC0000255, "STATUS_IP_ADDRESS_CONFLICT2" },
1705   { 0xC0000256, "STATUS_REGISTRY_QUOTA_LIMIT" },
1706   { 0xC0000257, "STATUS_PATH_NOT_COVERED" },
1707   { 0xC0000258, "STATUS_NO_CALLBACK_ACTIVE" },
1708   { 0xC0000259, "STATUS_LICENSE_QUOTA_EXCEEDED" },
1709   { 0xC000025A, "STATUS_PWD_TOO_SHORT" },
1710   { 0xC000025B, "STATUS_PWD_TOO_RECENT" },
1711   { 0xC000025C, "STATUS_PWD_HISTORY_CONFLICT" },
1712   { 0xC000025E, "STATUS_PLUGPLAY_NO_DEVICE" },
1713   { 0xC000025F, "STATUS_UNSUPPORTED_COMPRESSION" },
1714   { 0xC0000260, "STATUS_INVALID_HW_PROFILE" },
1715   { 0xC0000261, "STATUS_INVALID_PLUGPLAY_DEVICE_PATH" },
1716   { 0xC0000262, "STATUS_DRIVER_ORDINAL_NOT_FOUND" },
1717   { 0xC0000263, "STATUS_DRIVER_ENTRYPOINT_NOT_FOUND" },
1718   { 0xC0000264, "STATUS_RESOURCE_NOT_OWNED" },
1719   { 0xC0000265, "STATUS_TOO_MANY_LINKS" },
1720   { 0xC0000266, "STATUS_QUOTA_LIST_INCONSISTENT" },
1721   { 0xC0000267, "STATUS_FILE_IS_OFFLINE" },
1722   { 0xC0000268, "STATUS_EVALUATION_EXPIRATION" },
1723   { 0xC0000269, "STATUS_ILLEGAL_DLL_RELOCATION" },
1724   { 0xC000026A, "STATUS_LICENSE_VIOLATION" },
1725   { 0xC000026B, "STATUS_DLL_INIT_FAILED_LOGOFF" },
1726   { 0xC000026C, "STATUS_DRIVER_UNABLE_TO_LOAD" },
1727   { 0xC000026D, "STATUS_DFS_UNAVAILABLE" },
1728   { 0xC000026E, "STATUS_VOLUME_DISMOUNTED" },
1729   { 0xC000026F, "STATUS_WX86_INTERNAL_ERROR" },
1730   { 0xC0000270, "STATUS_WX86_FLOAT_STACK_CHECK" },
1731   { 0xC0000271, "STATUS_VALIDATE_CONTINUE" },
1732   { 0xC0000272, "STATUS_NO_MATCH" },
1733   { 0xC0000273, "STATUS_NO_MORE_MATCHES" },
1734   { 0xC0000275, "STATUS_NOT_A_REPARSE_POINT" },
1735   { 0xC0000276, "STATUS_IO_REPARSE_TAG_INVALID" },
1736   { 0xC0000277, "STATUS_IO_REPARSE_TAG_MISMATCH" },
1737   { 0xC0000278, "STATUS_IO_REPARSE_DATA_INVALID" },
1738   { 0xC0000279, "STATUS_IO_REPARSE_TAG_NOT_HANDLED" },
1739   { 0xC0000280, "STATUS_REPARSE_POINT_NOT_RESOLVED" },
1740   { 0xC0000281, "STATUS_DIRECTORY_IS_A_REPARSE_POINT" },
1741   { 0xC0000282, "STATUS_RANGE_LIST_CONFLICT" },
1742   { 0xC0000283, "STATUS_SOURCE_ELEMENT_EMPTY" },
1743   { 0xC0000284, "STATUS_DESTINATION_ELEMENT_FULL" },
1744   { 0xC0000285, "STATUS_ILLEGAL_ELEMENT_ADDRESS" },
1745   { 0xC0000286, "STATUS_MAGAZINE_NOT_PRESENT" },
1746   { 0xC0000287, "STATUS_REINITIALIZATION_NEEDED" },
1747   { 0x80000288, "STATUS_DEVICE_REQUIRES_CLEANING" },
1748   { 0x80000289, "STATUS_DEVICE_DOOR_OPEN" },
1749   { 0xC000028A, "STATUS_ENCRYPTION_FAILED" },
1750   { 0xC000028B, "STATUS_DECRYPTION_FAILED" },
1751   { 0xC000028C, "STATUS_RANGE_NOT_FOUND" },
1752   { 0xC000028D, "STATUS_NO_RECOVERY_POLICY" },
1753   { 0xC000028E, "STATUS_NO_EFS" },
1754   { 0xC000028F, "STATUS_WRONG_EFS" },
1755   { 0xC0000290, "STATUS_NO_USER_KEYS" },
1756   { 0xC0000291, "STATUS_FILE_NOT_ENCRYPTED" },
1757   { 0xC0000292, "STATUS_NOT_EXPORT_FORMAT" },
1758   { 0xC0000293, "STATUS_FILE_ENCRYPTED" },
1759   { 0x40000294, "STATUS_WAKE_SYSTEM" },
1760   { 0xC0000295, "STATUS_WMI_GUID_NOT_FOUND" },
1761   { 0xC0000296, "STATUS_WMI_INSTANCE_NOT_FOUND" },
1762   { 0xC0000297, "STATUS_WMI_ITEMID_NOT_FOUND" },
1763   { 0xC0000298, "STATUS_WMI_TRY_AGAIN" },
1764   { 0xC0000299, "STATUS_SHARED_POLICY" },
1765   { 0xC000029A, "STATUS_POLICY_OBJECT_NOT_FOUND" },
1766   { 0xC000029B, "STATUS_POLICY_ONLY_IN_DS" },
1767   { 0xC000029C, "STATUS_VOLUME_NOT_UPGRADED" },
1768   { 0xC000029D, "STATUS_REMOTE_STORAGE_NOT_ACTIVE" },
1769   { 0xC000029E, "STATUS_REMOTE_STORAGE_MEDIA_ERROR" },
1770   { 0xC000029F, "STATUS_NO_TRACKING_SERVICE" },
1771   { 0xC00002A0, "STATUS_SERVER_SID_MISMATCH" },
1772   { 0xC00002A1, "STATUS_DS_NO_ATTRIBUTE_OR_VALUE" },
1773   { 0xC00002A2, "STATUS_DS_INVALID_ATTRIBUTE_SYNTAX" },
1774   { 0xC00002A3, "STATUS_DS_ATTRIBUTE_TYPE_UNDEFINED" },
1775   { 0xC00002A4, "STATUS_DS_ATTRIBUTE_OR_VALUE_EXISTS" },
1776   { 0xC00002A5, "STATUS_DS_BUSY" },
1777   { 0xC00002A6, "STATUS_DS_UNAVAILABLE" },
1778   { 0xC00002A7, "STATUS_DS_NO_RIDS_ALLOCATED" },
1779   { 0xC00002A8, "STATUS_DS_NO_MORE_RIDS" },
1780   { 0xC00002A9, "STATUS_DS_INCORRECT_ROLE_OWNER" },
1781   { 0xC00002AA, "STATUS_DS_RIDMGR_INIT_ERROR" },
1782   { 0xC00002AB, "STATUS_DS_OBJ_CLASS_VIOLATION" },
1783   { 0xC00002AC, "STATUS_DS_CANT_ON_NON_LEAF" },
1784   { 0xC00002AD, "STATUS_DS_CANT_ON_RDN" },
1785   { 0xC00002AE, "STATUS_DS_CANT_MOD_OBJ_CLASS" },
1786   { 0xC00002AF, "STATUS_DS_CROSS_DOM_MOVE_FAILED" },
1787   { 0xC00002B0, "STATUS_DS_GC_NOT_AVAILABLE" },
1788   { 0xC00002B1, "STATUS_DIRECTORY_SERVICE_REQUIRED" },
1789   { 0xC00002B2, "STATUS_REPARSE_ATTRIBUTE_CONFLICT" },
1790   { 0xC00002B3, "STATUS_CANT_ENABLE_DENY_ONLY" },
1791   { 0xC00002B4, "STATUS_FLOAT_MULTIPLE_FAULTS" },
1792   { 0xC00002B5, "STATUS_FLOAT_MULTIPLE_TRAPS" },
1793   { 0xC00002B6, "STATUS_DEVICE_REMOVED" },
1794   { 0xC00002B7, "STATUS_JOURNAL_DELETE_IN_PROGRESS" },
1795   { 0xC00002B8, "STATUS_JOURNAL_NOT_ACTIVE" },
1796   { 0xC00002B9, "STATUS_NOINTERFACE" },
1797   { 0xC00002C1, "STATUS_DS_ADMIN_LIMIT_EXCEEDED" },
1798   { 0xC00002C2, "STATUS_DRIVER_FAILED_SLEEP" },
1799   { 0xC00002C3, "STATUS_MUTUAL_AUTHENTICATION_FAILED" },
1800   { 0xC00002C4, "STATUS_CORRUPT_SYSTEM_FILE" },
1801   { 0xC00002C5, "STATUS_DATATYPE_MISALIGNMENT_ERROR" },
1802   { 0xC00002C6, "STATUS_WMI_READ_ONLY" },
1803   { 0xC00002C7, "STATUS_WMI_SET_FAILURE" },
1804   { 0xC00002C8, "STATUS_COMMITMENT_MINIMUM" },
1805   { 0xC00002C9, "STATUS_REG_NAT_CONSUMPTION" },
1806   { 0xC00002CA, "STATUS_TRANSPORT_FULL" },
1807   { 0xC00002CB, "STATUS_DS_SAM_INIT_FAILURE" },
1808   { 0xC00002CC, "STATUS_ONLY_IF_CONNECTED" },
1809   { 0xC00002CD, "STATUS_DS_SENSITIVE_GROUP_VIOLATION" },
1810   { 0xC00002CE, "STATUS_PNP_RESTART_ENUMERATION" },
1811   { 0xC00002CF, "STATUS_JOURNAL_ENTRY_DELETED" },
1812   { 0xC00002D0, "STATUS_DS_CANT_MOD_PRIMARYGROUPID" },
1813   { 0xC00002D1, "STATUS_SYSTEM_IMAGE_BAD_SIGNATURE" },
1814   { 0xC00002D2, "STATUS_PNP_REBOOT_REQUIRED" },
1815   { 0xC00002D3, "STATUS_POWER_STATE_INVALID" },
1816   { 0xC00002D4, "STATUS_DS_INVALID_GROUP_TYPE" },
1817   { 0xC00002D5, "STATUS_DS_NO_NEST_GLOBALGROUP_IN_MIXEDDOMAIN" },
1818   { 0xC00002D6, "STATUS_DS_NO_NEST_LOCALGROUP_IN_MIXEDDOMAIN" },
1819   { 0xC00002D7, "STATUS_DS_GLOBAL_CANT_HAVE_LOCAL_MEMBER" },
1820   { 0xC00002D8, "STATUS_DS_GLOBAL_CANT_HAVE_UNIVERSAL_MEMBER" },
1821   { 0xC00002D9, "STATUS_DS_UNIVERSAL_CANT_HAVE_LOCAL_MEMBER" },
1822   { 0xC00002DA, "STATUS_DS_GLOBAL_CANT_HAVE_CROSSDOMAIN_MEMBER" },
1823   { 0xC00002DB, "STATUS_DS_LOCAL_CANT_HAVE_CROSSDOMAIN_LOCAL_MEMBER" },
1824   { 0xC00002DC, "STATUS_DS_HAVE_PRIMARY_MEMBERS" },
1825   { 0xC00002DD, "STATUS_WMI_NOT_SUPPORTED" },
1826   { 0xC00002DE, "STATUS_INSUFFICIENT_POWER" },
1827   { 0xC00002DF, "STATUS_SAM_NEED_BOOTKEY_PASSWORD" },
1828   { 0xC00002E0, "STATUS_SAM_NEED_BOOTKEY_FLOPPY" },
1829   { 0xC00002E1, "STATUS_DS_CANT_START" },
1830   { 0xC00002E2, "STATUS_DS_INIT_FAILURE" },
1831   { 0xC00002E3, "STATUS_SAM_INIT_FAILURE" },
1832   { 0xC00002E4, "STATUS_DS_GC_REQUIRED" },
1833   { 0xC00002E5, "STATUS_DS_LOCAL_MEMBER_OF_LOCAL_ONLY" },
1834   { 0xC00002E6, "STATUS_DS_NO_FPO_IN_UNIVERSAL_GROUPS" },
1835   { 0xC00002E7, "STATUS_DS_MACHINE_ACCOUNT_QUOTA_EXCEEDED" },
1836   { 0xC00002E8, "STATUS_MULTIPLE_FAULT_VIOLATION" },
1837   { 0xC0000300, "STATUS_NOT_SUPPORTED_ON_SBS" },
1838   { 0xC0009898, "STATUS_WOW_ASSERTION" },
1839   { 0xC0020001, "RPC_NT_INVALID_STRING_BINDING" },
1840   { 0xC0020002, "RPC_NT_WRONG_KIND_OF_BINDING" },
1841   { 0xC0020003, "RPC_NT_INVALID_BINDING" },
1842   { 0xC0020004, "RPC_NT_PROTSEQ_NOT_SUPPORTED" },
1843   { 0xC0020005, "RPC_NT_INVALID_RPC_PROTSEQ" },
1844   { 0xC0020006, "RPC_NT_INVALID_STRING_UUID" },
1845   { 0xC0020007, "RPC_NT_INVALID_ENDPOINT_FORMAT" },
1846   { 0xC0020008, "RPC_NT_INVALID_NET_ADDR" },
1847   { 0xC0020009, "RPC_NT_NO_ENDPOINT_FOUND" },
1848   { 0xC002000A, "RPC_NT_INVALID_TIMEOUT" },
1849   { 0xC002000B, "RPC_NT_OBJECT_NOT_FOUND" },
1850   { 0xC002000C, "RPC_NT_ALREADY_REGISTERED" },
1851   { 0xC002000D, "RPC_NT_TYPE_ALREADY_REGISTERED" },
1852   { 0xC002000E, "RPC_NT_ALREADY_LISTENING" },
1853   { 0xC002000F, "RPC_NT_NO_PROTSEQS_REGISTERED" },
1854   { 0xC0020010, "RPC_NT_NOT_LISTENING" },
1855   { 0xC0020011, "RPC_NT_UNKNOWN_MGR_TYPE" },
1856   { 0xC0020012, "RPC_NT_UNKNOWN_IF" },
1857   { 0xC0020013, "RPC_NT_NO_BINDINGS" },
1858   { 0xC0020014, "RPC_NT_NO_PROTSEQS" },
1859   { 0xC0020015, "RPC_NT_CANT_CREATE_ENDPOINT" },
1860   { 0xC0020016, "RPC_NT_OUT_OF_RESOURCES" },
1861   { 0xC0020017, "RPC_NT_SERVER_UNAVAILABLE" },
1862   { 0xC0020018, "RPC_NT_SERVER_TOO_BUSY" },
1863   { 0xC0020019, "RPC_NT_INVALID_NETWORK_OPTIONS" },
1864   { 0xC002001A, "RPC_NT_NO_CALL_ACTIVE" },
1865   { 0xC002001B, "RPC_NT_CALL_FAILED" },
1866   { 0xC002001C, "RPC_NT_CALL_FAILED_DNE" },
1867   { 0xC002001D, "RPC_NT_PROTOCOL_ERROR" },
1868   { 0xC002001F, "RPC_NT_UNSUPPORTED_TRANS_SYN" },
1869   { 0xC0020021, "RPC_NT_UNSUPPORTED_TYPE" },
1870   { 0xC0020022, "RPC_NT_INVALID_TAG" },
1871   { 0xC0020023, "RPC_NT_INVALID_BOUND" },
1872   { 0xC0020024, "RPC_NT_NO_ENTRY_NAME" },
1873   { 0xC0020025, "RPC_NT_INVALID_NAME_SYNTAX" },
1874   { 0xC0020026, "RPC_NT_UNSUPPORTED_NAME_SYNTAX" },
1875   { 0xC0020028, "RPC_NT_UUID_NO_ADDRESS" },
1876   { 0xC0020029, "RPC_NT_DUPLICATE_ENDPOINT" },
1877   { 0xC002002A, "RPC_NT_UNKNOWN_AUTHN_TYPE" },
1878   { 0xC002002B, "RPC_NT_MAX_CALLS_TOO_SMALL" },
1879   { 0xC002002C, "RPC_NT_STRING_TOO_LONG" },
1880   { 0xC002002D, "RPC_NT_PROTSEQ_NOT_FOUND" },
1881   { 0xC002002E, "RPC_NT_PROCNUM_OUT_OF_RANGE" },
1882   { 0xC002002F, "RPC_NT_BINDING_HAS_NO_AUTH" },
1883   { 0xC0020030, "RPC_NT_UNKNOWN_AUTHN_SERVICE" },
1884   { 0xC0020031, "RPC_NT_UNKNOWN_AUTHN_LEVEL" },
1885   { 0xC0020032, "RPC_NT_INVALID_AUTH_IDENTITY" },
1886   { 0xC0020033, "RPC_NT_UNKNOWN_AUTHZ_SERVICE" },
1887   { 0xC0020034, "EPT_NT_INVALID_ENTRY" },
1888   { 0xC0020035, "EPT_NT_CANT_PERFORM_OP" },
1889   { 0xC0020036, "EPT_NT_NOT_REGISTERED" },
1890   { 0xC0020037, "RPC_NT_NOTHING_TO_EXPORT" },
1891   { 0xC0020038, "RPC_NT_INCOMPLETE_NAME" },
1892   { 0xC0020039, "RPC_NT_INVALID_VERS_OPTION" },
1893   { 0xC002003A, "RPC_NT_NO_MORE_MEMBERS" },
1894   { 0xC002003B, "RPC_NT_NOT_ALL_OBJS_UNEXPORTED" },
1895   { 0xC002003C, "RPC_NT_INTERFACE_NOT_FOUND" },
1896   { 0xC002003D, "RPC_NT_ENTRY_ALREADY_EXISTS" },
1897   { 0xC002003E, "RPC_NT_ENTRY_NOT_FOUND" },
1898   { 0xC002003F, "RPC_NT_NAME_SERVICE_UNAVAILABLE" },
1899   { 0xC0020040, "RPC_NT_INVALID_NAF_ID" },
1900   { 0xC0020041, "RPC_NT_CANNOT_SUPPORT" },
1901   { 0xC0020042, "RPC_NT_NO_CONTEXT_AVAILABLE" },
1902   { 0xC0020043, "RPC_NT_INTERNAL_ERROR" },
1903   { 0xC0020044, "RPC_NT_ZERO_DIVIDE" },
1904   { 0xC0020045, "RPC_NT_ADDRESS_ERROR" },
1905   { 0xC0020046, "RPC_NT_FP_DIV_ZERO" },
1906   { 0xC0020047, "RPC_NT_FP_UNDERFLOW" },
1907   { 0xC0020048, "RPC_NT_FP_OVERFLOW" },
1908   { 0xC0021007, "RPC_P_RECEIVE_ALERTED" },
1909   { 0xC0021008, "RPC_P_CONNECTION_CLOSED" },
1910   { 0xC0021009, "RPC_P_RECEIVE_FAILED" },
1911   { 0xC002100A, "RPC_P_SEND_FAILED" },
1912   { 0xC002100B, "RPC_P_TIMEOUT" },
1913   { 0xC002100C, "RPC_P_SERVER_TRANSPORT_ERROR" },
1914   { 0xC002100E, "RPC_P_EXCEPTION_OCCURRED" },
1915   { 0xC0021012, "RPC_P_CONNECTION_SHUTDOWN" },
1916   { 0xC0021015, "RPC_P_THREAD_LISTENING" },
1917   { 0xC0030001, "RPC_NT_NO_MORE_ENTRIES" },
1918   { 0xC0030002, "RPC_NT_SS_CHAR_TRANS_OPEN_FAIL" },
1919   { 0xC0030003, "RPC_NT_SS_CHAR_TRANS_SHORT_FILE" },
1920   { 0xC0030004, "RPC_NT_SS_IN_NULL_CONTEXT" },
1921   { 0xC0030005, "RPC_NT_SS_CONTEXT_MISMATCH" },
1922   { 0xC0030006, "RPC_NT_SS_CONTEXT_DAMAGED" },
1923   { 0xC0030007, "RPC_NT_SS_HANDLES_MISMATCH" },
1924   { 0xC0030008, "RPC_NT_SS_CANNOT_GET_CALL_HANDLE" },
1925   { 0xC0030009, "RPC_NT_NULL_REF_POINTER" },
1926   { 0xC003000A, "RPC_NT_ENUM_VALUE_OUT_OF_RANGE" },
1927   { 0xC003000B, "RPC_NT_BYTE_COUNT_TOO_SMALL" },
1928   { 0xC003000C, "RPC_NT_BAD_STUB_DATA" },
1929   { 0xC0020049, "RPC_NT_CALL_IN_PROGRESS" },
1930   { 0xC002004A, "RPC_NT_NO_MORE_BINDINGS" },
1931   { 0xC002004B, "RPC_NT_GROUP_MEMBER_NOT_FOUND" },
1932   { 0xC002004C, "EPT_NT_CANT_CREATE" },
1933   { 0xC002004D, "RPC_NT_INVALID_OBJECT" },
1934   { 0xC002004F, "RPC_NT_NO_INTERFACES" },
1935   { 0xC0020050, "RPC_NT_CALL_CANCELLED" },
1936   { 0xC0020051, "RPC_NT_BINDING_INCOMPLETE" },
1937   { 0xC0020052, "RPC_NT_COMM_FAILURE" },
1938   { 0xC0020053, "RPC_NT_UNSUPPORTED_AUTHN_LEVEL" },
1939   { 0xC0020054, "RPC_NT_NO_PRINC_NAME" },
1940   { 0xC0020055, "RPC_NT_NOT_RPC_ERROR" },
1941   { 0x40020056, "RPC_NT_UUID_LOCAL_ONLY" },
1942   { 0xC0020057, "RPC_NT_SEC_PKG_ERROR" },
1943   { 0xC0020058, "RPC_NT_NOT_CANCELLED" },
1944   { 0xC0030059, "RPC_NT_INVALID_ES_ACTION" },
1945   { 0xC003005A, "RPC_NT_WRONG_ES_VERSION" },
1946   { 0xC003005B, "RPC_NT_WRONG_STUB_VERSION" },
1947   { 0xC003005C, "RPC_NT_INVALID_PIPE_OBJECT" },
1948   { 0xC003005D, "RPC_NT_INVALID_PIPE_OPERATION" },
1949   { 0xC003005E, "RPC_NT_WRONG_PIPE_VERSION" },
1950   { 0x400200AF, "RPC_NT_SEND_INCOMPLETE" },
1951   { 0,          NULL }
1952 };
1953 
1954 /*
1955  * return an NT error string from a SMB buffer
1956  */
1957 const char *
nt_errstr(uint32_t err)1958 nt_errstr(uint32_t err)
1959 {
1960     static char ret[128];
1961     int i;
1962 
1963     ret[0] = 0;
1964 
1965     for (i = 0; nt_errors[i].name; i++) {
1966           if (err == nt_errors[i].code)
1967               return nt_errors[i].name;
1968     }
1969 
1970     snprintf(ret, sizeof(ret), "0x%08x", err);
1971     return ret;
1972 }
1973