| /** |
| * This file has no copyright assigned and is placed in the Public Domain. |
| * This file is part of the mingw-w64 runtime package. |
| * No warranty is given; refer to the file DISCLAIMER.PD within this package. |
| */ |
| #ifndef __ROUTING_RTUTILS_H__ |
| #define __ROUTING_RTUTILS_H__ |
| |
| #include <_mingw_unicode.h> |
| |
| #ifdef __cplusplus |
| extern "C" { |
| #endif |
| |
| #define TRACE_USE_FILE 0x00000001 |
| #define TRACE_USE_CONSOLE 0x00000002 |
| #define TRACE_NO_SYNCH 0x00000004 |
| |
| #define TRACE_NO_STDINFO 0x00000001 |
| #define TRACE_USE_MASK 0x00000002 |
| #define TRACE_USE_MSEC 0x00000004 |
| #define TRACE_USE_DATE 0x00000008 |
| |
| #define INVALID_TRACEID 0xFFFFFFFF |
| |
| DWORD WINAPI TraceRegisterExA(LPCSTR lpszCallerName,DWORD dwFlags); |
| DWORD WINAPI TraceDeregisterA(DWORD dwTraceID); |
| DWORD WINAPI TraceDeregisterExA(DWORD dwTraceID,DWORD dwFlags); |
| DWORD WINAPI TraceGetConsoleA(DWORD dwTraceID,LPHANDLE lphConsole); |
| DWORD __cdecl TracePrintfA(DWORD dwTraceID,LPCSTR lpszFormat,...); |
| DWORD __cdecl TracePrintfExA(DWORD dwTraceID,DWORD dwFlags,LPCSTR lpszFormat,...); |
| DWORD WINAPI TraceVprintfExA(DWORD dwTraceID,DWORD dwFlags,LPCSTR lpszFormat,va_list arglist); |
| DWORD WINAPI TracePutsExA(DWORD dwTraceID,DWORD dwFlags,LPCSTR lpszString); |
| DWORD WINAPI TraceDumpExA(DWORD dwTraceID,DWORD dwFlags,LPBYTE lpbBytes,DWORD dwByteCount,DWORD dwGroupSize,WINBOOL bAddressPrefix,LPCSTR lpszPrefix); |
| |
| #define TraceRegisterA(a) TraceRegisterExA(a,0) |
| #define TraceVprintfA(a,b,c) TraceVprintfExA(a,0,b,c) |
| #define TracePutsA(a,b) TracePutsExA(a,0,b) |
| #define TraceDumpA(a,b,c,d,e,f) TraceDumpExA(a,0,b,c,d,e,f) |
| |
| DWORD WINAPI TraceRegisterExW(LPCWSTR lpszCallerName,DWORD dwFlags); |
| DWORD WINAPI TraceDeregisterW(DWORD dwTraceID); |
| DWORD WINAPI TraceDeregisterExW(DWORD dwTraceID,DWORD dwFlags); |
| DWORD WINAPI TraceGetConsoleW(DWORD dwTraceID,LPHANDLE lphConsole); |
| DWORD __cdecl TracePrintfW(DWORD dwTraceID,LPCWSTR lpszFormat,...); |
| DWORD __cdecl TracePrintfExW(DWORD dwTraceID,DWORD dwFlags,LPCWSTR lpszFormat,...); |
| DWORD WINAPI TraceVprintfExW(DWORD dwTraceID,DWORD dwFlags,LPCWSTR lpszFormat,va_list arglist); |
| DWORD WINAPI TracePutsExW(DWORD dwTraceID,DWORD dwFlags,LPCWSTR lpszString); |
| DWORD WINAPI TraceDumpExW(DWORD dwTraceID,DWORD dwFlags,LPBYTE lpbBytes,DWORD dwByteCount,DWORD dwGroupSize,WINBOOL bAddressPrefix,LPCWSTR lpszPrefix); |
| |
| #define TraceRegisterW(a) TraceRegisterExW(a,0) |
| #define TraceVprintfW(a,b,c) TraceVprintfExW(a,0,b,c) |
| #define TracePutsW(a,b) TracePutsExW(a,0,b) |
| #define TraceDumpW(a,b,c,d,e,f) TraceDumpExW(a,0,b,c,d,e,f) |
| |
| #define TraceRegister __MINGW_NAME_AW(TraceRegister) |
| #define TraceDeregister __MINGW_NAME_AW(TraceDeregister) |
| #define TraceDeregisterEx __MINGW_NAME_AW(TraceDeregisterEx) |
| #define TraceGetConsole __MINGW_NAME_AW(TraceGetConsole) |
| #define TracePrintf __MINGW_NAME_AW(TracePrintf) |
| #define TraceVprintf __MINGW_NAME_AW(TraceVprintf) |
| #define TracePuts __MINGW_NAME_AW(TracePuts) |
| #define TraceDump __MINGW_NAME_AW(TraceDump) |
| #define TraceRegisterEx __MINGW_NAME_AW(TraceRegisterEx) |
| #define TracePrintfEx __MINGW_NAME_AW(TracePrintfEx) |
| #define TraceVprintfEx __MINGW_NAME_AW(TraceVprintfEx) |
| #define TracePutsEx __MINGW_NAME_AW(TracePutsEx) |
| #define TraceDumpEx __MINGW_NAME_AW(TraceDumpEx) |
| |
| VOID WINAPI LogErrorA(DWORD dwMessageId,DWORD cNumberOfSubStrings,LPSTR *plpwsSubStrings,DWORD dwErrorCode); |
| VOID WINAPI LogEventA(DWORD wEventType,DWORD dwMessageId,DWORD cNumberOfSubStrings,LPSTR *plpwsSubStrings); |
| VOID LogErrorW(DWORD dwMessageId,DWORD cNumberOfSubStrings,LPWSTR *plpwsSubStrings,DWORD dwErrorCode); |
| VOID LogEventW(DWORD wEventType,DWORD dwMessageId,DWORD cNumberOfSubStrings,LPWSTR *plpwsSubStrings); |
| |
| #define LogError __MINGW_NAME_AW(LogError) |
| #define LogEvent __MINGW_NAME_AW(LogEvent) |
| |
| HANDLE RouterLogRegisterA(LPCSTR lpszSource); |
| VOID RouterLogDeregisterA(HANDLE hLogHandle); |
| VOID RouterLogEventA(HANDLE hLogHandle,DWORD dwEventType,DWORD dwMessageId,DWORD dwSubStringCount,LPSTR *plpszSubStringArray,DWORD dwErrorCode); |
| VOID RouterLogEventDataA(HANDLE hLogHandle,DWORD dwEventType,DWORD dwMessageId,DWORD dwSubStringCount,LPSTR *plpszSubStringArray,DWORD dwDataBytes,LPBYTE lpDataBytes); |
| VOID RouterLogEventStringA(HANDLE hLogHandle,DWORD dwEventType,DWORD dwMessageId,DWORD dwSubStringCount,LPSTR *plpszSubStringArray,DWORD dwErrorCode,DWORD dwErrorIndex); |
| VOID __cdecl RouterLogEventExA(HANDLE hLogHandle,DWORD dwEventType,DWORD dwErrorCode,DWORD dwMessageId,LPCSTR ptszFormat,...); |
| VOID RouterLogEventValistExA(HANDLE hLogHandle,DWORD dwEventType,DWORD dwErrorCode,DWORD dwMessageId,LPCSTR ptszFormat,va_list arglist); |
| DWORD RouterGetErrorStringA(DWORD dwErrorCode,LPSTR *lplpszErrorString); |
| |
| #define RouterLogErrorA(h,msg,count,array,err) RouterLogEventA(h,EVENTLOG_ERROR_TYPE,msg,count,array,err) |
| #define RouterLogWarningA(h,msg,count,array,err) RouterLogEventA(h,EVENTLOG_WARNING_TYPE,msg,count,array,err) |
| #define RouterLogInformationA(h,msg,count,array,err) RouterLogEventA(h,EVENTLOG_INFORMATION_TYPE,msg,count,array,err) |
| |
| #define RouterLogErrorDataA(h,msg,count,array,c,buf) RouterLogEventDataA(h,EVENTLOG_ERROR_TYPE,msg,count,array,c,buf) |
| #define RouterLogWarningDataA(h,msg,count,array,c,buf) RouterLogEventDataA(h,EVENTLOG_WARNING_TYPE,msg,count,array,c,buf) |
| #define RouterLogInformationDataA(h,msg,count,array,c,buf) RouterLogEventDataA(h,EVENTLOG_INFORMATION_TYPE,msg,count,array,c,buf) |
| |
| #define RouterLogErrorStringA(h,msg,count,array,err,index) RouterLogEventStringA(h,EVENTLOG_ERROR_TYPE,msg,count,array,err,index) |
| #define RouterLogWarningStringA(h,msg,count,array,err,index) RouterLogEventStringA(h,EVENTLOG_WARNING_TYPE,msg,count,array,err,index) |
| #define RouterLogInformationStringA(h,msg,count,array,err,index) RouterLogEventStringA(h,EVENTLOG_INFORMATION_TYPE,msg,count,array,err,index) |
| |
| HANDLE RouterLogRegisterW(LPCWSTR lpszSource); |
| VOID RouterLogDeregisterW(HANDLE hLogHandle); |
| VOID RouterLogEventW(HANDLE hLogHandle,DWORD dwEventType,DWORD dwMessageId,DWORD dwSubStringCount,LPWSTR *plpszSubStringArray,DWORD dwErrorCode); |
| VOID RouterLogEventDataW(HANDLE hLogHandle,DWORD dwEventType,DWORD dwMessageId,DWORD dwSubStringCount,LPWSTR *plpszSubStringArray,DWORD dwDataBytes,LPBYTE lpDataBytes); |
| VOID RouterLogEventStringW(HANDLE hLogHandle,DWORD dwEventType,DWORD dwMessageId,DWORD dwSubStringCount,LPWSTR *plpszSubStringArray,DWORD dwErrorCode,DWORD dwErrorIndex); |
| VOID __cdecl RouterLogEventExW(HANDLE hLogHandle,DWORD dwEventType,DWORD dwErrorCode,DWORD dwMessageId,LPCWSTR ptszFormat,...); |
| VOID RouterLogEventValistExW(HANDLE hLogHandle,DWORD dwEventType,DWORD dwErrorCode,DWORD dwMessageId,LPCWSTR ptszFormat,va_list arglist); |
| DWORD RouterGetErrorStringW(DWORD dwErrorCode,LPWSTR *lplpwszErrorString); |
| |
| #define RouterLogErrorW(h,msg,count,array,err) RouterLogEventW(h,EVENTLOG_ERROR_TYPE,msg,count,array,err) |
| #define RouterLogWarningW(h,msg,count,array,err) RouterLogEventW(h,EVENTLOG_WARNING_TYPE,msg,count,array,err) |
| #define RouterLogInformationW(h,msg,count,array,err) RouterLogEventW(h,EVENTLOG_INFORMATION_TYPE,msg,count,array,err) |
| |
| #define RouterLogErrorDataW(h,msg,count,array,c,buf) RouterLogEventDataW(h,EVENTLOG_ERROR_TYPE,msg,count,array,c,buf) |
| #define RouterLogWarningDataW(h,msg,count,array,c,buf) RouterLogEventDataW(h,EVENTLOG_WARNING_TYPE,msg,count,array,c,buf) |
| #define RouterLogInformationDataW(h,msg,count,array,c,buf) RouterLogEventDataW(h,EVENTLOG_INFORMATION_TYPE,msg,count,array,c,buf) |
| |
| #define RouterLogErrorStringW(h,msg,count,array,err,index) RouterLogEventStringW(h,EVENTLOG_ERROR_TYPE,msg,count,array,err,index) |
| #define RouterLogWarningStringW(h,msg,count,array,err,index) RouterLogEventStringW(h,EVENTLOG_WARNING_TYPE,msg,count,array,err,index) |
| #define RouterLogInformationStringW(h,msg,count,array,err,index) RouterLogEventStringW(h,EVENTLOG_INFORMATION_TYPE,msg,count,array,err,index) |
| |
| #define RouterLogRegister __MINGW_NAME_AW(RouterLogRegister) |
| #define RouterLogDeregister __MINGW_NAME_AW(RouterLogDeregister) |
| #define RouterLogEvent __MINGW_NAME_AW(RouterLogEvent) |
| #define RouterLogError __MINGW_NAME_AW(RouterLogError) |
| #define RouterLogWarning __MINGW_NAME_AW(RouterLogWarning) |
| #define RouterLogInformation __MINGW_NAME_AW(RouterLogInformation) |
| |
| #define RouterLogEventData __MINGW_NAME_AW(RouterLogEventData) |
| #define RouterLogErrorData __MINGW_NAME_AW(RouterLogErrorData) |
| #define RouterLogWarningData __MINGW_NAME_AW(RouterLogWarningData) |
| #define RouterLogInformationData __MINGW_NAME_AW(RouterLogInformationData) |
| #define RouterLogEventString __MINGW_NAME_AW(RouterLogEventString) |
| #define RouterLogEventEx __MINGW_NAME_AW(RouterLogEventEx) |
| #define RouterLogEventValistEx __MINGW_NAME_AW(RouterLogEventValistEx) |
| #define RouterLogErrorString __MINGW_NAME_AW(RouterLogErrorString) |
| #define RouterLogWarningString __MINGW_NAME_AW(RouterLogWarningString) |
| #define RouterLogInformationString __MINGW_NAME_AW(RouterLogInformationString) |
| #define RouterGetErrorString __MINGW_NAME_AW(RouterGetErrorString) |
| |
| typedef VOID (WINAPI *WORKERFUNCTION)(PVOID); |
| |
| DWORD WINAPI QueueWorkItem(WORKERFUNCTION functionptr,PVOID context,WINBOOL serviceinalertablethread); |
| DWORD WINAPI SetIoCompletionProc(HANDLE FileHandle,LPOVERLAPPED_COMPLETION_ROUTINE CompletionProc); |
| |
| #define NUM_ALERTABLE_THREADS 2 |
| #define MAX_WORKER_THREADS 10 |
| #define WORK_QUEUE_TIMEOUT 1 |
| #define THREAD_IDLE_TIMEOUT 10 |
| |
| VOID RouterAssert(PSTR pszFailedAssertion,PSTR pszFileName,DWORD dwLineNumber,PSTR pszMessage); |
| |
| #define RTASSERT(exp) |
| #define RTASSERTMSG(msg,exp) |
| |
| #define RTUTILS_MAX_PROTOCOL_NAME_LEN 40 |
| #define RTUTILS_MAX_PROTOCOL_DLL_LEN 48 |
| |
| #ifndef MAX_PROTOCOL_NAME_LEN |
| #define MAX_PROTOCOL_NAME_LEN RTUTILS_MAX_PROTOCOL_NAME_LEN |
| #else |
| #undef MAX_PROTOCOL_NAME_LEN |
| #endif |
| #define MAX_PROTOCOL_DLL_LEN RTUTILS_MAX_PROTOCOL_DLL_LEN |
| |
| typedef struct _MPR_PROTOCOL_0 { |
| DWORD dwProtocolId; |
| WCHAR wszProtocol[RTUTILS_MAX_PROTOCOL_NAME_LEN+1]; |
| WCHAR wszDLLName[RTUTILS_MAX_PROTOCOL_DLL_LEN+1]; |
| } MPR_PROTOCOL_0; |
| |
| DWORD WINAPI MprSetupProtocolEnum(DWORD dwTransportId,LPBYTE *lplpBuffer,LPDWORD lpdwEntriesRead); |
| DWORD WINAPI MprSetupProtocolFree(LPVOID lpBuffer); |
| |
| #define ROUTING_RESERVED |
| #define OPT1_1 |
| #define OPT1_2 |
| #define OPT2_1 |
| #define OPT2_2 |
| #define OPT3_1 |
| #define OPT3_2 |
| |
| struct _WAIT_THREAD_ENTRY; |
| struct _WT_EVENT_ENTRY; |
| |
| #define TIMER_INACTIVE 3 |
| #define TIMER_ACTIVE 4 |
| |
| typedef struct _WT_TIMER_ENTRY { |
| LONGLONG te_Timeout; |
| WORKERFUNCTION te_Function; |
| PVOID te_Context; |
| DWORD te_ContextSz; |
| WINBOOL te_RunInServer; |
| DWORD te_Status; |
| DWORD te_ServerId; |
| struct _WAIT_THREAD_ENTRY *teP_wte; |
| LIST_ENTRY te_ServerLinks; |
| LIST_ENTRY te_Links; |
| WINBOOL te_Flag; |
| DWORD te_TimerId; |
| } WT_TIMER_ENTRY,*PWT_TIMER_ENTRY; |
| |
| typedef struct _WT_WORK_ITEM { |
| WORKERFUNCTION wi_Function; |
| PVOID wi_Context; |
| DWORD wi_ContextSz; |
| WINBOOL wi_RunInServer; |
| struct _WT_EVENT_ENTRY *wiP_ee; |
| LIST_ENTRY wi_ServerLinks; |
| LIST_ENTRY wi_Links; |
| } WT_WORK_ITEM,*PWT_WORK_ITEM; |
| |
| #define WT_EVENT_BINDING WT_WORK_ITEM |
| #define PWT_EVENT_BINDING PWT_WORK_ITEM |
| |
| typedef struct _WT_EVENT_ENTRY { |
| HANDLE ee_Event; |
| WINBOOL ee_bManualReset; |
| WINBOOL ee_bInitialState; |
| WINBOOL ee_bDeleteEvent; |
| DWORD ee_Status; |
| WINBOOL ee_bHighPriority; |
| |
| LIST_ENTRY eeL_wi; |
| WINBOOL ee_bSignalSingle; |
| WINBOOL ee_bOwnerSelf; |
| INT ee_ArrayIndex; |
| DWORD ee_ServerId; |
| struct _WAIT_THREAD_ENTRY *eeP_wte; |
| LIST_ENTRY ee_ServerLinks; |
| LIST_ENTRY ee_Links; |
| DWORD ee_RefCount; |
| WINBOOL ee_bFlag; |
| DWORD ee_EventId; |
| } WT_EVENT_ENTRY,*PWT_EVENT_ENTRY; |
| |
| PWT_EVENT_ENTRY WINAPI CreateWaitEvent(HANDLE pEvent OPT1_1,LPSECURITY_ATTRIBUTES lpEventAttributes OPT1_2,WINBOOL bManualReset,WINBOOL bInitialState,LPCTSTR lpName OPT1_2,WINBOOL bHighPriority,WORKERFUNCTION pFunction OPT2_1,PVOID pContext OPT2_1,DWORD dwContextSz OPT2_1,WINBOOL bRunInServerContext OPT2_1); |
| PWT_EVENT_BINDING WINAPI CreateWaitEventBinding(PWT_EVENT_ENTRY pee,WORKERFUNCTION pFunction,PVOID pContext,DWORD dwContextSz,WINBOOL bRunInServerContext); |
| PWT_TIMER_ENTRY WINAPI CreateWaitTimer(WORKERFUNCTION pFunction,PVOID pContext,DWORD dwContextSz,WINBOOL bRunInServerContext); |
| DWORD WINAPI DeRegisterWaitEventBindingSelf(PWT_EVENT_BINDING pwiWorkItem); |
| DWORD WINAPI DeRegisterWaitEventBinding(PWT_EVENT_BINDING pwiWorkItem); |
| DWORD WINAPI DeRegisterWaitEventsTimers (PLIST_ENTRY pLEvents,PLIST_ENTRY pLTimers); |
| DWORD WINAPI DeRegisterWaitEventsTimersSelf(PLIST_ENTRY pLEvents,PLIST_ENTRY pLTimers); |
| DWORD WINAPI RegisterWaitEventBinding(PWT_EVENT_BINDING pwiWorkItem); |
| DWORD WINAPI RegisterWaitEventsTimers(PLIST_ENTRY pLEventsToAdd,PLIST_ENTRY pLTimersToAdd); |
| DWORD WINAPI UpdateWaitTimer(PWT_TIMER_ENTRY pte,LONGLONG *time); |
| VOID WINAPI WTFree (PVOID ptr); |
| VOID WINAPI WTFreeEvent(PWT_EVENT_ENTRY peeEvent); |
| VOID WINAPI WTFreeTimer(PWT_TIMER_ENTRY pteTimer); |
| VOID WINAPI DebugPrintWaitWorkerThreads (DWORD dwDebugLevel); |
| |
| #define DEBUGPRINT_FILTER_NONCLIENT_EVENTS 0x2 |
| #define DEBUGPRINT_FILTER_EVENTS 0x4 |
| #define DEBUGPRINT_FILTER_TIMERS 0x8 |
| |
| #define ERROR_WAIT_THREAD_UNAVAILABLE 1 |
| #define ERROR_WT_EVENT_ALREADY_DELETED 2 |
| #define TIMER_HIGH(time) (((LARGE_INTEGER*)&time)->HighPart) |
| #define TIMER_LOW(time) (((LARGE_INTEGER*)&time)->LowPart) |
| |
| #ifdef __cplusplus |
| } |
| #endif |
| #endif |