Windows: Make default mode bits configurable
[openafs.git] / src / WINNT / afsd / smb.h
index df1a64f..4f9d894 100644 (file)
@@ -10,6 +10,8 @@
 #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
@@ -18,9 +20,6 @@
 
 #include <cm_nls.h>
 
-/* Support largefiles by default */
-#define AFS_LARGEFILES
-
 /* basic core protocol SMB structure */
 #pragma pack(push, 1)
 typedef struct smb {
@@ -112,6 +111,19 @@ 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 */
 
@@ -324,6 +336,9 @@ typedef struct smb_pid {
 /* 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;
@@ -338,12 +353,16 @@ typedef struct smb_fid {
                                            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 */
@@ -376,6 +395,11 @@ typedef struct smb_fid {
 #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
@@ -415,6 +439,22 @@ typedef struct smb_fid {
 #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 */
@@ -504,33 +544,59 @@ extern void smb_Init(osi_log_t *logp, int useV3,
         , 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);
 
@@ -552,6 +618,19 @@ extern cm_user_t *smb_GetUserFromUID(smb_user_t *uidp);
 
 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);
@@ -559,6 +638,7 @@ 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);
@@ -606,7 +686,8 @@ extern void smb_StripLastComponent(clientchar_t *outPathp, clientchar_t **lastCo
 
 #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);
@@ -641,9 +722,7 @@ extern void smb_MapCoreError(long code, smb_vc_t *vcp, unsigned short *scodep,
 
 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;
@@ -666,6 +745,11 @@ extern unsigned int smb_IsDotFile(clientchar_t *lastComp);
 extern afs_uint32 smb_AsyncStore;
 extern afs_uint32 smb_AsyncStoreSize;
 
+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);
+
 /* the following are used for smb auth */
 extern int smb_authType; /* Type of SMB authentication to be used. One from below. */
 
@@ -709,6 +793,8 @@ 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);
@@ -735,9 +821,6 @@ extern char *smb_GetSharename(void);
 
 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);
@@ -745,6 +828,7 @@ extern long smb_IsNetworkStarted(void);
 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
@@ -754,6 +838,7 @@ extern void smb_SetLanAdapterChangeDetected(void);
 #include "smb3.h"
 #include "smb_ioctl.h"
 #include "smb_iocons.h"
+#include "smb_rpc.h"
 
 cm_user_t *smb_FindOrCreateUser(smb_vc_t *vcp, clientchar_t *usern);