xref: /illumos-gate/usr/src/uts/common/fs/smbclnt/netsmb/smb_subrs.c (revision 40c0e2317898b8c774791bdc2b30bd50111ab1fa)
1 /*
2  * Copyright (c) 2000-2001 Boris Popov
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  *    notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  *    notice, this list of conditions and the following disclaimer in the
12  *    documentation and/or other materials provided with the distribution.
13  * 3. All advertising materials mentioning features or use of this software
14  *    must display the following acknowledgement:
15  *    This product includes software developed by Boris Popov.
16  * 4. Neither the name of the author nor the names of any co-contributors
17  *    may be used to endorse or promote products derived from this software
18  *    without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
21  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
24  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30  * SUCH DAMAGE.
31  *
32  * $Id: smb_subr.c,v 1.27.108.1 2005/06/02 00:55:39 lindak Exp $
33  */
34 
35 /*
36  * Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.
37  * Portions Copyright (C) 2001 - 2013 Apple Inc. All rights reserved.
38  * Copyright 2018 Nexenta Systems, Inc.  All rights reserved.
39  */
40 
41 #include <sys/param.h>
42 #include <sys/systm.h>
43 #include <sys/kmem.h>
44 #include <sys/proc.h>
45 #include <sys/lock.h>
46 #include <sys/socket.h>
47 #include <sys/isa_defs.h>
48 #include <sys/stream.h>
49 #include <sys/strsun.h>
50 #include <sys/sunddi.h>
51 #include <sys/cmn_err.h>
52 #include <sys/sdt.h>
53 #include <sys/priv.h>
54 #include <sys/u8_textprep.h>
55 
56 #include <netsmb/smb_osdep.h>
57 #include <netsmb/smb.h>
58 #include <netsmb/smb_conn.h>
59 #include <netsmb/smb_rq.h>
60 #include <netsmb/smb_subr.h>
61 
62 void
63 smb_credinit(struct smb_cred *scred, cred_t *cr)
64 {
65 	/* cr arg is optional */
66 	if (cr == NULL)
67 		cr = ddi_get_cred();
68 #ifdef	_KERNEL
69 	if (is_system_labeled()) {
70 		cr = crdup(cr);
71 		(void) setpflags(NET_MAC_AWARE, 1, cr);
72 	} else
73 #endif
74 	{
75 		crhold(cr);
76 	}
77 	scred->scr_cred = cr;
78 }
79 
80 void
81 smb_credrele(struct smb_cred *scred)
82 {
83 	if (scred->scr_cred != NULL) {
84 		crfree(scred->scr_cred);
85 		scred->scr_cred = NULL;
86 	}
87 }
88 
89 /*
90  * Helper for the SMBERROR macro, etc.
91  * This is also a good place for a breakpoint
92  * or a dtrace probe, i.e. fbt:nsmb:smb_errmsg
93  */
94 void
95 smb_errmsg(int cel, const char *func_name, const char *fmt, ...)
96 {
97 	va_list adx;
98 	char buf[100];
99 
100 	va_start(adx, fmt);
101 	if (cel == CE_CONT) {
102 		/*
103 		 * This is one of our xxxDEBUG macros.
104 		 * Don't bother to log these, but just
105 		 * fire a dtrace probe with the message.
106 		 */
107 		(void) vsnprintf(buf, sizeof (buf), fmt, adx);
108 		DTRACE_PROBE2(debugmsg2,
109 		    (char *), func_name,
110 		    (char *), buf);
111 	} else {
112 		/*
113 		 * This is one of our xxxERROR macros.
114 		 * Add a prefix to the fmt string,
115 		 * then let vcmn_err do the args.
116 		 */
117 		(void) snprintf(buf, sizeof (buf), "?%s: %s", func_name, fmt);
118 		DTRACE_PROBE3(debugmsg3,
119 		    (char *), func_name,
120 		    (char *), buf,
121 		    va_list, adx);
122 		vcmn_err(cel, buf, adx);
123 	}
124 	va_end(adx);
125 }
126 
127 #if 1 /* def SMB_SOCKETDATA_DEBUG */
128 void
129 m_dumpm(mblk_t *m)
130 {
131 	int len, seg;
132 
133 	len = msgdsize(m);
134 	DTRACE_PROBE2(dsize, int, len, (mblk_t *), m);
135 
136 	for (seg = 0; m; seg++) {
137 		DTRACE_PROBE2(mblk, int, seg, (mblk_t *), m);
138 		m = m->b_cont;
139 	}
140 }
141 #endif
142 
143 #ifndef EPROTO
144 #define	EPROTO ECONNABORTED
145 #endif
146 #ifndef ELIBACC
147 #define	ELIBACC ENOENT
148 #endif
149 #ifndef ENODATA
150 #define	ENODATA EINVAL
151 #endif
152 #ifndef ENOTUNIQ
153 #define	ENOTUNIQ EADDRINUSE
154 #endif
155 #ifndef ECOMM
156 #define	ECOMM EIO
157 #endif
158 #ifndef ENOMEDIUM
159 #define	ENOMEDIUM ENXIO
160 #endif
161 #ifndef ETIME
162 #define	ETIME ETIMEDOUT
163 #endif
164 
165 /*
166  * Log any un-handled NT or DOS errors we encounter.
167  * Make these log NOTICE in a debug build to ensure
168  * they get noticed during tests.  In the field these
169  * are unimportant, so just fire a Dtrace probe.
170  */
171 static int unknown_err_logpri =
172 #ifdef	DEBUG
173 	CE_NOTE;
174 #else
175 	CE_CONT;
176 #endif
177 
178 typedef struct nt2errno {
179 	unsigned int nterr;
180 	int errno;
181 } nt2errno_t;
182 
183 static const nt2errno_t nt2errno[] = {
184 	/* Alphabetical order. */
185 	{NT_STATUS_ACCESS_DENIED,		EACCES},
186 	{NT_STATUS_ACCESS_VIOLATION,		EACCES},
187 	{NT_STATUS_ACCOUNT_DISABLED,		EACCES},
188 	{NT_STATUS_ACCOUNT_EXPIRED,		EACCES},
189 	{NT_STATUS_ACCOUNT_LOCKED_OUT,		EACCES},
190 	{NT_STATUS_ACCOUNT_RESTRICTION,		EACCES},
191 	{NT_STATUS_ADDRESS_ALREADY_EXISTS,	EADDRINUSE},
192 	{NT_STATUS_BAD_NETWORK_NAME,		ENOENT},
193 	{NT_STATUS_BAD_NETWORK_PATH,		ENOENT},
194 	{NT_STATUS_BUFFER_TOO_SMALL,		E2BIG},
195 	{NT_STATUS_CANCELLED,			ECANCELED},
196 	{NT_STATUS_CANNOT_DELETE,		EACCES},
197 	{NT_STATUS_CONFLICTING_ADDRESSES,	EADDRINUSE},
198 	{NT_STATUS_CONNECTION_ABORTED,		ECONNABORTED},
199 	{NT_STATUS_CONNECTION_DISCONNECTED,	ECONNABORTED},
200 	{NT_STATUS_CONNECTION_REFUSED,		ECONNREFUSED},
201 	{NT_STATUS_CONNECTION_RESET,		ENETRESET},
202 	{NT_STATUS_DELETE_PENDING,		EACCES},
203 	{NT_STATUS_DEVICE_DOES_NOT_EXIST,	ENODEV},
204 	{NT_STATUS_DEVICE_PROTOCOL_ERROR,	EPROTO},
205 	{NT_STATUS_DIRECTORY_NOT_EMPTY,		ENOTEMPTY},
206 	{NT_STATUS_DISK_FULL,			ENOSPC},
207 	{NT_STATUS_DLL_NOT_FOUND,		ELIBACC},
208 	{NT_STATUS_DUPLICATE_NAME,		EINVAL},
209 	{NT_STATUS_EAS_NOT_SUPPORTED,		ENOTSUP},
210 	{NT_STATUS_EA_TOO_LARGE,		E2BIG},
211 	{NT_STATUS_END_OF_FILE,			ENODATA},
212 	{NT_STATUS_FILE_CLOSED,			EBADF},
213 	{NT_STATUS_FILE_DELETED,		ENOENT},
214 	{NT_STATUS_FILE_INVALID,		EIO},
215 	{NT_STATUS_FILE_IS_A_DIRECTORY,		EISDIR},
216 	{NT_STATUS_FILE_LOCK_CONFLICT,		EAGAIN},
217 	{NT_STATUS_FILE_RENAMED,		ENOENT},
218 	{NT_STATUS_FLOAT_INEXACT_RESULT,	ERANGE},
219 	{NT_STATUS_FLOAT_OVERFLOW,		ERANGE},
220 	{NT_STATUS_FLOAT_UNDERFLOW,		ERANGE},
221 	{NT_STATUS_HOST_UNREACHABLE,		EHOSTUNREACH},
222 	{NT_STATUS_ILL_FORMED_PASSWORD,		EAUTH},
223 	{NT_STATUS_INFO_LENGTH_MISMATCH,	EINVAL},
224 	{NT_STATUS_INSUFFICIENT_RESOURCES,	EAGAIN},
225 	{NT_STATUS_INSUFF_SERVER_RESOURCES,	EAGAIN},
226 	{NT_STATUS_INTEGER_OVERFLOW,		ERANGE},
227 	{NT_STATUS_INVALID_ACCOUNT_NAME,	EAUTH},
228 	{NT_STATUS_INVALID_BUFFER_SIZE,		EIO},
229 	{NT_STATUS_INVALID_DEVICE_REQUEST,	EINVAL},
230 	{NT_STATUS_INVALID_HANDLE,		EBADF},
231 	{NT_STATUS_INVALID_INFO_CLASS,		EINVAL},
232 	{NT_STATUS_INVALID_LEVEL,		ENOTSUP},
233 	{NT_STATUS_INVALID_LOCK_SEQUENCE,	EINVAL},
234 	{NT_STATUS_INVALID_LOGON_HOURS,		EAUTH},
235 	{NT_STATUS_INVALID_OWNER,		EINVAL},
236 	{NT_STATUS_INVALID_PARAMETER,		EINVAL},
237 	{NT_STATUS_INVALID_PIPE_STATE,		EPIPE},
238 	{NT_STATUS_INVALID_PRIMARY_GROUP,	EINVAL},
239 	{NT_STATUS_INVALID_WORKSTATION,		EACCES},
240 	{NT_STATUS_IN_PAGE_ERROR,		EFAULT},
241 	{NT_STATUS_IO_DEVICE_ERROR,		EIO},
242 	{NT_STATUS_IO_TIMEOUT,			ETIMEDOUT},
243 	{NT_STATUS_IP_ADDRESS_CONFLICT1,	EADDRINUSE},
244 	{NT_STATUS_IP_ADDRESS_CONFLICT2,	EADDRINUSE},
245 	{NT_STATUS_LICENSE_QUOTA_EXCEEDED,	EDQUOT},
246 	{NT_STATUS_LOCK_NOT_GRANTED,		EAGAIN},
247 	{NT_STATUS_LOGIN_TIME_RESTRICTION,	EAUTH},
248 	{NT_STATUS_LOGON_FAILURE,		EAUTH},
249 	{NT_STATUS_LOGON_TYPE_NOT_GRANTED,	EAUTH},
250 	{NT_STATUS_MEDIA_WRITE_PROTECTED,	EROFS},
251 	{NT_STATUS_MEMORY_NOT_ALLOCATED,	EFAULT},
252 	{NT_STATUS_MORE_PROCESSING_REQUIRED,	EINPROGRESS},
253 	{NT_STATUS_NAME_TOO_LONG,		ENAMETOOLONG},
254 	{NT_STATUS_NETWORK_ACCESS_DENIED,	EACCES},
255 	{NT_STATUS_NETWORK_BUSY,		EBUSY},
256 	{NT_STATUS_NETWORK_NAME_DELETED,	ENOENT},
257 	{NT_STATUS_NETWORK_UNREACHABLE,		ENETUNREACH},
258 	{NT_STATUS_NET_WRITE_FAULT,		ECOMM},
259 	{NT_STATUS_NONEXISTENT_EA_ENTRY,	ENOENT},
260 	{NT_STATUS_NONEXISTENT_SECTOR,		ESPIPE},
261 	{NT_STATUS_NONE_MAPPED,			EINVAL},
262 	{NT_STATUS_NOT_A_DIRECTORY,		ENOTDIR},
263 	{NT_STATUS_NOT_FOUND,			ENOENT},
264 	{NT_STATUS_NOT_IMPLEMENTED,		ENOTSUP},
265 	{NT_STATUS_NOT_LOCKED,			ENOLCK},
266 	{NT_STATUS_NOT_MAPPED_VIEW,		EINVAL},
267 	{NT_STATUS_NOT_SUPPORTED,		ENOTSUP},
268 	{NT_STATUS_NO_EAS_ON_FILE,		ENOENT},
269 	{NT_STATUS_NO_LOGON_SERVERS,		EAUTH},
270 	{NT_STATUS_NO_MEDIA,			ENOMEDIUM},
271 	{NT_STATUS_NO_MEDIA_IN_DEVICE,		ENOMEDIUM},
272 	{NT_STATUS_NO_MEMORY,			ENOMEM},
273 	{NT_STATUS_NO_SUCH_DEVICE,		ENODEV},
274 	{NT_STATUS_NO_SUCH_FILE,		ENOENT},
275 	{NT_STATUS_NO_SUCH_LOGON_SESSION,	EAUTH},
276 	{NT_STATUS_NO_SUCH_USER,		EAUTH},
277 	{NT_STATUS_NO_TRUST_LSA_SECRET,		EAUTH},
278 	{NT_STATUS_NO_TRUST_SAM_ACCOUNT,	EAUTH},
279 	{NT_STATUS_OBJECT_NAME_COLLISION,	EEXIST},
280 	{NT_STATUS_OBJECT_NAME_INVALID,		EINVAL},
281 	{NT_STATUS_OBJECT_NAME_NOT_FOUND,	ENOENT},
282 	{NT_STATUS_OBJECT_PATH_INVALID,		ENOTDIR},
283 	{NT_STATUS_OBJECT_PATH_NOT_FOUND,	ENOENT},
284 	{NT_STATUS_OBJECT_PATH_SYNTAX_BAD,	EINVAL},
285 	{NT_STATUS_OBJECT_TYPE_MISMATCH,	EBADF},
286 	{NT_STATUS_PAGEFILE_QUOTA,		EDQUOT},
287 	{NT_STATUS_PASSWORD_EXPIRED,		EAUTH},
288 	{NT_STATUS_PASSWORD_MUST_CHANGE,	EAUTH},
289 	{NT_STATUS_PASSWORD_RESTRICTION,	EAUTH},
290 	{NT_STATUS_PATH_NOT_COVERED,		ENOENT},
291 	{NT_STATUS_PIPE_BROKEN,			EPIPE},
292 	{NT_STATUS_PIPE_BUSY,			EPIPE},
293 	{NT_STATUS_PIPE_CONNECTED,		EISCONN},
294 	{NT_STATUS_PIPE_DISCONNECTED,		EPIPE},
295 	{NT_STATUS_PIPE_NOT_AVAILABLE,		EBUSY},
296 	{NT_STATUS_PORT_CONNECTION_REFUSED,	ECONNREFUSED},
297 	{NT_STATUS_PORT_DISCONNECTED,		EBADF},
298 	{NT_STATUS_PORT_MESSAGE_TOO_LONG,	EMSGSIZE},
299 	{NT_STATUS_PORT_UNREACHABLE,		EHOSTUNREACH},
300 	{NT_STATUS_PROTOCOL_UNREACHABLE,	ENOPROTOOPT},
301 	{NT_STATUS_QUOTA_EXCEEDED,		EDQUOT},
302 	{NT_STATUS_RANGE_NOT_LOCKED,		EAGAIN}, /* like F_SETLK */
303 	{NT_STATUS_REGISTRY_QUOTA_LIMIT,	EDQUOT},
304 	{NT_STATUS_REMOTE_DISCONNECT,		ESHUTDOWN},
305 	{NT_STATUS_REMOTE_NOT_LISTENING,	ECONNREFUSED},
306 	{NT_STATUS_REQUEST_NOT_ACCEPTED,	EACCES},
307 	{NT_STATUS_RETRY,			EAGAIN},
308 	{NT_STATUS_SHARING_VIOLATION,		EBUSY},
309 	{NT_STATUS_TIMER_NOT_CANCELED,		ETIME},
310 	{NT_STATUS_TOO_MANY_LINKS,		EMLINK},
311 	{NT_STATUS_TOO_MANY_OPENED_FILES,	EMFILE},
312 	{NT_STATUS_TRUSTED_DOMAIN_FAILURE,	EAUTH},
313 	{NT_STATUS_TRUSTED_RELATIONSHIP_FAILURE, EAUTH},
314 	{NT_STATUS_UNABLE_TO_FREE_VM,		EADDRINUSE},
315 	{NT_STATUS_UNSUCCESSFUL,		EINVAL},
316 	{NT_STATUS_WRONG_PASSWORD,		EAUTH},
317 	{0,	0}
318 };
319 
320 /*
321  * Table for converting NT STATUS values to DOS class/code.
322  * Rows ordered by integer value of last column (NT STATUS)
323  */
324 typedef struct nt2doserr {
325 	unsigned short dclass;
326 	unsigned short derr;
327 	unsigned int nterr;
328 } nt2doserr_t;
329 
330 static const nt2doserr_t nt2doserr[] = {
331 	{ERRDOS,	ERRgeneral,	NT_STATUS_UNSUCCESSFUL},
332 	{ERRDOS,	ERRbadfunc,	NT_STATUS_NOT_IMPLEMENTED},
333 	{ERRDOS, ERROR_INVALID_PARAMETER,	NT_STATUS_INVALID_INFO_CLASS},
334 	{ERRDOS, ERROR_BAD_LENGTH,	NT_STATUS_INFO_LENGTH_MISMATCH},
335 	{ERRHRD,	ERRgeneral,	NT_STATUS_ACCESS_VIOLATION},
336 	{ERRHRD,	ERRgeneral,	NT_STATUS_IN_PAGE_ERROR},
337 	{ERRHRD,	ERRgeneral,	NT_STATUS_PAGEFILE_QUOTA},
338 	{ERRDOS,	ERRbadfid,	NT_STATUS_INVALID_HANDLE},
339 	{ERRHRD,	ERRgeneral,	NT_STATUS_BAD_INITIAL_STACK},
340 	{ERRDOS, ERROR_BAD_EXE_FORMAT,	NT_STATUS_BAD_INITIAL_PC},
341 	{ERRDOS, ERROR_INVALID_PARAMETER,	NT_STATUS_INVALID_CID},
342 	{ERRHRD,	ERRgeneral,	NT_STATUS_TIMER_NOT_CANCELED},
343 	{ERRDOS, ERROR_INVALID_PARAMETER,	NT_STATUS_INVALID_PARAMETER},
344 	{ERRDOS,	ERRbadfile,	NT_STATUS_NO_SUCH_DEVICE},
345 	{ERRDOS,	ERRbadfile,	NT_STATUS_NO_SUCH_FILE},
346 	{ERRDOS,	ERRbadfunc,	NT_STATUS_INVALID_DEVICE_REQUEST},
347 	{ERRDOS, ERROR_HANDLE_EOF,	NT_STATUS_END_OF_FILE},
348 	{ERRDOS, ERROR_WRONG_DISK,	NT_STATUS_WRONG_VOLUME},
349 	{ERRDOS, ERROR_NOT_READY,	NT_STATUS_NO_MEDIA_IN_DEVICE},
350 	{ERRHRD,	ERRgeneral,	NT_STATUS_UNRECOGNIZED_MEDIA},
351 	{ERRDOS, ERROR_SECTOR_NOT_FOUND,	NT_STATUS_NONEXISTENT_SECTOR},
352 	{ERRDOS,	ERRnomem,	NT_STATUS_NO_MEMORY},
353 	{ERRDOS, ERROR_INVALID_ADDRESS,	NT_STATUS_CONFLICTING_ADDRESSES},
354 	{ERRDOS, ERROR_INVALID_ADDRESS,	NT_STATUS_NOT_MAPPED_VIEW},
355 	{ERRDOS, ERROR_INVALID_PARAMETER,	NT_STATUS_UNABLE_TO_FREE_VM},
356 	{ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_UNABLE_TO_DELETE_SECTION},
357 	{ERRDOS, NERR_InvalidAPI,	NT_STATUS_INVALID_SYSTEM_SERVICE},
358 	{ERRHRD,	ERRgeneral,	NT_STATUS_ILLEGAL_INSTRUCTION},
359 	{ERRDOS,	ERRnoaccess,	NT_STATUS_INVALID_LOCK_SEQUENCE},
360 	{ERRDOS,	ERRnoaccess,	NT_STATUS_INVALID_VIEW_SIZE},
361 	{ERRDOS, ERROR_BAD_EXE_FORMAT,	NT_STATUS_INVALID_FILE_FOR_SECTION},
362 	{ERRDOS,	ERRnoaccess,	NT_STATUS_ALREADY_COMMITTED},
363 	{ERRDOS,	ERRnoaccess,	NT_STATUS_ACCESS_DENIED},
364 	{ERRDOS, ERROR_BUFFER_OVERFLOW,	NT_STATUS_BUFFER_TOO_SMALL},
365 	{ERRDOS,	ERRbadfid,	NT_STATUS_OBJECT_TYPE_MISMATCH},
366 	{ERRHRD,	ERRgeneral,	NT_STATUS_NONCONTINUABLE_EXCEPTION},
367 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_DISPOSITION},
368 	{ERRHRD,	ERRgeneral,	NT_STATUS_UNWIND},
369 	{ERRHRD,	ERRgeneral,	NT_STATUS_BAD_STACK},
370 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_UNWIND_TARGET},
371 	{ERRDOS, ERROR_NOT_LOCKED,	NT_STATUS_NOT_LOCKED},
372 	{ERRHRD,	ERRgeneral,	NT_STATUS_PARITY_ERROR},
373 	{ERRDOS, ERROR_INVALID_ADDRESS,	NT_STATUS_UNABLE_TO_DECOMMIT_VM},
374 	{ERRDOS, ERROR_INVALID_ADDRESS,	NT_STATUS_NOT_COMMITTED},
375 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_PORT_ATTRIBUTES},
376 	{ERRHRD,	ERRgeneral,	NT_STATUS_PORT_MESSAGE_TOO_LONG},
377 	{ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_MIX},
378 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_QUOTA_LOWER},
379 	{ERRHRD,	ERRgeneral,	NT_STATUS_DISK_CORRUPT_ERROR},
380 	{ERRDOS, ERROR_INVALID_NAME,	NT_STATUS_OBJECT_NAME_INVALID},
381 	{ERRDOS,	ERRbadfile,	NT_STATUS_OBJECT_NAME_NOT_FOUND},
382 	{ERRDOS, ERROR_ALREADY_EXISTS,	NT_STATUS_OBJECT_NAME_COLLISION},
383 	{ERRDOS,	ERRbadfid,	NT_STATUS_PORT_DISCONNECTED},
384 	{ERRHRD,	ERRgeneral,	NT_STATUS_DEVICE_ALREADY_ATTACHED},
385 	{ERRDOS, ERROR_BAD_PATHNAME,	NT_STATUS_OBJECT_PATH_INVALID},
386 	{ERRDOS,	ERRbadpath,	NT_STATUS_OBJECT_PATH_NOT_FOUND},
387 	{ERRDOS, ERROR_BAD_PATHNAME,	NT_STATUS_OBJECT_PATH_SYNTAX_BAD},
388 	{ERRHRD,	ERRgeneral,	NT_STATUS_DATA_OVERRUN},
389 	{ERRHRD,	ERRgeneral,	NT_STATUS_DATA_LATE_ERROR},
390 	{ERRDOS, ERROR_CRC,		NT_STATUS_DATA_ERROR},
391 	{ERRDOS, ERROR_CRC,		NT_STATUS_CRC_ERROR},
392 	{ERRDOS,	ERRnomem,	NT_STATUS_SECTION_TOO_BIG},
393 	{ERRDOS,	ERRnoaccess,	NT_STATUS_PORT_CONNECTION_REFUSED},
394 	{ERRDOS,	ERRbadfid,	NT_STATUS_INVALID_PORT_HANDLE},
395 	{ERRDOS, ERROR_SHARING_VIOLATION,	NT_STATUS_SHARING_VIOLATION},
396 	{ERRHRD,	ERRgeneral,	NT_STATUS_QUOTA_EXCEEDED},
397 	{ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PAGE_PROTECTION},
398 	{ERRDOS, ERROR_NOT_OWNER,	NT_STATUS_MUTANT_NOT_OWNED},
399 	{ERRDOS, ERROR_TOO_MANY_POSTS,	NT_STATUS_SEMAPHORE_LIMIT_EXCEEDED},
400 	{ERRDOS, ERROR_INVALID_PARAMETER,	NT_STATUS_PORT_ALREADY_SET},
401 	{ERRDOS, ERROR_INVALID_PARAMETER,	NT_STATUS_SECTION_NOT_IMAGE},
402 	{ERRDOS, ERROR_SIGNAL_REFUSED,	NT_STATUS_SUSPEND_COUNT_EXCEEDED},
403 	{ERRDOS,	ERRnoaccess,	NT_STATUS_THREAD_IS_TERMINATING},
404 	{ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_BAD_WORKING_SET_LIMIT},
405 	{ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INCOMPATIBLE_FILE_MAP},
406 	{ERRDOS, ERROR_INVALID_PARAMETER,	NT_STATUS_SECTION_PROTECTION},
407 	{ERRDOS, ERROR_EAS_NOT_SUPPORTED,	NT_STATUS_EAS_NOT_SUPPORTED},
408 	{ERRDOS, ERROR_EA_LIST_INCONSISTENT,	NT_STATUS_EA_TOO_LARGE},
409 	{ERRHRD,	ERRgeneral,	NT_STATUS_NONEXISTENT_EA_ENTRY},
410 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_EAS_ON_FILE},
411 	{ERRHRD,	ERRgeneral,	NT_STATUS_EA_CORRUPT_ERROR},
412 	{ERRDOS, ERROR_LOCK_VIOLATION,	NT_STATUS_FILE_LOCK_CONFLICT},
413 	{ERRDOS, ERROR_LOCK_VIOLATION,	NT_STATUS_LOCK_NOT_GRANTED},
414 	{ERRDOS,	ERRnoaccess,	NT_STATUS_DELETE_PENDING},
415 	{ERRDOS, ERROR_NOT_SUPPORTED,	NT_STATUS_CTL_FILE_NOT_SUPPORTED},
416 	{ERRHRD,	ERRgeneral,	NT_STATUS_UNKNOWN_REVISION},
417 	{ERRHRD,	ERRgeneral,	NT_STATUS_REVISION_MISMATCH},
418 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_OWNER},
419 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_PRIMARY_GROUP},
420 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_IMPERSONATION_TOKEN},
421 	{ERRHRD,	ERRgeneral,	NT_STATUS_CANT_DISABLE_MANDATORY},
422 	{ERRDOS, NERR_LogonServerNotFound,	NT_STATUS_NO_LOGON_SERVERS},
423 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_SUCH_LOGON_SESSION},
424 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_SUCH_PRIVILEGE},
425 	{ERRDOS,	ERRnoaccess,	NT_STATUS_PRIVILEGE_NOT_HELD},
426 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_ACCOUNT_NAME},
427 	{ERRHRD,	ERRgeneral,	NT_STATUS_USER_EXISTS},
428 	{ERRDOS,	ERRnoaccess,	NT_STATUS_NO_SUCH_USER},
429 	{ERRHRD,	ERRgeneral,	NT_STATUS_GROUP_EXISTS},
430 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_SUCH_GROUP},
431 	{ERRHRD,	ERRgeneral,	NT_STATUS_MEMBER_IN_GROUP},
432 	{ERRHRD,	ERRgeneral,	NT_STATUS_MEMBER_NOT_IN_GROUP},
433 	{ERRHRD,	ERRgeneral,	NT_STATUS_LAST_ADMIN},
434 	{ERRSRV,	ERRbadpw,	NT_STATUS_WRONG_PASSWORD},
435 	{ERRHRD,	ERRgeneral,	NT_STATUS_ILL_FORMED_PASSWORD},
436 	{ERRHRD,	ERRgeneral,	NT_STATUS_PASSWORD_RESTRICTION},
437 	{ERRDOS,	ERRnoaccess,	NT_STATUS_LOGON_FAILURE},
438 	{ERRHRD,	ERRgeneral,	NT_STATUS_ACCOUNT_RESTRICTION},
439 	{ERRSRV, NERR_InvalidLogonHours,	NT_STATUS_INVALID_LOGON_HOURS},
440 	{ERRSRV, NERR_InvalidWorkstation,	NT_STATUS_INVALID_WORKSTATION},
441 	{ERRSRV, NERR_PasswordExpired,	NT_STATUS_PASSWORD_EXPIRED},
442 	{ERRSRV, NERR_AccountExpired,	NT_STATUS_ACCOUNT_DISABLED},
443 	{ERRHRD,	ERRgeneral,	NT_STATUS_NONE_MAPPED},
444 	{ERRHRD,	ERRgeneral,	NT_STATUS_TOO_MANY_LUIDS_REQUESTED},
445 	{ERRHRD,	ERRgeneral,	NT_STATUS_LUIDS_EXHAUSTED},
446 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_SUB_AUTHORITY},
447 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_ACL},
448 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_SID},
449 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_SECURITY_DESCR},
450 	{ERRDOS, ERROR_PROC_NOT_FOUND,	NT_STATUS_PROCEDURE_NOT_FOUND},
451 	{ERRDOS, ERROR_BAD_EXE_FORMAT,	NT_STATUS_INVALID_IMAGE_FORMAT},
452 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_TOKEN},
453 	{ERRHRD,	ERRgeneral,	NT_STATUS_BAD_INHERITANCE_ACL},
454 	{ERRDOS, ERROR_NOT_LOCKED,	NT_STATUS_RANGE_NOT_LOCKED},
455 	{ERRDOS, ERROR_DISK_FULL,	NT_STATUS_DISK_FULL},
456 	{ERRHRD,	ERRgeneral,	NT_STATUS_SERVER_DISABLED},
457 	{ERRHRD,	ERRgeneral,	NT_STATUS_SERVER_NOT_DISABLED},
458 	{ERRDOS, ERROR_TOO_MANY_NAMES,	NT_STATUS_TOO_MANY_GUIDS_REQUESTED},
459 	{ERRDOS, ERROR_NO_MORE_ITEMS,	NT_STATUS_GUIDS_EXHAUSTED},
460 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_ID_AUTHORITY},
461 	{ERRDOS, ERROR_NO_MORE_ITEMS,	NT_STATUS_AGENTS_EXHAUSTED},
462 	{ERRDOS, ERROR_LABEL_TOO_LONG,	NT_STATUS_INVALID_VOLUME_LABEL},
463 	{ERRDOS, ERROR_OUTOFMEMORY,	NT_STATUS_SECTION_NOT_EXTENDED},
464 	{ERRDOS, ERROR_INVALID_ADDRESS,	NT_STATUS_NOT_MAPPED_DATA},
465 	{ERRHRD,	ERRgeneral,	NT_STATUS_RESOURCE_DATA_NOT_FOUND},
466 	{ERRHRD,	ERRgeneral,	NT_STATUS_RESOURCE_TYPE_NOT_FOUND},
467 	{ERRHRD,	ERRgeneral,	NT_STATUS_RESOURCE_NAME_NOT_FOUND},
468 	{ERRHRD,	ERRgeneral,	NT_STATUS_ARRAY_BOUNDS_EXCEEDED},
469 	{ERRHRD,	ERRgeneral,	NT_STATUS_FLOAT_DENORMAL_OPERAND},
470 	{ERRHRD,	ERRgeneral,	NT_STATUS_FLOAT_DIVIDE_BY_ZERO},
471 	{ERRHRD,	ERRgeneral,	NT_STATUS_FLOAT_INEXACT_RESULT},
472 	{ERRHRD,	ERRgeneral,	NT_STATUS_FLOAT_INVALID_OPERATION},
473 	{ERRHRD,	ERRgeneral,	NT_STATUS_FLOAT_OVERFLOW},
474 	{ERRHRD,	ERRgeneral,	NT_STATUS_FLOAT_STACK_CHECK},
475 	{ERRHRD,	ERRgeneral,	NT_STATUS_FLOAT_UNDERFLOW},
476 	{ERRHRD,	ERRgeneral,	NT_STATUS_INTEGER_DIVIDE_BY_ZERO},
477 	{ERRDOS, ERROR_ARITHMETIC_OVERFLOW,	NT_STATUS_INTEGER_OVERFLOW},
478 	{ERRHRD,	ERRgeneral,	NT_STATUS_PRIVILEGED_INSTRUCTION},
479 	{ERRDOS,	ERRnomem,	NT_STATUS_TOO_MANY_PAGING_FILES},
480 	{ERRHRD,	ERRgeneral,	NT_STATUS_FILE_INVALID},
481 	{ERRHRD,	ERRgeneral,	NT_STATUS_ALLOTTED_SPACE_EXCEEDED},
482 	{ERRDOS,	ERRnomem,	NT_STATUS_INSUFFICIENT_RESOURCES},
483 	{ERRDOS,	ERRbadpath,	NT_STATUS_DFS_EXIT_PATH_FOUND},
484 	{ERRDOS, ERROR_CRC,		NT_STATUS_DEVICE_DATA_ERROR},
485 	{ERRHRD,	ERRgeneral,	NT_STATUS_DEVICE_NOT_CONNECTED},
486 	{ERRDOS, ERROR_NOT_READY,	NT_STATUS_DEVICE_POWER_FAILURE},
487 	{ERRDOS, ERROR_INVALID_ADDRESS,	NT_STATUS_FREE_VM_NOT_AT_BASE},
488 	{ERRDOS, ERROR_INVALID_ADDRESS,	NT_STATUS_MEMORY_NOT_ALLOCATED},
489 	{ERRHRD,	ERRgeneral,	NT_STATUS_WORKING_SET_QUOTA},
490 	{ERRDOS, ERROR_WRITE_PROTECT,	NT_STATUS_MEDIA_WRITE_PROTECTED},
491 	{ERRDOS, ERROR_NOT_READY,	NT_STATUS_DEVICE_NOT_READY},
492 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_GROUP_ATTRIBUTES},
493 	{ERRHRD,	ERRgeneral,	NT_STATUS_BAD_IMPERSONATION_LEVEL},
494 	{ERRHRD,	ERRgeneral,	NT_STATUS_CANT_OPEN_ANONYMOUS},
495 	{ERRHRD,	ERRgeneral,	NT_STATUS_BAD_VALIDATION_CLASS},
496 	{ERRHRD,	ERRgeneral,	NT_STATUS_BAD_TOKEN_TYPE},
497 	{ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_BAD_MASTER_BOOT_RECORD},
498 	{ERRHRD,	ERRgeneral,	NT_STATUS_INSTRUCTION_MISALIGNMENT},
499 	{ERRDOS, ERROR_PIPE_BUSY,	NT_STATUS_INSTANCE_NOT_AVAILABLE},
500 	{ERRDOS, ERROR_PIPE_BUSY,	NT_STATUS_PIPE_NOT_AVAILABLE},
501 	{ERRDOS, ERROR_BAD_PIPE,	NT_STATUS_INVALID_PIPE_STATE},
502 	{ERRDOS, ERROR_PIPE_BUSY,	NT_STATUS_PIPE_BUSY},
503 	{ERRDOS,	ERRbadfunc,	NT_STATUS_ILLEGAL_FUNCTION},
504 	{ERRDOS, ERROR_PIPE_NOT_CONNECTED,	NT_STATUS_PIPE_DISCONNECTED},
505 	{ERRDOS, ERROR_NO_DATA,	NT_STATUS_PIPE_CLOSING},
506 	{ERRHRD,	ERRgeneral,	NT_STATUS_PIPE_CONNECTED},
507 	{ERRHRD,	ERRgeneral,	NT_STATUS_PIPE_LISTENING},
508 	{ERRDOS, ERROR_BAD_PIPE,	NT_STATUS_INVALID_READ_MODE},
509 	{ERRDOS, ERROR_SEM_TIMEOUT,	NT_STATUS_IO_TIMEOUT},
510 	{ERRDOS, ERROR_HANDLE_EOF,	NT_STATUS_FILE_FORCED_CLOSED},
511 	{ERRHRD,	ERRgeneral,	NT_STATUS_PROFILING_NOT_STARTED},
512 	{ERRHRD,	ERRgeneral,	NT_STATUS_PROFILING_NOT_STOPPED},
513 	{ERRHRD,	ERRgeneral,	NT_STATUS_COULD_NOT_INTERPRET},
514 	{ERRDOS,	ERRnoaccess,	NT_STATUS_FILE_IS_A_DIRECTORY},
515 	{ERRDOS, ERROR_NOT_SUPPORTED,	NT_STATUS_NOT_SUPPORTED},
516 	{ERRDOS, ERROR_REM_NOT_LIST,	NT_STATUS_REMOTE_NOT_LISTENING},
517 	{ERRDOS, ERROR_DUP_NAME,	NT_STATUS_DUPLICATE_NAME},
518 	{ERRDOS, ERROR_BAD_NETPATH,	NT_STATUS_BAD_NETWORK_PATH},
519 	{ERRDOS, ERROR_NETWORK_BUSY,	NT_STATUS_NETWORK_BUSY},
520 	{ERRDOS, ERROR_DEV_NOT_EXIST,	NT_STATUS_DEVICE_DOES_NOT_EXIST},
521 	{ERRDOS, ERROR_TOO_MANY_CMDS,	NT_STATUS_TOO_MANY_COMMANDS},
522 	{ERRDOS, ERROR_ADAP_HDW_ERR,	NT_STATUS_ADAPTER_HARDWARE_ERROR},
523 	{ERRDOS, ERROR_BAD_NET_RESP,	NT_STATUS_INVALID_NETWORK_RESPONSE},
524 	{ERRDOS, ERROR_UNEXP_NET_ERR,	NT_STATUS_UNEXPECTED_NETWORK_ERROR},
525 	{ERRDOS, ERROR_BAD_REM_ADAP,	NT_STATUS_BAD_REMOTE_ADAPTER},
526 	{ERRDOS, ERROR_PRINTQ_FULL,	NT_STATUS_PRINT_QUEUE_FULL},
527 	{ERRDOS, ERROR_NO_SPOOL_SPACE,	NT_STATUS_NO_SPOOL_SPACE},
528 	{ERRDOS, ERROR_PRINT_CANCELLED,	NT_STATUS_PRINT_CANCELLED},
529 	{ERRDOS, ERROR_NETNAME_DELETED,	NT_STATUS_NETWORK_NAME_DELETED},
530 	{ERRDOS, ERROR_NETWORK_ACCESS_DENIED, NT_STATUS_NETWORK_ACCESS_DENIED},
531 	{ERRDOS, ERROR_BAD_DEV_TYPE,	NT_STATUS_BAD_DEVICE_TYPE},
532 	{ERRDOS, ERROR_BAD_NET_NAME,	NT_STATUS_BAD_NETWORK_NAME},
533 	{ERRDOS, ERROR_TOO_MANY_NAMES,	NT_STATUS_TOO_MANY_NAMES},
534 	{ERRDOS, ERROR_TOO_MANY_SESS,	NT_STATUS_TOO_MANY_SESSIONS},
535 	{ERRDOS, ERROR_SHARING_PAUSED,	NT_STATUS_SHARING_PAUSED},
536 	{ERRDOS, ERROR_REQ_NOT_ACCEP,	NT_STATUS_REQUEST_NOT_ACCEPTED},
537 	{ERRDOS, ERROR_REDIR_PAUSED,	NT_STATUS_REDIRECTOR_PAUSED},
538 	{ERRDOS, ERROR_NET_WRITE_FAULT,	NT_STATUS_NET_WRITE_FAULT},
539 	{ERRHRD,	ERRgeneral,	NT_STATUS_PROFILING_AT_LIMIT},
540 	{ERRDOS, ERROR_NOT_SAME_DEVICE,	NT_STATUS_NOT_SAME_DEVICE},
541 	{ERRDOS,	ERRnoaccess,	NT_STATUS_FILE_RENAMED},
542 	{ERRDOS, ERROR_VC_DISCONNECTED,	NT_STATUS_VIRTUAL_CIRCUIT_CLOSED},
543 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_SECURITY_ON_OBJECT},
544 	{ERRHRD,	ERRgeneral,	NT_STATUS_CANT_WAIT},
545 	{ERRDOS, ERROR_NO_DATA,		NT_STATUS_PIPE_EMPTY},
546 	{ERRHRD,	ERRgeneral,	NT_STATUS_CANT_ACCESS_DOMAIN_INFO},
547 	{ERRHRD,	ERRgeneral,	NT_STATUS_CANT_TERMINATE_SELF},
548 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_SERVER_STATE},
549 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_DOMAIN_STATE},
550 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_DOMAIN_ROLE},
551 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_SUCH_DOMAIN},
552 	{ERRHRD,	ERRgeneral,	NT_STATUS_DOMAIN_EXISTS},
553 	{ERRHRD,	ERRgeneral,	NT_STATUS_DOMAIN_LIMIT_EXCEEDED},
554 	{ERRDOS, ERROR_OPLOCK_NOT_GRANTED, NT_STATUS_OPLOCK_NOT_GRANTED},
555 	{ERRDOS, ERROR_INVALID_OPLOCK_PROTOCOL,
556 					NT_STATUS_INVALID_OPLOCK_PROTOCOL},
557 	{ERRHRD,	ERRgeneral,	NT_STATUS_INTERNAL_DB_CORRUPTION},
558 	{ERRHRD,	ERRgeneral,	NT_STATUS_INTERNAL_ERROR},
559 	{ERRHRD,	ERRgeneral,	NT_STATUS_GENERIC_NOT_MAPPED},
560 	{ERRHRD,	ERRgeneral,	NT_STATUS_BAD_DESCRIPTOR_FORMAT},
561 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_USER_BUFFER},
562 	{ERRHRD,	ERRgeneral,	NT_STATUS_UNEXPECTED_IO_ERROR},
563 	{ERRHRD,	ERRgeneral,	NT_STATUS_UNEXPECTED_MM_CREATE_ERR},
564 	{ERRHRD,	ERRgeneral,	NT_STATUS_UNEXPECTED_MM_MAP_ERROR},
565 	{ERRHRD,	ERRgeneral,	NT_STATUS_UNEXPECTED_MM_EXTEND_ERR},
566 	{ERRHRD,	ERRgeneral,	NT_STATUS_NOT_LOGON_PROCESS},
567 	{ERRHRD,	ERRgeneral,	NT_STATUS_LOGON_SESSION_EXISTS},
568 	{ERRDOS, ERROR_INVALID_PARAMETER,	NT_STATUS_INVALID_PARAMETER_1},
569 	{ERRDOS, ERROR_INVALID_PARAMETER,	NT_STATUS_INVALID_PARAMETER_2},
570 	{ERRDOS, ERROR_INVALID_PARAMETER,	NT_STATUS_INVALID_PARAMETER_3},
571 	{ERRDOS, ERROR_INVALID_PARAMETER,	NT_STATUS_INVALID_PARAMETER_4},
572 	{ERRDOS, ERROR_INVALID_PARAMETER,	NT_STATUS_INVALID_PARAMETER_5},
573 	{ERRDOS, ERROR_INVALID_PARAMETER,	NT_STATUS_INVALID_PARAMETER_6},
574 	{ERRDOS, ERROR_INVALID_PARAMETER,	NT_STATUS_INVALID_PARAMETER_7},
575 	{ERRDOS, ERROR_INVALID_PARAMETER,	NT_STATUS_INVALID_PARAMETER_8},
576 	{ERRDOS, ERROR_INVALID_PARAMETER,	NT_STATUS_INVALID_PARAMETER_9},
577 	{ERRDOS, ERROR_INVALID_PARAMETER,	NT_STATUS_INVALID_PARAMETER_10},
578 	{ERRDOS, ERROR_INVALID_PARAMETER,	NT_STATUS_INVALID_PARAMETER_11},
579 	{ERRDOS, ERROR_INVALID_PARAMETER,	NT_STATUS_INVALID_PARAMETER_12},
580 	{ERRDOS,	ERRbadpath,	NT_STATUS_REDIRECTOR_NOT_STARTED},
581 	{ERRHRD,	ERRgeneral,	NT_STATUS_REDIRECTOR_STARTED},
582 	{ERRHRD,	ERRgeneral,	NT_STATUS_STACK_OVERFLOW},
583 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_SUCH_PACKAGE},
584 	{ERRHRD,	ERRgeneral,	NT_STATUS_BAD_FUNCTION_TABLE},
585 	{ERRDOS, ERROR_ENVVAR_NOT_FOUND,	NT_STATUS_VARIABLE_NOT_FOUND},
586 	{ERRDOS, ERROR_DIR_NOT_EMPTY,	NT_STATUS_DIRECTORY_NOT_EMPTY},
587 	{ERRHRD,	ERRgeneral,	NT_STATUS_FILE_CORRUPT_ERROR},
588 	{ERRDOS, ERROR_DIRECTORY,	NT_STATUS_NOT_A_DIRECTORY},
589 	{ERRHRD,	ERRgeneral,	NT_STATUS_BAD_LOGON_SESSION_STATE},
590 	{ERRHRD,	ERRgeneral,	NT_STATUS_LOGON_SESSION_COLLISION},
591 	{ERRDOS, ERROR_FILENAME_EXCED_RANGE,	NT_STATUS_NAME_TOO_LONG},
592 	{ERRDOS, NERR_OpenFiles,	NT_STATUS_FILES_OPEN},
593 	{ERRDOS, NERR_DevInUse,		NT_STATUS_CONNECTION_IN_USE},
594 	{ERRHRD,	ERRgeneral,	NT_STATUS_MESSAGE_NOT_FOUND},
595 	{ERRDOS,	ERRnoaccess,	NT_STATUS_PROCESS_IS_TERMINATING},
596 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_LOGON_TYPE},
597 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_GUID_TRANSLATION},
598 	{ERRHRD,	ERRgeneral,	NT_STATUS_CANNOT_IMPERSONATE},
599 	{ERRHRD,	ERRgeneral,	NT_STATUS_IMAGE_ALREADY_LOADED},
600 	{ERRHRD,	ERRgeneral,	NT_STATUS_ABIOS_NOT_PRESENT},
601 	{ERRHRD,	ERRgeneral,	NT_STATUS_ABIOS_LID_NOT_EXIST},
602 	{ERRHRD,	ERRgeneral,	NT_STATUS_ABIOS_LID_ALREADY_OWNED},
603 	{ERRHRD,	ERRgeneral,	NT_STATUS_ABIOS_NOT_LID_OWNER},
604 	{ERRHRD,	ERRgeneral,	NT_STATUS_ABIOS_INVALID_COMMAND},
605 	{ERRHRD,	ERRgeneral,	NT_STATUS_ABIOS_INVALID_LID},
606 	{ERRHRD,	ERRgeneral,	NT_STATUS_ABIOS_SELECTOR_NOT_AVAILABLE},
607 	{ERRHRD,	ERRgeneral,	NT_STATUS_ABIOS_INVALID_SELECTOR},
608 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_LDT},
609 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_LDT_SIZE},
610 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_LDT_OFFSET},
611 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_LDT_DESCRIPTOR},
612 	{ERRDOS, ERROR_BAD_EXE_FORMAT,	NT_STATUS_INVALID_IMAGE_NE_FORMAT},
613 	{ERRHRD,	ERRgeneral,	NT_STATUS_RXACT_INVALID_STATE},
614 	{ERRHRD,	ERRgeneral,	NT_STATUS_RXACT_COMMIT_FAILURE},
615 	{ERRHRD,	ERRgeneral,	NT_STATUS_MAPPED_FILE_SIZE_ZERO},
616 	{ERRDOS,	ERRnofids,	NT_STATUS_TOO_MANY_OPENED_FILES},
617 	{ERRHRD,	ERRgeneral,	NT_STATUS_CANCELLED},
618 	{ERRDOS,	ERRnoaccess,	NT_STATUS_CANNOT_DELETE},
619 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_COMPUTER_NAME},
620 	{ERRDOS,	ERRnoaccess,	NT_STATUS_FILE_DELETED},
621 	{ERRHRD,	ERRgeneral,	NT_STATUS_SPECIAL_ACCOUNT},
622 	{ERRHRD,	ERRgeneral,	NT_STATUS_SPECIAL_GROUP},
623 	{ERRHRD,	ERRgeneral,	NT_STATUS_SPECIAL_USER},
624 	{ERRHRD,	ERRgeneral,	NT_STATUS_MEMBERS_PRIMARY_GROUP},
625 	{ERRDOS,	ERRbadfid,	NT_STATUS_FILE_CLOSED},
626 	{ERRHRD,	ERRgeneral,	NT_STATUS_TOO_MANY_THREADS},
627 	{ERRHRD,	ERRgeneral,	NT_STATUS_THREAD_NOT_IN_PROCESS},
628 	{ERRHRD,	ERRgeneral,	NT_STATUS_TOKEN_ALREADY_IN_USE},
629 	{ERRHRD,	ERRgeneral,	NT_STATUS_PAGEFILE_QUOTA_EXCEEDED},
630 	{ERRHRD,	ERRgeneral,	NT_STATUS_COMMITMENT_LIMIT},
631 	{ERRDOS, ERROR_BAD_EXE_FORMAT,	NT_STATUS_INVALID_IMAGE_LE_FORMAT},
632 	{ERRDOS, ERROR_BAD_EXE_FORMAT,	NT_STATUS_INVALID_IMAGE_NOT_MZ},
633 	{ERRDOS, ERROR_BAD_EXE_FORMAT,	NT_STATUS_INVALID_IMAGE_PROTECT},
634 	{ERRDOS, ERROR_BAD_EXE_FORMAT,	NT_STATUS_INVALID_IMAGE_WIN_16},
635 	{ERRHRD,	ERRgeneral,	NT_STATUS_LOGON_SERVER_CONFLICT},
636 	{ERRHRD,	ERRgeneral,	NT_STATUS_TIME_DIFFERENCE_AT_DC},
637 	{ERRHRD,	ERRgeneral,	NT_STATUS_SYNCHRONIZATION_REQUIRED},
638 	{ERRDOS, ERROR_MOD_NOT_FOUND,	NT_STATUS_DLL_NOT_FOUND},
639 	{ERRHRD,	ERRgeneral,	NT_STATUS_OPEN_FAILED},
640 	{ERRHRD,	ERRgeneral,	NT_STATUS_IO_PRIVILEGE_FAILED},
641 	{ERRDOS, ERROR_INVALID_ORDINAL,	NT_STATUS_ORDINAL_NOT_FOUND},
642 	{ERRDOS, ERROR_PROC_NOT_FOUND,	NT_STATUS_ENTRYPOINT_NOT_FOUND},
643 	{ERRHRD,	ERRgeneral,	NT_STATUS_CONTROL_C_EXIT},
644 	{ERRDOS, ERROR_NETNAME_DELETED,	NT_STATUS_LOCAL_DISCONNECT},
645 	{ERRDOS, ERROR_NETNAME_DELETED,	NT_STATUS_REMOTE_DISCONNECT},
646 	{ERRDOS, ERROR_REM_NOT_LIST,	NT_STATUS_REMOTE_RESOURCES},
647 	{ERRDOS, ERROR_UNEXP_NET_ERR,	NT_STATUS_LINK_FAILED},
648 	{ERRDOS, ERROR_UNEXP_NET_ERR,	NT_STATUS_LINK_TIMEOUT},
649 	{ERRDOS, ERROR_UNEXP_NET_ERR,	NT_STATUS_INVALID_CONNECTION},
650 	{ERRDOS, ERROR_UNEXP_NET_ERR,	NT_STATUS_INVALID_ADDRESS},
651 	{ERRHRD,	ERRgeneral,	NT_STATUS_DLL_INIT_FAILED},
652 	{ERRHRD,	ERRgeneral,	NT_STATUS_MISSING_SYSTEMFILE},
653 	{ERRHRD,	ERRgeneral,	NT_STATUS_UNHANDLED_EXCEPTION},
654 	{ERRHRD,	ERRgeneral,	NT_STATUS_APP_INIT_FAILURE},
655 	{ERRHRD,	ERRgeneral,	NT_STATUS_PAGEFILE_CREATE_FAILED},
656 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_PAGEFILE},
657 	{ERRDOS, ERROR_INVALID_LEVEL,	NT_STATUS_INVALID_LEVEL},
658 	{ERRDOS, ERROR_INVALID_PASSWORD,	NT_STATUS_WRONG_PASSWORD_CORE},
659 	{ERRHRD,	ERRgeneral,	NT_STATUS_ILLEGAL_FLOAT_CONTEXT},
660 	{ERRDOS, ERROR_BROKEN_PIPE,	NT_STATUS_PIPE_BROKEN},
661 	{ERRHRD,	ERRgeneral,	NT_STATUS_REGISTRY_CORRUPT},
662 	{ERRHRD,	ERRgeneral,	NT_STATUS_REGISTRY_IO_FAILED},
663 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_EVENT_PAIR},
664 	{ERRHRD,	ERRgeneral,	NT_STATUS_UNRECOGNIZED_VOLUME},
665 	{ERRHRD,	ERRgeneral,	NT_STATUS_SERIAL_NO_DEVICE_INITED},
666 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_SUCH_ALIAS},
667 	{ERRHRD,	ERRgeneral,	NT_STATUS_MEMBER_NOT_IN_ALIAS},
668 	{ERRHRD,	ERRgeneral,	NT_STATUS_MEMBER_IN_ALIAS},
669 	{ERRHRD,	ERRgeneral,	NT_STATUS_ALIAS_EXISTS},
670 	{ERRHRD,	ERRgeneral,	NT_STATUS_LOGON_NOT_GRANTED},
671 	{ERRHRD,	ERRgeneral,	NT_STATUS_TOO_MANY_SECRETS},
672 	{ERRHRD,	ERRgeneral,	NT_STATUS_SECRET_TOO_LONG},
673 	{ERRHRD,	ERRgeneral,	NT_STATUS_INTERNAL_DB_ERROR},
674 	{ERRHRD,	ERRgeneral,	NT_STATUS_FULLSCREEN_MODE},
675 	{ERRHRD,	ERRgeneral,	NT_STATUS_TOO_MANY_CONTEXT_IDS},
676 	{ERRDOS,	ERRnoaccess,	NT_STATUS_LOGON_TYPE_NOT_GRANTED},
677 	{ERRHRD,	ERRgeneral,	NT_STATUS_NOT_REGISTRY_FILE},
678 	{ERRHRD,	ERRgeneral,	NT_STATUS_NT_CROSS_ENCRYPTION_REQUIRED},
679 	{ERRHRD,	ERRgeneral,	NT_STATUS_DOMAIN_CTRLR_CONFIG_ERROR},
680 	{ERRHRD,	ERRgeneral,	NT_STATUS_FT_MISSING_MEMBER},
681 	{ERRHRD,	ERRgeneral,	NT_STATUS_ILL_FORMED_SERVICE_ENTRY},
682 	{ERRHRD,	ERRgeneral,	NT_STATUS_ILLEGAL_CHARACTER},
683 	{ERRHRD,	ERRgeneral,	NT_STATUS_UNMAPPABLE_CHARACTER},
684 	{ERRHRD,	ERRgeneral,	NT_STATUS_UNDEFINED_CHARACTER},
685 	{ERRHRD,	ERRgeneral,	NT_STATUS_FLOPPY_VOLUME},
686 	{ERRHRD,	ERRgeneral,	NT_STATUS_FLOPPY_ID_MARK_NOT_FOUND},
687 	{ERRHRD,	ERRgeneral,	NT_STATUS_FLOPPY_WRONG_CYLINDER},
688 	{ERRHRD,	ERRgeneral,	NT_STATUS_FLOPPY_UNKNOWN_ERROR},
689 	{ERRHRD,	ERRgeneral,	NT_STATUS_FLOPPY_BAD_REGISTERS},
690 	{ERRHRD,	ERRgeneral,	NT_STATUS_DISK_RECALIBRATE_FAILED},
691 	{ERRHRD,	ERRgeneral,	NT_STATUS_DISK_OPERATION_FAILED},
692 	{ERRHRD,	ERRgeneral,	NT_STATUS_DISK_RESET_FAILED},
693 	{ERRHRD,	ERRgeneral,	NT_STATUS_SHARED_IRQ_BUSY},
694 	{ERRHRD,	ERRgeneral,	NT_STATUS_FT_ORPHANING},
695 	{ERRHRD,	ERRgeneral,
696 		NT_STATUS_BIOS_FAILED_TO_CONNECT_INTERRUPT},
697 	{ERRHRD,	ERRgeneral,	NT_STATUS_PARTITION_FAILURE},
698 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_BLOCK_LENGTH},
699 	{ERRHRD,	ERRgeneral,	NT_STATUS_DEVICE_NOT_PARTITIONED},
700 	{ERRHRD,	ERRgeneral,	NT_STATUS_UNABLE_TO_LOCK_MEDIA},
701 	{ERRHRD,	ERRgeneral,	NT_STATUS_UNABLE_TO_UNLOAD_MEDIA},
702 	{ERRHRD,	ERRgeneral,	NT_STATUS_EOM_OVERFLOW},
703 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_MEDIA},
704 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_SUCH_MEMBER},
705 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_MEMBER},
706 	{ERRHRD,	ERRgeneral,	NT_STATUS_KEY_DELETED},
707 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_LOG_SPACE},
708 	{ERRHRD,	ERRgeneral,	NT_STATUS_TOO_MANY_SIDS},
709 	{ERRHRD,	ERRgeneral,	NT_STATUS_LM_CROSS_ENCRYPTION_REQUIRED},
710 	{ERRHRD,	ERRgeneral,	NT_STATUS_KEY_HAS_CHILDREN},
711 	{ERRHRD,	ERRgeneral,	NT_STATUS_CHILD_MUST_BE_VOLATILE},
712 	{ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_DEVICE_CONFIGURATION_ERROR},
713 	{ERRHRD,	ERRgeneral,	NT_STATUS_DRIVER_INTERNAL_ERROR},
714 	{ERRDOS, ERROR_BAD_COMMAND,	NT_STATUS_INVALID_DEVICE_STATE},
715 	{ERRHRD,	ERRgeneral,	NT_STATUS_IO_DEVICE_ERROR},
716 	{ERRHRD,	ERRgeneral,	NT_STATUS_DEVICE_PROTOCOL_ERROR},
717 	{ERRHRD,	ERRgeneral,	NT_STATUS_BACKUP_CONTROLLER},
718 	{ERRHRD,	ERRgeneral,	NT_STATUS_LOG_FILE_FULL},
719 	{ERRDOS, ERROR_WRITE_PROTECT,	NT_STATUS_TOO_LATE},
720 	{ERRDOS,	ERRnoaccess,	NT_STATUS_NO_TRUST_LSA_SECRET},
721 	{ERRDOS,	ERRnoaccess,	NT_STATUS_NO_TRUST_SAM_ACCOUNT},
722 	{ERRDOS,	ERRnoaccess,	NT_STATUS_TRUSTED_DOMAIN_FAILURE},
723 	{ERRDOS,	ERRnoaccess,	NT_STATUS_TRUSTED_RELATIONSHIP_FAILURE},
724 	{ERRHRD,	ERRgeneral,	NT_STATUS_EVENTLOG_FILE_CORRUPT},
725 	{ERRHRD,	ERRgeneral,	NT_STATUS_EVENTLOG_CANT_START},
726 	{ERRDOS,	ERRnoaccess,	NT_STATUS_TRUST_FAILURE},
727 	{ERRHRD,	ERRgeneral,	NT_STATUS_MUTANT_LIMIT_EXCEEDED},
728 	{ERRDOS, NERR_NetlogonNotStarted,	NT_STATUS_NETLOGON_NOT_STARTED},
729 	{ERRSRV, NERR_AccountExpired,	NT_STATUS_ACCOUNT_EXPIRED},
730 	{ERRHRD,	ERRgeneral,	NT_STATUS_POSSIBLE_DEADLOCK},
731 	{ERRHRD,	ERRgeneral,	NT_STATUS_NETWORK_CREDENTIAL_CONFLICT},
732 	{ERRHRD,	ERRgeneral,	NT_STATUS_REMOTE_SESSION_LIMIT},
733 	{ERRHRD,	ERRgeneral,	NT_STATUS_EVENTLOG_FILE_CHANGED},
734 	{ERRDOS,	ERRnoaccess,
735 		NT_STATUS_NOLOGON_INTERDOMAIN_TRUST_ACCOUNT},
736 	{ERRDOS,	ERRnoaccess,
737 		NT_STATUS_NOLOGON_WORKSTATION_TRUST_ACCOUNT},
738 	{ERRDOS,	ERRnoaccess,	NT_STATUS_NOLOGON_SERVER_TRUST_ACCOUNT},
739 	{ERRDOS,	ERRnoaccess,	NT_STATUS_DOMAIN_TRUST_INCONSISTENT},
740 	{ERRHRD,	ERRgeneral,	NT_STATUS_FS_DRIVER_REQUIRED},
741 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_USER_SESSION_KEY},
742 	{ERRDOS, ERROR_UNEXP_NET_ERR,	NT_STATUS_USER_SESSION_DELETED},
743 	{ERRHRD,	ERRgeneral,	NT_STATUS_RESOURCE_LANG_NOT_FOUND},
744 	{ERRDOS,	ERRnomem,	NT_STATUS_INSUFF_SERVER_RESOURCES},
745 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_BUFFER_SIZE},
746 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_ADDRESS_COMPONENT},
747 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_ADDRESS_WILDCARD},
748 	{ERRDOS, ERROR_TOO_MANY_NAMES,	NT_STATUS_TOO_MANY_ADDRESSES},
749 	{ERRDOS, ERROR_DUP_NAME,	NT_STATUS_ADDRESS_ALREADY_EXISTS},
750 	{ERRDOS, ERROR_NETNAME_DELETED,	NT_STATUS_ADDRESS_CLOSED},
751 	{ERRDOS, ERROR_NETNAME_DELETED,	NT_STATUS_CONNECTION_DISCONNECTED},
752 	{ERRDOS, ERROR_NETNAME_DELETED,	NT_STATUS_CONNECTION_RESET},
753 	{ERRDOS, ERROR_TOO_MANY_NAMES,	NT_STATUS_TOO_MANY_NODES},
754 	{ERRDOS, ERROR_UNEXP_NET_ERR,	NT_STATUS_TRANSACTION_ABORTED},
755 	{ERRDOS, ERROR_UNEXP_NET_ERR,	NT_STATUS_TRANSACTION_TIMED_OUT},
756 	{ERRDOS, ERROR_UNEXP_NET_ERR,	NT_STATUS_TRANSACTION_NO_RELEASE},
757 	{ERRDOS, ERROR_UNEXP_NET_ERR,	NT_STATUS_TRANSACTION_NO_MATCH},
758 	{ERRDOS, ERROR_UNEXP_NET_ERR,	NT_STATUS_TRANSACTION_RESPONDED},
759 	{ERRDOS, ERROR_UNEXP_NET_ERR,	NT_STATUS_TRANSACTION_INVALID_ID},
760 	{ERRDOS, ERROR_UNEXP_NET_ERR,	NT_STATUS_TRANSACTION_INVALID_TYPE},
761 	{ERRDOS, ERROR_NOT_SUPPORTED,	NT_STATUS_NOT_SERVER_SESSION},
762 	{ERRDOS, ERROR_NOT_SUPPORTED,	NT_STATUS_NOT_CLIENT_SESSION},
763 	{ERRHRD,	ERRgeneral,	NT_STATUS_CANNOT_LOAD_REGISTRY_FILE},
764 	{ERRHRD,	ERRgeneral,	NT_STATUS_DEBUG_ATTACH_FAILED},
765 	{ERRHRD,	ERRgeneral,	NT_STATUS_SYSTEM_PROCESS_TERMINATED},
766 	{ERRHRD,	ERRgeneral,	NT_STATUS_DATA_NOT_ACCEPTED},
767 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_BROWSER_SERVERS_FOUND},
768 	{ERRHRD,	ERRgeneral,	NT_STATUS_VDM_HARD_ERROR},
769 	{ERRHRD,	ERRgeneral,	NT_STATUS_DRIVER_CANCEL_TIMEOUT},
770 	{ERRHRD,	ERRgeneral,	NT_STATUS_REPLY_MESSAGE_MISMATCH},
771 	{ERRHRD,	ERRgeneral,	NT_STATUS_MAPPED_ALIGNMENT},
772 	{ERRDOS, ERROR_BAD_EXE_FORMAT,	NT_STATUS_IMAGE_CHECKSUM_MISMATCH},
773 	{ERRHRD,	ERRgeneral,	NT_STATUS_LOST_WRITEBEHIND_DATA},
774 	{ERRHRD,	ERRgeneral, NT_STATUS_CLIENT_SERVER_PARAMETERS_INVALID},
775 	{ERRSRV, NERR_PasswordExpired,	NT_STATUS_PASSWORD_MUST_CHANGE},
776 	{ERRHRD,	ERRgeneral,	NT_STATUS_NOT_FOUND},
777 	{ERRHRD,	ERRgeneral,	NT_STATUS_NOT_TINY_STREAM},
778 	{ERRHRD,	ERRgeneral,	NT_STATUS_RECOVERY_FAILURE},
779 	{ERRHRD,	ERRgeneral,	NT_STATUS_STACK_OVERFLOW_READ},
780 	{ERRHRD,	ERRgeneral,	NT_STATUS_FAIL_CHECK},
781 	{ERRHRD,	ERRgeneral,	NT_STATUS_DUPLICATE_OBJECTID},
782 	{ERRHRD,	ERRgeneral,	NT_STATUS_OBJECTID_EXISTS},
783 	{ERRHRD,	ERRgeneral,	NT_STATUS_CONVERT_TO_LARGE},
784 	{ERRHRD,	ERRgeneral,	NT_STATUS_RETRY},
785 	{ERRHRD,	ERRgeneral,	NT_STATUS_FOUND_OUT_OF_SCOPE},
786 	{ERRHRD,	ERRgeneral,	NT_STATUS_ALLOCATE_BUCKET},
787 	{ERRHRD,	ERRgeneral,	NT_STATUS_PROPSET_NOT_FOUND},
788 	{ERRHRD,	ERRgeneral,	NT_STATUS_MARSHALL_OVERFLOW},
789 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_VARIANT},
790 	{ERRHRD,	ERRgeneral,	NT_STATUS_DOMAIN_CONTROLLER_NOT_FOUND},
791 	{ERRDOS,	ERRnoaccess,	NT_STATUS_ACCOUNT_LOCKED_OUT},
792 	{ERRDOS,	ERRbadfid,	NT_STATUS_HANDLE_NOT_CLOSABLE},
793 	{ERRHRD,	ERRgeneral,	NT_STATUS_CONNECTION_REFUSED},
794 	{ERRHRD,	ERRgeneral,	NT_STATUS_GRACEFUL_DISCONNECT},
795 	{ERRHRD,	ERRgeneral,	NT_STATUS_ADDRESS_ALREADY_ASSOCIATED},
796 	{ERRHRD,	ERRgeneral,	NT_STATUS_ADDRESS_NOT_ASSOCIATED},
797 	{ERRHRD,	ERRgeneral,	NT_STATUS_CONNECTION_INVALID},
798 	{ERRHRD,	ERRgeneral,	NT_STATUS_CONNECTION_ACTIVE},
799 	{ERRHRD,	ERRgeneral,	NT_STATUS_NETWORK_UNREACHABLE},
800 	{ERRHRD,	ERRgeneral,	NT_STATUS_HOST_UNREACHABLE},
801 	{ERRHRD,	ERRgeneral,	NT_STATUS_PROTOCOL_UNREACHABLE},
802 	{ERRHRD,	ERRgeneral,	NT_STATUS_PORT_UNREACHABLE},
803 	{ERRHRD,	ERRgeneral,	NT_STATUS_REQUEST_ABORTED},
804 	{ERRHRD,	ERRgeneral,	NT_STATUS_CONNECTION_ABORTED},
805 	{ERRHRD,	ERRgeneral,	NT_STATUS_BAD_COMPRESSION_BUFFER},
806 	{ERRHRD,	ERRgeneral,	NT_STATUS_USER_MAPPED_FILE},
807 	{ERRHRD,	ERRgeneral,	NT_STATUS_AUDIT_FAILED},
808 	{ERRHRD,	ERRgeneral,	NT_STATUS_TIMER_RESOLUTION_NOT_SET},
809 	{ERRHRD,	ERRgeneral,	NT_STATUS_CONNECTION_COUNT_LIMIT},
810 	{ERRHRD,	ERRgeneral,	NT_STATUS_LOGIN_TIME_RESTRICTION},
811 	{ERRHRD,	ERRgeneral,	NT_STATUS_LOGIN_WKSTA_RESTRICTION},
812 	{ERRDOS, ERROR_BAD_EXE_FORMAT,	NT_STATUS_IMAGE_MP_UP_MISMATCH},
813 	{ERRHRD,	ERRgeneral,	NT_STATUS_INSUFFICIENT_LOGON_INFO},
814 	{ERRHRD,	ERRgeneral,	NT_STATUS_BAD_DLL_ENTRYPOINT},
815 	{ERRHRD,	ERRgeneral,	NT_STATUS_BAD_SERVICE_ENTRYPOINT},
816 	{ERRHRD,	ERRgeneral,	NT_STATUS_LPC_REPLY_LOST},
817 	{ERRHRD,	ERRgeneral,	NT_STATUS_IP_ADDRESS_CONFLICT1},
818 	{ERRHRD,	ERRgeneral,	NT_STATUS_IP_ADDRESS_CONFLICT2},
819 	{ERRHRD,	ERRgeneral,	NT_STATUS_REGISTRY_QUOTA_LIMIT},
820 	{ERRSRV,	ERRbadtype,	NT_STATUS_PATH_NOT_COVERED},
821 	{ERRHRD,	ERRgeneral,	NT_STATUS_NO_CALLBACK_ACTIVE},
822 	{ERRHRD,	ERRgeneral,	NT_STATUS_LICENSE_QUOTA_EXCEEDED},
823 	{ERRHRD,	ERRgeneral,	NT_STATUS_PWD_TOO_SHORT},
824 	{ERRHRD,	ERRgeneral,	NT_STATUS_PWD_TOO_RECENT},
825 	{ERRHRD,	ERRgeneral,	NT_STATUS_PWD_HISTORY_CONFLICT},
826 	{ERRHRD,	ERRgeneral,	NT_STATUS_PLUGPLAY_NO_DEVICE},
827 	{ERRHRD,	ERRgeneral,	NT_STATUS_UNSUPPORTED_COMPRESSION},
828 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_HW_PROFILE},
829 	{ERRHRD,	ERRgeneral,	NT_STATUS_INVALID_PLUGPLAY_DEVICE_PATH},
830 	{ERRDOS, ERROR_INVALID_ORDINAL,	NT_STATUS_DRIVER_ORDINAL_NOT_FOUND},
831 	{ERRDOS, ERROR_PROC_NOT_FOUND,	NT_STATUS_DRIVER_ENTRYPOINT_NOT_FOUND},
832 	{ERRDOS, ERROR_NOT_OWNER,	NT_STATUS_RESOURCE_NOT_OWNED},
833 	{ERRHRD,	ERRgeneral,	NT_STATUS_TOO_MANY_LINKS},
834 	{ERRHRD,	ERRgeneral,	NT_STATUS_QUOTA_LIST_INCONSISTENT},
835 	{ERRHRD,	ERRgeneral,	NT_STATUS_FILE_IS_OFFLINE},
836 	{ERRDOS, ERROR_NOT_READY,	NT_STATUS_VOLUME_DISMOUNTED},
837 	{ERRDOS, ERROR_BAD_PATHNAME,	NT_STATUS_DIRECTORY_IS_A_REPARSE_POINT},
838 	{ERRDOS,	ERRnoaccess,	NT_STATUS_ENCRYPTION_FAILED},
839 	{ERRDOS,	ERRnoaccess,	NT_STATUS_DECRYPTION_FAILED},
840 	{ERRHRD,	ERRgeneral,	NT_STATUS_RANGE_NOT_FOUND},
841 	{ERRDOS,	ERRnoaccess,	NT_STATUS_NO_RECOVERY_POLICY},
842 	{ERRDOS,	ERRnoaccess,	NT_STATUS_NO_EFS},
843 	{ERRDOS,	ERRnoaccess,	NT_STATUS_WRONG_EFS},
844 	{ERRDOS,	ERRnoaccess,	NT_STATUS_NO_USER_KEYS},
845 	{ERRDOS,	ERRbadfunc,	NT_STATUS_VOLUME_NOT_UPGRADED},
846 	{0, 0, 0}
847 };
848 
849 int
850 smb_maperr32(uint32_t nterr)
851 {
852 	const nt2errno_t *nt2e;
853 	const nt2doserr_t *nt2d;
854 
855 	switch (NT_SC_SEVERITY(nterr)) {
856 	case NT_STATUS_SEVERITY_SUCCESS:
857 	case NT_STATUS_SEVERITY_INFORMATIONAL:
858 		return (0);
859 	}
860 
861 	/* first try direct map to unix */
862 	for (nt2e = nt2errno; nt2e->errno; nt2e++)
863 		if (nt2e->nterr == nterr)
864 			return (nt2e->errno);
865 	smb_errmsg(unknown_err_logpri, "smb_maperr32",
866 	    "No direct map for 32 bit server error (0x%x)\n", nterr);
867 
868 	/* ok, then try mapping to dos to unix */
869 	for (nt2d = nt2doserr; nt2d->nterr; nt2d++)
870 		if (nt2d->nterr == nterr)
871 			return (smb_maperror(nt2d->dclass, nt2d->derr));
872 	return (EIO);
873 }
874 
875 uint_t
876 smb_doserr2status(int dclass, int derr)
877 {
878 	const nt2doserr_t *nt2d;
879 
880 	if (dclass == 0 && derr == 0)
881 		return (0);
882 
883 	for (nt2d = nt2doserr; nt2d->nterr; nt2d++)
884 		if (nt2d->dclass == dclass && nt2d->derr == derr)
885 			return (nt2d->nterr);
886 	return (NT_STATUS_UNSUCCESSFUL);
887 }
888 
889 int
890 smb_maperror(int eclass, int eno)
891 {
892 	if (eclass == 0 && eno == 0)
893 		return (0);
894 	switch (eclass) {
895 	case ERRDOS:
896 		switch (eno) {
897 		case ERROR_INVALID_LEVEL:
898 			return (ENOTSUP);
899 		case ERRbadfunc:
900 		case ERRbadenv:
901 		case ERRbadformat:
902 		case ERRremcd:
903 		case ERRrmuns:
904 			return (EINVAL);
905 		case ERRbadfile:
906 		case ERRbadpath:
907 		case ERROR_BAD_DEV_TYPE:
908 		case ERROR_BAD_NET_NAME:
909 			return (ENOENT);
910 		case ERRnofids:
911 			return (EMFILE);
912 		case ERRnoaccess:
913 			/*
914 			 * XXX CSM Reported on samba-technical 12/7/2002
915 			 *
916 			 * There is a case for which server(s) return
917 			 * ERRnoaccess but should return ERRdiskfull: When
918 			 * the offset for a write is exactly the server
919 			 * file size limit then Samba (at least) thinks
920 			 * the reason for zero bytes having been written
921 			 * must have been "access denied" from the local
922 			 * filesystem.  This cannot be easily worked
923 			 * around since the server behaviour is
924 			 * indistinguishable from actual access denied.
925 			 * An incomplete workaround: attempt a 2 byte write
926 			 * from "offset-1".  (That may require reading at
927 			 * offset-1 first.)  The flaw is that reading or
928 			 * writing at offset-1 could cause an
929 			 * unrelated error (due to a byte range lock
930 			 * for instance) and we can't presume the
931 			 * order servers check errors in.
932 			 */
933 		case ERRbadaccess:
934 			return (EACCES);
935 		case ERRbadshare:
936 			return (EBUSY);
937 		case ERRbadfid:
938 			return (EBADF);
939 		case ERRbadmcb:
940 			return (EIO);
941 		case ERRnomem:
942 			return (ENOMEM);	/* actually remote no mem... */
943 		case ERRbadmem:
944 			return (EFAULT);
945 		case ERRbaddata:
946 			return (E2BIG);
947 		case ERRbaddrive:
948 		case ERRnotready:	/* nt */
949 			return (ENXIO);
950 		case ERRdiffdevice:
951 			return (EXDEV);
952 		case ERRnofiles:
953 			return (0);	/* eeof ? */
954 		case ERRlock:
955 			return (EAGAIN);
956 		case ERRfilexists:
957 			return (EEXIST);
958 		case ERROR_INVALID_NAME:
959 			return (ENOENT);
960 		case ERROR_DIR_NOT_EMPTY:
961 			return (ENOTEMPTY);
962 		case ERROR_NOT_LOCKED:
963 			return (0); /* we unlock on any close */
964 		case ERROR_ALREADY_EXISTS:
965 			return (EEXIST);
966 		case ERRmoredata:
967 			return (EMOREDATA);
968 		}
969 		break;
970 	case ERRSRV:
971 		switch (eno) {
972 		case ERRerror:
973 			return (EINVAL);
974 		case ERRbadpw:
975 			return (EAUTH);
976 		case ERRaccess:
977 		case ERRbaduid:
978 			return (EACCES);
979 		case ERRinvnid:
980 			return (ENETRESET);
981 		case ERRinvnetname:
982 			return (ENXIO);
983 		case ERRbadtype:		/* reserved and returned */
984 			return (EIO);
985 		case NERR_AccountExpired: /* account exists but disabled */
986 			return (EPERM);
987 		}
988 		break;
989 	case ERRHRD:
990 		switch (eno) {
991 		case ERRnowrite:
992 			return (EROFS);
993 		case ERRbadunit:
994 			return (ENODEV);
995 		case ERRbadreq:
996 			return (EBADRPC);
997 		case ERRbadshare:
998 			return (ETXTBSY);
999 		case ERRlock:
1000 			return (EAGAIN);
1001 		case ERRdiskfull:
1002 			return (EFBIG);
1003 		case ERRnotready:
1004 		case ERRbadcmd:
1005 		case ERRdata:
1006 		case ERRgeneral:
1007 			return (EIO);
1008 		}
1009 	}
1010 
1011 	smb_errmsg(unknown_err_logpri, "smb_maperror",
1012 	    "Unknown DOS error %d/%d\n", eclass, eno);
1013 	return (EIO);
1014 }
1015 
1016 #if defined(NOICONVSUPPORT) || defined(lint)
1017 extern int iconv_conv(void *handle, const char **inbuf,
1018     size_t *inbytesleft, char **outbuf, size_t *outbytesleft);
1019 #endif
1020 
1021 #define	SMALL_CONV 256
1022 
1023 /*ARGSUSED*/
1024 int
1025 smb_put_dmem(struct mbchain *mbp, struct smb_vc *vcp, const char *src,
1026 	int size, int caseopt, int *lenp)
1027 {
1028 	uint16_t convbuf[SMALL_CONV];
1029 	uint16_t *cbuf;
1030 	size_t cbufalloc, inlen, outlen;
1031 	int error;
1032 
1033 	if (size <= 0)
1034 		return (0);
1035 
1036 	/*
1037 	 * Handle the easy case (non-unicode).
1038 	 * XXX: Technically, we should convert
1039 	 * the string to OEM codeset first...
1040 	 * Modern servers all use Unicode, so
1041 	 * this is good enough.
1042 	 */
1043 	if (SMB_UNICODE_STRINGS(vcp) == 0) {
1044 		error = mb_put_mem(mbp, src, size, MB_MSYSTEM);
1045 		if (!error && lenp)
1046 			*lenp += size;
1047 		return (error);
1048 	}
1049 
1050 	/*
1051 	 * Convert to UCS-2 (really UTF-16).
1052 	 * Use stack buffer if the string is
1053 	 * small enough, else allocate.
1054 	 */
1055 	if (size <= SMALL_CONV) {
1056 		cbufalloc = 0;
1057 		outlen = SMALL_CONV;
1058 		cbuf = convbuf;
1059 	} else {
1060 		outlen = size; /* in utf-16 characters */
1061 		cbufalloc = outlen * 2;
1062 		cbuf = kmem_alloc(cbufalloc, KM_SLEEP);
1063 	}
1064 
1065 	inlen = size;
1066 	error = uconv_u8tou16((uchar_t *)src, &inlen, cbuf, &outlen,
1067 	    UCONV_OUT_LITTLE_ENDIAN | UCONV_IGNORE_NULL);
1068 	outlen *= 2;  /* convert to bytes */
1069 
1070 	if (!error) {
1071 		(void) mb_put_padbyte(mbp); /* align */
1072 		error = mb_put_mem(mbp, (char *)cbuf, outlen, MB_MSYSTEM);
1073 	}
1074 	if (!error && lenp)
1075 		*lenp += outlen;
1076 
1077 	if (cbufalloc)
1078 		kmem_free(cbuf, cbufalloc);
1079 
1080 	return (error);
1081 }
1082 
1083 int
1084 smb_put_dstring(struct mbchain *mbp, struct smb_vc *vcp, const char *src,
1085 	int caseopt)
1086 {
1087 	int error, len;
1088 
1089 	/*
1090 	 * Let smb_put_dmem put both the string
1091 	 * and the terminating null.
1092 	 */
1093 	len = strlen(src) + 1;
1094 	error = smb_put_dmem(mbp, vcp, src, len, caseopt, NULL);
1095 	if (error)
1096 		return (error);
1097 
1098 	return (error);
1099 }
1100