14bff34e3Sthurlow /*
24bff34e3Sthurlow * Copyright (c) 2000-2001 Boris Popov
34bff34e3Sthurlow * All rights reserved.
44bff34e3Sthurlow *
54bff34e3Sthurlow * Redistribution and use in source and binary forms, with or without
64bff34e3Sthurlow * modification, are permitted provided that the following conditions
74bff34e3Sthurlow * are met:
84bff34e3Sthurlow * 1. Redistributions of source code must retain the above copyright
94bff34e3Sthurlow * notice, this list of conditions and the following disclaimer.
104bff34e3Sthurlow * 2. Redistributions in binary form must reproduce the above copyright
114bff34e3Sthurlow * notice, this list of conditions and the following disclaimer in the
124bff34e3Sthurlow * documentation and/or other materials provided with the distribution.
134bff34e3Sthurlow * 3. All advertising materials mentioning features or use of this software
144bff34e3Sthurlow * must display the following acknowledgement:
154bff34e3Sthurlow * This product includes software developed by Boris Popov.
164bff34e3Sthurlow * 4. Neither the name of the author nor the names of any co-contributors
174bff34e3Sthurlow * may be used to endorse or promote products derived from this software
184bff34e3Sthurlow * without specific prior written permission.
194bff34e3Sthurlow *
204bff34e3Sthurlow * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
214bff34e3Sthurlow * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
224bff34e3Sthurlow * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
234bff34e3Sthurlow * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
244bff34e3Sthurlow * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
254bff34e3Sthurlow * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
264bff34e3Sthurlow * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
274bff34e3Sthurlow * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
284bff34e3Sthurlow * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
294bff34e3Sthurlow * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
304bff34e3Sthurlow * SUCH DAMAGE.
314bff34e3Sthurlow *
324bff34e3Sthurlow * $Id: smb_subr.c,v 1.27.108.1 2005/06/02 00:55:39 lindak Exp $
334bff34e3Sthurlow */
344bff34e3Sthurlow
35613a2f6bSGordon Ross /*
36148c5f43SAlan Wright * Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.
3740c0e231SGordon Ross * Portions Copyright (C) 2001 - 2013 Apple Inc. All rights reserved.
3840c0e231SGordon Ross * Copyright 2018 Nexenta Systems, Inc. All rights reserved.
39613a2f6bSGordon Ross */
404bff34e3Sthurlow
414bff34e3Sthurlow #include <sys/param.h>
424bff34e3Sthurlow #include <sys/systm.h>
434bff34e3Sthurlow #include <sys/kmem.h>
444bff34e3Sthurlow #include <sys/proc.h>
454bff34e3Sthurlow #include <sys/lock.h>
464bff34e3Sthurlow #include <sys/socket.h>
474bff34e3Sthurlow #include <sys/isa_defs.h>
484bff34e3Sthurlow #include <sys/stream.h>
494bff34e3Sthurlow #include <sys/strsun.h>
504bff34e3Sthurlow #include <sys/sunddi.h>
514bff34e3Sthurlow #include <sys/cmn_err.h>
524bff34e3Sthurlow #include <sys/sdt.h>
534bff34e3Sthurlow #include <sys/priv.h>
544bff34e3Sthurlow #include <sys/u8_textprep.h>
554bff34e3Sthurlow
564bff34e3Sthurlow #include <netsmb/smb_osdep.h>
574bff34e3Sthurlow #include <netsmb/smb.h>
584bff34e3Sthurlow #include <netsmb/smb_conn.h>
594bff34e3Sthurlow #include <netsmb/smb_rq.h>
604bff34e3Sthurlow #include <netsmb/smb_subr.h>
614bff34e3Sthurlow
624bff34e3Sthurlow void
smb_credinit(struct smb_cred * scred,cred_t * cr)63613a2f6bSGordon Ross smb_credinit(struct smb_cred *scred, cred_t *cr)
644bff34e3Sthurlow {
65613a2f6bSGordon Ross /* cr arg is optional */
66613a2f6bSGordon Ross if (cr == NULL)
67613a2f6bSGordon Ross cr = ddi_get_cred();
688329232eSGordon Ross #ifdef _KERNEL
694bff34e3Sthurlow if (is_system_labeled()) {
70613a2f6bSGordon Ross cr = crdup(cr);
71613a2f6bSGordon Ross (void) setpflags(NET_MAC_AWARE, 1, cr);
728329232eSGordon Ross } else
738329232eSGordon Ross #endif
748329232eSGordon Ross {
75613a2f6bSGordon Ross crhold(cr);
764bff34e3Sthurlow }
77613a2f6bSGordon Ross scred->scr_cred = cr;
784bff34e3Sthurlow }
794bff34e3Sthurlow
804bff34e3Sthurlow void
smb_credrele(struct smb_cred * scred)814bff34e3Sthurlow smb_credrele(struct smb_cred *scred)
824bff34e3Sthurlow {
83613a2f6bSGordon Ross if (scred->scr_cred != NULL) {
84613a2f6bSGordon Ross crfree(scred->scr_cred);
85613a2f6bSGordon Ross scred->scr_cred = NULL;
864bff34e3Sthurlow }
874bff34e3Sthurlow }
884bff34e3Sthurlow
89*adee6784SGordon Ross #ifndef _KERNEL
90*adee6784SGordon Ross /* ARGSUSED */
91*adee6784SGordon Ross void
smb_debugmsg(const char * func,char * msg)92*adee6784SGordon Ross smb_debugmsg(const char *func, char *msg)
93*adee6784SGordon Ross {
94*adee6784SGordon Ross }
95*adee6784SGordon Ross #endif /* _KERNEL */
96*adee6784SGordon Ross
974bff34e3Sthurlow /*
984bff34e3Sthurlow * Helper for the SMBERROR macro, etc.
994bff34e3Sthurlow * This is also a good place for a breakpoint
1004bff34e3Sthurlow * or a dtrace probe, i.e. fbt:nsmb:smb_errmsg
1014bff34e3Sthurlow */
1024bff34e3Sthurlow void
smb_errmsg(int cel,const char * func_name,const char * fmt,...)1034bff34e3Sthurlow smb_errmsg(int cel, const char *func_name, const char *fmt, ...)
1044bff34e3Sthurlow {
1054bff34e3Sthurlow va_list adx;
1064bff34e3Sthurlow char buf[100];
1074bff34e3Sthurlow
1084bff34e3Sthurlow va_start(adx, fmt);
1094bff34e3Sthurlow if (cel == CE_CONT) {
1104bff34e3Sthurlow /*
1114bff34e3Sthurlow * This is one of our xxxDEBUG macros.
1124bff34e3Sthurlow * Don't bother to log these, but just
1134bff34e3Sthurlow * fire a dtrace probe with the message.
1144bff34e3Sthurlow */
11502d09e03SGordon Ross (void) vsnprintf(buf, sizeof (buf), fmt, adx);
1164bff34e3Sthurlow DTRACE_PROBE2(debugmsg2,
1174bff34e3Sthurlow (char *), func_name,
1184bff34e3Sthurlow (char *), buf);
119*adee6784SGordon Ross #ifndef _KERNEL
120*adee6784SGordon Ross smb_debugmsg(func_name, buf);
121*adee6784SGordon Ross #endif
1224bff34e3Sthurlow } else {
1234bff34e3Sthurlow /*
1244bff34e3Sthurlow * This is one of our xxxERROR macros.
1254bff34e3Sthurlow * Add a prefix to the fmt string,
1264bff34e3Sthurlow * then let vcmn_err do the args.
1274bff34e3Sthurlow */
12802d09e03SGordon Ross (void) snprintf(buf, sizeof (buf), "?%s: %s", func_name, fmt);
1294bff34e3Sthurlow DTRACE_PROBE3(debugmsg3,
1304bff34e3Sthurlow (char *), func_name,
1314bff34e3Sthurlow (char *), buf,
1324bff34e3Sthurlow va_list, adx);
1334bff34e3Sthurlow vcmn_err(cel, buf, adx);
1344bff34e3Sthurlow }
1354bff34e3Sthurlow va_end(adx);
1364bff34e3Sthurlow }
1374bff34e3Sthurlow
1384bff34e3Sthurlow #if 1 /* def SMB_SOCKETDATA_DEBUG */
1394bff34e3Sthurlow void
m_dumpm(mblk_t * m)1404bff34e3Sthurlow m_dumpm(mblk_t *m)
1414bff34e3Sthurlow {
1424bff34e3Sthurlow int len, seg;
1434bff34e3Sthurlow
1444bff34e3Sthurlow len = msgdsize(m);
1454bff34e3Sthurlow DTRACE_PROBE2(dsize, int, len, (mblk_t *), m);
1464bff34e3Sthurlow
1474bff34e3Sthurlow for (seg = 0; m; seg++) {
1484bff34e3Sthurlow DTRACE_PROBE2(mblk, int, seg, (mblk_t *), m);
1494bff34e3Sthurlow m = m->b_cont;
1504bff34e3Sthurlow }
1514bff34e3Sthurlow }
1524bff34e3Sthurlow #endif
1534bff34e3Sthurlow
1544bff34e3Sthurlow #ifndef EPROTO
1554bff34e3Sthurlow #define EPROTO ECONNABORTED
1564bff34e3Sthurlow #endif
1574bff34e3Sthurlow #ifndef ELIBACC
1584bff34e3Sthurlow #define ELIBACC ENOENT
1594bff34e3Sthurlow #endif
1604bff34e3Sthurlow #ifndef ENODATA
1614bff34e3Sthurlow #define ENODATA EINVAL
1624bff34e3Sthurlow #endif
1634bff34e3Sthurlow #ifndef ENOTUNIQ
1644bff34e3Sthurlow #define ENOTUNIQ EADDRINUSE
1654bff34e3Sthurlow #endif
1664bff34e3Sthurlow #ifndef ECOMM
1674bff34e3Sthurlow #define ECOMM EIO
1684bff34e3Sthurlow #endif
1694bff34e3Sthurlow #ifndef ENOMEDIUM
17002d09e03SGordon Ross #define ENOMEDIUM ENXIO
1714bff34e3Sthurlow #endif
1724bff34e3Sthurlow #ifndef ETIME
1734bff34e3Sthurlow #define ETIME ETIMEDOUT
1744bff34e3Sthurlow #endif
175*adee6784SGordon Ross #ifndef EMOREDATA
176*adee6784SGordon Ross #define EMOREDATA (0x7fff)
177*adee6784SGordon Ross #endif
1784bff34e3Sthurlow
179ae3d7f90SGordon Ross /*
180ae3d7f90SGordon Ross * Log any un-handled NT or DOS errors we encounter.
181ae3d7f90SGordon Ross * Make these log NOTICE in a debug build to ensure
182ae3d7f90SGordon Ross * they get noticed during tests. In the field these
183ae3d7f90SGordon Ross * are unimportant, so just fire a Dtrace probe.
184ae3d7f90SGordon Ross */
185ae3d7f90SGordon Ross static int unknown_err_logpri =
186ae3d7f90SGordon Ross #ifdef DEBUG
187ae3d7f90SGordon Ross CE_NOTE;
188ae3d7f90SGordon Ross #else
189ae3d7f90SGordon Ross CE_CONT;
190ae3d7f90SGordon Ross #endif
191ae3d7f90SGordon Ross
192148c5f43SAlan Wright typedef struct nt2errno {
19302d09e03SGordon Ross unsigned int nterr;
194148c5f43SAlan Wright int errno;
195148c5f43SAlan Wright } nt2errno_t;
196148c5f43SAlan Wright
197148c5f43SAlan Wright static const nt2errno_t nt2errno[] = {
19802d09e03SGordon Ross /* Alphabetical order. */
1994bff34e3Sthurlow {NT_STATUS_ACCESS_DENIED, EACCES},
2004bff34e3Sthurlow {NT_STATUS_ACCESS_VIOLATION, EACCES},
2014bff34e3Sthurlow {NT_STATUS_ACCOUNT_DISABLED, EACCES},
20202d09e03SGordon Ross {NT_STATUS_ACCOUNT_EXPIRED, EACCES},
20302d09e03SGordon Ross {NT_STATUS_ACCOUNT_LOCKED_OUT, EACCES},
2044bff34e3Sthurlow {NT_STATUS_ACCOUNT_RESTRICTION, EACCES},
2054bff34e3Sthurlow {NT_STATUS_ADDRESS_ALREADY_EXISTS, EADDRINUSE},
2064bff34e3Sthurlow {NT_STATUS_BAD_NETWORK_NAME, ENOENT},
20740c0e231SGordon Ross {NT_STATUS_BAD_NETWORK_PATH, ENOENT},
20840c0e231SGordon Ross {NT_STATUS_BUFFER_TOO_SMALL, E2BIG},
20940c0e231SGordon Ross {NT_STATUS_CANCELLED, ECANCELED},
2104bff34e3Sthurlow {NT_STATUS_CANNOT_DELETE, EACCES},
2114bff34e3Sthurlow {NT_STATUS_CONFLICTING_ADDRESSES, EADDRINUSE},
2124bff34e3Sthurlow {NT_STATUS_CONNECTION_ABORTED, ECONNABORTED},
2134bff34e3Sthurlow {NT_STATUS_CONNECTION_DISCONNECTED, ECONNABORTED},
2144bff34e3Sthurlow {NT_STATUS_CONNECTION_REFUSED, ECONNREFUSED},
2154bff34e3Sthurlow {NT_STATUS_CONNECTION_RESET, ENETRESET},
21602d09e03SGordon Ross {NT_STATUS_DELETE_PENDING, EACCES},
2174bff34e3Sthurlow {NT_STATUS_DEVICE_DOES_NOT_EXIST, ENODEV},
2184bff34e3Sthurlow {NT_STATUS_DEVICE_PROTOCOL_ERROR, EPROTO},
2194bff34e3Sthurlow {NT_STATUS_DIRECTORY_NOT_EMPTY, ENOTEMPTY},
2204bff34e3Sthurlow {NT_STATUS_DISK_FULL, ENOSPC},
2214bff34e3Sthurlow {NT_STATUS_DLL_NOT_FOUND, ELIBACC},
222ae3d7f90SGordon Ross {NT_STATUS_DUPLICATE_NAME, EINVAL},
22340c0e231SGordon Ross {NT_STATUS_EAS_NOT_SUPPORTED, ENOTSUP},
22440c0e231SGordon Ross {NT_STATUS_EA_TOO_LARGE, E2BIG},
2254bff34e3Sthurlow {NT_STATUS_END_OF_FILE, ENODATA},
22640c0e231SGordon Ross {NT_STATUS_FILE_CLOSED, EBADF},
22740c0e231SGordon Ross {NT_STATUS_FILE_DELETED, ENOENT},
22840c0e231SGordon Ross {NT_STATUS_FILE_INVALID, EIO},
2294bff34e3Sthurlow {NT_STATUS_FILE_IS_A_DIRECTORY, EISDIR},
23002d09e03SGordon Ross {NT_STATUS_FILE_LOCK_CONFLICT, EAGAIN},
23140c0e231SGordon Ross {NT_STATUS_FILE_RENAMED, ENOENT},
2324bff34e3Sthurlow {NT_STATUS_FLOAT_INEXACT_RESULT, ERANGE},
2334bff34e3Sthurlow {NT_STATUS_FLOAT_OVERFLOW, ERANGE},
2344bff34e3Sthurlow {NT_STATUS_FLOAT_UNDERFLOW, ERANGE},
2354bff34e3Sthurlow {NT_STATUS_HOST_UNREACHABLE, EHOSTUNREACH},
23640c0e231SGordon Ross {NT_STATUS_ILL_FORMED_PASSWORD, EAUTH},
23740c0e231SGordon Ross {NT_STATUS_INFO_LENGTH_MISMATCH, EINVAL},
23840c0e231SGordon Ross {NT_STATUS_INSUFFICIENT_RESOURCES, EAGAIN},
23940c0e231SGordon Ross {NT_STATUS_INSUFF_SERVER_RESOURCES, EAGAIN},
2404bff34e3Sthurlow {NT_STATUS_INTEGER_OVERFLOW, ERANGE},
24140c0e231SGordon Ross {NT_STATUS_INVALID_ACCOUNT_NAME, EAUTH},
24240c0e231SGordon Ross {NT_STATUS_INVALID_BUFFER_SIZE, EIO},
24340c0e231SGordon Ross {NT_STATUS_INVALID_DEVICE_REQUEST, EINVAL},
2444bff34e3Sthurlow {NT_STATUS_INVALID_HANDLE, EBADF},
24540c0e231SGordon Ross {NT_STATUS_INVALID_INFO_CLASS, EINVAL},
24602d09e03SGordon Ross {NT_STATUS_INVALID_LEVEL, ENOTSUP},
24740c0e231SGordon Ross {NT_STATUS_INVALID_LOCK_SEQUENCE, EINVAL},
24840c0e231SGordon Ross {NT_STATUS_INVALID_LOGON_HOURS, EAUTH},
249148c5f43SAlan Wright {NT_STATUS_INVALID_OWNER, EINVAL},
2504bff34e3Sthurlow {NT_STATUS_INVALID_PARAMETER, EINVAL},
2514bff34e3Sthurlow {NT_STATUS_INVALID_PIPE_STATE, EPIPE},
252148c5f43SAlan Wright {NT_STATUS_INVALID_PRIMARY_GROUP, EINVAL},
2534bff34e3Sthurlow {NT_STATUS_INVALID_WORKSTATION, EACCES},
2544bff34e3Sthurlow {NT_STATUS_IN_PAGE_ERROR, EFAULT},
25540c0e231SGordon Ross {NT_STATUS_IO_DEVICE_ERROR, EIO},
2564bff34e3Sthurlow {NT_STATUS_IO_TIMEOUT, ETIMEDOUT},
25740c0e231SGordon Ross {NT_STATUS_IP_ADDRESS_CONFLICT1, EADDRINUSE},
25840c0e231SGordon Ross {NT_STATUS_IP_ADDRESS_CONFLICT2, EADDRINUSE},
2594bff34e3Sthurlow {NT_STATUS_LICENSE_QUOTA_EXCEEDED, EDQUOT},
26002d09e03SGordon Ross {NT_STATUS_LOCK_NOT_GRANTED, EAGAIN},
26140c0e231SGordon Ross {NT_STATUS_LOGIN_TIME_RESTRICTION, EAUTH},
26240c0e231SGordon Ross {NT_STATUS_LOGON_FAILURE, EAUTH},
26340c0e231SGordon Ross {NT_STATUS_LOGON_TYPE_NOT_GRANTED, EAUTH},
2644bff34e3Sthurlow {NT_STATUS_MEDIA_WRITE_PROTECTED, EROFS},
2654bff34e3Sthurlow {NT_STATUS_MEMORY_NOT_ALLOCATED, EFAULT},
26640c0e231SGordon Ross {NT_STATUS_MORE_PROCESSING_REQUIRED, EINPROGRESS},
2674bff34e3Sthurlow {NT_STATUS_NAME_TOO_LONG, ENAMETOOLONG},
2684bff34e3Sthurlow {NT_STATUS_NETWORK_ACCESS_DENIED, EACCES},
2694bff34e3Sthurlow {NT_STATUS_NETWORK_BUSY, EBUSY},
27040c0e231SGordon Ross {NT_STATUS_NETWORK_NAME_DELETED, ENOENT},
2714bff34e3Sthurlow {NT_STATUS_NETWORK_UNREACHABLE, ENETUNREACH},
2724bff34e3Sthurlow {NT_STATUS_NET_WRITE_FAULT, ECOMM},
27340c0e231SGordon Ross {NT_STATUS_NONEXISTENT_EA_ENTRY, ENOENT},
2744bff34e3Sthurlow {NT_STATUS_NONEXISTENT_SECTOR, ESPIPE},
27502d09e03SGordon Ross {NT_STATUS_NONE_MAPPED, EINVAL},
2764bff34e3Sthurlow {NT_STATUS_NOT_A_DIRECTORY, ENOTDIR},
27740c0e231SGordon Ross {NT_STATUS_NOT_FOUND, ENOENT},
278ae3d7f90SGordon Ross {NT_STATUS_NOT_IMPLEMENTED, ENOTSUP},
27940c0e231SGordon Ross {NT_STATUS_NOT_LOCKED, ENOLCK},
2804bff34e3Sthurlow {NT_STATUS_NOT_MAPPED_VIEW, EINVAL},
281ae3d7f90SGordon Ross {NT_STATUS_NOT_SUPPORTED, ENOTSUP},
28240c0e231SGordon Ross {NT_STATUS_NO_EAS_ON_FILE, ENOENT},
28340c0e231SGordon Ross {NT_STATUS_NO_LOGON_SERVERS, EAUTH},
2844bff34e3Sthurlow {NT_STATUS_NO_MEDIA, ENOMEDIUM},
2854bff34e3Sthurlow {NT_STATUS_NO_MEDIA_IN_DEVICE, ENOMEDIUM},
2864bff34e3Sthurlow {NT_STATUS_NO_MEMORY, ENOMEM},
2874bff34e3Sthurlow {NT_STATUS_NO_SUCH_DEVICE, ENODEV},
2884bff34e3Sthurlow {NT_STATUS_NO_SUCH_FILE, ENOENT},
28940c0e231SGordon Ross {NT_STATUS_NO_SUCH_LOGON_SESSION, EAUTH},
29040c0e231SGordon Ross {NT_STATUS_NO_SUCH_USER, EAUTH},
29140c0e231SGordon Ross {NT_STATUS_NO_TRUST_LSA_SECRET, EAUTH},
29240c0e231SGordon Ross {NT_STATUS_NO_TRUST_SAM_ACCOUNT, EAUTH},
2934bff34e3Sthurlow {NT_STATUS_OBJECT_NAME_COLLISION, EEXIST},
29491d632c8Sgwr {NT_STATUS_OBJECT_NAME_INVALID, EINVAL},
29502d09e03SGordon Ross {NT_STATUS_OBJECT_NAME_NOT_FOUND, ENOENT},
2964bff34e3Sthurlow {NT_STATUS_OBJECT_PATH_INVALID, ENOTDIR},
29702d09e03SGordon Ross {NT_STATUS_OBJECT_PATH_NOT_FOUND, ENOENT},
29840c0e231SGordon Ross {NT_STATUS_OBJECT_PATH_SYNTAX_BAD, EINVAL},
29940c0e231SGordon Ross {NT_STATUS_OBJECT_TYPE_MISMATCH, EBADF},
3004bff34e3Sthurlow {NT_STATUS_PAGEFILE_QUOTA, EDQUOT},
30140c0e231SGordon Ross {NT_STATUS_PASSWORD_EXPIRED, EAUTH},
30240c0e231SGordon Ross {NT_STATUS_PASSWORD_MUST_CHANGE, EAUTH},
30340c0e231SGordon Ross {NT_STATUS_PASSWORD_RESTRICTION, EAUTH},
3044bff34e3Sthurlow {NT_STATUS_PATH_NOT_COVERED, ENOENT},
3054bff34e3Sthurlow {NT_STATUS_PIPE_BROKEN, EPIPE},
3064bff34e3Sthurlow {NT_STATUS_PIPE_BUSY, EPIPE},
3074bff34e3Sthurlow {NT_STATUS_PIPE_CONNECTED, EISCONN},
3084bff34e3Sthurlow {NT_STATUS_PIPE_DISCONNECTED, EPIPE},
309ae3d7f90SGordon Ross {NT_STATUS_PIPE_NOT_AVAILABLE, EBUSY},
3104bff34e3Sthurlow {NT_STATUS_PORT_CONNECTION_REFUSED, ECONNREFUSED},
31140c0e231SGordon Ross {NT_STATUS_PORT_DISCONNECTED, EBADF},
3124bff34e3Sthurlow {NT_STATUS_PORT_MESSAGE_TOO_LONG, EMSGSIZE},
3134bff34e3Sthurlow {NT_STATUS_PORT_UNREACHABLE, EHOSTUNREACH},
3144bff34e3Sthurlow {NT_STATUS_PROTOCOL_UNREACHABLE, ENOPROTOOPT},
3154bff34e3Sthurlow {NT_STATUS_QUOTA_EXCEEDED, EDQUOT},
31640c0e231SGordon Ross {NT_STATUS_RANGE_NOT_LOCKED, EAGAIN}, /* like F_SETLK */
3174bff34e3Sthurlow {NT_STATUS_REGISTRY_QUOTA_LIMIT, EDQUOT},
3184bff34e3Sthurlow {NT_STATUS_REMOTE_DISCONNECT, ESHUTDOWN},
3194bff34e3Sthurlow {NT_STATUS_REMOTE_NOT_LISTENING, ECONNREFUSED},
3204bff34e3Sthurlow {NT_STATUS_REQUEST_NOT_ACCEPTED, EACCES},
3214bff34e3Sthurlow {NT_STATUS_RETRY, EAGAIN},
3224bff34e3Sthurlow {NT_STATUS_SHARING_VIOLATION, EBUSY},
3234bff34e3Sthurlow {NT_STATUS_TIMER_NOT_CANCELED, ETIME},
3244bff34e3Sthurlow {NT_STATUS_TOO_MANY_LINKS, EMLINK},
3254bff34e3Sthurlow {NT_STATUS_TOO_MANY_OPENED_FILES, EMFILE},
32640c0e231SGordon Ross {NT_STATUS_TRUSTED_DOMAIN_FAILURE, EAUTH},
32740c0e231SGordon Ross {NT_STATUS_TRUSTED_RELATIONSHIP_FAILURE, EAUTH},
3284bff34e3Sthurlow {NT_STATUS_UNABLE_TO_FREE_VM, EADDRINUSE},
3294bff34e3Sthurlow {NT_STATUS_UNSUCCESSFUL, EINVAL},
33040c0e231SGordon Ross {NT_STATUS_WRONG_PASSWORD, EAUTH},
3314bff34e3Sthurlow {0, 0}
3324bff34e3Sthurlow };
3334bff34e3Sthurlow
334148c5f43SAlan Wright /*
335148c5f43SAlan Wright * Table for converting NT STATUS values to DOS class/code.
336148c5f43SAlan Wright * Rows ordered by integer value of last column (NT STATUS)
337148c5f43SAlan Wright */
338148c5f43SAlan Wright typedef struct nt2doserr {
33902d09e03SGordon Ross unsigned short dclass;
34002d09e03SGordon Ross unsigned short derr;
34102d09e03SGordon Ross unsigned int nterr;
342148c5f43SAlan Wright } nt2doserr_t;
343148c5f43SAlan Wright
344148c5f43SAlan Wright static const nt2doserr_t nt2doserr[] = {
3454bff34e3Sthurlow {ERRDOS, ERRgeneral, NT_STATUS_UNSUCCESSFUL},
3464bff34e3Sthurlow {ERRDOS, ERRbadfunc, NT_STATUS_NOT_IMPLEMENTED},
347148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_INFO_CLASS},
348148c5f43SAlan Wright {ERRDOS, ERROR_BAD_LENGTH, NT_STATUS_INFO_LENGTH_MISMATCH},
3494bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_ACCESS_VIOLATION},
3504bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_IN_PAGE_ERROR},
3514bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PAGEFILE_QUOTA},
3524bff34e3Sthurlow {ERRDOS, ERRbadfid, NT_STATUS_INVALID_HANDLE},
3534bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_BAD_INITIAL_STACK},
354148c5f43SAlan Wright {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_BAD_INITIAL_PC},
355148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_CID},
3564bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_TIMER_NOT_CANCELED},
357148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER},
3584bff34e3Sthurlow {ERRDOS, ERRbadfile, NT_STATUS_NO_SUCH_DEVICE},
3594bff34e3Sthurlow {ERRDOS, ERRbadfile, NT_STATUS_NO_SUCH_FILE},
3604bff34e3Sthurlow {ERRDOS, ERRbadfunc, NT_STATUS_INVALID_DEVICE_REQUEST},
361148c5f43SAlan Wright {ERRDOS, ERROR_HANDLE_EOF, NT_STATUS_END_OF_FILE},
362148c5f43SAlan Wright {ERRDOS, ERROR_WRONG_DISK, NT_STATUS_WRONG_VOLUME},
363148c5f43SAlan Wright {ERRDOS, ERROR_NOT_READY, NT_STATUS_NO_MEDIA_IN_DEVICE},
3644bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_UNRECOGNIZED_MEDIA},
365148c5f43SAlan Wright {ERRDOS, ERROR_SECTOR_NOT_FOUND, NT_STATUS_NONEXISTENT_SECTOR},
3664bff34e3Sthurlow {ERRDOS, ERRnomem, NT_STATUS_NO_MEMORY},
367148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_ADDRESS, NT_STATUS_CONFLICTING_ADDRESSES},
368148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_ADDRESS, NT_STATUS_NOT_MAPPED_VIEW},
369148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_UNABLE_TO_FREE_VM},
370148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_UNABLE_TO_DELETE_SECTION},
371148c5f43SAlan Wright {ERRDOS, NERR_InvalidAPI, NT_STATUS_INVALID_SYSTEM_SERVICE},
3724bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_ILLEGAL_INSTRUCTION},
3734bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_INVALID_LOCK_SEQUENCE},
3744bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_INVALID_VIEW_SIZE},
375148c5f43SAlan Wright {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_INVALID_FILE_FOR_SECTION},
3764bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_ALREADY_COMMITTED},
3774bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_ACCESS_DENIED},
378148c5f43SAlan Wright {ERRDOS, ERROR_BUFFER_OVERFLOW, NT_STATUS_BUFFER_TOO_SMALL},
3794bff34e3Sthurlow {ERRDOS, ERRbadfid, NT_STATUS_OBJECT_TYPE_MISMATCH},
3804bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NONCONTINUABLE_EXCEPTION},
3814bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_DISPOSITION},
3824bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_UNWIND},
3834bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_BAD_STACK},
3844bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_UNWIND_TARGET},
385148c5f43SAlan Wright {ERRDOS, ERROR_NOT_LOCKED, NT_STATUS_NOT_LOCKED},
3864bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PARITY_ERROR},
387148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_ADDRESS, NT_STATUS_UNABLE_TO_DECOMMIT_VM},
388148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_ADDRESS, NT_STATUS_NOT_COMMITTED},
3894bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_PORT_ATTRIBUTES},
3904bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PORT_MESSAGE_TOO_LONG},
391148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_MIX},
3924bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_QUOTA_LOWER},
3934bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DISK_CORRUPT_ERROR},
394148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_NAME, NT_STATUS_OBJECT_NAME_INVALID},
3954bff34e3Sthurlow {ERRDOS, ERRbadfile, NT_STATUS_OBJECT_NAME_NOT_FOUND},
396148c5f43SAlan Wright {ERRDOS, ERROR_ALREADY_EXISTS, NT_STATUS_OBJECT_NAME_COLLISION},
3974bff34e3Sthurlow {ERRDOS, ERRbadfid, NT_STATUS_PORT_DISCONNECTED},
3984bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DEVICE_ALREADY_ATTACHED},
399148c5f43SAlan Wright {ERRDOS, ERROR_BAD_PATHNAME, NT_STATUS_OBJECT_PATH_INVALID},
4004bff34e3Sthurlow {ERRDOS, ERRbadpath, NT_STATUS_OBJECT_PATH_NOT_FOUND},
401148c5f43SAlan Wright {ERRDOS, ERROR_BAD_PATHNAME, NT_STATUS_OBJECT_PATH_SYNTAX_BAD},
4024bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DATA_OVERRUN},
4034bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DATA_LATE_ERROR},
404148c5f43SAlan Wright {ERRDOS, ERROR_CRC, NT_STATUS_DATA_ERROR},
405148c5f43SAlan Wright {ERRDOS, ERROR_CRC, NT_STATUS_CRC_ERROR},
4064bff34e3Sthurlow {ERRDOS, ERRnomem, NT_STATUS_SECTION_TOO_BIG},
4074bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_PORT_CONNECTION_REFUSED},
4084bff34e3Sthurlow {ERRDOS, ERRbadfid, NT_STATUS_INVALID_PORT_HANDLE},
409148c5f43SAlan Wright {ERRDOS, ERROR_SHARING_VIOLATION, NT_STATUS_SHARING_VIOLATION},
4104bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_QUOTA_EXCEEDED},
411148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PAGE_PROTECTION},
412148c5f43SAlan Wright {ERRDOS, ERROR_NOT_OWNER, NT_STATUS_MUTANT_NOT_OWNED},
413148c5f43SAlan Wright {ERRDOS, ERROR_TOO_MANY_POSTS, NT_STATUS_SEMAPHORE_LIMIT_EXCEEDED},
414148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_PORT_ALREADY_SET},
415148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_SECTION_NOT_IMAGE},
416148c5f43SAlan Wright {ERRDOS, ERROR_SIGNAL_REFUSED, NT_STATUS_SUSPEND_COUNT_EXCEEDED},
4174bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_THREAD_IS_TERMINATING},
418148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_BAD_WORKING_SET_LIMIT},
419148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INCOMPATIBLE_FILE_MAP},
420148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_SECTION_PROTECTION},
421148c5f43SAlan Wright {ERRDOS, ERROR_EAS_NOT_SUPPORTED, NT_STATUS_EAS_NOT_SUPPORTED},
422148c5f43SAlan Wright {ERRDOS, ERROR_EA_LIST_INCONSISTENT, NT_STATUS_EA_TOO_LARGE},
4234bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NONEXISTENT_EA_ENTRY},
4244bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_EAS_ON_FILE},
4254bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_EA_CORRUPT_ERROR},
426148c5f43SAlan Wright {ERRDOS, ERROR_LOCK_VIOLATION, NT_STATUS_FILE_LOCK_CONFLICT},
427148c5f43SAlan Wright {ERRDOS, ERROR_LOCK_VIOLATION, NT_STATUS_LOCK_NOT_GRANTED},
4284bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_DELETE_PENDING},
429148c5f43SAlan Wright {ERRDOS, ERROR_NOT_SUPPORTED, NT_STATUS_CTL_FILE_NOT_SUPPORTED},
4304bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_UNKNOWN_REVISION},
4314bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_REVISION_MISMATCH},
4324bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_OWNER},
4334bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_PRIMARY_GROUP},
4344bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_IMPERSONATION_TOKEN},
4354bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_CANT_DISABLE_MANDATORY},
436148c5f43SAlan Wright {ERRDOS, NERR_LogonServerNotFound, NT_STATUS_NO_LOGON_SERVERS},
4374bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_SUCH_LOGON_SESSION},
4384bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_SUCH_PRIVILEGE},
4394bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_PRIVILEGE_NOT_HELD},
4404bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_ACCOUNT_NAME},
4414bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_USER_EXISTS},
4424bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_NO_SUCH_USER},
4434bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_GROUP_EXISTS},
4444bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_SUCH_GROUP},
4454bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_MEMBER_IN_GROUP},
4464bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_MEMBER_NOT_IN_GROUP},
4474bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_LAST_ADMIN},
4484bff34e3Sthurlow {ERRSRV, ERRbadpw, NT_STATUS_WRONG_PASSWORD},
4494bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_ILL_FORMED_PASSWORD},
4504bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PASSWORD_RESTRICTION},
4514bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_LOGON_FAILURE},
4524bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_ACCOUNT_RESTRICTION},
453148c5f43SAlan Wright {ERRSRV, NERR_InvalidLogonHours, NT_STATUS_INVALID_LOGON_HOURS},
454148c5f43SAlan Wright {ERRSRV, NERR_InvalidWorkstation, NT_STATUS_INVALID_WORKSTATION},
455148c5f43SAlan Wright {ERRSRV, NERR_PasswordExpired, NT_STATUS_PASSWORD_EXPIRED},
456148c5f43SAlan Wright {ERRSRV, NERR_AccountExpired, NT_STATUS_ACCOUNT_DISABLED},
4574bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NONE_MAPPED},
4584bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_TOO_MANY_LUIDS_REQUESTED},
4594bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_LUIDS_EXHAUSTED},
4604bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_SUB_AUTHORITY},
4614bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_ACL},
4624bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_SID},
4634bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_SECURITY_DESCR},
464148c5f43SAlan Wright {ERRDOS, ERROR_PROC_NOT_FOUND, NT_STATUS_PROCEDURE_NOT_FOUND},
465148c5f43SAlan Wright {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_INVALID_IMAGE_FORMAT},
4664bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_TOKEN},
4674bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_BAD_INHERITANCE_ACL},
468148c5f43SAlan Wright {ERRDOS, ERROR_NOT_LOCKED, NT_STATUS_RANGE_NOT_LOCKED},
469148c5f43SAlan Wright {ERRDOS, ERROR_DISK_FULL, NT_STATUS_DISK_FULL},
4704bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_SERVER_DISABLED},
4714bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_SERVER_NOT_DISABLED},
472148c5f43SAlan Wright {ERRDOS, ERROR_TOO_MANY_NAMES, NT_STATUS_TOO_MANY_GUIDS_REQUESTED},
473148c5f43SAlan Wright {ERRDOS, ERROR_NO_MORE_ITEMS, NT_STATUS_GUIDS_EXHAUSTED},
4744bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_ID_AUTHORITY},
475148c5f43SAlan Wright {ERRDOS, ERROR_NO_MORE_ITEMS, NT_STATUS_AGENTS_EXHAUSTED},
476148c5f43SAlan Wright {ERRDOS, ERROR_LABEL_TOO_LONG, NT_STATUS_INVALID_VOLUME_LABEL},
477148c5f43SAlan Wright {ERRDOS, ERROR_OUTOFMEMORY, NT_STATUS_SECTION_NOT_EXTENDED},
478148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_ADDRESS, NT_STATUS_NOT_MAPPED_DATA},
4794bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_RESOURCE_DATA_NOT_FOUND},
4804bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_RESOURCE_TYPE_NOT_FOUND},
4814bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_RESOURCE_NAME_NOT_FOUND},
4824bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_ARRAY_BOUNDS_EXCEEDED},
4834bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FLOAT_DENORMAL_OPERAND},
4844bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FLOAT_DIVIDE_BY_ZERO},
4854bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FLOAT_INEXACT_RESULT},
4864bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FLOAT_INVALID_OPERATION},
4874bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FLOAT_OVERFLOW},
4884bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FLOAT_STACK_CHECK},
4894bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FLOAT_UNDERFLOW},
4904bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INTEGER_DIVIDE_BY_ZERO},
491148c5f43SAlan Wright {ERRDOS, ERROR_ARITHMETIC_OVERFLOW, NT_STATUS_INTEGER_OVERFLOW},
4924bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PRIVILEGED_INSTRUCTION},
4934bff34e3Sthurlow {ERRDOS, ERRnomem, NT_STATUS_TOO_MANY_PAGING_FILES},
4944bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FILE_INVALID},
4954bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_ALLOTTED_SPACE_EXCEEDED},
4964bff34e3Sthurlow {ERRDOS, ERRnomem, NT_STATUS_INSUFFICIENT_RESOURCES},
4974bff34e3Sthurlow {ERRDOS, ERRbadpath, NT_STATUS_DFS_EXIT_PATH_FOUND},
498148c5f43SAlan Wright {ERRDOS, ERROR_CRC, NT_STATUS_DEVICE_DATA_ERROR},
4994bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DEVICE_NOT_CONNECTED},
500148c5f43SAlan Wright {ERRDOS, ERROR_NOT_READY, NT_STATUS_DEVICE_POWER_FAILURE},
501148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_ADDRESS, NT_STATUS_FREE_VM_NOT_AT_BASE},
502148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_ADDRESS, NT_STATUS_MEMORY_NOT_ALLOCATED},
5034bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_WORKING_SET_QUOTA},
504148c5f43SAlan Wright {ERRDOS, ERROR_WRITE_PROTECT, NT_STATUS_MEDIA_WRITE_PROTECTED},
505148c5f43SAlan Wright {ERRDOS, ERROR_NOT_READY, NT_STATUS_DEVICE_NOT_READY},
5064bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_GROUP_ATTRIBUTES},
5074bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_BAD_IMPERSONATION_LEVEL},
5084bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_CANT_OPEN_ANONYMOUS},
5094bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_BAD_VALIDATION_CLASS},
5104bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_BAD_TOKEN_TYPE},
511148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_BAD_MASTER_BOOT_RECORD},
5124bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INSTRUCTION_MISALIGNMENT},
513148c5f43SAlan Wright {ERRDOS, ERROR_PIPE_BUSY, NT_STATUS_INSTANCE_NOT_AVAILABLE},
514148c5f43SAlan Wright {ERRDOS, ERROR_PIPE_BUSY, NT_STATUS_PIPE_NOT_AVAILABLE},
515148c5f43SAlan Wright {ERRDOS, ERROR_BAD_PIPE, NT_STATUS_INVALID_PIPE_STATE},
516148c5f43SAlan Wright {ERRDOS, ERROR_PIPE_BUSY, NT_STATUS_PIPE_BUSY},
5174bff34e3Sthurlow {ERRDOS, ERRbadfunc, NT_STATUS_ILLEGAL_FUNCTION},
518148c5f43SAlan Wright {ERRDOS, ERROR_PIPE_NOT_CONNECTED, NT_STATUS_PIPE_DISCONNECTED},
519148c5f43SAlan Wright {ERRDOS, ERROR_NO_DATA, NT_STATUS_PIPE_CLOSING},
5204bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PIPE_CONNECTED},
5214bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PIPE_LISTENING},
522148c5f43SAlan Wright {ERRDOS, ERROR_BAD_PIPE, NT_STATUS_INVALID_READ_MODE},
523148c5f43SAlan Wright {ERRDOS, ERROR_SEM_TIMEOUT, NT_STATUS_IO_TIMEOUT},
524148c5f43SAlan Wright {ERRDOS, ERROR_HANDLE_EOF, NT_STATUS_FILE_FORCED_CLOSED},
5254bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PROFILING_NOT_STARTED},
5264bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PROFILING_NOT_STOPPED},
5274bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_COULD_NOT_INTERPRET},
5284bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_FILE_IS_A_DIRECTORY},
529148c5f43SAlan Wright {ERRDOS, ERROR_NOT_SUPPORTED, NT_STATUS_NOT_SUPPORTED},
530148c5f43SAlan Wright {ERRDOS, ERROR_REM_NOT_LIST, NT_STATUS_REMOTE_NOT_LISTENING},
531148c5f43SAlan Wright {ERRDOS, ERROR_DUP_NAME, NT_STATUS_DUPLICATE_NAME},
532148c5f43SAlan Wright {ERRDOS, ERROR_BAD_NETPATH, NT_STATUS_BAD_NETWORK_PATH},
533148c5f43SAlan Wright {ERRDOS, ERROR_NETWORK_BUSY, NT_STATUS_NETWORK_BUSY},
534148c5f43SAlan Wright {ERRDOS, ERROR_DEV_NOT_EXIST, NT_STATUS_DEVICE_DOES_NOT_EXIST},
535148c5f43SAlan Wright {ERRDOS, ERROR_TOO_MANY_CMDS, NT_STATUS_TOO_MANY_COMMANDS},
536148c5f43SAlan Wright {ERRDOS, ERROR_ADAP_HDW_ERR, NT_STATUS_ADAPTER_HARDWARE_ERROR},
537148c5f43SAlan Wright {ERRDOS, ERROR_BAD_NET_RESP, NT_STATUS_INVALID_NETWORK_RESPONSE},
538148c5f43SAlan Wright {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_UNEXPECTED_NETWORK_ERROR},
539148c5f43SAlan Wright {ERRDOS, ERROR_BAD_REM_ADAP, NT_STATUS_BAD_REMOTE_ADAPTER},
540148c5f43SAlan Wright {ERRDOS, ERROR_PRINTQ_FULL, NT_STATUS_PRINT_QUEUE_FULL},
541148c5f43SAlan Wright {ERRDOS, ERROR_NO_SPOOL_SPACE, NT_STATUS_NO_SPOOL_SPACE},
542148c5f43SAlan Wright {ERRDOS, ERROR_PRINT_CANCELLED, NT_STATUS_PRINT_CANCELLED},
543148c5f43SAlan Wright {ERRDOS, ERROR_NETNAME_DELETED, NT_STATUS_NETWORK_NAME_DELETED},
544148c5f43SAlan Wright {ERRDOS, ERROR_NETWORK_ACCESS_DENIED, NT_STATUS_NETWORK_ACCESS_DENIED},
545148c5f43SAlan Wright {ERRDOS, ERROR_BAD_DEV_TYPE, NT_STATUS_BAD_DEVICE_TYPE},
546148c5f43SAlan Wright {ERRDOS, ERROR_BAD_NET_NAME, NT_STATUS_BAD_NETWORK_NAME},
547148c5f43SAlan Wright {ERRDOS, ERROR_TOO_MANY_NAMES, NT_STATUS_TOO_MANY_NAMES},
548148c5f43SAlan Wright {ERRDOS, ERROR_TOO_MANY_SESS, NT_STATUS_TOO_MANY_SESSIONS},
549148c5f43SAlan Wright {ERRDOS, ERROR_SHARING_PAUSED, NT_STATUS_SHARING_PAUSED},
550148c5f43SAlan Wright {ERRDOS, ERROR_REQ_NOT_ACCEP, NT_STATUS_REQUEST_NOT_ACCEPTED},
551148c5f43SAlan Wright {ERRDOS, ERROR_REDIR_PAUSED, NT_STATUS_REDIRECTOR_PAUSED},
552148c5f43SAlan Wright {ERRDOS, ERROR_NET_WRITE_FAULT, NT_STATUS_NET_WRITE_FAULT},
5534bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PROFILING_AT_LIMIT},
554148c5f43SAlan Wright {ERRDOS, ERROR_NOT_SAME_DEVICE, NT_STATUS_NOT_SAME_DEVICE},
5554bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_FILE_RENAMED},
556148c5f43SAlan Wright {ERRDOS, ERROR_VC_DISCONNECTED, NT_STATUS_VIRTUAL_CIRCUIT_CLOSED},
5574bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_SECURITY_ON_OBJECT},
5584bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_CANT_WAIT},
559148c5f43SAlan Wright {ERRDOS, ERROR_NO_DATA, NT_STATUS_PIPE_EMPTY},
5604bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_CANT_ACCESS_DOMAIN_INFO},
5614bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_CANT_TERMINATE_SELF},
5624bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_SERVER_STATE},
5634bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_DOMAIN_STATE},
5644bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_DOMAIN_ROLE},
5654bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_SUCH_DOMAIN},
5664bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DOMAIN_EXISTS},
5674bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DOMAIN_LIMIT_EXCEEDED},
568148c5f43SAlan Wright {ERRDOS, ERROR_OPLOCK_NOT_GRANTED, NT_STATUS_OPLOCK_NOT_GRANTED},
569148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_OPLOCK_PROTOCOL,
570148c5f43SAlan Wright NT_STATUS_INVALID_OPLOCK_PROTOCOL},
5714bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INTERNAL_DB_CORRUPTION},
5724bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INTERNAL_ERROR},
5734bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_GENERIC_NOT_MAPPED},
5744bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_BAD_DESCRIPTOR_FORMAT},
5754bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_USER_BUFFER},
5764bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_UNEXPECTED_IO_ERROR},
5774bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_UNEXPECTED_MM_CREATE_ERR},
5784bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_UNEXPECTED_MM_MAP_ERROR},
5794bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_UNEXPECTED_MM_EXTEND_ERR},
5804bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NOT_LOGON_PROCESS},
5814bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_LOGON_SESSION_EXISTS},
582148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_1},
583148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_2},
584148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_3},
585148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_4},
586148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_5},
587148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_6},
588148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_7},
589148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_8},
590148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_9},
591148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_10},
592148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_11},
593148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_INVALID_PARAMETER_12},
5944bff34e3Sthurlow {ERRDOS, ERRbadpath, NT_STATUS_REDIRECTOR_NOT_STARTED},
5954bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_REDIRECTOR_STARTED},
5964bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_STACK_OVERFLOW},
5974bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_SUCH_PACKAGE},
5984bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_BAD_FUNCTION_TABLE},
599148c5f43SAlan Wright {ERRDOS, ERROR_ENVVAR_NOT_FOUND, NT_STATUS_VARIABLE_NOT_FOUND},
600148c5f43SAlan Wright {ERRDOS, ERROR_DIR_NOT_EMPTY, NT_STATUS_DIRECTORY_NOT_EMPTY},
6014bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FILE_CORRUPT_ERROR},
602148c5f43SAlan Wright {ERRDOS, ERROR_DIRECTORY, NT_STATUS_NOT_A_DIRECTORY},
6034bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_BAD_LOGON_SESSION_STATE},
6044bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_LOGON_SESSION_COLLISION},
605148c5f43SAlan Wright {ERRDOS, ERROR_FILENAME_EXCED_RANGE, NT_STATUS_NAME_TOO_LONG},
606148c5f43SAlan Wright {ERRDOS, NERR_OpenFiles, NT_STATUS_FILES_OPEN},
607148c5f43SAlan Wright {ERRDOS, NERR_DevInUse, NT_STATUS_CONNECTION_IN_USE},
6084bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_MESSAGE_NOT_FOUND},
6094bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_PROCESS_IS_TERMINATING},
6104bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_LOGON_TYPE},
6114bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_GUID_TRANSLATION},
6124bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_CANNOT_IMPERSONATE},
6134bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_IMAGE_ALREADY_LOADED},
6144bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_LDT},
6154bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_LDT_SIZE},
6164bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_LDT_OFFSET},
6174bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_LDT_DESCRIPTOR},
618148c5f43SAlan Wright {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_INVALID_IMAGE_NE_FORMAT},
6194bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_RXACT_INVALID_STATE},
6204bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_RXACT_COMMIT_FAILURE},
6214bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_MAPPED_FILE_SIZE_ZERO},
6224bff34e3Sthurlow {ERRDOS, ERRnofids, NT_STATUS_TOO_MANY_OPENED_FILES},
6234bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_CANCELLED},
6244bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_CANNOT_DELETE},
6254bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_COMPUTER_NAME},
6264bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_FILE_DELETED},
6274bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_SPECIAL_ACCOUNT},
6284bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_SPECIAL_GROUP},
6294bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_SPECIAL_USER},
6304bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_MEMBERS_PRIMARY_GROUP},
6314bff34e3Sthurlow {ERRDOS, ERRbadfid, NT_STATUS_FILE_CLOSED},
6324bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_TOO_MANY_THREADS},
6334bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_THREAD_NOT_IN_PROCESS},
6344bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_TOKEN_ALREADY_IN_USE},
6354bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PAGEFILE_QUOTA_EXCEEDED},
6364bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_COMMITMENT_LIMIT},
637148c5f43SAlan Wright {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_INVALID_IMAGE_LE_FORMAT},
638148c5f43SAlan Wright {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_INVALID_IMAGE_NOT_MZ},
639148c5f43SAlan Wright {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_INVALID_IMAGE_PROTECT},
640148c5f43SAlan Wright {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_INVALID_IMAGE_WIN_16},
6414bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_LOGON_SERVER_CONFLICT},
6424bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_TIME_DIFFERENCE_AT_DC},
6434bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_SYNCHRONIZATION_REQUIRED},
644148c5f43SAlan Wright {ERRDOS, ERROR_MOD_NOT_FOUND, NT_STATUS_DLL_NOT_FOUND},
6454bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_OPEN_FAILED},
6464bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_IO_PRIVILEGE_FAILED},
647148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_ORDINAL, NT_STATUS_ORDINAL_NOT_FOUND},
648148c5f43SAlan Wright {ERRDOS, ERROR_PROC_NOT_FOUND, NT_STATUS_ENTRYPOINT_NOT_FOUND},
6494bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_CONTROL_C_EXIT},
650148c5f43SAlan Wright {ERRDOS, ERROR_NETNAME_DELETED, NT_STATUS_LOCAL_DISCONNECT},
651148c5f43SAlan Wright {ERRDOS, ERROR_NETNAME_DELETED, NT_STATUS_REMOTE_DISCONNECT},
652148c5f43SAlan Wright {ERRDOS, ERROR_REM_NOT_LIST, NT_STATUS_REMOTE_RESOURCES},
653148c5f43SAlan Wright {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_LINK_FAILED},
654148c5f43SAlan Wright {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_LINK_TIMEOUT},
655148c5f43SAlan Wright {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_INVALID_CONNECTION},
656148c5f43SAlan Wright {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_INVALID_ADDRESS},
6574bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DLL_INIT_FAILED},
6584bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_MISSING_SYSTEMFILE},
6594bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_UNHANDLED_EXCEPTION},
6604bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_APP_INIT_FAILURE},
6614bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PAGEFILE_CREATE_FAILED},
6624bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_PAGEFILE},
663148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_LEVEL, NT_STATUS_INVALID_LEVEL},
664148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PASSWORD, NT_STATUS_WRONG_PASSWORD_CORE},
6654bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_ILLEGAL_FLOAT_CONTEXT},
666148c5f43SAlan Wright {ERRDOS, ERROR_BROKEN_PIPE, NT_STATUS_PIPE_BROKEN},
6674bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_REGISTRY_CORRUPT},
6684bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_REGISTRY_IO_FAILED},
6694bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_EVENT_PAIR},
6704bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_UNRECOGNIZED_VOLUME},
6714bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_SERIAL_NO_DEVICE_INITED},
6724bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_SUCH_ALIAS},
6734bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_MEMBER_NOT_IN_ALIAS},
6744bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_MEMBER_IN_ALIAS},
6754bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_ALIAS_EXISTS},
6764bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_LOGON_NOT_GRANTED},
6774bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_TOO_MANY_SECRETS},
6784bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_SECRET_TOO_LONG},
6794bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INTERNAL_DB_ERROR},
6804bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FULLSCREEN_MODE},
6814bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_TOO_MANY_CONTEXT_IDS},
6824bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_LOGON_TYPE_NOT_GRANTED},
6834bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NOT_REGISTRY_FILE},
6844bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NT_CROSS_ENCRYPTION_REQUIRED},
6854bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DOMAIN_CTRLR_CONFIG_ERROR},
6864bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FT_MISSING_MEMBER},
6874bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_ILL_FORMED_SERVICE_ENTRY},
6884bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_ILLEGAL_CHARACTER},
6894bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_UNMAPPABLE_CHARACTER},
6904bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_UNDEFINED_CHARACTER},
6914bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FLOPPY_VOLUME},
6924bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FLOPPY_ID_MARK_NOT_FOUND},
6934bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FLOPPY_WRONG_CYLINDER},
6944bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FLOPPY_UNKNOWN_ERROR},
6954bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FLOPPY_BAD_REGISTERS},
6964bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DISK_RECALIBRATE_FAILED},
6974bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DISK_OPERATION_FAILED},
6984bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DISK_RESET_FAILED},
6994bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_SHARED_IRQ_BUSY},
7004bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FT_ORPHANING},
70102d09e03SGordon Ross {ERRHRD, ERRgeneral,
70202d09e03SGordon Ross NT_STATUS_BIOS_FAILED_TO_CONNECT_INTERRUPT},
7034bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PARTITION_FAILURE},
7044bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_BLOCK_LENGTH},
7054bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DEVICE_NOT_PARTITIONED},
7064bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_UNABLE_TO_LOCK_MEDIA},
7074bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_UNABLE_TO_UNLOAD_MEDIA},
7084bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_EOM_OVERFLOW},
7094bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_MEDIA},
7104bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_SUCH_MEMBER},
7114bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_MEMBER},
7124bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_KEY_DELETED},
7134bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_LOG_SPACE},
7144bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_TOO_MANY_SIDS},
7154bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_LM_CROSS_ENCRYPTION_REQUIRED},
7164bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_KEY_HAS_CHILDREN},
7174bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_CHILD_MUST_BE_VOLATILE},
718148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_PARAMETER, NT_STATUS_DEVICE_CONFIGURATION_ERROR},
7194bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DRIVER_INTERNAL_ERROR},
720148c5f43SAlan Wright {ERRDOS, ERROR_BAD_COMMAND, NT_STATUS_INVALID_DEVICE_STATE},
7214bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_IO_DEVICE_ERROR},
7224bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DEVICE_PROTOCOL_ERROR},
7234bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_BACKUP_CONTROLLER},
7244bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_LOG_FILE_FULL},
725148c5f43SAlan Wright {ERRDOS, ERROR_WRITE_PROTECT, NT_STATUS_TOO_LATE},
7264bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_NO_TRUST_LSA_SECRET},
7274bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_NO_TRUST_SAM_ACCOUNT},
7284bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_TRUSTED_DOMAIN_FAILURE},
7294bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_TRUSTED_RELATIONSHIP_FAILURE},
7304bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_EVENTLOG_FILE_CORRUPT},
7314bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_EVENTLOG_CANT_START},
7324bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_TRUST_FAILURE},
7334bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_MUTANT_LIMIT_EXCEEDED},
734148c5f43SAlan Wright {ERRDOS, NERR_NetlogonNotStarted, NT_STATUS_NETLOGON_NOT_STARTED},
735148c5f43SAlan Wright {ERRSRV, NERR_AccountExpired, NT_STATUS_ACCOUNT_EXPIRED},
7364bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_POSSIBLE_DEADLOCK},
7374bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NETWORK_CREDENTIAL_CONFLICT},
7384bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_REMOTE_SESSION_LIMIT},
7394bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_EVENTLOG_FILE_CHANGED},
7404bff34e3Sthurlow {ERRDOS, ERRnoaccess,
74102d09e03SGordon Ross NT_STATUS_NOLOGON_INTERDOMAIN_TRUST_ACCOUNT},
7424bff34e3Sthurlow {ERRDOS, ERRnoaccess,
7434bff34e3Sthurlow NT_STATUS_NOLOGON_WORKSTATION_TRUST_ACCOUNT},
7444bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_NOLOGON_SERVER_TRUST_ACCOUNT},
7454bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_DOMAIN_TRUST_INCONSISTENT},
7464bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FS_DRIVER_REQUIRED},
7474bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_USER_SESSION_KEY},
748148c5f43SAlan Wright {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_USER_SESSION_DELETED},
7494bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_RESOURCE_LANG_NOT_FOUND},
7504bff34e3Sthurlow {ERRDOS, ERRnomem, NT_STATUS_INSUFF_SERVER_RESOURCES},
7514bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_BUFFER_SIZE},
7524bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_ADDRESS_COMPONENT},
7534bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_ADDRESS_WILDCARD},
754148c5f43SAlan Wright {ERRDOS, ERROR_TOO_MANY_NAMES, NT_STATUS_TOO_MANY_ADDRESSES},
755148c5f43SAlan Wright {ERRDOS, ERROR_DUP_NAME, NT_STATUS_ADDRESS_ALREADY_EXISTS},
756148c5f43SAlan Wright {ERRDOS, ERROR_NETNAME_DELETED, NT_STATUS_ADDRESS_CLOSED},
757148c5f43SAlan Wright {ERRDOS, ERROR_NETNAME_DELETED, NT_STATUS_CONNECTION_DISCONNECTED},
758148c5f43SAlan Wright {ERRDOS, ERROR_NETNAME_DELETED, NT_STATUS_CONNECTION_RESET},
759148c5f43SAlan Wright {ERRDOS, ERROR_TOO_MANY_NAMES, NT_STATUS_TOO_MANY_NODES},
760148c5f43SAlan Wright {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_TRANSACTION_ABORTED},
761148c5f43SAlan Wright {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_TRANSACTION_TIMED_OUT},
762148c5f43SAlan Wright {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_TRANSACTION_NO_RELEASE},
763148c5f43SAlan Wright {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_TRANSACTION_NO_MATCH},
764148c5f43SAlan Wright {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_TRANSACTION_RESPONDED},
765148c5f43SAlan Wright {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_TRANSACTION_INVALID_ID},
766148c5f43SAlan Wright {ERRDOS, ERROR_UNEXP_NET_ERR, NT_STATUS_TRANSACTION_INVALID_TYPE},
767148c5f43SAlan Wright {ERRDOS, ERROR_NOT_SUPPORTED, NT_STATUS_NOT_SERVER_SESSION},
768148c5f43SAlan Wright {ERRDOS, ERROR_NOT_SUPPORTED, NT_STATUS_NOT_CLIENT_SESSION},
7694bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_CANNOT_LOAD_REGISTRY_FILE},
7704bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DEBUG_ATTACH_FAILED},
7714bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_SYSTEM_PROCESS_TERMINATED},
7724bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DATA_NOT_ACCEPTED},
7734bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_BROWSER_SERVERS_FOUND},
7744bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_VDM_HARD_ERROR},
7754bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DRIVER_CANCEL_TIMEOUT},
7764bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_REPLY_MESSAGE_MISMATCH},
7774bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_MAPPED_ALIGNMENT},
778148c5f43SAlan Wright {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_IMAGE_CHECKSUM_MISMATCH},
7794bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_LOST_WRITEBEHIND_DATA},
7804bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_CLIENT_SERVER_PARAMETERS_INVALID},
781148c5f43SAlan Wright {ERRSRV, NERR_PasswordExpired, NT_STATUS_PASSWORD_MUST_CHANGE},
7824bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NOT_FOUND},
7834bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NOT_TINY_STREAM},
7844bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_RECOVERY_FAILURE},
7854bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_STACK_OVERFLOW_READ},
7864bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FAIL_CHECK},
7874bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DUPLICATE_OBJECTID},
7884bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_OBJECTID_EXISTS},
7894bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_CONVERT_TO_LARGE},
7904bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_RETRY},
7914bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FOUND_OUT_OF_SCOPE},
7924bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_ALLOCATE_BUCKET},
7934bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PROPSET_NOT_FOUND},
7944bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_MARSHALL_OVERFLOW},
7954bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_VARIANT},
7964bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_DOMAIN_CONTROLLER_NOT_FOUND},
7974bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_ACCOUNT_LOCKED_OUT},
7984bff34e3Sthurlow {ERRDOS, ERRbadfid, NT_STATUS_HANDLE_NOT_CLOSABLE},
7994bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_CONNECTION_REFUSED},
8004bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_GRACEFUL_DISCONNECT},
8014bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_ADDRESS_ALREADY_ASSOCIATED},
8024bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_ADDRESS_NOT_ASSOCIATED},
8034bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_CONNECTION_INVALID},
8044bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_CONNECTION_ACTIVE},
8054bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NETWORK_UNREACHABLE},
8064bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_HOST_UNREACHABLE},
8074bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PROTOCOL_UNREACHABLE},
8084bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PORT_UNREACHABLE},
8094bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_REQUEST_ABORTED},
8104bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_CONNECTION_ABORTED},
8114bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_BAD_COMPRESSION_BUFFER},
8124bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_USER_MAPPED_FILE},
8134bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_AUDIT_FAILED},
8144bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_TIMER_RESOLUTION_NOT_SET},
8154bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_CONNECTION_COUNT_LIMIT},
8164bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_LOGIN_TIME_RESTRICTION},
8174bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_LOGIN_WKSTA_RESTRICTION},
818148c5f43SAlan Wright {ERRDOS, ERROR_BAD_EXE_FORMAT, NT_STATUS_IMAGE_MP_UP_MISMATCH},
8194bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INSUFFICIENT_LOGON_INFO},
8204bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_BAD_DLL_ENTRYPOINT},
8214bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_BAD_SERVICE_ENTRYPOINT},
8224bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_LPC_REPLY_LOST},
8234bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_IP_ADDRESS_CONFLICT1},
8244bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_IP_ADDRESS_CONFLICT2},
8254bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_REGISTRY_QUOTA_LIMIT},
8264bff34e3Sthurlow {ERRSRV, ERRbadtype, NT_STATUS_PATH_NOT_COVERED},
8274bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_NO_CALLBACK_ACTIVE},
8284bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_LICENSE_QUOTA_EXCEEDED},
8294bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PWD_TOO_SHORT},
8304bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PWD_TOO_RECENT},
8314bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PWD_HISTORY_CONFLICT},
8324bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_PLUGPLAY_NO_DEVICE},
8334bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_UNSUPPORTED_COMPRESSION},
8344bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_HW_PROFILE},
8354bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_INVALID_PLUGPLAY_DEVICE_PATH},
836148c5f43SAlan Wright {ERRDOS, ERROR_INVALID_ORDINAL, NT_STATUS_DRIVER_ORDINAL_NOT_FOUND},
837148c5f43SAlan Wright {ERRDOS, ERROR_PROC_NOT_FOUND, NT_STATUS_DRIVER_ENTRYPOINT_NOT_FOUND},
838148c5f43SAlan Wright {ERRDOS, ERROR_NOT_OWNER, NT_STATUS_RESOURCE_NOT_OWNED},
8394bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_TOO_MANY_LINKS},
8404bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_QUOTA_LIST_INCONSISTENT},
8414bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_FILE_IS_OFFLINE},
842148c5f43SAlan Wright {ERRDOS, ERROR_NOT_READY, NT_STATUS_VOLUME_DISMOUNTED},
843148c5f43SAlan Wright {ERRDOS, ERROR_BAD_PATHNAME, NT_STATUS_DIRECTORY_IS_A_REPARSE_POINT},
8444bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_ENCRYPTION_FAILED},
8454bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_DECRYPTION_FAILED},
8464bff34e3Sthurlow {ERRHRD, ERRgeneral, NT_STATUS_RANGE_NOT_FOUND},
8474bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_NO_RECOVERY_POLICY},
8484bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_NO_EFS},
8494bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_WRONG_EFS},
8504bff34e3Sthurlow {ERRDOS, ERRnoaccess, NT_STATUS_NO_USER_KEYS},
8514bff34e3Sthurlow {ERRDOS, ERRbadfunc, NT_STATUS_VOLUME_NOT_UPGRADED},
852148c5f43SAlan Wright {0, 0, 0}
8534bff34e3Sthurlow };
8544bff34e3Sthurlow
855148c5f43SAlan Wright int
smb_maperr32(uint32_t nterr)856148c5f43SAlan Wright smb_maperr32(uint32_t nterr)
8574bff34e3Sthurlow {
858148c5f43SAlan Wright const nt2errno_t *nt2e;
859148c5f43SAlan Wright const nt2doserr_t *nt2d;
8604bff34e3Sthurlow
861148c5f43SAlan Wright switch (NT_SC_SEVERITY(nterr)) {
862148c5f43SAlan Wright case NT_STATUS_SEVERITY_SUCCESS:
863148c5f43SAlan Wright case NT_STATUS_SEVERITY_INFORMATIONAL:
8644bff34e3Sthurlow return (0);
865148c5f43SAlan Wright }
8664bff34e3Sthurlow
8674bff34e3Sthurlow /* first try direct map to unix */
868148c5f43SAlan Wright for (nt2e = nt2errno; nt2e->errno; nt2e++)
869148c5f43SAlan Wright if (nt2e->nterr == nterr)
870148c5f43SAlan Wright return (nt2e->errno);
871ae3d7f90SGordon Ross smb_errmsg(unknown_err_logpri, "smb_maperr32",
872ae3d7f90SGordon Ross "No direct map for 32 bit server error (0x%x)\n", nterr);
8734bff34e3Sthurlow
8744bff34e3Sthurlow /* ok, then try mapping to dos to unix */
875148c5f43SAlan Wright for (nt2d = nt2doserr; nt2d->nterr; nt2d++)
876148c5f43SAlan Wright if (nt2d->nterr == nterr)
877148c5f43SAlan Wright return (smb_maperror(nt2d->dclass, nt2d->derr));
878148c5f43SAlan Wright return (EIO);
8794bff34e3Sthurlow }
8804bff34e3Sthurlow
88140c0e231SGordon Ross uint_t
smb_doserr2status(int dclass,int derr)88240c0e231SGordon Ross smb_doserr2status(int dclass, int derr)
88340c0e231SGordon Ross {
88440c0e231SGordon Ross const nt2doserr_t *nt2d;
88540c0e231SGordon Ross
88640c0e231SGordon Ross if (dclass == 0 && derr == 0)
88740c0e231SGordon Ross return (0);
88840c0e231SGordon Ross
88940c0e231SGordon Ross for (nt2d = nt2doserr; nt2d->nterr; nt2d++)
89040c0e231SGordon Ross if (nt2d->dclass == dclass && nt2d->derr == derr)
89140c0e231SGordon Ross return (nt2d->nterr);
89240c0e231SGordon Ross return (NT_STATUS_UNSUCCESSFUL);
89340c0e231SGordon Ross }
8944bff34e3Sthurlow
8954bff34e3Sthurlow int
smb_maperror(int eclass,int eno)8964bff34e3Sthurlow smb_maperror(int eclass, int eno)
8974bff34e3Sthurlow {
8984bff34e3Sthurlow if (eclass == 0 && eno == 0)
8994bff34e3Sthurlow return (0);
9004bff34e3Sthurlow switch (eclass) {
9014bff34e3Sthurlow case ERRDOS:
9024bff34e3Sthurlow switch (eno) {
903148c5f43SAlan Wright case ERROR_INVALID_LEVEL:
90402d09e03SGordon Ross return (ENOTSUP);
9054bff34e3Sthurlow case ERRbadfunc:
9064bff34e3Sthurlow case ERRbadenv:
9074bff34e3Sthurlow case ERRbadformat:
9084bff34e3Sthurlow case ERRremcd:
9094bff34e3Sthurlow case ERRrmuns:
9104bff34e3Sthurlow return (EINVAL);
9114bff34e3Sthurlow case ERRbadfile:
9124bff34e3Sthurlow case ERRbadpath:
913148c5f43SAlan Wright case ERROR_BAD_DEV_TYPE:
914148c5f43SAlan Wright case ERROR_BAD_NET_NAME:
9154bff34e3Sthurlow return (ENOENT);
9164bff34e3Sthurlow case ERRnofids:
9174bff34e3Sthurlow return (EMFILE);
9184bff34e3Sthurlow case ERRnoaccess:
9194bff34e3Sthurlow /*
9204bff34e3Sthurlow * XXX CSM Reported on samba-technical 12/7/2002
9214bff34e3Sthurlow *
9224bff34e3Sthurlow * There is a case for which server(s) return
9234bff34e3Sthurlow * ERRnoaccess but should return ERRdiskfull: When
9244bff34e3Sthurlow * the offset for a write is exactly the server
9254bff34e3Sthurlow * file size limit then Samba (at least) thinks
9264bff34e3Sthurlow * the reason for zero bytes having been written
9274bff34e3Sthurlow * must have been "access denied" from the local
9284bff34e3Sthurlow * filesystem. This cannot be easily worked
9294bff34e3Sthurlow * around since the server behaviour is
9304bff34e3Sthurlow * indistinguishable from actual access denied.
9314bff34e3Sthurlow * An incomplete workaround: attempt a 2 byte write
9324bff34e3Sthurlow * from "offset-1". (That may require reading at
9334bff34e3Sthurlow * offset-1 first.) The flaw is that reading or
9344bff34e3Sthurlow * writing at offset-1 could cause an
9354bff34e3Sthurlow * unrelated error (due to a byte range lock
9364bff34e3Sthurlow * for instance) and we can't presume the
9374bff34e3Sthurlow * order servers check errors in.
9384bff34e3Sthurlow */
9394bff34e3Sthurlow case ERRbadaccess:
9404bff34e3Sthurlow return (EACCES);
9414bff34e3Sthurlow case ERRbadshare:
9424bff34e3Sthurlow return (EBUSY);
9434bff34e3Sthurlow case ERRbadfid:
9444bff34e3Sthurlow return (EBADF);
9454bff34e3Sthurlow case ERRbadmcb:
9464bff34e3Sthurlow return (EIO);
9474bff34e3Sthurlow case ERRnomem:
9484bff34e3Sthurlow return (ENOMEM); /* actually remote no mem... */
9494bff34e3Sthurlow case ERRbadmem:
9504bff34e3Sthurlow return (EFAULT);
9514bff34e3Sthurlow case ERRbaddata:
9524bff34e3Sthurlow return (E2BIG);
9534bff34e3Sthurlow case ERRbaddrive:
9544bff34e3Sthurlow case ERRnotready: /* nt */
9554bff34e3Sthurlow return (ENXIO);
9564bff34e3Sthurlow case ERRdiffdevice:
9574bff34e3Sthurlow return (EXDEV);
9584bff34e3Sthurlow case ERRnofiles:
9594bff34e3Sthurlow return (0); /* eeof ? */
9604bff34e3Sthurlow case ERRlock:
96102d09e03SGordon Ross return (EAGAIN);
9624bff34e3Sthurlow case ERRfilexists:
9634bff34e3Sthurlow return (EEXIST);
964148c5f43SAlan Wright case ERROR_INVALID_NAME:
9654bff34e3Sthurlow return (ENOENT);
966148c5f43SAlan Wright case ERROR_DIR_NOT_EMPTY:
9674bff34e3Sthurlow return (ENOTEMPTY);
968148c5f43SAlan Wright case ERROR_NOT_LOCKED:
969148c5f43SAlan Wright return (0); /* we unlock on any close */
970148c5f43SAlan Wright case ERROR_ALREADY_EXISTS:
9714bff34e3Sthurlow return (EEXIST);
9724bff34e3Sthurlow case ERRmoredata:
9734bff34e3Sthurlow return (EMOREDATA);
9744bff34e3Sthurlow }
9754bff34e3Sthurlow break;
9764bff34e3Sthurlow case ERRSRV:
9774bff34e3Sthurlow switch (eno) {
9784bff34e3Sthurlow case ERRerror:
9794bff34e3Sthurlow return (EINVAL);
9804bff34e3Sthurlow case ERRbadpw:
9814bff34e3Sthurlow return (EAUTH);
9824bff34e3Sthurlow case ERRaccess:
9834bff34e3Sthurlow case ERRbaduid:
9844bff34e3Sthurlow return (EACCES);
9854bff34e3Sthurlow case ERRinvnid:
9864bff34e3Sthurlow return (ENETRESET);
9874bff34e3Sthurlow case ERRinvnetname:
98802d09e03SGordon Ross return (ENXIO);
9894bff34e3Sthurlow case ERRbadtype: /* reserved and returned */
9904bff34e3Sthurlow return (EIO);
991148c5f43SAlan Wright case NERR_AccountExpired: /* account exists but disabled */
9924bff34e3Sthurlow return (EPERM);
9934bff34e3Sthurlow }
9944bff34e3Sthurlow break;
9954bff34e3Sthurlow case ERRHRD:
9964bff34e3Sthurlow switch (eno) {
9974bff34e3Sthurlow case ERRnowrite:
9984bff34e3Sthurlow return (EROFS);
9994bff34e3Sthurlow case ERRbadunit:
10004bff34e3Sthurlow return (ENODEV);
10014bff34e3Sthurlow case ERRbadreq:
10024bff34e3Sthurlow return (EBADRPC);
10034bff34e3Sthurlow case ERRbadshare:
10044bff34e3Sthurlow return (ETXTBSY);
10054bff34e3Sthurlow case ERRlock:
100602d09e03SGordon Ross return (EAGAIN);
10074bff34e3Sthurlow case ERRdiskfull:
10084bff34e3Sthurlow return (EFBIG);
10094bff34e3Sthurlow case ERRnotready:
10104bff34e3Sthurlow case ERRbadcmd:
10114bff34e3Sthurlow case ERRdata:
10124bff34e3Sthurlow case ERRgeneral:
10134bff34e3Sthurlow return (EIO);
10144bff34e3Sthurlow }
10154bff34e3Sthurlow }
1016ae3d7f90SGordon Ross
1017ae3d7f90SGordon Ross smb_errmsg(unknown_err_logpri, "smb_maperror",
1018ae3d7f90SGordon Ross "Unknown DOS error %d/%d\n", eclass, eno);
1019ae3d7f90SGordon Ross return (EIO);
10204bff34e3Sthurlow }
10214bff34e3Sthurlow
10224bff34e3Sthurlow #define SMALL_CONV 256
10234bff34e3Sthurlow
1024*adee6784SGordon Ross /*
1025*adee6784SGordon Ross * Decode an SMB OTW string (Unicode or OEM chars)
1026*adee6784SGordon Ross * converting to UTF-8 in the output buffer.
1027*adee6784SGordon Ross * outlen is in/out (max size on input)
1028*adee6784SGordon Ross * insize is the wire size (2 * chars if unicode)
1029*adee6784SGordon Ross * The output string is null terminated.
1030*adee6784SGordon Ross * Output length does not include the null.
1031*adee6784SGordon Ross */
1032*adee6784SGordon Ross int
smb_get_dstring(struct mdchain * mdc,struct smb_vc * vcp,char * outbuf,size_t * outlen,int insize)1033*adee6784SGordon Ross smb_get_dstring(struct mdchain *mdc, struct smb_vc *vcp,
1034*adee6784SGordon Ross char *outbuf, size_t *outlen, int insize)
1035*adee6784SGordon Ross {
1036*adee6784SGordon Ross uint16_t convbuf[SMALL_CONV];
1037*adee6784SGordon Ross uint16_t *cbuf;
1038*adee6784SGordon Ross size_t cbufalloc, inlen, outsize;
1039*adee6784SGordon Ross int error;
1040*adee6784SGordon Ross
1041*adee6784SGordon Ross if (insize <= 0)
1042*adee6784SGordon Ross return (0);
1043*adee6784SGordon Ross /* Note: inlen is UTF-16 symbols. */
1044*adee6784SGordon Ross inlen = insize / 2;
1045*adee6784SGordon Ross
1046*adee6784SGordon Ross if (*outlen < 2)
1047*adee6784SGordon Ross return (EINVAL);
1048*adee6784SGordon Ross outsize = *outlen - 1; /* room for null */
1049*adee6784SGordon Ross
1050*adee6784SGordon Ross /*
1051*adee6784SGordon Ross * Get a buffer for the conversion and fill it.
1052*adee6784SGordon Ross * Use stack buffer if the string is
1053*adee6784SGordon Ross * small enough, else allocate.
1054*adee6784SGordon Ross */
1055*adee6784SGordon Ross if (insize < sizeof (convbuf)) {
1056*adee6784SGordon Ross cbufalloc = 0;
1057*adee6784SGordon Ross cbuf = convbuf;
1058*adee6784SGordon Ross } else {
1059*adee6784SGordon Ross cbufalloc = insize + 2;
1060*adee6784SGordon Ross cbuf = kmem_alloc(cbufalloc, KM_SLEEP);
1061*adee6784SGordon Ross }
1062*adee6784SGordon Ross error = md_get_mem(mdc, cbuf, insize, MB_MSYSTEM);
1063*adee6784SGordon Ross if (error != 0)
1064*adee6784SGordon Ross goto out;
1065*adee6784SGordon Ross cbuf[inlen] = 0;
1066*adee6784SGordon Ross
1067*adee6784SGordon Ross /*
1068*adee6784SGordon Ross * Handle the easy case (non-unicode).
1069*adee6784SGordon Ross * XXX: Technically, we should convert
1070*adee6784SGordon Ross * the string to OEM codeset first...
1071*adee6784SGordon Ross * Modern servers all use Unicode, so
1072*adee6784SGordon Ross * this is good enough.
1073*adee6784SGordon Ross */
1074*adee6784SGordon Ross if (SMB_UNICODE_STRINGS(vcp) == 0) {
1075*adee6784SGordon Ross *outlen = strlcpy(outbuf, (char *)cbuf, outsize);
1076*adee6784SGordon Ross if (*outlen > outsize) {
1077*adee6784SGordon Ross *outlen = outsize;
1078*adee6784SGordon Ross error = E2BIG;
1079*adee6784SGordon Ross }
1080*adee6784SGordon Ross } else {
1081*adee6784SGordon Ross /*
1082*adee6784SGordon Ross * Convert from UTF-16 to UTF-8
1083*adee6784SGordon Ross */
1084*adee6784SGordon Ross error = uconv_u16tou8(cbuf, &inlen,
1085*adee6784SGordon Ross (uchar_t *)outbuf, outlen,
1086*adee6784SGordon Ross UCONV_IN_LITTLE_ENDIAN);
1087*adee6784SGordon Ross if (error == 0) {
1088*adee6784SGordon Ross outbuf[*outlen] = '\0';
1089*adee6784SGordon Ross }
1090*adee6784SGordon Ross }
1091*adee6784SGordon Ross
1092*adee6784SGordon Ross ASSERT(*outlen == strlen(outbuf));
1093*adee6784SGordon Ross
1094*adee6784SGordon Ross out:
1095*adee6784SGordon Ross if (cbufalloc != 0)
1096*adee6784SGordon Ross kmem_free(cbuf, cbufalloc);
1097*adee6784SGordon Ross
1098*adee6784SGordon Ross return (error);
1099*adee6784SGordon Ross }
1100*adee6784SGordon Ross
1101*adee6784SGordon Ross /*
1102*adee6784SGordon Ross * It's surprising that this function does utf8-ucs2 conversion.
1103*adee6784SGordon Ross * One would expect only smb_put_dstring to do that.
1104*adee6784SGordon Ross * Fixing that will require changing a bunch of callers. XXX
1105*adee6784SGordon Ross */
11064bff34e3Sthurlow /*ARGSUSED*/
11074bff34e3Sthurlow int
smb_put_dmem(struct mbchain * mbp,struct smb_vc * vcp,const char * src,int size,int caseopt,int * lenp)11084bff34e3Sthurlow smb_put_dmem(struct mbchain *mbp, struct smb_vc *vcp, const char *src,
11094bff34e3Sthurlow int size, int caseopt, int *lenp)
11104bff34e3Sthurlow {
11114bff34e3Sthurlow uint16_t convbuf[SMALL_CONV];
11124bff34e3Sthurlow uint16_t *cbuf;
11134bff34e3Sthurlow size_t cbufalloc, inlen, outlen;
11144bff34e3Sthurlow int error;
11154bff34e3Sthurlow
11164bff34e3Sthurlow if (size <= 0)
11174bff34e3Sthurlow return (0);
11184bff34e3Sthurlow
11194bff34e3Sthurlow /*
11204bff34e3Sthurlow * Handle the easy case (non-unicode).
11214bff34e3Sthurlow * XXX: Technically, we should convert
11224bff34e3Sthurlow * the string to OEM codeset first...
11234bff34e3Sthurlow * Modern servers all use Unicode, so
11244bff34e3Sthurlow * this is good enough.
11254bff34e3Sthurlow */
11264bff34e3Sthurlow if (SMB_UNICODE_STRINGS(vcp) == 0) {
11274bff34e3Sthurlow error = mb_put_mem(mbp, src, size, MB_MSYSTEM);
11284bff34e3Sthurlow if (!error && lenp)
11294bff34e3Sthurlow *lenp += size;
11304bff34e3Sthurlow return (error);
11314bff34e3Sthurlow }
11324bff34e3Sthurlow
11334bff34e3Sthurlow /*
11344bff34e3Sthurlow * Convert to UCS-2 (really UTF-16).
11354bff34e3Sthurlow * Use stack buffer if the string is
11364bff34e3Sthurlow * small enough, else allocate.
11374bff34e3Sthurlow */
11384bff34e3Sthurlow if (size <= SMALL_CONV) {
11394bff34e3Sthurlow cbufalloc = 0;
11404bff34e3Sthurlow outlen = SMALL_CONV;
11414bff34e3Sthurlow cbuf = convbuf;
11424bff34e3Sthurlow } else {
11434bff34e3Sthurlow outlen = size; /* in utf-16 characters */
11444bff34e3Sthurlow cbufalloc = outlen * 2;
11454bff34e3Sthurlow cbuf = kmem_alloc(cbufalloc, KM_SLEEP);
11464bff34e3Sthurlow }
11474bff34e3Sthurlow
11484bff34e3Sthurlow inlen = size;
11494bff34e3Sthurlow error = uconv_u8tou16((uchar_t *)src, &inlen, cbuf, &outlen,
11504bff34e3Sthurlow UCONV_OUT_LITTLE_ENDIAN | UCONV_IGNORE_NULL);
11514bff34e3Sthurlow outlen *= 2; /* convert to bytes */
11524bff34e3Sthurlow
11534bff34e3Sthurlow if (!error) {
11544bff34e3Sthurlow (void) mb_put_padbyte(mbp); /* align */
11554bff34e3Sthurlow error = mb_put_mem(mbp, (char *)cbuf, outlen, MB_MSYSTEM);
11564bff34e3Sthurlow }
11574bff34e3Sthurlow if (!error && lenp)
11584bff34e3Sthurlow *lenp += outlen;
11594bff34e3Sthurlow
11604bff34e3Sthurlow if (cbufalloc)
11614bff34e3Sthurlow kmem_free(cbuf, cbufalloc);
11624bff34e3Sthurlow
11634bff34e3Sthurlow return (error);
11644bff34e3Sthurlow }
11654bff34e3Sthurlow
11664bff34e3Sthurlow int
smb_put_dstring(struct mbchain * mbp,struct smb_vc * vcp,const char * src,int caseopt)11674bff34e3Sthurlow smb_put_dstring(struct mbchain *mbp, struct smb_vc *vcp, const char *src,
11684bff34e3Sthurlow int caseopt)
11694bff34e3Sthurlow {
11704bff34e3Sthurlow int error, len;
11714bff34e3Sthurlow
11724bff34e3Sthurlow /*
11734bff34e3Sthurlow * Let smb_put_dmem put both the string
11744bff34e3Sthurlow * and the terminating null.
11754bff34e3Sthurlow */
11764bff34e3Sthurlow len = strlen(src) + 1;
11774bff34e3Sthurlow error = smb_put_dmem(mbp, vcp, src, len, caseopt, NULL);
11784bff34e3Sthurlow if (error)
11794bff34e3Sthurlow return (error);
11804bff34e3Sthurlow
11814bff34e3Sthurlow return (error);
11824bff34e3Sthurlow }
1183*adee6784SGordon Ross 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)1184*adee6784SGordon Ross smb_smb_ntcreate(struct smb_share *ssp, struct mbchain *name_mb,
1185*adee6784SGordon Ross uint32_t crflag, uint32_t req_acc, uint32_t efa, uint32_t sh_acc,
1186*adee6784SGordon Ross uint32_t disp, uint32_t createopt, uint32_t impersonate,
1187*adee6784SGordon Ross struct smb_cred *scrp, smb_fh_t *fhp,
1188*adee6784SGordon Ross uint32_t *cr_act_p, struct smbfattr *fap)
1189*adee6784SGordon Ross {
1190*adee6784SGordon Ross int err;
1191*adee6784SGordon Ross
1192*adee6784SGordon Ross if (SSTOVC(ssp)->vc_flags & SMBV_SMB2) {
1193*adee6784SGordon Ross err = smb2_smb_ntcreate(ssp, name_mb, NULL, NULL,
1194*adee6784SGordon Ross crflag, req_acc, efa, sh_acc, disp, createopt,
1195*adee6784SGordon Ross impersonate, scrp, &fhp->fh_fid2, cr_act_p, fap);
1196*adee6784SGordon Ross } else {
1197*adee6784SGordon Ross err = smb1_smb_ntcreate(ssp, name_mb, crflag, req_acc,
1198*adee6784SGordon Ross efa, sh_acc, disp, createopt, impersonate, scrp,
1199*adee6784SGordon Ross &fhp->fh_fid1, cr_act_p, fap);
1200*adee6784SGordon Ross }
1201*adee6784SGordon Ross return (err);
1202*adee6784SGordon Ross }
1203*adee6784SGordon Ross
1204*adee6784SGordon Ross int
smb_smb_close(struct smb_share * ssp,smb_fh_t * fhp,struct smb_cred * scrp)1205*adee6784SGordon Ross smb_smb_close(struct smb_share *ssp, smb_fh_t *fhp,
1206*adee6784SGordon Ross struct smb_cred *scrp)
1207*adee6784SGordon Ross {
1208*adee6784SGordon Ross int err;
1209*adee6784SGordon Ross
1210*adee6784SGordon Ross if (SSTOVC(ssp)->vc_flags & SMBV_SMB2) {
1211*adee6784SGordon Ross err = smb2_smb_close(ssp, &fhp->fh_fid2, scrp);
1212*adee6784SGordon Ross } else {
1213*adee6784SGordon Ross err = smb1_smb_close(ssp, fhp->fh_fid1, NULL, scrp);
1214*adee6784SGordon Ross }
1215*adee6784SGordon Ross
1216*adee6784SGordon Ross return (err);
1217*adee6784SGordon Ross }
1218*adee6784SGordon Ross
1219*adee6784SGordon Ross /*
1220*adee6784SGordon Ross * Largest size to use with LARGE_READ/LARGE_WRITE.
1221*adee6784SGordon Ross * Specs say up to 64k data bytes, but Windows traffic
1222*adee6784SGordon Ross * uses 60k... no doubt for some good reason.
1223*adee6784SGordon Ross * (Probably to keep 4k block alignment.)
1224*adee6784SGordon Ross */
1225*adee6784SGordon Ross uint32_t smb1_large_io_max = (60*1024);
1226*adee6784SGordon Ross
1227*adee6784SGordon Ross /*
1228*adee6784SGordon Ross * Common function for read/write with UIO.
1229*adee6784SGordon Ross * Called by netsmb smb_usr_rw,
1230*adee6784SGordon Ross * smbfs_readvnode, smbfs_writevnode
1231*adee6784SGordon Ross */
1232*adee6784SGordon Ross int
smb_rwuio(smb_fh_t * fhp,uio_rw_t rw,uio_t * uiop,smb_cred_t * scred,int timo)1233*adee6784SGordon Ross smb_rwuio(smb_fh_t *fhp, uio_rw_t rw,
1234*adee6784SGordon Ross uio_t *uiop, smb_cred_t *scred, int timo)
1235*adee6784SGordon Ross {
1236*adee6784SGordon Ross struct smb_share *ssp = FHTOSS(fhp);
1237*adee6784SGordon Ross struct smb_vc *vcp = SSTOVC(ssp);
1238*adee6784SGordon Ross ssize_t save_resid;
1239*adee6784SGordon Ross uint32_t len, rlen, maxlen;
1240*adee6784SGordon Ross int error = 0;
1241*adee6784SGordon Ross int (*iofun)(smb_fh_t *, uint32_t *,
1242*adee6784SGordon Ross uio_t *, smb_cred_t *, int);
1243*adee6784SGordon Ross
1244*adee6784SGordon Ross /* After reconnect, the fid is invalid. */
1245*adee6784SGordon Ross if (fhp->fh_vcgenid != ssp->ss_vcgenid)
1246*adee6784SGordon Ross return (ESTALE);
1247*adee6784SGordon Ross
1248*adee6784SGordon Ross if (SSTOVC(ssp)->vc_flags & SMBV_SMB2) {
1249*adee6784SGordon Ross if (rw == UIO_READ) {
1250*adee6784SGordon Ross iofun = smb2_smb_read;
1251*adee6784SGordon Ross maxlen = vcp->vc_sopt.sv2_maxread;
1252*adee6784SGordon Ross } else { /* UIO_WRITE */
1253*adee6784SGordon Ross iofun = smb2_smb_write;
1254*adee6784SGordon Ross maxlen = vcp->vc_sopt.sv2_maxwrite;
1255*adee6784SGordon Ross }
1256*adee6784SGordon Ross } else {
1257*adee6784SGordon Ross /*
1258*adee6784SGordon Ross * Using NT LM 0.12, so readx, writex.
1259*adee6784SGordon Ross * Make sure we can represent the offset.
1260*adee6784SGordon Ross */
1261*adee6784SGordon Ross if ((vcp->vc_sopt.sv_caps & SMB_CAP_LARGE_FILES) == 0 &&
1262*adee6784SGordon Ross (uiop->uio_loffset + uiop->uio_resid) > UINT32_MAX)
1263*adee6784SGordon Ross return (EFBIG);
1264*adee6784SGordon Ross
1265*adee6784SGordon Ross if (rw == UIO_READ) {
1266*adee6784SGordon Ross iofun = smb_smb_readx;
1267*adee6784SGordon Ross if (vcp->vc_sopt.sv_caps & SMB_CAP_LARGE_READX)
1268*adee6784SGordon Ross maxlen = smb1_large_io_max;
1269*adee6784SGordon Ross else
1270*adee6784SGordon Ross maxlen = vcp->vc_rxmax;
1271*adee6784SGordon Ross } else { /* UIO_WRITE */
1272*adee6784SGordon Ross iofun = smb_smb_writex;
1273*adee6784SGordon Ross if (vcp->vc_sopt.sv_caps & SMB_CAP_LARGE_WRITEX)
1274*adee6784SGordon Ross maxlen = smb1_large_io_max;
1275*adee6784SGordon Ross else
1276*adee6784SGordon Ross maxlen = vcp->vc_wxmax;
1277*adee6784SGordon Ross }
1278*adee6784SGordon Ross }
1279*adee6784SGordon Ross
1280*adee6784SGordon Ross save_resid = uiop->uio_resid;
1281*adee6784SGordon Ross while (uiop->uio_resid > 0) {
1282*adee6784SGordon Ross /* Lint: uio_resid may be 64-bits */
1283*adee6784SGordon Ross rlen = len = (uint32_t)min(maxlen, uiop->uio_resid);
1284*adee6784SGordon Ross error = (*iofun)(fhp, &rlen, uiop, scred, timo);
1285*adee6784SGordon Ross
1286*adee6784SGordon Ross /*
1287*adee6784SGordon Ross * Note: the iofun called uio_update, so
1288*adee6784SGordon Ross * not doing that here as one might expect.
1289*adee6784SGordon Ross *
1290*adee6784SGordon Ross * Quit the loop either on error, or if we
1291*adee6784SGordon Ross * transferred less then requested.
1292*adee6784SGordon Ross */
1293*adee6784SGordon Ross if (error || (rlen < len))
1294*adee6784SGordon Ross break;
1295*adee6784SGordon Ross
1296*adee6784SGordon Ross timo = 0; /* only first I/O should wait */
1297*adee6784SGordon Ross }
1298*adee6784SGordon Ross if (error && (save_resid != uiop->uio_resid)) {
1299*adee6784SGordon Ross /*
1300*adee6784SGordon Ross * Stopped on an error after having
1301*adee6784SGordon Ross * successfully transferred data.
1302*adee6784SGordon Ross * Suppress this error.
1303*adee6784SGordon Ross */
1304*adee6784SGordon Ross SMBSDEBUG("error %d suppressed\n", error);
1305*adee6784SGordon Ross error = 0;
1306*adee6784SGordon Ross }
1307*adee6784SGordon Ross
1308*adee6784SGordon Ross return (error);
1309*adee6784SGordon Ross }
1310