/*++ Copyright (c) 1989 Microsoft Corporation Module Name: srvdata.h Abstract: This module defines global data for the LAN Manager server. Author: Chuck Lenzmeier (chuckl) 22-Sep-1989 Revision History: --*/ #ifndef _SRVDATA_ #define _SRVDATA_ //#include //#include "lock.h" //#include "srvconst.h" //#include "smbtypes.h" // // All global variables referenced in this module are defined in // srvdata.c. See that module for complete descriptions. // // The variables referenced herein, because they are part of the driver // image, are not pageable. However, some of the things pointed to by // these variables are in the FSP's address space and are pageable. // These variables are only accessed by the FSP, and only at low IRQL. // Any data referenced by the FSP at elevated IRQL or by the FSD must // be nonpageable. // // // Routine to initialize data structures contained herein that cannot // be statically initialized. // VOID SrvInitializeData ( VOID ); // // Routine to clean up global server data when the driver is unloaded. // VOID SrvTerminateData ( VOID ); // // Address of the server device object. // extern PDEVICE_OBJECT SrvDeviceObject; // // Fields describing the state of the FSP. // extern BOOLEAN SrvFspActive; // Indicates whether the FSP is running extern BOOLEAN SrvFspTransitioning; // Indicates that the server is in the // process of starting up or // shutting down extern PEPROCESS SrvServerProcess; // Pointer to the initial system process extern PEPROCESS SrvSvcProcess; // Pointer to the service controller process extern BOOLEAN SrvCompletedPNPRegistration; // Indicates whether the FSP has completed // registering for PNP notifications // // Endpoint variables. SrvEndpointCount is used to count the number of // active endpoints. When the last endpoint is closed, SrvEndpointEvent // is set so that the thread processing the shutdown request continues // server termination. // extern CLONG SrvEndpointCount; // Number of transport endpoints extern KEVENT SrvEndpointEvent; // Signaled when no active endpoints // // DMA alignment size // extern ULONG SrvCacheLineSize; // // Global spin locks. // extern SRV_GLOBAL_SPIN_LOCKS SrvGlobalSpinLocks; #if SRVDBG || SRVDBG_HANDLES // // Lock used to protect debugging structures. // extern SRV_LOCK SrvDebugLock; #endif // // SrvConfigurationLock is used to synchronize configuration requests. // extern SRV_LOCK SrvConfigurationLock; // // SrvStartupShutdownLock is used to synchronize driver starting and stopping // extern SRV_LOCK SrvStartupShutdownLock; // // SrvEndpointLock serializes access to the global endpoint list and // all endpoints. Note that the list of connections in each endpoint // is also protected by this lock. // extern SRV_LOCK SrvEndpointLock; // // SrvShareLock protects all shares. // extern SRV_LOCK SrvShareLock; // // The number of processors in the system // extern ULONG SrvNumberOfProcessors; // // Work queues -- nonblocking, blocking, and critical. // #if MULTIPROCESSOR extern PBYTE SrvWorkQueuesBase; extern PWORK_QUEUE SrvWorkQueues; extern PBYTE SrvBlockingWorkQueuesBase; extern PWORK_QUEUE SrvBlockingWorkQueues; #else extern WORK_QUEUE SrvWorkQueues[1]; #endif extern WORK_QUEUE SrvLpcWorkQueue; extern PWORK_QUEUE eSrvWorkQueues; // used to terminate 'for' loops extern PWORK_QUEUE eSrvBlockingWorkQueues; extern ULONG SrvReBalanced; // how often we've picked another CPU extern ULONG SrvNextBalanceProcessor; // Which processor we'll look for next extern CLONG SrvBlockingOpsInProgress; // // Various list heads. // extern LIST_ENTRY SrvNeedResourceQueue; // The need resource queue extern LIST_ENTRY SrvDisconnectQueue; // The disconnect queue // // Queue of connections that needs to be dereferenced. // extern SLIST_HEADER SrvBlockOrphanage; // // FSP configuration queue. The FSD puts configuration request IRPs // (from NtDeviceIoControlFile) on this queue, and it is serviced by an // EX worker thread. // extern LIST_ENTRY SrvConfigurationWorkQueue; // // This is the number of configuration IRPs which have been queued but not // yet completed. // extern ULONG SrvConfigurationIrpsInProgress; // // Work item for running the configuration thread in the context of an // EX worker thread. extern WORK_QUEUE_ITEM SrvConfigurationThreadWorkItem[ MAX_CONFIG_WORK_ITEMS ]; // // Base address of the large block allocated to hold initial normal // work items (see blkwork.c\SrvAllocateInitialWorkItems). // extern PVOID SrvInitialWorkItemBlock; // // Work item used to run the resource thread. Booleans used to inform // the resource thread to continue running. // extern WORK_QUEUE_ITEM SrvResourceThreadWorkItem; extern BOOLEAN SrvResourceThreadRunning; extern BOOLEAN SrvResourceDisconnectPending; extern WORK_QUEUE_ITEM SrvResourceAllocThreadWorkItem; extern BOOLEAN SrvResourceAllocThreadRunning; extern BOOLEAN SrvResourceAllocConnection; extern LONG SrvResourceOrphanedBlocks; // // Denial of Service monitoring variables for the Resource Thread // #define SRV_DOS_MINIMUM_DOS_WAIT_PERIOD (50*1000*10) #define SRV_DOS_TEARDOWN_MIN (LONG)MAX((SrvMaxReceiveWorkItemCount>>4),32) #define SRV_DOS_TEARDOWN_MAX (LONG)(SrvMaxReceiveWorkItemCount>>1) #define SRV_DOS_INCREASE_TEARDOWN() { \ LONG lTearDown = InterlockedCompareExchange( &SrvDoSWorkItemTearDown, 0, 0 ); \ LONG lNewTearDown = MIN(lTearDown+(lTearDown>>2), SRV_DOS_TEARDOWN_MAX); \ SrvDoSRundownIncreased = TRUE; \ InterlockedCompareExchange( &SrvDoSWorkItemTearDown, lNewTearDown, lTearDown ); \ } #define SRV_DOS_DECREASE_TEARDOWN() { \ LONG lTearDown = InterlockedCompareExchange( &SrvDoSWorkItemTearDown, 0, 0 ); \ LONG lNewTearDown = MAX(lTearDown-(SRV_DOS_TEARDOWN_MIN), SRV_DOS_TEARDOWN_MIN); \ if( lNewTearDown == SRV_DOS_TEARDOWN_MIN ) SrvDoSRundownIncreased = FALSE; \ InterlockedCompareExchange( &SrvDoSWorkItemTearDown, lNewTearDown, lTearDown ); \ } #define SRV_DOS_GET_TEARDOWN() InterlockedCompareExchange( &SrvDoSWorkItemTearDown, 0, 0 ) #define SRV_DOS_IS_TEARDOWN_IN_PROGRESS() InterlockedCompareExchange( &SrvDoSTearDownInProgress, 0, 0 ) #define SRV_DOS_CAN_START_TEARDOWN() !InterlockedCompareExchange( &SrvDoSTearDownInProgress, 1, 0 ) #define SRV_DOS_COMPLETE_TEARDOWN() InterlockedCompareExchange( &SrvDoSTearDownInProgress, 0, 1 ) extern LONG SrvDoSWorkItemTearDown; extern LONG SrvDoSTearDownInProgress; // Is a teardown in progress? extern BOOLEAN SrvDoSDetected; extern BOOLEAN SrvDoSRundownDetector; // Used to rundown the teardown amounts extern BOOLEAN SrvDoSRundownIncreased; // Have we increased the Rundown past the minimum extern BOOLEAN SrvDisableDoSChecking; extern SPECIAL_WORK_ITEM SrvDoSWorkItem; extern KSPIN_LOCK SrvDosSpinLock; extern LARGE_INTEGER SrvDoSLastRan; // // Should we disable strict name checking // extern BOOLEAN SrvDisableStrictNameChecking; // // Should we disable large read/write ops? // extern BOOLEAN SrvDisableLargeRead; extern BOOLEAN SrvDisableLargeWrite; // // Should we disable downlevel timewarp // extern BOOLEAN SrvDisableDownlevelTimewarp; // // Can the client do name-space caching (Global setting) // extern BOOLEAN SrvNoAliasingOnFilesystem; // // Should we map no-intermediate-buffering into write-through // extern BOOLEAN SrvMapNoIntermediateBuffering; // // Generic security mapping for connecting to shares // extern GENERIC_MAPPING SrvShareConnectMapping; // // What's the minumum # of free work items each processor should have? // extern ULONG SrvMinPerProcessorFreeWorkItems; // // The server has callouts to enable a smart card to accelerate its direct // host IPX performance. This is the vector of entry points. // extern SRV_IPX_SMART_CARD SrvIpxSmartCard; // // This is the name of the server computer. Returned in the negprot response // extern UNICODE_STRING SrvComputerName; // // The master file table contains one entry for each named file that has // at least one open instance. // extern MFCBHASH SrvMfcbHashTable[ NMFCB_HASH_TABLE ]; // // The share table contains one entry for each share // extern LIST_ENTRY SrvShareHashTable[ NSHARE_HASH_TABLE ]; // // Hex digits array used by the dump routines and SrvSmbCreateTemporary. // extern CHAR SrvHexChars[]; #if SRVCATCH // // Are we looking for the special file? // extern UNICODE_STRING SrvCatch; extern PWSTR *SrvCatchBuf; extern UNICODE_STRING SrvCatchExt; extern PWSTR *SrvCatchExtBuf; extern ULONG SrvCatchShares; extern PWSTR *SrvCatchShareNames; #endif // // SMB dispatch table // extern UCHAR SrvSmbIndexTable[]; // // This is an enum structure that enumerates all the routines in the // SrvSmbDispatchTable. This is done for convenience only. Note that // this will only work if this list corresponds exactly to // SrvSmbDispatchTable. // typedef enum _SRV_SMB_INDEX { ISrvSmbIllegalCommand, ISrvSmbCreateDirectory, ISrvSmbDeleteDirectory, ISrvSmbOpen, ISrvSmbCreate, ISrvSmbClose, ISrvSmbFlush, ISrvSmbDelete, ISrvSmbRename, ISrvSmbQueryInformation, ISrvSmbSetInformation, ISrvSmbRead, ISrvSmbWrite, ISrvSmbLockByteRange, ISrvSmbUnlockByteRange, ISrvSmbCreateTemporary, ISrvSmbCheckDirectory, ISrvSmbProcessExit, ISrvSmbSeek, ISrvSmbLockAndRead, ISrvSmbSetInformation2, ISrvSmbQueryInformation2, ISrvSmbLockingAndX, ISrvSmbTransaction, ISrvSmbTransactionSecondary, ISrvSmbIoctl, ISrvSmbIoctlSecondary, ISrvSmbMove, ISrvSmbEcho, ISrvSmbOpenAndX, ISrvSmbReadAndX, ISrvSmbWriteAndX, ISrvSmbFindClose2, ISrvSmbFindNotifyClose, ISrvSmbTreeConnect, ISrvSmbTreeDisconnect, ISrvSmbNegotiate, ISrvSmbSessionSetupAndX, ISrvSmbLogoffAndX, ISrvSmbTreeConnectAndX, ISrvSmbQueryInformationDisk, ISrvSmbSearch, ISrvSmbNtTransaction, ISrvSmbNtTransactionSecondary, ISrvSmbNtCreateAndX, ISrvSmbNtCancel, ISrvSmbOpenPrintFile, ISrvSmbClosePrintFile, ISrvSmbGetPrintQueue, ISrvSmbReadRaw, ISrvSmbWriteRaw, ISrvSmbReadMpx, ISrvSmbWriteMpx, ISrvSmbWriteMpxSecondary } SRV_SMB_INDEX; typedef struct { PSMB_PROCESSOR Func; #if DBG LPSTR Name; #endif } SRV_SMB_DISPATCH_TABLE; extern SRV_SMB_DISPATCH_TABLE SrvSmbDispatchTable[]; // // SMB word count table. // extern SCHAR SrvSmbWordCount[]; // // Device prefix strings. // extern UNICODE_STRING SrvCanonicalNamedPipePrefix; extern UNICODE_STRING SrvNamedPipeRootDirectory; extern UNICODE_STRING SrvMailslotRootDirectory; // // Transaction2 dispatch table // extern PSMB_TRANSACTION_PROCESSOR SrvTransaction2DispatchTable[]; extern PSMB_TRANSACTION_PROCESSOR SrvNtTransactionDispatchTable[]; extern SRV_STATISTICS SrvStatistics; #if SRVDBG_STATS || SRVDBG_STATS2 extern SRV_STATISTICS_DEBUG SrvDbgStatistics; #endif // // The number of abortive disconnects that the server has gotten // extern ULONG SrvAbortiveDisconnects; // // Server environment information strings. // extern UNICODE_STRING SrvNativeOS; extern OEM_STRING SrvOemNativeOS; extern UNICODE_STRING SrvNativeLanMan; extern OEM_STRING SrvOemNativeLanMan; extern UNICODE_STRING SrvSystemRoot; // // The following will be a permanent handle and device object pointer // to NPFS. // extern HANDLE SrvNamedPipeHandle; extern PDEVICE_OBJECT SrvNamedPipeDeviceObject; extern PFILE_OBJECT SrvNamedPipeFileObject; // // The following are used to converse with the Dfs driver // extern PFAST_IO_DEVICE_CONTROL SrvDfsFastIoDeviceControl; extern PDEVICE_OBJECT SrvDfsDeviceObject; extern PFILE_OBJECT SrvDfsFileObject; // // The following will be a permanent handle and device object pointer // to MSFS. // extern HANDLE SrvMailslotHandle; extern PDEVICE_OBJECT SrvMailslotDeviceObject; extern PFILE_OBJECT SrvMailslotFileObject; // // Flag indicating XACTSRV whether is active, and resource synchronizing // access to XACTSRV-related variabled. // extern BOOLEAN SrvXsActive; extern ERESOURCE SrvXsResource; // // Handle to the unnamed shared memory and communication port used for // communication between the server and XACTSRV. // extern HANDLE SrvXsSectionHandle; extern HANDLE SrvXsPortHandle; // // Pointers to control the unnamed shared memory for the XACTSRV LPC port. // extern PVOID SrvXsPortMemoryBase; extern ULONG_PTR SrvXsPortMemoryDelta; extern PVOID SrvXsPortMemoryHeap; // // Pointer to heap header for the special XACTSRV shared-memory heap. // extern PVOID SrvXsHeap; // // Dispatch table for handling server API requests. // extern PAPI_PROCESSOR SrvApiDispatchTable[]; // // Names for the various types of clients. // extern UNICODE_STRING SrvClientTypes[]; // // All the resumable Enum APIs use ordered lists for context-free // resume. All data blocks in the server that correspond to return // information for Enum APIs are maintained in ordered lists. // extern SRV_LOCK SrvOrderedListLock; extern ORDERED_LIST_HEAD SrvEndpointList; extern ORDERED_LIST_HEAD SrvRfcbList; extern ORDERED_LIST_HEAD SrvSessionList; extern ORDERED_LIST_HEAD SrvShareList; extern ORDERED_LIST_HEAD SrvTreeConnectList; // The DNS domain name for the domain extern PUNICODE_STRING SrvDnsDomainName; // // To synchronize server shutdown with API requests handled in the // server FSD, we track the number of outstanding API requests. The // shutdown code waits until all APIs have been completed to start // termination. // // SrvApiRequestCount tracks the active APIs in the FSD. // SrvApiCompletionEvent is set by the last API to complete, and the // shutdown code waits on it if there are outstanding APIs. // extern ULONG SrvApiRequestCount; extern KEVENT SrvApiCompletionEvent; // // Security contexts required for mutual authentication. // SrvKerberosLsaHandle and SrvLmLsaHandle are credentials of the server // principal. They are used to validate incoming kerberos tickets. // SrvNullSessionToken is a cached token handle representing the null session. // extern CtxtHandle SrvLmLsaHandle; extern CtxtHandle SrvNullSessionToken; extern CtxtHandle SrvExtensibleSecurityHandle; // // Oplock break information. // extern LIST_ENTRY SrvWaitForOplockBreakList; extern SRV_LOCK SrvOplockBreakListLock; extern LIST_ENTRY SrvOplockBreaksInProgressList; // // The default server security quality of service. // extern SECURITY_QUALITY_OF_SERVICE SrvSecurityQOS; // // A BOOLEAN to indicate whether the server is paused. If paused, the // server will not accept new tree connections from non-admin users. // extern BOOLEAN SrvPaused; // // Alerting information. // extern SRV_ERROR_RECORD SrvErrorRecord; extern SRV_ERROR_RECORD SrvNetworkErrorRecord; extern BOOLEAN SrvDiskAlertRaised[26]; // // Counts of the number of times pool allocations have failed because // the server was at its configured pool limit. // extern ULONG SrvNonPagedPoolLimitHitCount; extern ULONG SrvPagedPoolLimitHitCount; // // SrvOpenCount counts the number of active opens of the server device. // This is used at server shutdown time to determine whether the server // service should unload the driver. // extern ULONG SrvOpenCount; // // Counters for logging resource shortage events during a scavenger pass. // extern ULONG SrvOutOfFreeConnectionCount; extern ULONG SrvOutOfRawWorkItemCount; extern ULONG SrvFailedBlockingIoCount; // // Current core search timeout time in seconds // extern ULONG SrvCoreSearchTimeout; // // SrvTimerList is a pool of timer/DPC structures available for use by // code that needs to start a timer. // extern SLIST_HEADER SrvTimerList; // // Name that should be displayed when doing a server alert. // extern PWSTR SrvAlertServiceName; // // Variable to store the number of tick counts for 5 seconds // extern ULONG SrvFiveSecondTickCount; // // Holds the PNP notification handle for TDI // extern HANDLE SrvTdiNotificationHandle; // // Should we log invalid SMB commands // extern BOOLEAN SrvEnableInvalidSmbLogging; // // Flag indicating whether or not SMB security signatures are enabled. // extern BOOLEAN SrvSmbSecuritySignaturesEnabled; // // Flag indicating whether or not SMB security signatures are required. The signature // must match between the client and the server for the smb to be accepted. // extern BOOLEAN SrvSmbSecuritySignaturesRequired; // // Flag indicating whether or not SMB security signatures should be applied to W9x // clients. // extern BOOLEAN SrvEnableW9xSecuritySignatures; // // Security descriptor granting Administrator READ access. // Used to see if a client has administrative privileges // extern SECURITY_DESCRIPTOR SrvAdminSecurityDescriptor; // // Security descriptor granting Anonymous READ access. // Used to see if a client was an anonymous (null session) logon // extern SECURITY_DESCRIPTOR SrvNullSessionSecurityDescriptor; // // Flag indicating whether or not we need to filter extended characters // out of 8.3 names ourselves. // extern BOOLEAN SrvFilterExtendedCharsInPath; // // Flag indicating whether we enforce logoff times // extern BOOLEAN SrvEnforceLogoffTimes; // // Maximum amount of data that we'll allocate to support a METHOD_NEITHER Fsctl call // extern ULONG SrvMaxFsctlBufferSize; // // Should we try to do extended security signatures // extern BOOLEAN SrvEnableExtendedSignatures; extern BOOLEAN SrvRequireExtendedSignatures; // // Maximum NT transaction size which we'll accept. // extern ULONG SrvMaxNtTransactionSize; // // Maximum size of large Read&X that we'll allow. We need to lock down a cache region // to service this request, so we don't want it to get too big // extern ULONG SrvMaxReadSize; // // When we receive an large write from a client, we receive it in chunks, // locking & unlocking the file cache as we receive the data. SrvMaxWriteChunk is the // size of this 'chunk'. There's no magic to this chosen value. // extern ULONG SrvMaxWriteChunk; // // Handle used for PoRegisterSystemState calls // extern PVOID SrvPoRegistrationState; // // Counter used to suppress extraneous PoRegisterSystemStateCalls // extern ULONG SrvIdleCount; #if SRVNTVERCHK // // This is the minimum NT5 client build number that we will allow to connect to the server // extern ULONG SrvMinNT5Client; extern BOOLEAN SrvMinNT5ClientIPCToo; // // To force upgrades of our internal development community, we can set a // value in the registry that governs the minimum NT release that we allow // people to run to connect to this server. However, some folks have special // needs that preclude a forced upgrade. Presuming they have a static IP address, // you can add their address to the registry to exclude them from the build number // checking logic // extern DWORD SrvAllowIPAddress[25]; // // If a server worker threads remains idle for this many ticks, then it terminate // extern LONGLONG SrvIdleThreadTimeOut; extern LARGE_INTEGER SrvLastDosAttackTime; extern ULONG SrvDOSAttacks; extern BOOLEAN SrvLogEventOnDOS; #endif // // These are used for internal testing of the reauthentication code // extern USHORT SessionInvalidateCommand; extern USHORT SessionInvalidateMod; typedef struct _SRV_REAUTH_TEST_ { USHORT InvalidateCommand; USHORT InvalidateModulo; } SRV_REAUTH_TEST, *PSRV_REAUTH_TEST; // // These are used for LWIO server extensions // extern PBYTE SrvLWIOContext; extern ULONG SrvLWIOContextLength; extern PSRV_RESUME_CONTEXT_CALLBACK SrvLWIOCallback; #endif // ndef _SRVDATA_