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