2 * Copyright (c) 2000-2001, Boris Popov
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
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.
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
32 * $Id: smb_rq.h,v 1.9 2005/01/22 22:20:58 lindak Exp $
36 * Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.
39 #ifndef _NETSMB_SMB_RQ_H_
40 #define _NETSMB_SMB_RQ_H_
42 #include <netsmb/mchain.h>
43 #include <sys/queue.h>
45 #define SMBR_ALLOCED 0x0001 /* structure was malloced */
46 #define SMBR_SENT 0x0002 /* request successfully transmitted */
47 #define SMBR_REXMIT 0x0004 /* request should be retransmitted */
48 #define SMBR_INTR 0x0008 /* request interrupted */
49 #define SMBR_RESTART 0x0010 /* req should be repeated if possible */
50 #define SMBR_NORESTART 0x0020 /* request is not restartable */
51 #define SMBR_MULTIPACKET 0x0040 /* multiple pkts can be sent/received */
52 #define SMBR_INTERNAL 0x0080 /* request enqueued by the IOD! */
53 #define SMBR_NOINTR_SEND 0x0100 /* no interrupt in send wait */
54 #define SMBR_NOINTR_RECV 0x0200 /* no interrupt in recv wait */
55 #define SMBR_SENDWAIT 0x0400 /* waiting for send to complete */
56 #define SMBR_NORECONNECT 0x0800 /* do not reconnect for this */
57 /* SMBR_VCREF 0x4000 * took vc reference (obsolete) */
58 #define SMBR_MOREDATA 0x8000 /* our buffer was too small */
60 #define SMBT2_ALLSENT 0x0001 /* all data and params are sent */
61 #define SMBT2_ALLRECV 0x0002 /* all data and params are received */
62 #define SMBT2_ALLOCED 0x0004
63 #define SMBT2_RESTART 0x0008
64 #define SMBT2_NORESTART 0x0010
65 #define SMBT2_MOREDATA 0x8000 /* our buffer was too small */
67 #define SMBRQ_LOCK(rqp) mutex_enter(&(rqp)->sr_lock)
68 #define SMBRQ_UNLOCK(rqp) mutex_exit(&(rqp)->sr_lock)
71 SMBRQ_NOTSENT
, /* rq have data to send */
72 SMBRQ_SENT
, /* send procedure completed */
74 SMBRQ_NOTIFIED
/* owner notified about completion */
80 TAILQ_ENTRY(smb_rq
) sr_link
;
83 enum smbrq_state sr_state
;
85 struct smb_share
*sr_share
;
86 struct _kthread
*sr_owner
;
87 uint32_t sr_seqno
; /* Seq. no. of request */
88 uint32_t sr_rseqno
; /* Seq. no. of reply */
102 int sr_flags
; /* SMBR_* */
104 struct smb_cred
*sr_cred
;
106 int sr_rexmit
; /* how many more retries. dflt 0 */
108 struct timespec sr_timesent
;
114 uint16_t sr_rpflags2
;
120 typedef struct smb_rq smb_rq_t
;
125 uint16_t t2_setupcount
;
126 uint16_t *t2_setupdata
;
127 uint16_t t2_setup
[SMBIOC_T2RQ_MAXSETUP
];
128 uint8_t t2_maxscount
; /* max setup words to return */
129 uint16_t t2_maxpcount
; /* max param bytes to return */
130 uint16_t t2_maxdcount
; /* max data bytes to return */
131 uint16_t t2_fid
; /* for T2 request */
132 char *t_name
; /* for T, must be NULL for T2 */
133 int t_name_len
; /* t_name string length */
134 int t_name_maxlen
; /* t_name allocated size */
135 int t2_flags
; /* SMBT2_ */
136 struct mbchain t2_tparam
; /* parameters to transmit */
137 struct mbchain t2_tdata
; /* data to transmit */
138 struct mdchain t2_rparam
; /* received paramters */
139 struct mdchain t2_rdata
; /* received data */
140 struct smb_cred
*t2_cred
;
141 struct smb_connobj
*t2_source
;
142 struct smb_rq
*t2_rq
;
143 struct smb_vc
*t2_vc
;
144 struct smb_share
*t2_share
; /* for smb up/down */
145 /* unmapped windows error detail */
146 uint8_t t2_sr_errclass
;
147 uint16_t t2_sr_serror
;
148 uint32_t t2_sr_error
;
149 uint16_t t2_sr_rpflags2
;
151 typedef struct smb_t2rq smb_t2rq_t
;
156 uint16_t nt_function
;
157 uint8_t nt_maxscount
; /* max setup words to return */
158 uint32_t nt_maxpcount
; /* max param bytes to return */
159 uint32_t nt_maxdcount
; /* max data bytes to return */
160 int nt_flags
; /* SMBT2_ */
161 struct mbchain nt_tsetup
; /* setup to transmit */
162 struct mbchain nt_tparam
; /* parameters to transmit */
163 struct mbchain nt_tdata
; /* data to transmit */
164 struct mdchain nt_rparam
; /* received paramters */
165 struct mdchain nt_rdata
; /* received data */
166 struct smb_cred
*nt_cred
;
167 struct smb_connobj
*nt_source
;
168 struct smb_rq
*nt_rq
;
169 struct smb_vc
*nt_vc
;
170 struct smb_share
*nt_share
; /* for smb up/down */
171 /* unmapped windows error details */
172 uint32_t nt_sr_error
;
173 uint16_t nt_sr_rpflags2
;
175 typedef struct smb_ntrq smb_ntrq_t
;
177 #define smb_rq_getrequest(RQ, MBPP) \
178 *(MBPP) = &(RQ)->sr_rq
179 #define smb_rq_getreply(RQ, MDPP) \
180 *(MDPP) = &(RQ)->sr_rp
182 void smb_rq_done(struct smb_rq
*rqp
);
183 int smb_rq_alloc(struct smb_connobj
*layer
, uchar_t cmd
,
184 struct smb_cred
*scred
, struct smb_rq
**rqpp
);
185 int smb_rq_init(struct smb_rq
*rqp
, struct smb_connobj
*layer
,
186 uchar_t cmd
, struct smb_cred
*scred
);
188 void smb_rq_fillhdr(struct smb_rq
*rqp
);
189 void smb_rq_wstart(struct smb_rq
*rqp
);
190 void smb_rq_wend(struct smb_rq
*rqp
);
191 void smb_rq_bstart(struct smb_rq
*rqp
);
192 void smb_rq_bend(struct smb_rq
*rqp
);
193 int smb_rq_intr(struct smb_rq
*rqp
);
194 int smb_rq_simple(struct smb_rq
*rqp
);
195 int smb_rq_simple_timed(struct smb_rq
*rqp
, int timeout
);
197 int smb_t2_alloc(struct smb_connobj
*layer
, ushort_t setup
,
198 struct smb_cred
*scred
, struct smb_t2rq
**rqpp
);
199 int smb_t2_init(struct smb_t2rq
*rqp
, struct smb_connobj
*layer
,
200 ushort_t
*setup
, int setupcnt
, struct smb_cred
*scred
);
201 void smb_t2_done(struct smb_t2rq
*t2p
);
202 int smb_t2_request(struct smb_t2rq
*t2p
);
204 int smb_nt_alloc(struct smb_connobj
*layer
, ushort_t fn
,
205 struct smb_cred
*scred
, struct smb_ntrq
**rqpp
);
206 int smb_nt_init(struct smb_ntrq
*rqp
, struct smb_connobj
*layer
,
207 ushort_t fn
, struct smb_cred
*scred
);
208 void smb_nt_done(struct smb_ntrq
*ntp
);
209 int smb_nt_request(struct smb_ntrq
*ntp
);
211 #endif /* _NETSMB_SMB_RQ_H_ */