/*
* Copyright 2000, International Business Machines Corporation and others.
* All Rights Reserved.
- *
+ *
* This software has been released under the terms of the IBM Public
* License. For details, see the LICENSE file in the top-level source
* directory or online at http://www.openafs.org/dl/license10.html
#ifndef __SMB_H_ENV__
#define __SMB_H_ENV__ 1
+/* #define DEBUG_SMB_REFCOUNT 1 */
+
#if _WIN32_WINNT < 0x0501
#undef _WIN32_WINNT
#define _WIN32_WINNT 0x0501
#include <cm_nls.h>
-/* Support largefiles by default */
-#define AFS_LARGEFILES
-
/* basic core protocol SMB structure */
#pragma pack(push, 1)
typedef struct smb {
#define SMB_FIND_FILE_NAMES_INFO 0x103
#define SMB_FIND_FILE_BOTH_DIRECTORY_INFO 0x104
+/* SMB_COM_TRANSACTION Named pipe operations */
+#define SMB_TRANS_SET_NMPIPE_STATE 0x0001
+#define SMB_TRANS_RAW_READ_NMPIPE 0x0011
+#define SMB_TRANS_QUERY_NMPIPE_STATE 0x0021
+#define SMB_TRANS_QUERY_NMPIPE_INFO 0x0022
+#define SMB_TRANS_PEEK_NMPIPE 0x0023
+#define SMB_TRANS_TRANSACT_NMPIPE 0x0026
+#define SMB_TRANS_RAW_WRITE_NMPIPE 0x0031
+#define SMB_TRANS_READ_NMPIPE 0x0036
+#define SMB_TRANS_WRITE_NMPIPE 0x0037
+#define SMB_TRANS_WAIT_NMPIPE 0x0053
+#define SMB_TRANS_CALL_NMPIPE 0x0054
+
/* more defines */
#define SMB_NOPCODES 256 /* # of opcodes in the dispatch table */
#define NTNEGOTIATE_CAPABILITY_COMPRESSED 0x40000000L
#define NTNEGOTIATE_CAPABILITY_EXTENDED_SECURITY 0x80000000L
+#define NTSID_LOCAL_SYSTEM L"S-1-5-18"
+
/* a packet structure for receiving SMB messages; locked by smb_globalLock.
* Most of the work involved is in handling chained requests and responses.
*
time_t last_logoff_t; /* most recent logoff time */
} smb_username_t;
-/* The SMB_USERNAMEFLAG_AFSLOGON is used to preserve the existence of an
+/* The SMB_USERNAMEFLAG_AFSLOGON is used to preserve the existence of an
* smb_username_t even when the refCount is zero. This is used to ensure
- * that tokens set to a username during the integrated logon process are
+ * that tokens set to a username during the integrated logon process are
* preserved until the SMB Session that will require the tokens is created.
* The cm_IoctlSetTokens() function when executed from the Network Provider
* connects to the AFS Client Service using the credentials of the machine
/* The SMB_USERNAMEFLAG_LOGOFF is used to indicate that the user most
* recently logged off at 'last_logoff_t'. The smb_username_t should not
- * be deleted even if the refCount is zero before 'last_logoff_t' +
+ * be deleted even if the refCount is zero before 'last_logoff_t' +
* 'smb_LogoffTransferTimeout' if 'smb_LogoffTokenTransfer' is non-zero.
* The smb_Daemon() thread is responsible for purging the expired objects */
#define SMB_USERNAMEFLAG_LOGOFF 2
+/*
+ * The SMB_USERNAMEFLAG_SID flag indicates that the name is not a username
+ * but a SID string.
+ */
+#define SMB_USERNAMEFLAG_SID 4
+
#define SMB_MAX_USERNAME_LENGTH 256
/* one per tree-connect */
/* Defined in smb_ioctl.h */
struct smb_ioctl;
+/* Defined in smb_rpc.h */
+struct smb_rpc;
+
/* one per file ID; these are really file descriptors */
typedef struct smb_fid {
osi_queue_t q;
the file if session is
terminated) */
osi_hyper_t offset; /* our file pointer */
- struct smb_ioctl *ioctlp; /* ptr to ioctl structure */
+ struct smb_ioctl *ioctlp; /* ptr to ioctl structure */
/* Under NT, we may need to know the
* parent directory and pathname used
* to open the file, either to delete
* the file on close, or to do a
* change notification */
+ struct smb_rpc *rpcp; /* ptr to RPC structure. Used
+ to keep track of endpoint
+ that was opened for the
+ RPC. */
struct cm_scache *NTopen_dscp; /* parent directory (NT) */
clientchar_t *NTopen_pathp; /* path used in open (NT) */
clientchar_t *NTopen_wholepathp; /* entire path, not just last name */
#define SMB_FID_SHARE_READ 0x1000
#define SMB_FID_SHARE_WRITE 0x2000
+#define SMB_FID_RPC 0x4000 /* open for MS RPC */
+#define SMB_FID_MESSAGEMODEPIPE 0x8000 /* message mode pipe */
+#define SMB_FID_BLOCKINGPIPE 0x10000 /* blocking pipe */
+#define SMB_FID_RPC_INCALL 0x20000 /* in an RPC call */
+
#define SMB_FID_QLOCK_HIGH 0x7f000000
#define SMB_FID_QLOCK_LOW 0x00000000
#define SMB_FID_QLOCK_LENGTH 1
#define LOCKING_ANDX_CANCEL_LOCK 0x08 /* Cancel outstanding request */
#define LOCKING_ANDX_LARGE_FILES 0x10 /* Large file locking format */
+/* File type constants */
+#define SMB_FILETYPE_DISK 0x0000
+#define SMB_FILETYPE_BYTE_MODE_PIPE 0x0001
+#define SMB_FILETYPE_MESSAGE_MODE_PIPE 0x0002
+#define SMB_FILETYPE_PRINTER 0x0003
+#define SMB_FILETYPE_UNKNOWN 0xffff
+
+/* Device state constants */
+#define SMB_DEVICESTATE_READASBYTESTREAM 0x0000
+#define SMB_DEVICESTATE_READMSGFROMPIPE 0x0100
+#define SMB_DEVICESTATE_BYTESTREAMPIPE 0x0000
+#define SMB_DEVICESTATE_MESSAGEMODEPIPE 0x0400
+#define SMB_DEVICESTATE_PIPECLIENTEND 0x0000
+#define SMB_DEVICESTATE_PIPESERVEREND 0x4000
+#define SMB_DEVICESTATE_BLOCKING 0x8000
+
/* for tracking in-progress directory searches */
typedef struct smb_dirSearch {
osi_queue_t q; /* queue of all outstanding cookies */
unsigned short attribute; /* search attribute
* (used for extended protocol) */
clientchar_t tidPath[256]; /* tid path */
- clientchar_t relPath[1024]; /* relative path */
+ clientchar_t relPath[1024]; /* relative path */
clientchar_t mask[256]; /* search mask for V3 */
} smb_dirSearch_t;
} smb_dirListPatch_t;
/* dirListPatch Flags */
-#define SMB_DIRLISTPATCH_DOTFILE 1
+#define SMB_DIRLISTPATCH_DOTFILE 1
/* the file referenced is a dot file
- * Note: will not be set if smb_hideDotFiles is false
+ * Note: will not be set if smb_hideDotFiles is false
*/
/* individual lock on a waiting lock request */
, void *aMBfunc
);
-extern void smb_LargeSearchTimeFromUnixTime(FILETIME *largeTimep, time_t unixTime);
+extern void smb_DosUTimeFromUnixTime(afs_uint32 *dosUTimep, time_t unixTime);
-extern void smb_UnixTimeFromLargeSearchTime(time_t *unixTimep, FILETIME *largeTimep);
+extern void smb_UnixTimeFromDosUTime(time_t *unixTimep, afs_uint32 dosUTime);
-extern void smb_SearchTimeFromUnixTime(afs_uint32 *searchTimep, time_t unixTime);
+extern void CompensateForSmbClientLastWriteTimeBugs(afs_uint32 *dosTimep);
-extern void smb_UnixTimeFromSearchTime(time_t *unixTimep, afs_uint32 searchTime);
+#ifdef DEBUG_SMB_REFCOUNT
+extern smb_vc_t *smb_FindVCDbg(unsigned short lsn, int flags, int lana, char *, long);
+#define smb_FindVC(a,b,c) smb_FindVCDbg(a,b,c,__FILE__,__LINE__);
-extern void smb_DosUTimeFromUnixTime(afs_uint32 *dosUTimep, time_t unixTime);
+extern void smb_HoldVCDbg(smb_vc_t *vcp, char *, long);
+#define smb_HoldVC(a) smb_HoldVCDbg(a,__FILE__,__LINE__);
-extern void smb_UnixTimeFromDosUTime(time_t *unixTimep, afs_uint32 dosUTime);
+extern void smb_HoldVCNoLockDbg(smb_vc_t *vcp, char *, long);
+#define smb_HoldVCNoLock(a) smb_HoldVCNoLockDbg(a,__FILE__,__LINE__);
-extern void CompensateForSmbClientLastWriteTimeBugs(afs_uint32 *dosTimep);
+extern void smb_ReleaseVCDbg(smb_vc_t *vcp, char *, long);
+#define smb_ReleaseVC(a) smb_ReleaseVCDbg(a,__FILE__,__LINE__);
+extern void smb_ReleaseVCNoLockDbg(smb_vc_t *vcp, char *, long);
+#define smb_ReleaseVCNoLock(a) smb_ReleaseVCNoLockDbg(a,__FILE__,__LINE__);
+#else
extern smb_vc_t *smb_FindVC(unsigned short lsn, int flags, int lana);
-extern void smb_CleanupDeadVC(smb_vc_t *vcp);
+extern void smb_HoldVC(smb_vc_t *vcp);
+
+extern void smb_HoldVCNoLock(smb_vc_t *vcp);
extern void smb_ReleaseVC(smb_vc_t *vcp);
extern void smb_ReleaseVCNoLock(smb_vc_t *vcp);
+#endif
+
+extern void smb_CleanupDeadVC(smb_vc_t *vcp);
+
+extern void smb_MarkAllVCsDead(smb_vc_t *exclude_vcp);
+#ifdef DEBUG_SMB_REFCOUNT
+extern smb_tid_t *smb_FindTIDDbg(smb_vc_t *vcp, unsigned short tid, int flags, char *, long);
+#define smb_FindTID(a,b,c) smb_FindTIDDbg(a,b,c,__FILE__,__LINE__);
+
+extern void smb_HoldTIDNoLockDbg(smb_tid_t *tidp, char *, long);
+#define smb_HoldTIDNoLock(a) smb_HoldTIDNoLockDbg(a,__FILE__,__LINE__);
+
+extern void smb_ReleaseTIDDbg(smb_tid_t *tidp, afs_uint32 locked, char *, long);
+#define smb_ReleaseTID(a,b) smb_ReleaseTIDDbg(a,b,__FILE__,__LINE__);
+#else
extern smb_tid_t *smb_FindTID(smb_vc_t *vcp, unsigned short tid, int flags);
extern void smb_HoldTIDNoLock(smb_tid_t *tidp);
extern void smb_ReleaseTID(smb_tid_t *tidp, afs_uint32 locked);
+#endif
extern smb_user_t *smb_FindUID(smb_vc_t *vcp, unsigned short uid, int flags);
+extern afs_int32 smb_userIsLocalSystem(smb_user_t *userp);
+
extern smb_username_t *smb_FindUserByName(clientchar_t *usern, clientchar_t *machine, afs_uint32 flags);
extern cm_user_t *smb_FindCMUserByName(clientchar_t *usern, clientchar_t *machine, afs_uint32 flags);
-extern smb_user_t *smb_FindUserByNameThisSession(smb_vc_t *vcp, clientchar_t *usern);
+extern cm_user_t *smb_FindCMUserBySID(clientchar_t *usern, clientchar_t *machine, afs_uint32 flags);
+
+extern smb_user_t *smb_FindUserByNameThisSession(smb_vc_t *vcp, clientchar_t *usern);
extern void smb_ReleaseUsername(smb_username_t *unp);
extern long smb_LookupTIDPath(smb_vc_t *vcp, unsigned short tid, clientchar_t ** tidPathp);
+#ifdef DEBUG_SMB_REFCOUNT
+extern smb_fid_t *smb_FindFIDDbg(smb_vc_t *vcp, unsigned short fid, int flags, char *, long);
+#define smb_FindFID(a,b,c) smb_FindFIDDbg(a,b,c,__FILE__,__LINE__);
+
+extern smb_fid_t *smb_FindFIDByScacheDbg(smb_vc_t *vcp, cm_scache_t * scp, char *, long);
+#define smb_FindFIDByScache(a,b) smb_FindFIDByScacheDbg(a,b,__FILE__,__LINE__);
+
+extern void smb_HoldFIDNoLockDbg(smb_fid_t *fidp, char *, long);
+#define smb_HoldFIDNoLock(a) smb_HoldFIDNoLockDbg(a,__FILE__,__LINE__);
+
+extern void smb_ReleaseFIDDbg(smb_fid_t *fidp, char *, long);
+#define smb_ReleaseFID(a) smb_ReleaseFIDDbg(a,__FILE__,__LINE__);
+#else
extern smb_fid_t *smb_FindFID(smb_vc_t *vcp, unsigned short fid, int flags);
extern smb_fid_t *smb_FindFIDByScache(smb_vc_t *vcp, cm_scache_t * scp);
extern void smb_HoldFIDNoLock(smb_fid_t *fidp);
extern void smb_ReleaseFID(smb_fid_t *fidp);
+#endif
extern long smb_CloseFID(smb_vc_t *vcp, smb_fid_t *fidp, cm_user_t *userp,
afs_uint32 dosTime);
#define SMB_STRF_FORCEASCII (1<<0)
#define SMB_STRF_ANSIPATH (1<<1)
-#define SMB_STRF_IGNORENULL (1<<2)
+#define SMB_STRF_IGNORENUL (1<<2)
+#define SMB_STRF_SRCNULTERM (1<<3)
extern clientchar_t *smb_ParseASCIIBlock(smb_packet_t * pktp, unsigned char *inp,
char **chainpp, int flags);
extern void smb_MapNTError(long code, unsigned long *NTStatusp);
-extern void smb_HoldVC(smb_vc_t *vcp);
-
-extern void smb_HoldVCNoLock(smb_vc_t *vcp);
+extern void smb_MapWin32Error(long code, unsigned long *Win32Ep);
/* some globals, too */
extern char *smb_localNamep;
extern GUID smb_ServerGUID;
extern LSA_STRING smb_lsaLogonOrigin;
extern LONG smb_UseUnicode;
+extern DWORD smb_monitorReqs;
/* used for getting a challenge for SMB auth */
-typedef struct _MSV1_0_LM20_CHALLENGE_REQUEST {
+typedef struct _MSV1_0_LM20_CHALLENGE_REQUEST {
MSV1_0_PROTOCOL_MESSAGE_TYPE MessageType;
} MSV1_0_LM20_CHALLENGE_REQUEST, *PMSV1_0_LM20_CHALLENGE_REQUEST;
-typedef struct _MSV1_0_LM20_CHALLENGE_RESPONSE {
- MSV1_0_PROTOCOL_MESSAGE_TYPE MessageType;
+typedef struct _MSV1_0_LM20_CHALLENGE_RESPONSE {
+ MSV1_0_PROTOCOL_MESSAGE_TYPE MessageType;
UCHAR ChallengeToClient[MSV1_0_CHALLENGE_LENGTH];
} MSV1_0_LM20_CHALLENGE_RESPONSE, *PMSV1_0_LM20_CHALLENGE_RESPONSE;
/**/
extern void smb_FormatResponsePacket(smb_vc_t *vcp, smb_packet_t *inp,
smb_packet_t *op);
-extern char *myCrt_Dispatch(int i);
+extern char *myCrt_Dispatch(int i);
extern char *myCrt_2Dispatch(int i);
extern char *myCrt_RapDispatch(int i);
+extern char * myCrt_NmpipeDispatch(int i);
+
extern unsigned int smb_Attributes(cm_scache_t *scp);
extern int smb_ChainFID(int fid, smb_packet_t *inp);
extern DWORD smb_ServerExceptionFilter(void);
-extern void smb_UpdateServerPriority(void);
-extern void smb_SetRequestStartTime(void);
-extern void smb_ResetServerPriority(void);
extern void smb_RestartListeners(int);
extern void smb_StopListeners(int);
extern void smb_StopListener(NCB *ncbp, int lana, int wait);
extern void smb_LanAdapterChange(int);
extern void smb_SetLanAdapterChangeDetected(void);
+extern void smb_InitReq(cm_req_t *reqp);
#define SMB_LISTENER_UNINITIALIZED -1
#define SMB_LISTENER_STOPPED 0
#include "smb3.h"
#include "smb_ioctl.h"
#include "smb_iocons.h"
+#include "smb_rpc.h"
+#include "cm_vnodeops.h"
+
+extern int smb_unixModeDefaultFile;
+extern int smb_unixModeDefaultDir;
+extern void smb_SetInitialModeBitsForFile(int smb_attr, cm_attr_t * attr);
+extern void smb_SetInitialModeBitsForDir(int smb_attr, cm_attr_t * attr);
cm_user_t *smb_FindOrCreateUser(smb_vc_t *vcp, clientchar_t *usern);
MSV1_0_PROTOCOL_MESSAGE_TYPE MessageType;
ULONG ProcessOptions;
BOOLEAN DisableOptions;
-} MSV1_0_SETPROCESSOPTION_REQUEST, *PMSV1_0_SETPROCESSOPTION_REQUEST;
+} MSV1_0_SETPROCESSOPTION_REQUEST, *PMSV1_0_SETPROCESSOPTION_REQUEST;
#endif
#endif /* whole file */