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 * Copyright 2025 RackTop Systems, Inc.
40 */
41
42 #include <sys/param.h>
43 #include <sys/systm.h>
44 #include <sys/kmem.h>
45 #include <sys/proc.h>
46 #include <sys/lock.h>
47 #include <sys/socket.h>
48 #include <sys/isa_defs.h>
49 #include <sys/stream.h>
50 #include <sys/strsun.h>
51 #include <sys/sunddi.h>
52 #include <sys/cmn_err.h>
53 #include <sys/sdt.h>
54 #include <sys/priv.h>
55 #include <sys/u8_textprep.h>
56
57 #include <netsmb/smb_osdep.h>
58 #include <netsmb/smb.h>
59 #include <netsmb/smb_conn.h>
60 #include <netsmb/smb_rq.h>
61 #include <netsmb/smb_subr.h>
62
63 void
smb_credinit(struct smb_cred * scred,cred_t * cr)64 smb_credinit(struct smb_cred *scred, cred_t *cr)
65 {
66 /* cr arg is optional */
67 if (cr == NULL)
68 cr = ddi_get_cred();
69 #ifdef _KERNEL
70 if (is_system_labeled()) {
71 cr = crdup(cr);
72 (void) setpflags(NET_MAC_AWARE, 1, cr);
73 } else
74 #endif
75 {
76 crhold(cr);
77 }
78 scred->scr_cred = cr;
79 }
80
81 void
smb_credrele(struct smb_cred * scred)82 smb_credrele(struct smb_cred *scred)
83 {
84 if (scred->scr_cred != NULL) {
85 crfree(scred->scr_cred);
86 scred->scr_cred = NULL;
87 }
88 }
89
90 #ifndef _KERNEL
91 /* ARGSUSED */
92 void
smb_debugmsg(const char * func,char * msg)93 smb_debugmsg(const char *func, char *msg)
94 {
95 }
96 #endif /* _KERNEL */
97
98 /*
99 * Helper for the SMBERROR macro, etc.
100 * This is also a good place for a breakpoint
101 * or a dtrace probe, i.e. fbt:nsmb:smb_errmsg
102 */
103 void
smb_errmsg(int cel,const char * func_name,const char * fmt,...)104 smb_errmsg(int cel, const char *func_name, const char *fmt, ...)
105 {
106 va_list adx;
107 char buf[100];
108
109 va_start(adx, fmt);
110 if (cel == CE_CONT) {
111 /*
112 * This is one of our xxxDEBUG macros.
113 * Don't bother to log these, but just
114 * fire a dtrace probe with the message.
115 */
116 (void) vsnprintf(buf, sizeof (buf), fmt, adx);
117 DTRACE_PROBE2(debugmsg2,
118 (char *), func_name,
119 (char *), buf);
120 #ifndef _KERNEL
121 smb_debugmsg(func_name, buf);
122 #endif
123 } else {
124 /*
125 * This is one of our xxxERROR macros.
126 * Add a prefix to the fmt string,
127 * then let vcmn_err do the args.
128 */
129 (void) snprintf(buf, sizeof (buf), "?%s: %s", func_name, fmt);
130 DTRACE_PROBE3(debugmsg3,
131 (char *), func_name,
132 (char *), buf,
133 va_list, adx);
134 vcmn_err(cel, buf, adx);
135 }
136 va_end(adx);
137 }
138
139 #if 1 /* def SMB_SOCKETDATA_DEBUG */
140 void
m_dumpm(mblk_t * m)141 m_dumpm(mblk_t *m)
142 {
143 int len, seg;
144
145 len = msgdsize(m);
146 DTRACE_PROBE2(dsize, int, len, (mblk_t *), m);
147
148 for (seg = 0; m; seg++) {
149 DTRACE_PROBE2(mblk, int, seg, (mblk_t *), m);
150 m = m->b_cont;
151 }
152 }
153 #endif
154
155 #ifndef EPROTO
156 #define EPROTO ECONNABORTED
157 #endif
158 #ifndef ELIBACC
159 #define ELIBACC ENOENT
160 #endif
161 #ifndef ENODATA
162 #define ENODATA EINVAL
163 #endif
164 #ifndef ENOTUNIQ
165 #define ENOTUNIQ EADDRINUSE
166 #endif
167 #ifndef ECOMM
168 #define ECOMM EIO
169 #endif
170 #ifndef ENOMEDIUM
171 #define ENOMEDIUM ENXIO
172 #endif
173 #ifndef ETIME
174 #define ETIME ETIMEDOUT
175 #endif
176 #ifndef EMOREDATA
177 #define EMOREDATA (0x7fff)
178 #endif
179
180 /*
181 * Log any un-handled NT or DOS errors we encounter.
182 * Make these log NOTICE in a debug build to ensure
183 * they get noticed during tests. In the field these
184 * are unimportant, so just fire a Dtrace probe.
185 */
186 static int unknown_err_logpri =
187 #ifdef DEBUG
188 CE_NOTE;
189 #else
190 CE_CONT;
191 #endif
192
193 typedef struct nt2errno {
194 unsigned int nterr;
195 int errno;
196 } nt2errno_t;
197
198 static const nt2errno_t nt2errno[] = {
199 /* Alphabetical order. */
200 {NT_STATUS_ACCESS_DENIED, EACCES},
201 {NT_STATUS_ACCESS_VIOLATION, EACCES},
202 {NT_STATUS_ACCOUNT_DISABLED, EACCES},
203 {NT_STATUS_ACCOUNT_EXPIRED, EACCES},
204 {NT_STATUS_ACCOUNT_LOCKED_OUT, EACCES},
205 {NT_STATUS_ACCOUNT_RESTRICTION, EACCES},
206 {NT_STATUS_ADDRESS_ALREADY_EXISTS, EADDRINUSE},
207 {NT_STATUS_BAD_NETWORK_NAME, ENOENT},
208 {NT_STATUS_BAD_NETWORK_PATH, ENOENT},
209 {NT_STATUS_BUFFER_TOO_SMALL, E2BIG},
210 {NT_STATUS_CANCELLED, ECANCELED},
211 {NT_STATUS_CANNOT_DELETE, EACCES},
212 {NT_STATUS_CONFLICTING_ADDRESSES, EADDRINUSE},
213 {NT_STATUS_CONNECTION_ABORTED, ECONNABORTED},
214 {NT_STATUS_CONNECTION_DISCONNECTED, ECONNABORTED},
215 {NT_STATUS_CONNECTION_REFUSED, ECONNREFUSED},
216 {NT_STATUS_CONNECTION_RESET, ENETRESET},
217 {NT_STATUS_DELETE_PENDING, EACCES},
218 {NT_STATUS_DEVICE_DOES_NOT_EXIST, ENODEV},
219 {NT_STATUS_DEVICE_PROTOCOL_ERROR, EPROTO},
220 {NT_STATUS_DIRECTORY_NOT_EMPTY, ENOTEMPTY},
221 {NT_STATUS_DISK_FULL, ENOSPC},
222 {NT_STATUS_DLL_NOT_FOUND, ELIBACC},
223 {NT_STATUS_DUPLICATE_NAME, EINVAL},
224 {NT_STATUS_EAS_NOT_SUPPORTED, ENOTSUP},
225 {NT_STATUS_EA_TOO_LARGE, E2BIG},
226 {NT_STATUS_END_OF_FILE, ENODATA},
227 {NT_STATUS_FILE_CLOSED, EBADF},
228 {NT_STATUS_FILE_DELETED, ENOENT},
229 {NT_STATUS_FILE_INVALID, EIO},
230 {NT_STATUS_FILE_IS_A_DIRECTORY, EISDIR},
231 {NT_STATUS_FILE_LOCK_CONFLICT, EAGAIN},
232 {NT_STATUS_FILE_RENAMED, ENOENT},
233 {NT_STATUS_FLOAT_INEXACT_RESULT, ERANGE},
234 {NT_STATUS_FLOAT_OVERFLOW, ERANGE},
235 {NT_STATUS_FLOAT_UNDERFLOW, ERANGE},
236 {NT_STATUS_HOST_UNREACHABLE, EHOSTUNREACH},
237 {NT_STATUS_ILL_FORMED_PASSWORD, EAUTH},
238 {NT_STATUS_INFO_LENGTH_MISMATCH, EINVAL},
239 {NT_STATUS_INSUFFICIENT_RESOURCES, EAGAIN},
240 {NT_STATUS_INSUFF_SERVER_RESOURCES, EAGAIN},
241 {NT_STATUS_INTEGER_OVERFLOW, ERANGE},
242 {NT_STATUS_INVALID_ACCOUNT_NAME, EAUTH},
243 {NT_STATUS_INVALID_BUFFER_SIZE, EIO},
244 {NT_STATUS_INVALID_DEVICE_REQUEST, EINVAL},
245 {NT_STATUS_INVALID_HANDLE, EBADF},
246 {NT_STATUS_INVALID_INFO_CLASS, EINVAL},
247 {NT_STATUS_INVALID_LEVEL, ENOTSUP},
248 {NT_STATUS_INVALID_LOCK_SEQUENCE, EINVAL},
249 {NT_STATUS_INVALID_LOGON_HOURS, EAUTH},
250 {NT_STATUS_INVALID_OWNER, EINVAL},
251 {NT_STATUS_INVALID_PARAMETER, EINVAL},
252 {NT_STATUS_INVALID_PIPE_STATE, EPIPE},
253 {NT_STATUS_INVALID_PRIMARY_GROUP, EINVAL},
254 {NT_STATUS_INVALID_WORKSTATION, EACCES},
255 {NT_STATUS_IN_PAGE_ERROR, EFAULT},
256 {NT_STATUS_IO_DEVICE_ERROR, EIO},
257 {NT_STATUS_IO_TIMEOUT, ETIMEDOUT},
258 {NT_STATUS_IP_ADDRESS_CONFLICT1, EADDRINUSE},
259 {NT_STATUS_IP_ADDRESS_CONFLICT2, EADDRINUSE},
260 {NT_STATUS_LICENSE_QUOTA_EXCEEDED, EDQUOT},
261 {NT_STATUS_LOCK_NOT_GRANTED, EAGAIN},
262 {NT_STATUS_LOGIN_TIME_RESTRICTION, EAUTH},
263 {NT_STATUS_LOGON_FAILURE, EAUTH},
264 {NT_STATUS_LOGON_TYPE_NOT_GRANTED, EAUTH},
265 {NT_STATUS_MEDIA_WRITE_PROTECTED, EROFS},
266 {NT_STATUS_MEMORY_NOT_ALLOCATED, EFAULT},
267 {NT_STATUS_MORE_PROCESSING_REQUIRED, EINPROGRESS},
268 {NT_STATUS_NAME_TOO_LONG, ENAMETOOLONG},
269 {NT_STATUS_NETWORK_ACCESS_DENIED, EACCES},
270 {NT_STATUS_NETWORK_BUSY, EBUSY},
271 {NT_STATUS_NETWORK_NAME_DELETED, ENOENT},
272 {NT_STATUS_NETWORK_UNREACHABLE, ENETUNREACH},
273 {NT_STATUS_NET_WRITE_FAULT, ECOMM},
274 {NT_STATUS_NONEXISTENT_EA_ENTRY, ENOENT},
275 {NT_STATUS_NONEXISTENT_SECTOR, ESPIPE},
276 {NT_STATUS_NONE_MAPPED, EINVAL},
277 {NT_STATUS_NOT_A_DIRECTORY, ENOTDIR},
278 {NT_STATUS_NOT_FOUND, ENOENT},
279 {NT_STATUS_NOT_IMPLEMENTED, ENOTSUP},
280 {NT_STATUS_NOT_LOCKED, ENOLCK},
281 {NT_STATUS_NOT_MAPPED_VIEW, EINVAL},
282 {NT_STATUS_NOT_SUPPORTED, ENOTSUP},
283 {NT_STATUS_NO_EAS_ON_FILE, ENOENT},
284 {NT_STATUS_NO_LOGON_SERVERS, EAUTH},
285 {NT_STATUS_NO_MEDIA, ENOMEDIUM},
286 {NT_STATUS_NO_MEDIA_IN_DEVICE, ENOMEDIUM},
287 {NT_STATUS_NO_MEMORY, ENOMEM},
288 {NT_STATUS_NO_MORE_FILES, ENOENT},
289 {NT_STATUS_NO_SUCH_DEVICE, ENODEV},
290 {NT_STATUS_NO_SUCH_FILE, ENOENT},
291 {NT_STATUS_NO_SUCH_LOGON_SESSION, EAUTH},
292 {NT_STATUS_NO_SUCH_USER, EAUTH},
293 {NT_STATUS_NO_TRUST_LSA_SECRET, EAUTH},
294 {NT_STATUS_NO_TRUST_SAM_ACCOUNT, EAUTH},
295 {NT_STATUS_OBJECT_NAME_COLLISION, EEXIST},
296 {NT_STATUS_OBJECT_NAME_INVALID, EINVAL},
297 {NT_STATUS_OBJECT_NAME_NOT_FOUND, ENOENT},
298 {NT_STATUS_OBJECT_PATH_INVALID, ENOTDIR},
299 {NT_STATUS_OBJECT_PATH_NOT_FOUND, ENOENT},
300 {NT_STATUS_OBJECT_PATH_SYNTAX_BAD, EINVAL},
301 {NT_STATUS_OBJECT_TYPE_MISMATCH, EBADF},
302 {NT_STATUS_PAGEFILE_QUOTA, EDQUOT},
303 {NT_STATUS_PASSWORD_EXPIRED, EAUTH},
304 {NT_STATUS_PASSWORD_MUST_CHANGE, EAUTH},
305 {NT_STATUS_PASSWORD_RESTRICTION, EAUTH},
306 {NT_STATUS_PATH_NOT_COVERED, ENOENT},
307 {NT_STATUS_PIPE_BROKEN, EPIPE},
308 {NT_STATUS_PIPE_BUSY, EPIPE},
309 {NT_STATUS_PIPE_CONNECTED, EISCONN},
310 {NT_STATUS_PIPE_DISCONNECTED, EPIPE},
311 {NT_STATUS_PIPE_NOT_AVAILABLE, EBUSY},
312 {NT_STATUS_PORT_CONNECTION_REFUSED, ECONNREFUSED},
313 {NT_STATUS_PORT_DISCONNECTED, EBADF},
314 {NT_STATUS_PORT_MESSAGE_TOO_LONG, EMSGSIZE},
315 {NT_STATUS_PORT_UNREACHABLE, EHOSTUNREACH},
316 {NT_STATUS_PROTOCOL_UNREACHABLE, ENOPROTOOPT},
317 {NT_STATUS_QUOTA_EXCEEDED, EDQUOT},
318 {NT_STATUS_RANGE_NOT_LOCKED, EAGAIN}, /* like F_SETLK */
319 {NT_STATUS_REGISTRY_QUOTA_LIMIT, EDQUOT},
320 {NT_STATUS_REMOTE_DISCONNECT, ESHUTDOWN},
321 {NT_STATUS_REMOTE_NOT_LISTENING, ECONNREFUSED},
322 {NT_STATUS_REQUEST_NOT_ACCEPTED, EACCES},
323 {NT_STATUS_RETRY, EAGAIN},
324 {NT_STATUS_SHARING_VIOLATION, EBUSY},
325 {NT_STATUS_TIMER_NOT_CANCELED, ETIME},
326 {NT_STATUS_TOO_MANY_LINKS, EMLINK},
327 {NT_STATUS_TOO_MANY_OPENED_FILES, EMFILE},
328 {NT_STATUS_TRUSTED_DOMAIN_FAILURE, EAUTH},
329 {NT_STATUS_TRUSTED_RELATIONSHIP_FAILURE, EAUTH},
330 {NT_STATUS_UNABLE_TO_FREE_VM, EADDRINUSE},
331 {NT_STATUS_UNSUCCESSFUL, EINVAL},
332 {NT_STATUS_WRONG_PASSWORD, EAUTH},
333 {0, 0}
334 };
335
336 /*
337 * Table for converting NT STATUS values to DOS class/code.
338 * Rows ordered by integer value of last column (NT STATUS)
339 */
340 typedef struct nt2doserr {
341 unsigned short dclass;
342 unsigned short derr;
343 unsigned int nterr;
344 } nt2doserr_t;
345
346 static const nt2doserr_t nt2doserr[] = {
347 {ERRDOS, ERRgeneral, NT_STATUS_UNSUCCESSFUL},
348 {ERRDOS, ERRbadfunc, NT_STATUS_NOT_IMPLEMENTED},
349 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_INFO_CLASS},
350 {ERRDOS, ERROR_BAD_LENGTH, NT_STATUS_INFO_LENGTH_MISMATCH},
351 {ERRHRD, ERRgeneral, NT_STATUS_ACCESS_VIOLATION},
352 {ERRHRD, ERRgeneral, NT_STATUS_IN_PAGE_ERROR},
353 {ERRHRD, ERRgeneral, NT_STATUS_PAGEFILE_QUOTA},
354 {ERRDOS, ERRbadfid, NT_STATUS_INVALID_HANDLE},
355 {ERRHRD, ERRgeneral, NT_STATUS_BAD_INITIAL_STACK},
356 {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_BAD_INITIAL_PC},
357 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_CID},
358 {ERRHRD, ERRgeneral, NT_STATUS_TIMER_NOT_CANCELED},
359 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER},
360 {ERRDOS, ERRbadfile, NT_STATUS_NO_SUCH_DEVICE},
361 {ERRDOS, ERRbadfile, NT_STATUS_NO_SUCH_FILE},
362 {ERRDOS, ERRbadfunc, NT_STATUS_INVALID_DEVICE_REQUEST},
363 {ERRDOS, ERROR_HANDLE_EOF, NT_STATUS_END_OF_FILE},
364 {ERRDOS, ERROR_WRONG_DISK, NT_STATUS_WRONG_VOLUME},
365 {ERRDOS, ERROR_NOT_READY, NT_STATUS_NO_MEDIA_IN_DEVICE},
366 {ERRHRD, ERRgeneral, NT_STATUS_UNRECOGNIZED_MEDIA},
367 {ERRDOS, ERROR_SECTOR_NOT_FOUND, NT_STATUS_NONEXISTENT_SECTOR},
368 {ERRDOS, ERRnomem, NT_STATUS_NO_MEMORY},
369 {ERRDOS, ERROR_INVALID_ADDRESS, NT_STATUS_CONFLICTING_ADDRESSES},
370 {ERRDOS, ERROR_INVALID_ADDRESS, NT_STATUS_NOT_MAPPED_VIEW},
371 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_UNABLE_TO_FREE_VM},
372 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_UNABLE_TO_DELETE_SECTION},
373 {ERRDOS, NERR_InvalidAPI, NT_STATUS_INVALID_SYSTEM_SERVICE},
374 {ERRHRD, ERRgeneral, NT_STATUS_ILLEGAL_INSTRUCTION},
375 {ERRDOS, ERRnoaccess, NT_STATUS_INVALID_LOCK_SEQUENCE},
376 {ERRDOS, ERRnoaccess, NT_STATUS_INVALID_VIEW_SIZE},
377 {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_INVALID_FILE_FOR_SECTION},
378 {ERRDOS, ERRnoaccess, NT_STATUS_ALREADY_COMMITTED},
379 {ERRDOS, ERRnoaccess, NT_STATUS_ACCESS_DENIED},
380 {ERRDOS, ERROR_BUFFER_OVERFLOW, NT_STATUS_BUFFER_TOO_SMALL},
381 {ERRDOS, ERRbadfid, NT_STATUS_OBJECT_TYPE_MISMATCH},
382 {ERRHRD, ERRgeneral, NT_STATUS_NONCONTINUABLE_EXCEPTION},
383 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_DISPOSITION},
384 {ERRHRD, ERRgeneral, NT_STATUS_UNWIND},
385 {ERRHRD, ERRgeneral, NT_STATUS_BAD_STACK},
386 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_UNWIND_TARGET},
387 {ERRDOS, ERROR_NOT_LOCKED, NT_STATUS_NOT_LOCKED},
388 {ERRHRD, ERRgeneral, NT_STATUS_PARITY_ERROR},
389 {ERRDOS, ERROR_INVALID_ADDRESS, NT_STATUS_UNABLE_TO_DECOMMIT_VM},
390 {ERRDOS, ERROR_INVALID_ADDRESS, NT_STATUS_NOT_COMMITTED},
391 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_PORT_ATTRIBUTES},
392 {ERRHRD, ERRgeneral, NT_STATUS_PORT_MESSAGE_TOO_LONG},
393 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_MIX},
394 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_QUOTA_LOWER},
395 {ERRHRD, ERRgeneral, NT_STATUS_DISK_CORRUPT_ERROR},
396 {ERRDOS, ERROR_INVALID_NAME, NT_STATUS_OBJECT_NAME_INVALID},
397 {ERRDOS, ERRbadfile, NT_STATUS_OBJECT_NAME_NOT_FOUND},
398 {ERRDOS, ERROR_ALREADY_EXISTS, NT_STATUS_OBJECT_NAME_COLLISION},
399 {ERRDOS, ERRbadfid, NT_STATUS_PORT_DISCONNECTED},
400 {ERRHRD, ERRgeneral, NT_STATUS_DEVICE_ALREADY_ATTACHED},
401 {ERRDOS, ERROR_BAD_PATHNAME, NT_STATUS_OBJECT_PATH_INVALID},
402 {ERRDOS, ERRbadpath, NT_STATUS_OBJECT_PATH_NOT_FOUND},
403 {ERRDOS, ERROR_BAD_PATHNAME, NT_STATUS_OBJECT_PATH_SYNTAX_BAD},
404 {ERRHRD, ERRgeneral, NT_STATUS_DATA_OVERRUN},
405 {ERRHRD, ERRgeneral, NT_STATUS_DATA_LATE_ERROR},
406 {ERRDOS, ERROR_CRC, NT_STATUS_DATA_ERROR},
407 {ERRDOS, ERROR_CRC, NT_STATUS_CRC_ERROR},
408 {ERRDOS, ERRnomem, NT_STATUS_SECTION_TOO_BIG},
409 {ERRDOS, ERRnoaccess, NT_STATUS_PORT_CONNECTION_REFUSED},
410 {ERRDOS, ERRbadfid, NT_STATUS_INVALID_PORT_HANDLE},
411 {ERRDOS, ERROR_SHARING_VIOLATION, NT_STATUS_SHARING_VIOLATION},
412 {ERRHRD, ERRgeneral, NT_STATUS_QUOTA_EXCEEDED},
413 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PAGE_PROTECTION},
414 {ERRDOS, ERROR_NOT_OWNER, NT_STATUS_MUTANT_NOT_OWNED},
415 {ERRDOS, ERROR_TOO_MANY_POSTS, NT_STATUS_SEMAPHORE_LIMIT_EXCEEDED},
416 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_PORT_ALREADY_SET},
417 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_SECTION_NOT_IMAGE},
418 {ERRDOS, ERROR_SIGNAL_REFUSED, NT_STATUS_SUSPEND_COUNT_EXCEEDED},
419 {ERRDOS, ERRnoaccess, NT_STATUS_THREAD_IS_TERMINATING},
420 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_BAD_WORKING_SET_LIMIT},
421 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INCOMPATIBLE_FILE_MAP},
422 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_SECTION_PROTECTION},
423 {ERRDOS, ERROR_EAS_NOT_SUPPORTED, NT_STATUS_EAS_NOT_SUPPORTED},
424 {ERRDOS, ERROR_EA_LIST_INCONSISTENT, NT_STATUS_EA_TOO_LARGE},
425 {ERRHRD, ERRgeneral, NT_STATUS_NONEXISTENT_EA_ENTRY},
426 {ERRHRD, ERRgeneral, NT_STATUS_NO_EAS_ON_FILE},
427 {ERRHRD, ERRgeneral, NT_STATUS_EA_CORRUPT_ERROR},
428 {ERRDOS, ERROR_LOCK_VIOLATION, NT_STATUS_FILE_LOCK_CONFLICT},
429 {ERRDOS, ERROR_LOCK_VIOLATION, NT_STATUS_LOCK_NOT_GRANTED},
430 {ERRDOS, ERRnoaccess, NT_STATUS_DELETE_PENDING},
431 {ERRDOS, ERROR_NOT_SUPPORTED, NT_STATUS_CTL_FILE_NOT_SUPPORTED},
432 {ERRHRD, ERRgeneral, NT_STATUS_UNKNOWN_REVISION},
433 {ERRHRD, ERRgeneral, NT_STATUS_REVISION_MISMATCH},
434 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_OWNER},
435 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_PRIMARY_GROUP},
436 {ERRHRD, ERRgeneral, NT_STATUS_NO_IMPERSONATION_TOKEN},
437 {ERRHRD, ERRgeneral, NT_STATUS_CANT_DISABLE_MANDATORY},
438 {ERRDOS, NERR_LogonServerNotFound, NT_STATUS_NO_LOGON_SERVERS},
439 {ERRHRD, ERRgeneral, NT_STATUS_NO_SUCH_LOGON_SESSION},
440 {ERRHRD, ERRgeneral, NT_STATUS_NO_SUCH_PRIVILEGE},
441 {ERRDOS, ERRnoaccess, NT_STATUS_PRIVILEGE_NOT_HELD},
442 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_ACCOUNT_NAME},
443 {ERRHRD, ERRgeneral, NT_STATUS_USER_EXISTS},
444 {ERRDOS, ERRnoaccess, NT_STATUS_NO_SUCH_USER},
445 {ERRHRD, ERRgeneral, NT_STATUS_GROUP_EXISTS},
446 {ERRHRD, ERRgeneral, NT_STATUS_NO_SUCH_GROUP},
447 {ERRHRD, ERRgeneral, NT_STATUS_MEMBER_IN_GROUP},
448 {ERRHRD, ERRgeneral, NT_STATUS_MEMBER_NOT_IN_GROUP},
449 {ERRHRD, ERRgeneral, NT_STATUS_LAST_ADMIN},
450 {ERRSRV, ERRbadpw, NT_STATUS_WRONG_PASSWORD},
451 {ERRHRD, ERRgeneral, NT_STATUS_ILL_FORMED_PASSWORD},
452 {ERRHRD, ERRgeneral, NT_STATUS_PASSWORD_RESTRICTION},
453 {ERRDOS, ERRnoaccess, NT_STATUS_LOGON_FAILURE},
454 {ERRHRD, ERRgeneral, NT_STATUS_ACCOUNT_RESTRICTION},
455 {ERRSRV, NERR_InvalidLogonHours, NT_STATUS_INVALID_LOGON_HOURS},
456 {ERRSRV, NERR_InvalidWorkstation, NT_STATUS_INVALID_WORKSTATION},
457 {ERRSRV, NERR_PasswordExpired, NT_STATUS_PASSWORD_EXPIRED},
458 {ERRSRV, NERR_AccountExpired, NT_STATUS_ACCOUNT_DISABLED},
459 {ERRHRD, ERRgeneral, NT_STATUS_NONE_MAPPED},
460 {ERRHRD, ERRgeneral, NT_STATUS_TOO_MANY_LUIDS_REQUESTED},
461 {ERRHRD, ERRgeneral, NT_STATUS_LUIDS_EXHAUSTED},
462 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_SUB_AUTHORITY},
463 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_ACL},
464 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_SID},
465 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_SECURITY_DESCR},
466 {ERRDOS, ERROR_PROC_NOT_FOUND, NT_STATUS_PROCEDURE_NOT_FOUND},
467 {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_INVALID_IMAGE_FORMAT},
468 {ERRHRD, ERRgeneral, NT_STATUS_NO_TOKEN},
469 {ERRHRD, ERRgeneral, NT_STATUS_BAD_INHERITANCE_ACL},
470 {ERRDOS, ERROR_NOT_LOCKED, NT_STATUS_RANGE_NOT_LOCKED},
471 {ERRDOS, ERROR_DISK_FULL, NT_STATUS_DISK_FULL},
472 {ERRHRD, ERRgeneral, NT_STATUS_SERVER_DISABLED},
473 {ERRHRD, ERRgeneral, NT_STATUS_SERVER_NOT_DISABLED},
474 {ERRDOS, ERROR_TOO_MANY_NAMES, NT_STATUS_TOO_MANY_GUIDS_REQUESTED},
475 {ERRDOS, ERROR_NO_MORE_ITEMS, NT_STATUS_GUIDS_EXHAUSTED},
476 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_ID_AUTHORITY},
477 {ERRDOS, ERROR_NO_MORE_ITEMS, NT_STATUS_AGENTS_EXHAUSTED},
478 {ERRDOS, ERROR_LABEL_TOO_LONG, NT_STATUS_INVALID_VOLUME_LABEL},
479 {ERRDOS, ERROR_OUTOFMEMORY, NT_STATUS_SECTION_NOT_EXTENDED},
480 {ERRDOS, ERROR_INVALID_ADDRESS, NT_STATUS_NOT_MAPPED_DATA},
481 {ERRHRD, ERRgeneral, NT_STATUS_RESOURCE_DATA_NOT_FOUND},
482 {ERRHRD, ERRgeneral, NT_STATUS_RESOURCE_TYPE_NOT_FOUND},
483 {ERRHRD, ERRgeneral, NT_STATUS_RESOURCE_NAME_NOT_FOUND},
484 {ERRHRD, ERRgeneral, NT_STATUS_ARRAY_BOUNDS_EXCEEDED},
485 {ERRHRD, ERRgeneral, NT_STATUS_FLOAT_DENORMAL_OPERAND},
486 {ERRHRD, ERRgeneral, NT_STATUS_FLOAT_DIVIDE_BY_ZERO},
487 {ERRHRD, ERRgeneral, NT_STATUS_FLOAT_INEXACT_RESULT},
488 {ERRHRD, ERRgeneral, NT_STATUS_FLOAT_INVALID_OPERATION},
489 {ERRHRD, ERRgeneral, NT_STATUS_FLOAT_OVERFLOW},
490 {ERRHRD, ERRgeneral, NT_STATUS_FLOAT_STACK_CHECK},
491 {ERRHRD, ERRgeneral, NT_STATUS_FLOAT_UNDERFLOW},
492 {ERRHRD, ERRgeneral, NT_STATUS_INTEGER_DIVIDE_BY_ZERO},
493 {ERRDOS, ERROR_ARITHMETIC_OVERFLOW, NT_STATUS_INTEGER_OVERFLOW},
494 {ERRHRD, ERRgeneral, NT_STATUS_PRIVILEGED_INSTRUCTION},
495 {ERRDOS, ERRnomem, NT_STATUS_TOO_MANY_PAGING_FILES},
496 {ERRHRD, ERRgeneral, NT_STATUS_FILE_INVALID},
497 {ERRHRD, ERRgeneral, NT_STATUS_ALLOTTED_SPACE_EXCEEDED},
498 {ERRDOS, ERRnomem, NT_STATUS_INSUFFICIENT_RESOURCES},
499 {ERRDOS, ERRbadpath, NT_STATUS_DFS_EXIT_PATH_FOUND},
500 {ERRDOS, ERROR_CRC, NT_STATUS_DEVICE_DATA_ERROR},
501 {ERRHRD, ERRgeneral, NT_STATUS_DEVICE_NOT_CONNECTED},
502 {ERRDOS, ERROR_NOT_READY, NT_STATUS_DEVICE_POWER_FAILURE},
503 {ERRDOS, ERROR_INVALID_ADDRESS, NT_STATUS_FREE_VM_NOT_AT_BASE},
504 {ERRDOS, ERROR_INVALID_ADDRESS, NT_STATUS_MEMORY_NOT_ALLOCATED},
505 {ERRHRD, ERRgeneral, NT_STATUS_WORKING_SET_QUOTA},
506 {ERRDOS, ERROR_WRITE_PROTECT, NT_STATUS_MEDIA_WRITE_PROTECTED},
507 {ERRDOS, ERROR_NOT_READY, NT_STATUS_DEVICE_NOT_READY},
508 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_GROUP_ATTRIBUTES},
509 {ERRHRD, ERRgeneral, NT_STATUS_BAD_IMPERSONATION_LEVEL},
510 {ERRHRD, ERRgeneral, NT_STATUS_CANT_OPEN_ANONYMOUS},
511 {ERRHRD, ERRgeneral, NT_STATUS_BAD_VALIDATION_CLASS},
512 {ERRHRD, ERRgeneral, NT_STATUS_BAD_TOKEN_TYPE},
513 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_BAD_MASTER_BOOT_RECORD},
514 {ERRHRD, ERRgeneral, NT_STATUS_INSTRUCTION_MISALIGNMENT},
515 {ERRDOS, ERROR_PIPE_BUSY, NT_STATUS_INSTANCE_NOT_AVAILABLE},
516 {ERRDOS, ERROR_PIPE_BUSY, NT_STATUS_PIPE_NOT_AVAILABLE},
517 {ERRDOS, ERROR_BAD_PIPE, NT_STATUS_INVALID_PIPE_STATE},
518 {ERRDOS, ERROR_PIPE_BUSY, NT_STATUS_PIPE_BUSY},
519 {ERRDOS, ERRbadfunc, NT_STATUS_ILLEGAL_FUNCTION},
520 {ERRDOS, ERROR_PIPE_NOT_CONNECTED, NT_STATUS_PIPE_DISCONNECTED},
521 {ERRDOS, ERROR_NO_DATA, NT_STATUS_PIPE_CLOSING},
522 {ERRHRD, ERRgeneral, NT_STATUS_PIPE_CONNECTED},
523 {ERRHRD, ERRgeneral, NT_STATUS_PIPE_LISTENING},
524 {ERRDOS, ERROR_BAD_PIPE, NT_STATUS_INVALID_READ_MODE},
525 {ERRDOS, ERROR_SEM_TIMEOUT, NT_STATUS_IO_TIMEOUT},
526 {ERRDOS, ERROR_HANDLE_EOF, NT_STATUS_FILE_FORCED_CLOSED},
527 {ERRHRD, ERRgeneral, NT_STATUS_PROFILING_NOT_STARTED},
528 {ERRHRD, ERRgeneral, NT_STATUS_PROFILING_NOT_STOPPED},
529 {ERRHRD, ERRgeneral, NT_STATUS_COULD_NOT_INTERPRET},
530 {ERRDOS, ERRnoaccess, NT_STATUS_FILE_IS_A_DIRECTORY},
531 {ERRDOS, ERROR_NOT_SUPPORTED, NT_STATUS_NOT_SUPPORTED},
532 {ERRDOS, ERROR_REM_NOT_LIST, NT_STATUS_REMOTE_NOT_LISTENING},
533 {ERRDOS, ERROR_DUP_NAME, NT_STATUS_DUPLICATE_NAME},
534 {ERRDOS, ERROR_BAD_NETPATH, NT_STATUS_BAD_NETWORK_PATH},
535 {ERRDOS, ERROR_NETWORK_BUSY, NT_STATUS_NETWORK_BUSY},
536 {ERRDOS, ERROR_DEV_NOT_EXIST, NT_STATUS_DEVICE_DOES_NOT_EXIST},
537 {ERRDOS, ERROR_TOO_MANY_CMDS, NT_STATUS_TOO_MANY_COMMANDS},
538 {ERRDOS, ERROR_ADAP_HDW_ERR, NT_STATUS_ADAPTER_HARDWARE_ERROR},
539 {ERRDOS, ERROR_BAD_NET_RESP, NT_STATUS_INVALID_NETWORK_RESPONSE},
540 {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_UNEXPECTED_NETWORK_ERROR},
541 {ERRDOS, ERROR_BAD_REM_ADAP, NT_STATUS_BAD_REMOTE_ADAPTER},
542 {ERRDOS, ERROR_PRINTQ_FULL, NT_STATUS_PRINT_QUEUE_FULL},
543 {ERRDOS, ERROR_NO_SPOOL_SPACE, NT_STATUS_NO_SPOOL_SPACE},
544 {ERRDOS, ERROR_PRINT_CANCELLED, NT_STATUS_PRINT_CANCELLED},
545 {ERRDOS, ERROR_NETNAME_DELETED, NT_STATUS_NETWORK_NAME_DELETED},
546 {ERRDOS, ERROR_NETWORK_ACCESS_DENIED, NT_STATUS_NETWORK_ACCESS_DENIED},
547 {ERRDOS, ERROR_BAD_DEV_TYPE, NT_STATUS_BAD_DEVICE_TYPE},
548 {ERRDOS, ERROR_BAD_NET_NAME, NT_STATUS_BAD_NETWORK_NAME},
549 {ERRDOS, ERROR_TOO_MANY_NAMES, NT_STATUS_TOO_MANY_NAMES},
550 {ERRDOS, ERROR_TOO_MANY_SESS, NT_STATUS_TOO_MANY_SESSIONS},
551 {ERRDOS, ERROR_SHARING_PAUSED, NT_STATUS_SHARING_PAUSED},
552 {ERRDOS, ERROR_REQ_NOT_ACCEP, NT_STATUS_REQUEST_NOT_ACCEPTED},
553 {ERRDOS, ERROR_REDIR_PAUSED, NT_STATUS_REDIRECTOR_PAUSED},
554 {ERRDOS, ERROR_NET_WRITE_FAULT, NT_STATUS_NET_WRITE_FAULT},
555 {ERRHRD, ERRgeneral, NT_STATUS_PROFILING_AT_LIMIT},
556 {ERRDOS, ERROR_NOT_SAME_DEVICE, NT_STATUS_NOT_SAME_DEVICE},
557 {ERRDOS, ERRnoaccess, NT_STATUS_FILE_RENAMED},
558 {ERRDOS, ERROR_VC_DISCONNECTED, NT_STATUS_VIRTUAL_CIRCUIT_CLOSED},
559 {ERRHRD, ERRgeneral, NT_STATUS_NO_SECURITY_ON_OBJECT},
560 {ERRHRD, ERRgeneral, NT_STATUS_CANT_WAIT},
561 {ERRDOS, ERROR_NO_DATA, NT_STATUS_PIPE_EMPTY},
562 {ERRHRD, ERRgeneral, NT_STATUS_CANT_ACCESS_DOMAIN_INFO},
563 {ERRHRD, ERRgeneral, NT_STATUS_CANT_TERMINATE_SELF},
564 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_SERVER_STATE},
565 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_DOMAIN_STATE},
566 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_DOMAIN_ROLE},
567 {ERRHRD, ERRgeneral, NT_STATUS_NO_SUCH_DOMAIN},
568 {ERRHRD, ERRgeneral, NT_STATUS_DOMAIN_EXISTS},
569 {ERRHRD, ERRgeneral, NT_STATUS_DOMAIN_LIMIT_EXCEEDED},
570 {ERRDOS, ERROR_OPLOCK_NOT_GRANTED, NT_STATUS_OPLOCK_NOT_GRANTED},
571 {ERRDOS, ERROR_INVALID_OPLOCK_PROTOCOL,
572 NT_STATUS_INVALID_OPLOCK_PROTOCOL},
573 {ERRHRD, ERRgeneral, NT_STATUS_INTERNAL_DB_CORRUPTION},
574 {ERRHRD, ERRgeneral, NT_STATUS_INTERNAL_ERROR},
575 {ERRHRD, ERRgeneral, NT_STATUS_GENERIC_NOT_MAPPED},
576 {ERRHRD, ERRgeneral, NT_STATUS_BAD_DESCRIPTOR_FORMAT},
577 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_USER_BUFFER},
578 {ERRHRD, ERRgeneral, NT_STATUS_UNEXPECTED_IO_ERROR},
579 {ERRHRD, ERRgeneral, NT_STATUS_UNEXPECTED_MM_CREATE_ERR},
580 {ERRHRD, ERRgeneral, NT_STATUS_UNEXPECTED_MM_MAP_ERROR},
581 {ERRHRD, ERRgeneral, NT_STATUS_UNEXPECTED_MM_EXTEND_ERR},
582 {ERRHRD, ERRgeneral, NT_STATUS_NOT_LOGON_PROCESS},
583 {ERRHRD, ERRgeneral, NT_STATUS_LOGON_SESSION_EXISTS},
584 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_1},
585 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_2},
586 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_3},
587 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_4},
588 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_5},
589 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_6},
590 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_7},
591 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_8},
592 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_9},
593 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_10},
594 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_11},
595 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_12},
596 {ERRDOS, ERRbadpath, NT_STATUS_REDIRECTOR_NOT_STARTED},
597 {ERRHRD, ERRgeneral, NT_STATUS_REDIRECTOR_STARTED},
598 {ERRHRD, ERRgeneral, NT_STATUS_STACK_OVERFLOW},
599 {ERRHRD, ERRgeneral, NT_STATUS_NO_SUCH_PACKAGE},
600 {ERRHRD, ERRgeneral, NT_STATUS_BAD_FUNCTION_TABLE},
601 {ERRDOS, ERROR_ENVVAR_NOT_FOUND, NT_STATUS_VARIABLE_NOT_FOUND},
602 {ERRDOS, ERROR_DIR_NOT_EMPTY, NT_STATUS_DIRECTORY_NOT_EMPTY},
603 {ERRHRD, ERRgeneral, NT_STATUS_FILE_CORRUPT_ERROR},
604 {ERRDOS, ERROR_DIRECTORY, NT_STATUS_NOT_A_DIRECTORY},
605 {ERRHRD, ERRgeneral, NT_STATUS_BAD_LOGON_SESSION_STATE},
606 {ERRHRD, ERRgeneral, NT_STATUS_LOGON_SESSION_COLLISION},
607 {ERRDOS, ERROR_FILENAME_EXCED_RANGE, NT_STATUS_NAME_TOO_LONG},
608 {ERRDOS, NERR_OpenFiles, NT_STATUS_FILES_OPEN},
609 {ERRDOS, NERR_DevInUse, NT_STATUS_CONNECTION_IN_USE},
610 {ERRHRD, ERRgeneral, NT_STATUS_MESSAGE_NOT_FOUND},
611 {ERRDOS, ERRnoaccess, NT_STATUS_PROCESS_IS_TERMINATING},
612 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_LOGON_TYPE},
613 {ERRHRD, ERRgeneral, NT_STATUS_NO_GUID_TRANSLATION},
614 {ERRHRD, ERRgeneral, NT_STATUS_CANNOT_IMPERSONATE},
615 {ERRHRD, ERRgeneral, NT_STATUS_IMAGE_ALREADY_LOADED},
616 {ERRHRD, ERRgeneral, NT_STATUS_NO_LDT},
617 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_LDT_SIZE},
618 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_LDT_OFFSET},
619 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_LDT_DESCRIPTOR},
620 {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_INVALID_IMAGE_NE_FORMAT},
621 {ERRHRD, ERRgeneral, NT_STATUS_RXACT_INVALID_STATE},
622 {ERRHRD, ERRgeneral, NT_STATUS_RXACT_COMMIT_FAILURE},
623 {ERRHRD, ERRgeneral, NT_STATUS_MAPPED_FILE_SIZE_ZERO},
624 {ERRDOS, ERRnofids, NT_STATUS_TOO_MANY_OPENED_FILES},
625 {ERRHRD, ERRgeneral, NT_STATUS_CANCELLED},
626 {ERRDOS, ERRnoaccess, NT_STATUS_CANNOT_DELETE},
627 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_COMPUTER_NAME},
628 {ERRDOS, ERRnoaccess, NT_STATUS_FILE_DELETED},
629 {ERRHRD, ERRgeneral, NT_STATUS_SPECIAL_ACCOUNT},
630 {ERRHRD, ERRgeneral, NT_STATUS_SPECIAL_GROUP},
631 {ERRHRD, ERRgeneral, NT_STATUS_SPECIAL_USER},
632 {ERRHRD, ERRgeneral, NT_STATUS_MEMBERS_PRIMARY_GROUP},
633 {ERRDOS, ERRbadfid, NT_STATUS_FILE_CLOSED},
634 {ERRHRD, ERRgeneral, NT_STATUS_TOO_MANY_THREADS},
635 {ERRHRD, ERRgeneral, NT_STATUS_THREAD_NOT_IN_PROCESS},
636 {ERRHRD, ERRgeneral, NT_STATUS_TOKEN_ALREADY_IN_USE},
637 {ERRHRD, ERRgeneral, NT_STATUS_PAGEFILE_QUOTA_EXCEEDED},
638 {ERRHRD, ERRgeneral, NT_STATUS_COMMITMENT_LIMIT},
639 {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_INVALID_IMAGE_LE_FORMAT},
640 {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_INVALID_IMAGE_NOT_MZ},
641 {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_INVALID_IMAGE_PROTECT},
642 {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_INVALID_IMAGE_WIN_16},
643 {ERRHRD, ERRgeneral, NT_STATUS_LOGON_SERVER_CONFLICT},
644 {ERRHRD, ERRgeneral, NT_STATUS_TIME_DIFFERENCE_AT_DC},
645 {ERRHRD, ERRgeneral, NT_STATUS_SYNCHRONIZATION_REQUIRED},
646 {ERRDOS, ERROR_MOD_NOT_FOUND, NT_STATUS_DLL_NOT_FOUND},
647 {ERRHRD, ERRgeneral, NT_STATUS_OPEN_FAILED},
648 {ERRHRD, ERRgeneral, NT_STATUS_IO_PRIVILEGE_FAILED},
649 {ERRDOS, ERROR_INVALID_ORDINAL, NT_STATUS_ORDINAL_NOT_FOUND},
650 {ERRDOS, ERROR_PROC_NOT_FOUND, NT_STATUS_ENTRYPOINT_NOT_FOUND},
651 {ERRHRD, ERRgeneral, NT_STATUS_CONTROL_C_EXIT},
652 {ERRDOS, ERROR_NETNAME_DELETED, NT_STATUS_LOCAL_DISCONNECT},
653 {ERRDOS, ERROR_NETNAME_DELETED, NT_STATUS_REMOTE_DISCONNECT},
654 {ERRDOS, ERROR_REM_NOT_LIST, NT_STATUS_REMOTE_RESOURCES},
655 {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_LINK_FAILED},
656 {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_LINK_TIMEOUT},
657 {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_INVALID_CONNECTION},
658 {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_INVALID_ADDRESS},
659 {ERRHRD, ERRgeneral, NT_STATUS_DLL_INIT_FAILED},
660 {ERRHRD, ERRgeneral, NT_STATUS_MISSING_SYSTEMFILE},
661 {ERRHRD, ERRgeneral, NT_STATUS_UNHANDLED_EXCEPTION},
662 {ERRHRD, ERRgeneral, NT_STATUS_APP_INIT_FAILURE},
663 {ERRHRD, ERRgeneral, NT_STATUS_PAGEFILE_CREATE_FAILED},
664 {ERRHRD, ERRgeneral, NT_STATUS_NO_PAGEFILE},
665 {ERRDOS, ERROR_INVALID_LEVEL, NT_STATUS_INVALID_LEVEL},
666 {ERRDOS, ERROR_INVALID_PASSWORD, NT_STATUS_WRONG_PASSWORD_CORE},
667 {ERRHRD, ERRgeneral, NT_STATUS_ILLEGAL_FLOAT_CONTEXT},
668 {ERRDOS, ERROR_BROKEN_PIPE, NT_STATUS_PIPE_BROKEN},
669 {ERRHRD, ERRgeneral, NT_STATUS_REGISTRY_CORRUPT},
670 {ERRHRD, ERRgeneral, NT_STATUS_REGISTRY_IO_FAILED},
671 {ERRHRD, ERRgeneral, NT_STATUS_NO_EVENT_PAIR},
672 {ERRHRD, ERRgeneral, NT_STATUS_UNRECOGNIZED_VOLUME},
673 {ERRHRD, ERRgeneral, NT_STATUS_SERIAL_NO_DEVICE_INITED},
674 {ERRHRD, ERRgeneral, NT_STATUS_NO_SUCH_ALIAS},
675 {ERRHRD, ERRgeneral, NT_STATUS_MEMBER_NOT_IN_ALIAS},
676 {ERRHRD, ERRgeneral, NT_STATUS_MEMBER_IN_ALIAS},
677 {ERRHRD, ERRgeneral, NT_STATUS_ALIAS_EXISTS},
678 {ERRHRD, ERRgeneral, NT_STATUS_LOGON_NOT_GRANTED},
679 {ERRHRD, ERRgeneral, NT_STATUS_TOO_MANY_SECRETS},
680 {ERRHRD, ERRgeneral, NT_STATUS_SECRET_TOO_LONG},
681 {ERRHRD, ERRgeneral, NT_STATUS_INTERNAL_DB_ERROR},
682 {ERRHRD, ERRgeneral, NT_STATUS_FULLSCREEN_MODE},
683 {ERRHRD, ERRgeneral, NT_STATUS_TOO_MANY_CONTEXT_IDS},
684 {ERRDOS, ERRnoaccess, NT_STATUS_LOGON_TYPE_NOT_GRANTED},
685 {ERRHRD, ERRgeneral, NT_STATUS_NOT_REGISTRY_FILE},
686 {ERRHRD, ERRgeneral, NT_STATUS_NT_CROSS_ENCRYPTION_REQUIRED},
687 {ERRHRD, ERRgeneral, NT_STATUS_DOMAIN_CTRLR_CONFIG_ERROR},
688 {ERRHRD, ERRgeneral, NT_STATUS_FT_MISSING_MEMBER},
689 {ERRHRD, ERRgeneral, NT_STATUS_ILL_FORMED_SERVICE_ENTRY},
690 {ERRHRD, ERRgeneral, NT_STATUS_ILLEGAL_CHARACTER},
691 {ERRHRD, ERRgeneral, NT_STATUS_UNMAPPABLE_CHARACTER},
692 {ERRHRD, ERRgeneral, NT_STATUS_UNDEFINED_CHARACTER},
693 {ERRHRD, ERRgeneral, NT_STATUS_FLOPPY_VOLUME},
694 {ERRHRD, ERRgeneral, NT_STATUS_FLOPPY_ID_MARK_NOT_FOUND},
695 {ERRHRD, ERRgeneral, NT_STATUS_FLOPPY_WRONG_CYLINDER},
696 {ERRHRD, ERRgeneral, NT_STATUS_FLOPPY_UNKNOWN_ERROR},
697 {ERRHRD, ERRgeneral, NT_STATUS_FLOPPY_BAD_REGISTERS},
698 {ERRHRD, ERRgeneral, NT_STATUS_DISK_RECALIBRATE_FAILED},
699 {ERRHRD, ERRgeneral, NT_STATUS_DISK_OPERATION_FAILED},
700 {ERRHRD, ERRgeneral, NT_STATUS_DISK_RESET_FAILED},
701 {ERRHRD, ERRgeneral, NT_STATUS_SHARED_IRQ_BUSY},
702 {ERRHRD, ERRgeneral, NT_STATUS_FT_ORPHANING},
703 {ERRHRD, ERRgeneral,
704 NT_STATUS_BIOS_FAILED_TO_CONNECT_INTERRUPT},
705 {ERRHRD, ERRgeneral, NT_STATUS_PARTITION_FAILURE},
706 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_BLOCK_LENGTH},
707 {ERRHRD, ERRgeneral, NT_STATUS_DEVICE_NOT_PARTITIONED},
708 {ERRHRD, ERRgeneral, NT_STATUS_UNABLE_TO_LOCK_MEDIA},
709 {ERRHRD, ERRgeneral, NT_STATUS_UNABLE_TO_UNLOAD_MEDIA},
710 {ERRHRD, ERRgeneral, NT_STATUS_EOM_OVERFLOW},
711 {ERRHRD, ERRgeneral, NT_STATUS_NO_MEDIA},
712 {ERRHRD, ERRgeneral, NT_STATUS_NO_SUCH_MEMBER},
713 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_MEMBER},
714 {ERRHRD, ERRgeneral, NT_STATUS_KEY_DELETED},
715 {ERRHRD, ERRgeneral, NT_STATUS_NO_LOG_SPACE},
716 {ERRHRD, ERRgeneral, NT_STATUS_TOO_MANY_SIDS},
717 {ERRHRD, ERRgeneral, NT_STATUS_LM_CROSS_ENCRYPTION_REQUIRED},
718 {ERRHRD, ERRgeneral, NT_STATUS_KEY_HAS_CHILDREN},
719 {ERRHRD, ERRgeneral, NT_STATUS_CHILD_MUST_BE_VOLATILE},
720 {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_DEVICE_CONFIGURATION_ERROR},
721 {ERRHRD, ERRgeneral, NT_STATUS_DRIVER_INTERNAL_ERROR},
722 {ERRDOS, ERROR_BAD_COMMAND, NT_STATUS_INVALID_DEVICE_STATE},
723 {ERRHRD, ERRgeneral, NT_STATUS_IO_DEVICE_ERROR},
724 {ERRHRD, ERRgeneral, NT_STATUS_DEVICE_PROTOCOL_ERROR},
725 {ERRHRD, ERRgeneral, NT_STATUS_BACKUP_CONTROLLER},
726 {ERRHRD, ERRgeneral, NT_STATUS_LOG_FILE_FULL},
727 {ERRDOS, ERROR_WRITE_PROTECT, NT_STATUS_TOO_LATE},
728 {ERRDOS, ERRnoaccess, NT_STATUS_NO_TRUST_LSA_SECRET},
729 {ERRDOS, ERRnoaccess, NT_STATUS_NO_TRUST_SAM_ACCOUNT},
730 {ERRDOS, ERRnoaccess, NT_STATUS_TRUSTED_DOMAIN_FAILURE},
731 {ERRDOS, ERRnoaccess, NT_STATUS_TRUSTED_RELATIONSHIP_FAILURE},
732 {ERRHRD, ERRgeneral, NT_STATUS_EVENTLOG_FILE_CORRUPT},
733 {ERRHRD, ERRgeneral, NT_STATUS_EVENTLOG_CANT_START},
734 {ERRDOS, ERRnoaccess, NT_STATUS_TRUST_FAILURE},
735 {ERRHRD, ERRgeneral, NT_STATUS_MUTANT_LIMIT_EXCEEDED},
736 {ERRDOS, NERR_NetlogonNotStarted, NT_STATUS_NETLOGON_NOT_STARTED},
737 {ERRSRV, NERR_AccountExpired, NT_STATUS_ACCOUNT_EXPIRED},
738 {ERRHRD, ERRgeneral, NT_STATUS_POSSIBLE_DEADLOCK},
739 {ERRHRD, ERRgeneral, NT_STATUS_NETWORK_CREDENTIAL_CONFLICT},
740 {ERRHRD, ERRgeneral, NT_STATUS_REMOTE_SESSION_LIMIT},
741 {ERRHRD, ERRgeneral, NT_STATUS_EVENTLOG_FILE_CHANGED},
742 {ERRDOS, ERRnoaccess,
743 NT_STATUS_NOLOGON_INTERDOMAIN_TRUST_ACCOUNT},
744 {ERRDOS, ERRnoaccess,
745 NT_STATUS_NOLOGON_WORKSTATION_TRUST_ACCOUNT},
746 {ERRDOS, ERRnoaccess, NT_STATUS_NOLOGON_SERVER_TRUST_ACCOUNT},
747 {ERRDOS, ERRnoaccess, NT_STATUS_DOMAIN_TRUST_INCONSISTENT},
748 {ERRHRD, ERRgeneral, NT_STATUS_FS_DRIVER_REQUIRED},
749 {ERRHRD, ERRgeneral, NT_STATUS_NO_USER_SESSION_KEY},
750 {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_USER_SESSION_DELETED},
751 {ERRHRD, ERRgeneral, NT_STATUS_RESOURCE_LANG_NOT_FOUND},
752 {ERRDOS, ERRnomem, NT_STATUS_INSUFF_SERVER_RESOURCES},
753 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_BUFFER_SIZE},
754 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_ADDRESS_COMPONENT},
755 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_ADDRESS_WILDCARD},
756 {ERRDOS, ERROR_TOO_MANY_NAMES, NT_STATUS_TOO_MANY_ADDRESSES},
757 {ERRDOS, ERROR_DUP_NAME, NT_STATUS_ADDRESS_ALREADY_EXISTS},
758 {ERRDOS, ERROR_NETNAME_DELETED, NT_STATUS_ADDRESS_CLOSED},
759 {ERRDOS, ERROR_NETNAME_DELETED, NT_STATUS_CONNECTION_DISCONNECTED},
760 {ERRDOS, ERROR_NETNAME_DELETED, NT_STATUS_CONNECTION_RESET},
761 {ERRDOS, ERROR_TOO_MANY_NAMES, NT_STATUS_TOO_MANY_NODES},
762 {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_TRANSACTION_ABORTED},
763 {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_TRANSACTION_TIMED_OUT},
764 {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_TRANSACTION_NO_RELEASE},
765 {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_TRANSACTION_NO_MATCH},
766 {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_TRANSACTION_RESPONDED},
767 {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_TRANSACTION_INVALID_ID},
768 {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_TRANSACTION_INVALID_TYPE},
769 {ERRDOS, ERROR_NOT_SUPPORTED, NT_STATUS_NOT_SERVER_SESSION},
770 {ERRDOS, ERROR_NOT_SUPPORTED, NT_STATUS_NOT_CLIENT_SESSION},
771 {ERRHRD, ERRgeneral, NT_STATUS_CANNOT_LOAD_REGISTRY_FILE},
772 {ERRHRD, ERRgeneral, NT_STATUS_DEBUG_ATTACH_FAILED},
773 {ERRHRD, ERRgeneral, NT_STATUS_SYSTEM_PROCESS_TERMINATED},
774 {ERRHRD, ERRgeneral, NT_STATUS_DATA_NOT_ACCEPTED},
775 {ERRHRD, ERRgeneral, NT_STATUS_NO_BROWSER_SERVERS_FOUND},
776 {ERRHRD, ERRgeneral, NT_STATUS_VDM_HARD_ERROR},
777 {ERRHRD, ERRgeneral, NT_STATUS_DRIVER_CANCEL_TIMEOUT},
778 {ERRHRD, ERRgeneral, NT_STATUS_REPLY_MESSAGE_MISMATCH},
779 {ERRHRD, ERRgeneral, NT_STATUS_MAPPED_ALIGNMENT},
780 {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_IMAGE_CHECKSUM_MISMATCH},
781 {ERRHRD, ERRgeneral, NT_STATUS_LOST_WRITEBEHIND_DATA},
782 {ERRHRD, ERRgeneral, NT_STATUS_CLIENT_SERVER_PARAMETERS_INVALID},
783 {ERRSRV, NERR_PasswordExpired, NT_STATUS_PASSWORD_MUST_CHANGE},
784 {ERRHRD, ERRgeneral, NT_STATUS_NOT_FOUND},
785 {ERRHRD, ERRgeneral, NT_STATUS_NOT_TINY_STREAM},
786 {ERRHRD, ERRgeneral, NT_STATUS_RECOVERY_FAILURE},
787 {ERRHRD, ERRgeneral, NT_STATUS_STACK_OVERFLOW_READ},
788 {ERRHRD, ERRgeneral, NT_STATUS_FAIL_CHECK},
789 {ERRHRD, ERRgeneral, NT_STATUS_DUPLICATE_OBJECTID},
790 {ERRHRD, ERRgeneral, NT_STATUS_OBJECTID_EXISTS},
791 {ERRHRD, ERRgeneral, NT_STATUS_CONVERT_TO_LARGE},
792 {ERRHRD, ERRgeneral, NT_STATUS_RETRY},
793 {ERRHRD, ERRgeneral, NT_STATUS_FOUND_OUT_OF_SCOPE},
794 {ERRHRD, ERRgeneral, NT_STATUS_ALLOCATE_BUCKET},
795 {ERRHRD, ERRgeneral, NT_STATUS_PROPSET_NOT_FOUND},
796 {ERRHRD, ERRgeneral, NT_STATUS_MARSHALL_OVERFLOW},
797 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_VARIANT},
798 {ERRHRD, ERRgeneral, NT_STATUS_DOMAIN_CONTROLLER_NOT_FOUND},
799 {ERRDOS, ERRnoaccess, NT_STATUS_ACCOUNT_LOCKED_OUT},
800 {ERRDOS, ERRbadfid, NT_STATUS_HANDLE_NOT_CLOSABLE},
801 {ERRHRD, ERRgeneral, NT_STATUS_CONNECTION_REFUSED},
802 {ERRHRD, ERRgeneral, NT_STATUS_GRACEFUL_DISCONNECT},
803 {ERRHRD, ERRgeneral, NT_STATUS_ADDRESS_ALREADY_ASSOCIATED},
804 {ERRHRD, ERRgeneral, NT_STATUS_ADDRESS_NOT_ASSOCIATED},
805 {ERRHRD, ERRgeneral, NT_STATUS_CONNECTION_INVALID},
806 {ERRHRD, ERRgeneral, NT_STATUS_CONNECTION_ACTIVE},
807 {ERRHRD, ERRgeneral, NT_STATUS_NETWORK_UNREACHABLE},
808 {ERRHRD, ERRgeneral, NT_STATUS_HOST_UNREACHABLE},
809 {ERRHRD, ERRgeneral, NT_STATUS_PROTOCOL_UNREACHABLE},
810 {ERRHRD, ERRgeneral, NT_STATUS_PORT_UNREACHABLE},
811 {ERRHRD, ERRgeneral, NT_STATUS_REQUEST_ABORTED},
812 {ERRHRD, ERRgeneral, NT_STATUS_CONNECTION_ABORTED},
813 {ERRHRD, ERRgeneral, NT_STATUS_BAD_COMPRESSION_BUFFER},
814 {ERRHRD, ERRgeneral, NT_STATUS_USER_MAPPED_FILE},
815 {ERRHRD, ERRgeneral, NT_STATUS_AUDIT_FAILED},
816 {ERRHRD, ERRgeneral, NT_STATUS_TIMER_RESOLUTION_NOT_SET},
817 {ERRHRD, ERRgeneral, NT_STATUS_CONNECTION_COUNT_LIMIT},
818 {ERRHRD, ERRgeneral, NT_STATUS_LOGIN_TIME_RESTRICTION},
819 {ERRHRD, ERRgeneral, NT_STATUS_LOGIN_WKSTA_RESTRICTION},
820 {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_IMAGE_MP_UP_MISMATCH},
821 {ERRHRD, ERRgeneral, NT_STATUS_INSUFFICIENT_LOGON_INFO},
822 {ERRHRD, ERRgeneral, NT_STATUS_BAD_DLL_ENTRYPOINT},
823 {ERRHRD, ERRgeneral, NT_STATUS_BAD_SERVICE_ENTRYPOINT},
824 {ERRHRD, ERRgeneral, NT_STATUS_LPC_REPLY_LOST},
825 {ERRHRD, ERRgeneral, NT_STATUS_IP_ADDRESS_CONFLICT1},
826 {ERRHRD, ERRgeneral, NT_STATUS_IP_ADDRESS_CONFLICT2},
827 {ERRHRD, ERRgeneral, NT_STATUS_REGISTRY_QUOTA_LIMIT},
828 {ERRSRV, ERRbadtype, NT_STATUS_PATH_NOT_COVERED},
829 {ERRHRD, ERRgeneral, NT_STATUS_NO_CALLBACK_ACTIVE},
830 {ERRHRD, ERRgeneral, NT_STATUS_LICENSE_QUOTA_EXCEEDED},
831 {ERRHRD, ERRgeneral, NT_STATUS_PWD_TOO_SHORT},
832 {ERRHRD, ERRgeneral, NT_STATUS_PWD_TOO_RECENT},
833 {ERRHRD, ERRgeneral, NT_STATUS_PWD_HISTORY_CONFLICT},
834 {ERRHRD, ERRgeneral, NT_STATUS_PLUGPLAY_NO_DEVICE},
835 {ERRHRD, ERRgeneral, NT_STATUS_UNSUPPORTED_COMPRESSION},
836 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_HW_PROFILE},
837 {ERRHRD, ERRgeneral, NT_STATUS_INVALID_PLUGPLAY_DEVICE_PATH},
838 {ERRDOS, ERROR_INVALID_ORDINAL, NT_STATUS_DRIVER_ORDINAL_NOT_FOUND},
839 {ERRDOS, ERROR_PROC_NOT_FOUND, NT_STATUS_DRIVER_ENTRYPOINT_NOT_FOUND},
840 {ERRDOS, ERROR_NOT_OWNER, NT_STATUS_RESOURCE_NOT_OWNED},
841 {ERRHRD, ERRgeneral, NT_STATUS_TOO_MANY_LINKS},
842 {ERRHRD, ERRgeneral, NT_STATUS_QUOTA_LIST_INCONSISTENT},
843 {ERRHRD, ERRgeneral, NT_STATUS_FILE_IS_OFFLINE},
844 {ERRDOS, ERROR_NOT_READY, NT_STATUS_VOLUME_DISMOUNTED},
845 {ERRDOS, ERROR_BAD_PATHNAME, NT_STATUS_DIRECTORY_IS_A_REPARSE_POINT},
846 {ERRDOS, ERRnoaccess, NT_STATUS_ENCRYPTION_FAILED},
847 {ERRDOS, ERRnoaccess, NT_STATUS_DECRYPTION_FAILED},
848 {ERRHRD, ERRgeneral, NT_STATUS_RANGE_NOT_FOUND},
849 {ERRDOS, ERRnoaccess, NT_STATUS_NO_RECOVERY_POLICY},
850 {ERRDOS, ERRnoaccess, NT_STATUS_NO_EFS},
851 {ERRDOS, ERRnoaccess, NT_STATUS_WRONG_EFS},
852 {ERRDOS, ERRnoaccess, NT_STATUS_NO_USER_KEYS},
853 {ERRDOS, ERRbadfunc, NT_STATUS_VOLUME_NOT_UPGRADED},
854 {0, 0, 0}
855 };
856
857 int
smb_maperr32(uint32_t nterr)858 smb_maperr32(uint32_t nterr)
859 {
860 const nt2errno_t *nt2e;
861 const nt2doserr_t *nt2d;
862
863 switch (NT_SC_SEVERITY(nterr)) {
864 case NT_STATUS_SEVERITY_SUCCESS:
865 case NT_STATUS_SEVERITY_INFORMATIONAL:
866 return (0);
867 }
868
869 /* first try direct map to unix */
870 for (nt2e = nt2errno; nt2e->errno; nt2e++)
871 if (nt2e->nterr == nterr)
872 return (nt2e->errno);
873 smb_errmsg(unknown_err_logpri, "smb_maperr32",
874 "No direct map for 32 bit server error (0x%x)\n", nterr);
875
876 /* ok, then try mapping to dos to unix */
877 for (nt2d = nt2doserr; nt2d->nterr; nt2d++)
878 if (nt2d->nterr == nterr)
879 return (smb_maperror(nt2d->dclass, nt2d->derr));
880 return (EIO);
881 }
882
883 uint_t
smb_doserr2status(int dclass,int derr)884 smb_doserr2status(int dclass, int derr)
885 {
886 const nt2doserr_t *nt2d;
887
888 if (dclass == 0 && derr == 0)
889 return (0);
890
891 for (nt2d = nt2doserr; nt2d->nterr; nt2d++)
892 if (nt2d->dclass == dclass && nt2d->derr == derr)
893 return (nt2d->nterr);
894 return (NT_STATUS_UNSUCCESSFUL);
895 }
896
897 int
smb_maperror(int eclass,int eno)898 smb_maperror(int eclass, int eno)
899 {
900 if (eclass == 0 && eno == 0)
901 return (0);
902 switch (eclass) {
903 case ERRDOS:
904 switch (eno) {
905 case ERROR_INVALID_LEVEL:
906 return (ENOTSUP);
907 case ERRbadfunc:
908 case ERRbadenv:
909 case ERRbadformat:
910 case ERRremcd:
911 case ERRrmuns:
912 return (EINVAL);
913 case ERRbadfile:
914 case ERRbadpath:
915 case ERROR_BAD_DEV_TYPE:
916 case ERROR_BAD_NET_NAME:
917 return (ENOENT);
918 case ERRnofids:
919 return (EMFILE);
920 case ERRnoaccess:
921 /*
922 * XXX CSM Reported on samba-technical 12/7/2002
923 *
924 * There is a case for which server(s) return
925 * ERRnoaccess but should return ERRdiskfull: When
926 * the offset for a write is exactly the server
927 * file size limit then Samba (at least) thinks
928 * the reason for zero bytes having been written
929 * must have been "access denied" from the local
930 * filesystem. This cannot be easily worked
931 * around since the server behaviour is
932 * indistinguishable from actual access denied.
933 * An incomplete workaround: attempt a 2 byte write
934 * from "offset-1". (That may require reading at
935 * offset-1 first.) The flaw is that reading or
936 * writing at offset-1 could cause an
937 * unrelated error (due to a byte range lock
938 * for instance) and we can't presume the
939 * order servers check errors in.
940 */
941 case ERRbadaccess:
942 return (EACCES);
943 case ERRbadshare:
944 return (EBUSY);
945 case ERRbadfid:
946 return (EBADF);
947 case ERRbadmcb:
948 return (EIO);
949 case ERRnomem:
950 return (ENOMEM); /* actually remote no mem... */
951 case ERRbadmem:
952 return (EFAULT);
953 case ERRbaddata:
954 return (E2BIG);
955 case ERRbaddrive:
956 case ERRnotready: /* nt */
957 return (ENXIO);
958 case ERRdiffdevice:
959 return (EXDEV);
960 case ERRnofiles:
961 return (0); /* eeof ? */
962 case ERRlock:
963 return (EAGAIN);
964 case ERRfilexists:
965 return (EEXIST);
966 case ERROR_INVALID_NAME:
967 return (ENOENT);
968 case ERROR_DIR_NOT_EMPTY:
969 return (ENOTEMPTY);
970 case ERROR_NOT_LOCKED:
971 return (0); /* we unlock on any close */
972 case ERROR_ALREADY_EXISTS:
973 return (EEXIST);
974 case ERRmoredata:
975 return (EMOREDATA);
976 }
977 break;
978 case ERRSRV:
979 switch (eno) {
980 case ERRerror:
981 return (EINVAL);
982 case ERRbadpw:
983 return (EAUTH);
984 case ERRaccess:
985 case ERRbaduid:
986 return (EACCES);
987 case ERRinvnid:
988 return (ENETRESET);
989 case ERRinvnetname:
990 return (ENXIO);
991 case ERRbadtype: /* reserved and returned */
992 return (EIO);
993 case NERR_AccountExpired: /* account exists but disabled */
994 return (EPERM);
995 }
996 break;
997 case ERRHRD:
998 switch (eno) {
999 case ERRnowrite:
1000 return (EROFS);
1001 case ERRbadunit:
1002 return (ENODEV);
1003 case ERRbadreq:
1004 return (EBADRPC);
1005 case ERRbadshare:
1006 return (ETXTBSY);
1007 case ERRlock:
1008 return (EAGAIN);
1009 case ERRdiskfull:
1010 return (EFBIG);
1011 case ERRnotready:
1012 case ERRbadcmd:
1013 case ERRdata:
1014 case ERRgeneral:
1015 return (EIO);
1016 }
1017 }
1018
1019 smb_errmsg(unknown_err_logpri, "smb_maperror",
1020 "Unknown DOS error %d/%d\n", eclass, eno);
1021 return (EIO);
1022 }
1023
1024 #define SMALL_CONV 256
1025
1026 /*
1027 * Decode an SMB OTW string (Unicode or OEM chars)
1028 * converting to UTF-8 in the output buffer.
1029 * outlen is in/out (max size on input)
1030 * insize is the wire size (2 * chars if unicode)
1031 * The output string is null terminated.
1032 * Output length does not include the null.
1033 */
1034 int
smb_get_dstring(struct mdchain * mdc,struct smb_vc * vcp,char * outbuf,size_t * outlen,int insize)1035 smb_get_dstring(struct mdchain *mdc, struct smb_vc *vcp,
1036 char *outbuf, size_t *outlen, int insize)
1037 {
1038 uint16_t convbuf[SMALL_CONV];
1039 uint16_t *cbuf;
1040 size_t cbufalloc, inlen, outsize;
1041 int error;
1042
1043 if (insize <= 0)
1044 return (0);
1045 /* Note: inlen is UTF-16 symbols. */
1046 inlen = insize / 2;
1047
1048 if (*outlen < 2)
1049 return (EINVAL);
1050 outsize = *outlen - 1; /* room for null */
1051
1052 /*
1053 * Get a buffer for the conversion and fill it.
1054 * Use stack buffer if the string is
1055 * small enough, else allocate.
1056 */
1057 if (insize < sizeof (convbuf)) {
1058 cbufalloc = 0;
1059 cbuf = convbuf;
1060 } else {
1061 cbufalloc = insize + 2;
1062 cbuf = kmem_alloc(cbufalloc, KM_SLEEP);
1063 }
1064 error = md_get_mem(mdc, cbuf, insize, MB_MSYSTEM);
1065 if (error != 0)
1066 goto out;
1067 cbuf[inlen] = 0;
1068
1069 /*
1070 * Handle the easy case (non-unicode).
1071 * XXX: Technically, we should convert
1072 * the string to OEM codeset first...
1073 * Modern servers all use Unicode, so
1074 * this is good enough.
1075 */
1076 if (SMB_UNICODE_STRINGS(vcp) == 0) {
1077 *outlen = strlcpy(outbuf, (char *)cbuf, outsize);
1078 if (*outlen > outsize) {
1079 *outlen = outsize;
1080 error = E2BIG;
1081 }
1082 } else {
1083 /*
1084 * Convert from UTF-16 to UTF-8
1085 */
1086 error = uconv_u16tou8(cbuf, &inlen,
1087 (uchar_t *)outbuf, outlen,
1088 UCONV_IN_LITTLE_ENDIAN);
1089 if (error == 0) {
1090 outbuf[*outlen] = '\0';
1091 }
1092 }
1093
1094 ASSERT(*outlen == strlen(outbuf));
1095
1096 out:
1097 if (cbufalloc != 0)
1098 kmem_free(cbuf, cbufalloc);
1099
1100 return (error);
1101 }
1102
1103 /*
1104 * It's surprising that this function does utf8-ucs2 conversion.
1105 * One would expect only smb_put_dstring to do that.
1106 * Fixing that will require changing a bunch of callers. XXX
1107 */
1108 /*ARGSUSED*/
1109 int
smb_put_dmem(struct mbchain * mbp,struct smb_vc * vcp,const char * src,int size,int caseopt,int * lenp)1110 smb_put_dmem(struct mbchain *mbp, struct smb_vc *vcp, const char *src,
1111 int size, int caseopt, int *lenp)
1112 {
1113 uint16_t convbuf[SMALL_CONV];
1114 uint16_t *cbuf;
1115 size_t cbufalloc, inlen, outlen;
1116 int error;
1117
1118 if (size <= 0)
1119 return (0);
1120
1121 /*
1122 * Handle the easy case (non-unicode).
1123 * XXX: Technically, we should convert
1124 * the string to OEM codeset first...
1125 * Modern servers all use Unicode, so
1126 * this is good enough.
1127 */
1128 if (SMB_UNICODE_STRINGS(vcp) == 0) {
1129 error = mb_put_mem(mbp, src, size, MB_MSYSTEM);
1130 if (!error && lenp)
1131 *lenp += size;
1132 return (error);
1133 }
1134
1135 /*
1136 * Convert to UCS-2 (really UTF-16).
1137 * Use stack buffer if the string is
1138 * small enough, else allocate.
1139 */
1140 if (size <= SMALL_CONV) {
1141 cbufalloc = 0;
1142 outlen = SMALL_CONV;
1143 cbuf = convbuf;
1144 } else {
1145 outlen = size; /* in utf-16 characters */
1146 cbufalloc = outlen * 2;
1147 cbuf = kmem_alloc(cbufalloc, KM_SLEEP);
1148 }
1149
1150 inlen = size;
1151 error = uconv_u8tou16((uchar_t *)src, &inlen, cbuf, &outlen,
1152 UCONV_OUT_LITTLE_ENDIAN | UCONV_IGNORE_NULL);
1153 outlen *= 2; /* convert to bytes */
1154
1155 if (!error) {
1156 (void) mb_put_padbyte(mbp); /* align */
1157 error = mb_put_mem(mbp, (char *)cbuf, outlen, MB_MSYSTEM);
1158 }
1159 if (!error && lenp)
1160 *lenp += outlen;
1161
1162 if (cbufalloc)
1163 kmem_free(cbuf, cbufalloc);
1164
1165 return (error);
1166 }
1167
1168 int
smb_put_dstring(struct mbchain * mbp,struct smb_vc * vcp,const char * src,int caseopt)1169 smb_put_dstring(struct mbchain *mbp, struct smb_vc *vcp, const char *src,
1170 int caseopt)
1171 {
1172 int error, len;
1173
1174 /*
1175 * Let smb_put_dmem put both the string
1176 * and the terminating null.
1177 */
1178 len = strlen(src) + 1;
1179 error = smb_put_dmem(mbp, vcp, src, len, caseopt, NULL);
1180 if (error)
1181 return (error);
1182
1183 return (error);
1184 }
1185 int
smb_smb_ntcreate(struct smb_share * ssp,struct mbchain * name_mb,uint32_t crflag,uint32_t req_acc,uint32_t efa,uint32_t sh_acc,uint32_t disp,uint32_t createopt,uint32_t impersonate,struct smb_cred * scrp,smb_fh_t * fhp,uint32_t * cr_act_p,struct smbfattr * fap)1186 smb_smb_ntcreate(struct smb_share *ssp, struct mbchain *name_mb,
1187 uint32_t crflag, uint32_t req_acc, uint32_t efa, uint32_t sh_acc,
1188 uint32_t disp, uint32_t createopt, uint32_t impersonate,
1189 struct smb_cred *scrp, smb_fh_t *fhp,
1190 uint32_t *cr_act_p, struct smbfattr *fap)
1191 {
1192 int err;
1193
1194 if (SSTOVC(ssp)->vc_flags & SMBV_SMB2) {
1195 err = smb2_smb_ntcreate(ssp, name_mb, NULL, NULL,
1196 crflag, req_acc, efa, sh_acc, disp, createopt,
1197 impersonate, scrp, &fhp->fh_fid2, cr_act_p, fap);
1198 } else {
1199 err = smb1_smb_ntcreate(ssp, name_mb, crflag, req_acc,
1200 efa, sh_acc, disp, createopt, impersonate, scrp,
1201 &fhp->fh_fid1, cr_act_p, fap);
1202 }
1203 return (err);
1204 }
1205
1206 int
smb_smb_close(struct smb_share * ssp,smb_fh_t * fhp,struct smb_cred * scrp)1207 smb_smb_close(struct smb_share *ssp, smb_fh_t *fhp,
1208 struct smb_cred *scrp)
1209 {
1210 int err;
1211
1212 if (SSTOVC(ssp)->vc_flags & SMBV_SMB2) {
1213 err = smb2_smb_close(ssp, &fhp->fh_fid2, scrp);
1214 } else {
1215 err = smb1_smb_close(ssp, fhp->fh_fid1, NULL, scrp);
1216 }
1217
1218 return (err);
1219 }
1220
1221 /*
1222 * Largest size to use with LARGE_READ/LARGE_WRITE.
1223 * Specs say up to 64k data bytes, but Windows traffic
1224 * uses 60k... no doubt for some good reason.
1225 * (Probably to keep 4k block alignment.)
1226 */
1227 uint32_t smb1_large_io_max = (60*1024);
1228
1229 /*
1230 * Common function for read/write with UIO.
1231 * Called by netsmb smb_usr_rw,
1232 * smbfs_readvnode, smbfs_writevnode
1233 */
1234 int
smb_rwuio(smb_fh_t * fhp,uio_rw_t rw,uio_t * uiop,smb_cred_t * scred,int timo)1235 smb_rwuio(smb_fh_t *fhp, uio_rw_t rw,
1236 uio_t *uiop, smb_cred_t *scred, int timo)
1237 {
1238 struct smb_share *ssp = FHTOSS(fhp);
1239 struct smb_vc *vcp = SSTOVC(ssp);
1240 ssize_t save_resid;
1241 uint32_t len, rlen, maxlen;
1242 int error = 0;
1243 int (*iofun)(smb_fh_t *, uint32_t *,
1244 uio_t *, smb_cred_t *, int);
1245
1246 /* After reconnect, the fid is invalid. */
1247 if (fhp->fh_vcgenid != ssp->ss_vcgenid)
1248 return (ESTALE);
1249
1250 if (SSTOVC(ssp)->vc_flags & SMBV_SMB2) {
1251 if (rw == UIO_READ) {
1252 iofun = smb2_smb_read;
1253 maxlen = vcp->vc_sopt.sv2_maxread;
1254 } else { /* UIO_WRITE */
1255 iofun = smb2_smb_write;
1256 maxlen = vcp->vc_sopt.sv2_maxwrite;
1257 }
1258 } else {
1259 /*
1260 * Using NT LM 0.12, so readx, writex.
1261 * Make sure we can represent the offset.
1262 */
1263 if ((vcp->vc_sopt.sv_caps & SMB_CAP_LARGE_FILES) == 0 &&
1264 (uiop->uio_loffset + uiop->uio_resid) > UINT32_MAX)
1265 return (EFBIG);
1266
1267 if (rw == UIO_READ) {
1268 iofun = smb_smb_readx;
1269 if (vcp->vc_sopt.sv_caps & SMB_CAP_LARGE_READX)
1270 maxlen = smb1_large_io_max;
1271 else
1272 maxlen = vcp->vc_rxmax;
1273 } else { /* UIO_WRITE */
1274 iofun = smb_smb_writex;
1275 if (vcp->vc_sopt.sv_caps & SMB_CAP_LARGE_WRITEX)
1276 maxlen = smb1_large_io_max;
1277 else
1278 maxlen = vcp->vc_wxmax;
1279 }
1280 }
1281
1282 save_resid = uiop->uio_resid;
1283 while (uiop->uio_resid > 0) {
1284 /* Lint: uio_resid may be 64-bits */
1285 rlen = len = (uint32_t)min(maxlen, uiop->uio_resid);
1286 error = (*iofun)(fhp, &rlen, uiop, scred, timo);
1287
1288 /*
1289 * Note: the iofun called uio_update, so
1290 * not doing that here as one might expect.
1291 *
1292 * Quit the loop either on error, or if we
1293 * transferred less then requested.
1294 */
1295 if (error || (rlen < len))
1296 break;
1297
1298 timo = 0; /* only first I/O should wait */
1299 }
1300 if (error && (save_resid != uiop->uio_resid)) {
1301 /*
1302 * Stopped on an error after having
1303 * successfully transferred data.
1304 * Suppress this error.
1305 */
1306 SMBSDEBUG("error %d suppressed\n", error);
1307 error = 0;
1308 }
1309
1310 return (error);
1311 }
1312