Print this page
NEX-14666 Need to provide SMB 2.1 Client
NEX-17187 panic in smbfs_acl_store
NEX-17231 smbfs create xattr files finds wrong file
NEX-17224 smbfs lookup EINVAL should be ENOENT
NEX-17260 SMB1 client fails to list directory after NEX-14666
Reviewed by: Evan Layton <evan.layton@nexenta.com>
Reviewed by: Matt Barden <matt.barden@nexenta.com>
Reviewed by: Rick McNeal <rick.mcneal@nexenta.com>
Reviewed by: Saso Kiselkov <saso.kiselkov@nexenta.com>
Reviewed by: Joyce McIntosh <joyce.mcintosh@nexenta.com>
and: (cleanup)
NEX-16824 SMB client connection setup rework
NEX-17232 SMB client reconnect failures
Reviewed by: Evan Layton <evan.layton@nexenta.com>
Reviewed by: Matt Barden <matt.barden@nexenta.com>
and: (improve debug)

*** 31,52 **** * * $Id: smb_subr.h,v 1.13 2004/09/14 22:59:08 lindak Exp $ */ /* - * Copyright 2011 Nexenta Systems, Inc. All rights reserved. * Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved. */ #ifndef _NETSMB_SMB_SUBR_H_ #define _NETSMB_SMB_SUBR_H_ #include <sys/cmn_err.h> #include <sys/lock.h> #include <sys/note.h> #include <netsmb/smb_conn.h> struct msgb; /* avoiding sys/stream.h here */ /* Helper function for SMBERROR */ /*PRINTFLIKE3*/ extern void smb_errmsg(int, const char *, const char *, ...) --- 31,60 ---- * * $Id: smb_subr.h,v 1.13 2004/09/14 22:59:08 lindak Exp $ */ /* * Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved. + * Copyright 2018 Nexenta Systems, Inc. All rights reserved. */ #ifndef _NETSMB_SMB_SUBR_H_ #define _NETSMB_SMB_SUBR_H_ #include <sys/cmn_err.h> #include <sys/lock.h> #include <sys/note.h> + #include <netsmb/mchain.h> #include <netsmb/smb_conn.h> + /* + * Possible lock commands + */ + #define SMB_LOCK_EXCL 0 + #define SMB_LOCK_SHARED 1 + #define SMB_LOCK_RELEASE 2 + struct msgb; /* avoiding sys/stream.h here */ /* Helper function for SMBERROR */ /*PRINTFLIKE3*/ extern void smb_errmsg(int, const char *, const char *, ...)
*** 115,202 **** extern int smb_timo_default; extern int smb_timo_open; extern int smb_timo_read; extern int smb_timo_write; extern int smb_timo_append; ! #define EMOREDATA (0x7fff) void smb_credinit(struct smb_cred *scred, cred_t *cr); void smb_credrele(struct smb_cred *scred); - void smb_oldlm_hash(const char *apwd, uchar_t *hash); - void smb_ntlmv1hash(const char *apwd, uchar_t *hash); - void smb_ntlmv2hash(const uchar_t *v1hash, const char *user, - const char *destination, uchar_t *v2hash); - - int smb_lmresponse(const uchar_t *hash, const uchar_t *C8, uchar_t *RN); - int smb_ntlmv2response(const uchar_t *hash, const uchar_t *C8, - const uchar_t *blob, size_t bloblen, uchar_t **RN, size_t *RNlen); int smb_maperror(int eclass, int eno); int smb_maperr32(uint32_t eno); int smb_put_dmem(struct mbchain *mbp, struct smb_vc *vcp, const char *src, int len, int caseopt, int *lenp); int smb_put_dstring(struct mbchain *mbp, struct smb_vc *vcp, const char *src, int caseopt); int smb_put_string(struct smb_rq *rqp, const char *src); int smb_put_asunistring(struct smb_rq *rqp, const char *src); - int smb_checksmp(void); int smb_cmp_sockaddr(struct sockaddr *, struct sockaddr *); struct sockaddr *smb_dup_sockaddr(struct sockaddr *sa); void smb_free_sockaddr(struct sockaddr *sa); - int smb_toupper(const char *, char *, size_t); void smb_rq_sign(struct smb_rq *); int smb_rq_verify(struct smb_rq *); int smb_calcv2mackey(struct smb_vc *, const uchar_t *, const uchar_t *, size_t); int smb_calcmackey(struct smb_vc *, const uchar_t *, const uchar_t *, size_t); - void smb_crypto_mech_init(void); /* * SMB protocol level functions */ int smb_smb_echo(smb_vc_t *vcp, smb_cred_t *scred, int timo); int smb_smb_treeconnect(smb_share_t *ssp, smb_cred_t *scred); int smb_smb_treedisconnect(smb_share_t *ssp, smb_cred_t *scred); ! 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, uint16_t *fidp, uint32_t *cr_act_p, struct smbfattr *fap); ! int smb_smb_close(struct smb_share *ssp, uint16_t fid, struct timespec *mtime, struct smb_cred *scrp); ! int ! smb_smb_open_prjob(struct smb_share *ssp, char *title, uint16_t setuplen, uint16_t mode, struct smb_cred *scrp, uint16_t *fidp); int smb_smb_close_prjob(struct smb_share *ssp, uint16_t fid, struct smb_cred *scrp); ! int smb_rwuio(smb_share_t *ssp, uint16_t fid, uio_rw_t rw, uio_t *uiop, smb_cred_t *scred, int timo); /* ! * time conversions */ ! void smb_time_init(void); ! void smb_time_fini(void); void smb_time_local2server(struct timespec *tsp, int tzoff, long *seconds); void smb_time_server2local(ulong_t seconds, int tzoff, struct timespec *tsp); void smb_time_NT2local(uint64_t nsec, struct timespec *tsp); void smb_time_local2NT(struct timespec *tsp, uint64_t *nsec); - void smb_time_unix2dos(struct timespec *tsp, int tzoff, uint16_t *ddp, - uint16_t *dtp, uint8_t *dhp); - void smb_dos2unixtime(uint_t dd, uint_t dt, uint_t dh, int tzoff, - struct timespec *tsp); #endif /* !_NETSMB_SMB_SUBR_H_ */ --- 123,255 ---- extern int smb_timo_default; extern int smb_timo_open; extern int smb_timo_read; extern int smb_timo_write; extern int smb_timo_append; + extern dev_t nsmb_dev_tcp; + extern dev_t nsmb_dev_tcp6; ! /* ! * Tunable timeout values. See: smb2_smb.c ! */ ! extern int smb2_timo_notice; ! extern int smb2_timo_default; ! extern int smb2_timo_open; ! extern int smb2_timo_read; ! extern int smb2_timo_write; ! extern int smb2_timo_append; void smb_credinit(struct smb_cred *scred, cred_t *cr); void smb_credrele(struct smb_cred *scred); int smb_maperror(int eclass, int eno); int smb_maperr32(uint32_t eno); + uint_t smb_doserr2status(int, int); + int smb_get_dstring(struct mdchain *mdc, struct smb_vc *vcp, + char *outbuf, size_t *outlen, int inlen); int smb_put_dmem(struct mbchain *mbp, struct smb_vc *vcp, const char *src, int len, int caseopt, int *lenp); int smb_put_dstring(struct mbchain *mbp, struct smb_vc *vcp, const char *src, int caseopt); int smb_put_string(struct smb_rq *rqp, const char *src); int smb_put_asunistring(struct smb_rq *rqp, const char *src); + 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); + + int smb_smb_close(struct smb_share *ssp, smb_fh_t *fhp, + struct smb_cred *scrp); + + int smb_rwuio(smb_fh_t *fhp, uio_rw_t rw, + uio_t *uiop, smb_cred_t *scred, int timo); + int smb_cmp_sockaddr(struct sockaddr *, struct sockaddr *); struct sockaddr *smb_dup_sockaddr(struct sockaddr *sa); void smb_free_sockaddr(struct sockaddr *sa); + int smb_sign_init(struct smb_vc *); void smb_rq_sign(struct smb_rq *); int smb_rq_verify(struct smb_rq *); int smb_calcv2mackey(struct smb_vc *, const uchar_t *, const uchar_t *, size_t); int smb_calcmackey(struct smb_vc *, const uchar_t *, const uchar_t *, size_t); + int smb2_sign_init(struct smb_vc *); + void smb2_rq_sign(struct smb_rq *); + int smb2_rq_verify(struct smb_rq *); /* * SMB protocol level functions */ + int smb_smb_negotiate(struct smb_vc *vcp, struct smb_cred *scred); + int smb_smb_ssnsetup(struct smb_vc *vcp, struct smb_cred *scred); + int smb_smb_logoff(struct smb_vc *vcp, struct smb_cred *scred); int smb_smb_echo(smb_vc_t *vcp, smb_cred_t *scred, int timo); int smb_smb_treeconnect(smb_share_t *ssp, smb_cred_t *scred); int smb_smb_treedisconnect(smb_share_t *ssp, smb_cred_t *scred); ! int smb1_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, uint16_t *fidp, uint32_t *cr_act_p, struct smbfattr *fap); ! int smb1_smb_close(struct smb_share *ssp, uint16_t fid, struct timespec *mtime, struct smb_cred *scrp); ! int smb_smb_open_prjob(struct smb_share *ssp, char *title, uint16_t setuplen, uint16_t mode, struct smb_cred *scrp, uint16_t *fidp); int smb_smb_close_prjob(struct smb_share *ssp, uint16_t fid, struct smb_cred *scrp); ! int smb_smb_readx(smb_fh_t *fhp, uint32_t *lenp, uio_t *uiop, smb_cred_t *scred, int timo); + int smb_smb_writex(smb_fh_t *fhp, uint32_t *lenp, + uio_t *uiop, smb_cred_t *scred, int timo); /* ! * SMB2 protocol level functions */ + int smb2_smb_negotiate(struct smb_vc *vcp, struct smb_cred *scred); + int smb2_smb_ssnsetup(struct smb_vc *vcp, struct smb_cred *scred); + int smb2_smb_logoff(struct smb_vc *vcp, struct smb_cred *scred); + int smb2_smb_echo(smb_vc_t *vcp, smb_cred_t *scred, int timo); + int smb2_smb_treeconnect(smb_share_t *ssp, smb_cred_t *scred); + int smb2_smb_treedisconnect(smb_share_t *ssp, smb_cred_t *scred); ! int ! smb2_smb_ntcreate(struct smb_share *ssp, struct mbchain *name_mb, ! struct mbchain *cctx_in, struct mdchain *cctx_out, ! 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, smb2fid_t *fidp, ! uint32_t *cr_act_p, struct smbfattr *fap); + int smb2_smb_close(struct smb_share *ssp, smb2fid_t *fid, + struct smb_cred *scrp); + + int smb2_smb_ioctl(struct smb_share *ssp, smb2fid_t *fid, + struct mbchain *data_in, struct mdchain *data_out, + uint32_t *data_out_sz, /* max / returned */ + uint32_t ctl_code, struct smb_cred *scrp); + + int smb2_smb_read(smb_fh_t *fhp, uint32_t *lenp, + uio_t *uiop, smb_cred_t *scred, int timo); + int smb2_smb_write(smb_fh_t *fhp, uint32_t *lenp, + uio_t *uiop, smb_cred_t *scred, int timo); + + /* + * time conversions + */ + void smb_time_local2server(struct timespec *tsp, int tzoff, long *seconds); void smb_time_server2local(ulong_t seconds, int tzoff, struct timespec *tsp); void smb_time_NT2local(uint64_t nsec, struct timespec *tsp); void smb_time_local2NT(struct timespec *tsp, uint64_t *nsec); #endif /* !_NETSMB_SMB_SUBR_H_ */