smb_kproto.h revision 6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2e
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * CDDL HEADER START
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * The contents of this file are subject to the terms of the
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * Common Development and Distribution License (the "License").
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * You may not use this file except in compliance with the License.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * See the License for the specific language governing permissions
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * and limitations under the License.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * When distributing Covered Code, include this CDDL HEADER in each
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * If applicable, add the following below this CDDL HEADER, with the
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * fields enclosed by brackets "[]" replaced with your own identifying
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * information: Portions Copyright [yyyy] [name of copyright owner]
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * CDDL HEADER END
dc20a3024900c47dd2ee44b9707e6df38f7d62a5as * Copyright 2008 Sun Microsystems, Inc. All rights reserved.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * Use is subject to license terms.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * Function prototypes for the SMB module.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw#pragma ident "%Z%%M% %I% %E% SMI"
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwextern "C" {
faa1795a28a5c712eed6d0a3f84d98c368a316c6jb#define smb_gmt2local(_sr_, _gmt_) ((_gmt_) + (_sr_)->sr_gmtoff)
faa1795a28a5c712eed6d0a3f84d98c368a316c6jb#define smb_local2gmt(_sr_, _local_) ((_local_) - (_sr_)->sr_gmtoff)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * Definitions that should be elsewhere...
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw/* Why? uint32_t inet_addr(char *str); */
7b59d02d2a384be9a08087b14defadd214b3c1ddjb * SMB request handers called from the dispatcher.
faa1795a28a5c712eed6d0a3f84d98c368a316c6jb smb_sdrc_t smb_pre_##NAME(smb_request_t *, smb_xa_t *); \
7b59d02d2a384be9a08087b14defadd214b3c1ddjbsmb_sdrc_t smb_nt_transact_notify_change(struct smb_request *, struct smb_xa *);
7b59d02d2a384be9a08087b14defadd214b3c1ddjbsmb_sdrc_t smb_nt_transact_query_security_info(struct smb_request *,
7b59d02d2a384be9a08087b14defadd214b3c1ddjb struct smb_xa *);
7b59d02d2a384be9a08087b14defadd214b3c1ddjbsmb_sdrc_t smb_nt_transact_set_security_info(struct smb_request *,
7b59d02d2a384be9a08087b14defadd214b3c1ddjb struct smb_xa *);
7b59d02d2a384be9a08087b14defadd214b3c1ddjbsmb_sdrc_t smb_nt_transact_ioctl(struct smb_request *, struct smb_xa *);
7b59d02d2a384be9a08087b14defadd214b3c1ddjbsmb_sdrc_t smb_com_trans2_create_directory(struct smb_request *,
7b59d02d2a384be9a08087b14defadd214b3c1ddjb struct smb_xa *);
7b59d02d2a384be9a08087b14defadd214b3c1ddjbsmb_sdrc_t smb_com_trans2_find_first2(struct smb_request *, struct smb_xa *);
7b59d02d2a384be9a08087b14defadd214b3c1ddjbsmb_sdrc_t smb_com_trans2_find_next2(struct smb_request *, struct smb_xa *);
7b59d02d2a384be9a08087b14defadd214b3c1ddjbsmb_sdrc_t smb_com_trans2_query_fs_information(struct smb_request *,
7b59d02d2a384be9a08087b14defadd214b3c1ddjb struct smb_xa *);
7b59d02d2a384be9a08087b14defadd214b3c1ddjbsmb_sdrc_t smb_com_trans2_query_path_information(struct smb_request *,
7b59d02d2a384be9a08087b14defadd214b3c1ddjb struct smb_xa *);
7b59d02d2a384be9a08087b14defadd214b3c1ddjbsmb_sdrc_t smb_com_trans2_query_file_information(struct smb_request *,
7b59d02d2a384be9a08087b14defadd214b3c1ddjb struct smb_xa *);
7b59d02d2a384be9a08087b14defadd214b3c1ddjbsmb_sdrc_t smb_com_trans2_set_path_information(struct smb_request *,
7b59d02d2a384be9a08087b14defadd214b3c1ddjb struct smb_xa *);
7b59d02d2a384be9a08087b14defadd214b3c1ddjbsmb_sdrc_t smb_com_trans2_set_file_information(struct smb_request *,
7b59d02d2a384be9a08087b14defadd214b3c1ddjb struct smb_xa *);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * Logging functions
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_correct_keep_alive_values(uint32_t new_keep_alive);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_session_send(smb_session_t *, uint8_t type, struct mbuf_chain *);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_session_xprt_gethdr(smb_session_t *, smb_xprt_t *);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_process_file_notify_change_queue(struct smb_ofile *of);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw unsigned int level_requested,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw unsigned int *level_granted);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwDWORD smb_break_oplock(struct smb_request *sr, struct smb_node *node);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_release_oplock(struct smb_ofile *file, int reason);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwuint32_t smb_unlock_range(struct smb_request *, struct smb_node *,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easuint32_t smb_lock_range(smb_request_t *, uint64_t, uint64_t, uint32_t,
dc20a3024900c47dd2ee44b9707e6df38f7d62a5asDWORD smb_range_check(smb_request_t *, cred_t *, smb_node_t *,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_mangle_name(ino64_t fileid, char *name, char *shortname,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_unmangle_name(struct smb_request *sr, cred_t *cred,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw smb_node_t *dir_node, char *name, char *real_name, int realname_size,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_maybe_mangled_path(const char *path, size_t pathlen);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_ascii_or_unicode_strlen(struct smb_request *, char *);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_ascii_or_unicode_strlen_null(struct smb_request *, char *);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_rdir_open(struct smb_request *, char *, unsigned short);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwDWORD smb_validate_object_name(char *path, unsigned int ftype);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smbsr_decode_vwv(struct smb_request *sr, char *fmt, ...);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smbsr_decode_data(struct smb_request *sr, char *fmt, ...);
7b59d02d2a384be9a08087b14defadd214b3c1ddjbint smbsr_encode_result(struct smb_request *, int, int, char *, ...);
dc20a3024900c47dd2ee44b9707e6df38f7d62a5asvoid smbsr_warn(struct smb_request *, DWORD, uint16_t, uint16_t);
dc20a3024900c47dd2ee44b9707e6df38f7d62a5asvoid smbsr_error(struct smb_request *, DWORD, uint16_t, uint16_t);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_mbc_encode(struct mbuf_chain *mbc, char *fmt, va_list ap);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_mbc_decode(struct mbuf_chain *mbc, char *fmt, va_list ap);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint dosfs_ux_to_dos_time(int, short int *, short int *);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_decode_mbc(struct mbuf_chain *mbc, char *fmt, ...);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_decode_buf(unsigned char *buf, int n_buf, char *fmt, ...);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_encode_mbc(struct mbuf_chain *mbc, char *fmt, ...);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_encode_buf(unsigned char *buf, int n_buf, char *fmt, ...);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_peek_mbc(struct mbuf_chain *buf, int offset, char *fmt, ...);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_poke_mbc(struct mbuf_chain *buf, int offset, char *fmt, ...);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smbsr_encode_header(struct smb_request *sr, int wct,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_od_destruct(struct smb_session *, struct smb_odir *);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smbd_fs_query(struct smb_request *, struct smb_fqi *, int);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_component_match(struct smb_request *sr, ino64_t fileid,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_lock_range_access(struct smb_request *, struct smb_node *,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * Socket functions
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwstruct sonode *smb_socreate(int domain, int type, int protocol);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_sorecv(struct sonode *so, void *msg, size_t len);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_iov_sorecv(struct sonode *so, iovec_t *iop, int iovlen,
5cdbe942b031cac50f4252efc4371b15d624fcd1jbint smb_net_txb_send(struct sonode *, smb_txlst_t *, smb_txbuf_t *);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * SMB RPC interface
7b59d02d2a384be9a08087b14defadd214b3c1ddjbsmb_sdrc_t smb_rpc_transact(struct smb_request *, struct uio *);
faa1795a28a5c712eed6d0a3f84d98c368a316c6jb * SMB server functions (file smb_server.c)
faa1795a28a5c712eed6d0a3f84d98c368a316c6jbint smb_server_share_unexport(char *, char *);
faa1795a28a5c712eed6d0a3f84d98c368a316c6jbvoid smb_server_reconnection_check(smb_server_t *, smb_session_t *);
faa1795a28a5c712eed6d0a3f84d98c368a316c6jbvoid smb_server_get_cfg(smb_server_t *, smb_kmod_cfg_t *);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * SMB node functions (file smb_node.c)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwstruct smb_node *smb_node_lookup(struct smb_request *sr, struct open_param *op,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw cred_t *cr, vnode_t *vp, char *od_name, smb_node_t *dir_snode,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwstruct smb_node *smb_stream_node_lookup(struct smb_request *sr, cred_t *cr,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw smb_node_t *fnode, vnode_t *xattrdirvp, vnode_t *vp, char *stream_name,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_node_assert(smb_node_t *node, const char *file, int line);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_node_rename(smb_node_t *from_dir_snode, smb_node_t *ret_snode,
faa1795a28a5c712eed6d0a3f84d98c368a316c6jbint smb_node_root_init(vnode_t *, smb_server_t *, smb_node_t **);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_node_add_lock(smb_node_t *node, smb_lock_t *lock);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_node_destroy_lock(smb_node_t *node, smb_lock_t *lock);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_node_destroy_lock_by_ofile(smb_node_t *node, smb_ofile_t *file);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_node_set_time(struct smb_node *node, timestruc_t *crtime,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_node_set_delete_on_close(smb_node_t *, cred_t *);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * Pathname functions
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw const char *, smb_node_t *, smb_node_t *, smb_node_t **, char *);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_pathname(struct smb_request *, char *, int, smb_node_t *,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * smb_vfs functions
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * String manipulation function
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_encode_stream_info(struct smb_request *sr, struct smb_xa *xa,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw/* NOTIFY CHANGE */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_process_session_notify_change_queue(struct smb_session *session);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_process_node_notify_change_queue(struct smb_node *node);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_reply_specific_cancel_request(struct smb_request *sr);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_try_grow(struct smb_request *sr, int64_t new_size);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw/* functions from smb_memory_manager.c */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwunsigned short smb_worker_getnum();
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_common_close(struct smb_request *sr, uint32_t last_wtime);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_stream_parse_name(char *name, char *u_stream_name,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw/* SMB signing routines smb_signing.c */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw smb_session_key_t *session_key, char *resp, int resp_len);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_sign_check_secondary(struct smb_request *req, unsigned int seqnum);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_sign_reply(struct smb_request *req, struct mbuf_chain *reply);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_sattr_check(smb_attr_t *ap, char *name, unsigned short sattr);
faa1795a28a5c712eed6d0a3f84d98c368a316c6jb * session functions (file smb_session.c)
faa1795a28a5c712eed6d0a3f84d98c368a316c6jbsmb_session_t *smb_session_create(struct sonode *, uint16_t, smb_server_t *);
faa1795a28a5c712eed6d0a3f84d98c368a316c6jbvoid smb_session_reconnection_check(smb_session_list_t *, smb_session_t *);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_session_cancel_requests(smb_session_t *session);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_session_reject(smb_session_t *session, char *reason);
faa1795a28a5c712eed6d0a3f84d98c368a316c6jbvoid smb_session_disconnect_share(smb_session_list_t *, char *);
faa1795a28a5c712eed6d0a3f84d98c368a316c6jbvoid smb_session_disconnect_volume(smb_session_list_t *, fs_desc_t *);
faa1795a28a5c712eed6d0a3f84d98c368a316c6jbvoid smb_session_list_append(smb_session_list_t *, smb_session_t *);
faa1795a28a5c712eed6d0a3f84d98c368a316c6jbsmb_session_t *smb_session_list_activate_head(smb_session_list_t *);
faa1795a28a5c712eed6d0a3f84d98c368a316c6jbvoid smb_session_list_terminate(smb_session_list_t *, smb_session_t *);
faa1795a28a5c712eed6d0a3f84d98c368a316c6jbvoid smb_session_correct_keep_alive_values(smb_session_list_t *, uint32_t);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * ofile functions (file smb_ofile.c)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwsmb_ofile_t *smb_ofile_lookup_by_fid(smb_tree_t *tree, uint16_t fid);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwsmb_ofile_t *smb_ofile_open(smb_tree_t *tree, smb_node_t *node, uint16_t pid,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw uint32_t access_granted, uint32_t create_options, uint32_t share_access,
dc20a3024900c47dd2ee44b9707e6df38f7d62a5as uint16_t ftype, char *pipe_name, uint32_t rpc_fid, uint32_t uniqid,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_ofile_close(smb_ofile_t *ofile, uint32_t last_wtime);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwuint32_t smb_ofile_access(smb_ofile_t *ofile, cred_t *cr, uint32_t access);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_ofile_seek(smb_ofile_t *of, ushort_t mode, int32_t off,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_ofile_close_all_by_pid(smb_tree_t *tree, uint16_t pid);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_ofile_set_flags(smb_ofile_t *of, uint32_t flags);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_ofile_close_timestamp_update(smb_ofile_t *of, uint32_t last_wtime);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw#define smb_ofile_granted_access(_of_) ((_of_)->f_granted_access)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * odir functions (file smb_odir.c)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwsmb_odir_t *smb_odir_open(smb_tree_t *tree, smb_node_t *node, char *pattern,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_odir_close_all_by_pid(smb_tree_t *tree, uint16_t pid);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwsmb_odir_t *smb_odir_lookup_by_sid(smb_tree_t *tree, uint16_t sid);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * SMB user functions (file smb_user.c)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwsmb_user_t *smb_user_lookup_by_uid(smb_session_t *, cred_t **, uint16_t);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwsmb_user_t *smb_user_lookup_by_name(smb_session_t *, char *, char *);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwsmb_user_t *smb_user_lookup_by_state(smb_session_t *, smb_user_t *user);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_user_disconnect_share(smb_user_t *user, char *sharename);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_user_disconnect_volume(smb_user_t *user, fs_desc_t *fsd);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * SMB tree functions (file smb_tree.c)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwsmb_tree_t *smb_tree_connect(smb_user_t *user, uint16_t access_flags,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_tree_close_all_by_pid(smb_user_t *user, uint16_t pid);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwsmb_tree_t *smb_tree_lookup_by_tid(smb_user_t *user, uint16_t tid);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwsmb_tree_t *smb_tree_lookup_by_name(smb_user_t *, char *, smb_tree_t *);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwsmb_tree_t *smb_tree_lookup_by_fsd(smb_user_t *, fs_desc_t *, smb_tree_t *);
faa1795a28a5c712eed6d0a3f84d98c368a316c6jbint smb_dr_user_create(smb_dr_user_ctx_t *, uint64_t, uint16_t, char *, char *,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * SMB user's credential functions
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwsmb_xa_t *smb_xa_create(smb_session_t *session, smb_request_t *sr,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw uint32_t total_parameter_count, uint32_t total_data_count,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwsmb_xa_t *smb_xa_find(smb_session_t *session, uint16_t pid, uint16_t mid);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_handle_write_raw(smb_session_t *session, smb_request_t *sr);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_winpipe_call(smb_request_t *, mlsvc_pipe_t *, mlsvc_stream_t *,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_reconnection_check(struct smb_session *session);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwuint32_t nt_to_unix_time(uint64_t nt_time, timestruc_t *unix_time);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwunicodestooems(char *oemstring, const mts_wchar_t *unicodestring,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwsize_t oemstounicodes(mts_wchar_t *unicodestring, const char *oemstring,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint uioxfer(struct uio *src_uio, struct uio *dst_uio, int n);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwint smb_match_name(ino64_t fileid, char *name, char *shortname,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * Pool ID function prototypes
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * SMB thread function prototypes
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * SMB locked list function prototypes
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_llist_constructor(smb_llist_t *, size_t, size_t);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw#define smb_llist_enter(ll, mode) rw_enter(&(ll)->ll_lock, mode)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw#define smb_llist_next(ll, obj) list_next(&(ll)->ll_list, obj)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * SMB Synchronized list function prototypes
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_slist_constructor(smb_slist_t *, size_t, size_t);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwuint32_t smb_slist_move_tail(list_t *lst, smb_slist_t *sl);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_slist_obj_move(smb_slist_t *dst, smb_slist_t *src, void *obj);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw#define smb_slist_next(sl, obj) list_next(&(sl)->sl_list, obj)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw#define smb_rwx_rwenter(rwx, mode) rw_enter(&(rwx)->rwx_lock, mode)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw#define smb_rwx_xenter(rwx) mutex_enter(&(rwx)->rwx_mutex)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_thread_init(smb_thread_t *, char *, smb_thread_ep_t, void *,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwboolean_t smb_thread_continue_timedwait(smb_thread_t *, int /* seconds */);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwvoid smb_thread_set_awaken(smb_thread_t *, smb_thread_aw_t, void *);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwuint32_t smb_denymode_to_sharemode(uint32_t desired_access, char *fname);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw/* 100's of ns between 1/1/1970 and 1/1/1601 */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw#define NT_TIME_BIAS (134774LL * 24LL * 60LL * 60LL * 10000000LL)
55bf511df53aad0fdb7eb3fa349f0308cc05234casuint32_t smb_sd_read(smb_request_t *, smb_sd_t *, uint32_t);
55bf511df53aad0fdb7eb3fa349f0308cc05234casuint32_t smb_sd_write(smb_request_t *, smb_sd_t *, uint32_t);
55bf511df53aad0fdb7eb3fa349f0308cc05234casuint32_t smb_acl_to_zfs(smb_acl_t *, uint32_t, int, acl_t **);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw#endif /* _SMB_KPROTO_H_ */