annotate usr/src/uts/common/fs/smbclnt/netsmb/smb_trantcp.h @ 13595:565bd3085959

2041 panic in nsmb_close Reviewed by: Dan McDonald <danmcd@nexenta.com> Reviewed by: Richard Elling <richard.elling@richardelling.com> Reviewed by: Robert Mustacchi <rm@joyent.com> Approved by: Garrett D'Amore <garrett@damore.org>
author Gordon Ross <gwr@nexenta.com>
date Sat, 04 Feb 2012 15:55:57 -0500
parents d57e38e8fdd1
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
6007
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
1 /*
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
2 * Copyright (c) 2000-2001, Boris Popov
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
3 * All rights reserved.
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
4 *
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
5 * Redistribution and use in source and binary forms, with or without
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
6 * modification, are permitted provided that the following conditions
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
7 * are met:
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
8 * 1. Redistributions of source code must retain the above copyright
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
9 * notice, this list of conditions and the following disclaimer.
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
10 * 2. Redistributions in binary form must reproduce the above copyright
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
11 * notice, this list of conditions and the following disclaimer in the
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
12 * documentation and/or other materials provided with the distribution.
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
13 * 3. All advertising materials mentioning features or use of this software
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
14 * must display the following acknowledgement:
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
15 * This product includes software developed by Boris Popov.
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
16 * 4. Neither the name of the author nor the names of any co-contributors
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
17 * may be used to endorse or promote products derived from this software
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
18 * without specific prior written permission.
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
19 *
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
20 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
21 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
22 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
23 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
24 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
25 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
26 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
27 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
28 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
29 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
30 * SUCH DAMAGE.
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
31 *
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
32 * $Id: smb_trantcp.h,v 1.8 2004/08/03 23:50:01 lindak Exp $
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
33 */
13595
565bd3085959 2041 panic in nsmb_close
Gordon Ross <gwr@nexenta.com>
parents: 6007
diff changeset
34 /*
565bd3085959 2041 panic in nsmb_close
Gordon Ross <gwr@nexenta.com>
parents: 6007
diff changeset
35 * Copyright 2012 Nexenta Systems, Inc. All rights reserved.
565bd3085959 2041 panic in nsmb_close
Gordon Ross <gwr@nexenta.com>
parents: 6007
diff changeset
36 */
6007
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
37 #ifndef _NETSMB_SMB_TRANTCP_H_
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
38 #define _NETSMB_SMB_TRANTCP_H_
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
39
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
40 enum nbstate {
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
41 NBST_CLOSED,
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
42 NBST_RQSENT,
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
43 NBST_SESSION,
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
44 NBST_RETARGET,
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
45 NBST_REFUSED
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
46 };
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
47
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
48
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
49 /*
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
50 * socket specific data
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
51 */
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
52 struct nbpcb {
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
53 struct smb_vc *nbp_vc;
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
54 struct tiuser *nbp_tiptr; /* KTLI transport handle... */
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
55 mblk_t *nbp_frag; /* left-over from last recv */
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
56
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
57 struct sockaddr_nb *nbp_laddr; /* local address */
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
58 struct sockaddr_nb *nbp_paddr; /* peer address */
13595
565bd3085959 2041 panic in nsmb_close
Gordon Ross <gwr@nexenta.com>
parents: 6007
diff changeset
59 void *nbp_selectid;
565bd3085959 2041 panic in nsmb_close
Gordon Ross <gwr@nexenta.com>
parents: 6007
diff changeset
60 cred_t *nbp_cred;
6007
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
61
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
62 int nbp_flags;
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
63 #define NBF_LOCADDR 0x0001 /* has local addr */
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
64 #define NBF_CONNECTED 0x0002
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
65 #define NBF_RECVLOCK 0x0004
13595
565bd3085959 2041 panic in nsmb_close
Gordon Ross <gwr@nexenta.com>
parents: 6007
diff changeset
66 #define NBF_SENDLOCK 0x0008
565bd3085959 2041 panic in nsmb_close
Gordon Ross <gwr@nexenta.com>
parents: 6007
diff changeset
67 #define NBF_LOCKWAIT 0x0010
6007
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
68
13595
565bd3085959 2041 panic in nsmb_close
Gordon Ross <gwr@nexenta.com>
parents: 6007
diff changeset
69 ushort_t nbp_fmode;
6007
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
70 enum nbstate nbp_state;
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
71 struct timespec nbp_timo;
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
72 int nbp_sndbuf;
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
73 int nbp_rcvbuf;
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
74 kmutex_t nbp_lock;
13595
565bd3085959 2041 panic in nsmb_close
Gordon Ross <gwr@nexenta.com>
parents: 6007
diff changeset
75 kcondvar_t nbp_cv;
6007
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
76 };
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
77 typedef struct nbpcb nbpcb_t;
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
78
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
79 /*
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
80 * Nominal space allocated per a NETBIOS socket.
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
81 */
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
82 #define NB_SNDQ (10 * 1024)
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
83 #define NB_RCVQ (20 * 1024)
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
84
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
85 /*
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
86 * TCP slowstart presents a problem in conjunction with large
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
87 * reads. To ensure a steady stream of ACKs while reading using
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
88 * large transaction sizes, we call soreceive() with a smaller
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
89 * buffer size. See nbssn_recv().
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
90 */
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
91 #define NB_SORECEIVE_CHUNK (8 * 1024)
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
92
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
93 #define SMBSBTIMO 15 /* seconds for sockbuf timeouts */
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
94
d57e38e8fdd1 PSARC 2005/695 CIFS Client on Solaris
thurlow
parents:
diff changeset
95 #endif /* !_NETSMB_SMB_TRANTCP_H_ */