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 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 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 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 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 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 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 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 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 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 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 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 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 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 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