// // Constants used to identify what general structure has been initialized. // #define INIT_SA_DATABASE 0x00000001 #define INIT_MDL_POOLS 0x00000002 #define INIT_CACHE_STRUCT 0x00000004 #define INIT_DEBUG_MEMORY 0x00000008 #define INIT_TIMERS 0x00000010 #define WORK_BUFFER_SIZE 256 #define IPSEC_REG_KEY L"\\Registry\\Machine\\System\\CurrentControlSet\\Services\\IPSEC" #define IPSEC_REG_PARAM_ENABLE_OFFLOAD L"EnableOffload" #define IPSEC_REG_PARAM_SA_IDLE_TIME L"SAIdleTime" #define IPSEC_REG_PARAM_EVENT_QUEUE_SIZE L"EventQueueSize" #define IPSEC_REG_PARAM_LOG_INTERVAL L"LogInterval" #define IPSEC_REG_PARAM_REKEY_TIME L"RekeyTime" #define IPSEC_REG_PARAM_CACHE_SIZE L"CacheSize" #define IPSEC_REG_PARAM_SA_HASH_SIZE L"SAHashSize" #define IPSEC_REG_PARAM_NO_DEFAULT_EXEMPT L"NoDefaultExempt" #define IPSEC_REG_PARAM_ENABLE_DIAGNOSTICS L"EnableDiagnostics" #define IPSEC_REG_PARAM_OPERATION_MODE L"OperationMode" // // Enable offload. // #define IPSEC_DEFAULT_ENABLE_OFFLOAD 1 #define IPSEC_MIN_ENABLE_OFFLOAD 0 #define IPSEC_MAX_ENABLE_OFFLOAD 1 // // SA idle time. // #define IPSEC_DEFAULT_SA_IDLE_TIME (5 * 60) #define IPSEC_MIN_SA_IDLE_TIME (5 * 60) #define IPSEC_MAX_SA_IDLE_TIME (60 * 60) // // Log interval. // #define IPSEC_DEFAULT_LOG_INTERVAL (60 * 60) #define IPSEC_MIN_LOG_INTERVAL (60) #define IPSEC_MAX_LOG_INTERVAL (24 * 60 * 60) // // Event queue size. // #define IPSEC_DEFAULT_EVENT_QUEUE_SIZE 50 #define IPSEC_MIN_EVENT_QUEUE_SIZE 10 #define IPSEC_MAX_EVENT_QUEUE_SIZE 500 // // Rekey time. // #define IPSEC_DEFAULT_REKEY 600 #define IPSEC_MIN_REKEY 300 #define IPSEC_MAX_REKEY 1500 // // No kerberos exempt. // #define IPSEC_DEFAULT_NO_DEFAULT_EXEMPT 0 #define IPSEC_MIN_NO_DEFAULT_EXEMPT 0 #define IPSEC_MAX_NO_DEFAULT_EXEMPT 3 #define IPSEC_DIAGNOSTIC_ENABLE_LOG 0x00000001 #define IPSEC_DIAGNOSTIC_INBOUND 0x00000002 #define IPSEC_DIAGNOSTIC_OUTBOUND 0x00000004 #define IPSEC_DEFAULT_ENABLE_DIAGNOSTICS 0 #define IPSEC_MIN_ENABLE_DIAGNOSTICS 0 #define IPSEC_MAX_ENABLE_DIAGNOSTICS 0x00000007 // // First level (IP header based) cache size. // #define IPSEC_DEFAULT_CACHE_SIZE 64 #define IPSEC_DEFAULT_AS_CACHE_SIZE 1024 #define IPSEC_MIN_CACHE_SIZE 64 #define IPSEC_MAX_CACHE_SIZE 4096 // // Size of the hash table for inbound SAs. // #define IPSEC_DEFAULT_SA_HASH_SIZE 64 #define IPSEC_DEFAULT_AS_SA_HASH_SIZE 1024 #define IPSEC_MIN_SA_HASH_SIZE 64 #define IPSEC_MAX_SA_HASH_SIZE 4096 NTSTATUS DriverEntry( IN PDRIVER_OBJECT DriverObject, IN PUNICODE_STRING RegistryPath ); VOID IPSecUnload( IN PDRIVER_OBJECT DriverObject ); NTSTATUS IPSecDispatch( IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp ); NTSTATUS IPSecBindToIP( ); NTSTATUS IPSecUnbindFromIP( ); NTSTATUS IPSecUnbindSendFromIP( ); NTSTATUS OpenRegKey( PHANDLE HandlePtr, PWCHAR KeyName ); NTSTATUS GetRegDWORDValue( HANDLE KeyHandle, PWCHAR ValueName, PULONG ValueData ); NTSTATUS GetRegStringValue( HANDLE KeyHandle, PWCHAR ValueName, PKEY_VALUE_PARTIAL_INFORMATION *ValueData, PUSHORT ValueSize ); NTSTATUS GetRegMultiSZValue( HANDLE KeyHandle, PWCHAR ValueName, PUNICODE_STRING ValueData ); VOID IPSecReadRegistry( ); NTSTATUS IPSecGeneralInit( ); NTSTATUS IPSecGeneralFree( ); NTSTATUS IPSecFreeConfig( ); NTSTATUS IPSecInitMdlPool( ); VOID IPSecDeinitMdlPool( ); NTSTATUS IPSecQuiesce( ); BOOLEAN AllocateCacheStructures( ); VOID FreeExistingCache( ); VOID FreePatternDbase( ); SIZE_T IPSecCalculateBufferSize( IN SIZE_T BufferDataSize ); VOID IPSecInitializeBuffer( IN PIPSEC_LA_BUFFER IPSecBuffer, IN SIZE_T BufferDataSize ); PVOID IPSecAllocateBufferPool( IN POOL_TYPE PoolType, IN SIZE_T NumberOfBytes, IN ULONG Tag ); PIPSEC_LA_BUFFER IPSecGetBuffer( IN CLONG BufferDataSize, IN ULONG Tag ); VOID IPSecReturnBuffer ( IN PIPSEC_LA_BUFFER IPSecBuffer ); NTSTATUS IPSecWriteEvent( PDRIVER_OBJECT IPSecDriverObject, IN ULONG EventCode, IN NTSTATUS NtStatusCode, IN ULONG OffloadStatus, IN ULONG ExtraStatus1, IN ULONG ExtraStatus2, IN PVOID RawDataBuffer, IN USHORT RawDataLength, IN USHORT NumberOfInsertionStrings, ... ); VOID IPSecLogEvents( IN PVOID Context ); VOID IPSecBufferEvent( IN IPAddr Addr, IN ULONG EventCode, IN ULONG UniqueEventValue, IN BOOLEAN fBufferEvent ); NTSTATUS CopyOutboundPacketToBuffer( IN PUCHAR pIPHeader, IN PVOID pData, OUT PUCHAR * pPacket, OUT ULONG * PacketSize ); NTSTATUS CopyInboundPacketToBuffer( IN PUCHAR pIPHeader, IN PVOID pData, OUT PUCHAR * pPacket, OUT ULONG * PacketSize ); VOID IPSecBufferPacketDrop( IN PUCHAR pIPHeader, IN PVOID pData, IN OUT PULONG pIpsecFlags, IN PIPSEC_DROP_STATUS pDropStatus ); VOID IPSecQueueLogEvent( VOID ); #if FIPS BOOLEAN IPSecFipsInitialize( VOID ); #endif BOOLEAN IPSecCryptoInitialize( VOID ); BOOLEAN IPSecCryptoDeinitialize( VOID ); NTSTATUS IPSecRegisterProtocols( PIPSEC_REGISTER_PROTOCOL pIpsecRegisterProtocol );