| 1 | // Licensed to the .NET Foundation under one or more agreements. | 
| 2 | // The .NET Foundation licenses this file to you under the MIT license. | 
| 3 | // See the LICENSE file in the project root for more information. | 
| 4 |  | 
| 5 | // | 
| 6 | // Logging Facility | 
| 7 | // | 
| 8 |  | 
| 9 |  | 
| 10 | // Logging Subsystems | 
| 11 |  | 
| 12 |  | 
| 13 | #ifndef __LOG_H__ | 
| 14 | #define __LOG_H__ | 
| 15 |  | 
| 16 |  | 
| 17 | #define DEFINE_LOG_FACILITY(logname, value)  logname = value, | 
| 18 |  | 
| 19 | enum { | 
| 20 | #include "loglf.h" | 
| 21 |     LF_ALWAYS        = 0x80000000, // Log message irrepespective of LogFacility (if the level matches) | 
| 22 |     LF_ALL           = 0xFFFFFFFF, // Used only to mask bits. Never use as LOG((LF_ALL, ...)) | 
| 23 |  | 
| 24 |     // LogFacility2: all 32-bit of LogFacility are used, need a 2nd DWORD for more facilities | 
| 25 |     LF2_MULTICOREJIT = 0x00000001  // Multicore JIT | 
| 26 | }; | 
| 27 |  | 
| 28 |  | 
| 29 | #define LL_EVERYTHING  10    | 
| 30 | #define LL_INFO1000000  9       // can be expected to generate 1,000,000 logs per small but not trival run | 
| 31 | #define LL_INFO100000   8       // can be expected to generate 100,000 logs per small but not trival run | 
| 32 | #define LL_INFO10000    7       // can be expected to generate 10,000 logs per small but not trival run | 
| 33 | #define LL_INFO1000     6       // can be expected to generate 1,000 logs per small but not trival run | 
| 34 | #define LL_INFO100      5       // can be expected to generate 100 logs per small but not trival run | 
| 35 | #define LL_INFO10       4       // can be expected to generate 10 logs per small but not trival run | 
| 36 | #define LL_WARNING      3 | 
| 37 | #define LL_ERROR        2 | 
| 38 | #define LL_FATALERROR   1 | 
| 39 | #define LL_ALWAYS   	0		// impossible to turn off (log level never negative) | 
| 40 |  | 
| 41 |  | 
| 42 | #define INFO5       LL_INFO10 | 
| 43 | #define INFO4       LL_INFO100 | 
| 44 | #define INFO3       LL_INFO1000 | 
| 45 | #define INFO2       LL_INFO10000 | 
| 46 | #define INFO1       LL_INFO100000 | 
| 47 | #define WARNING     0 | 
| 48 | #define ERROR       0 | 
| 49 | #define FATALERROR  0 | 
| 50 |  | 
| 51 | #ifndef LOGGING | 
| 52 |  | 
| 53 | #define LOG(x) | 
| 54 | #define LOG2(x) | 
| 55 |  | 
| 56 | #define InitializeLogging() | 
| 57 | #define InitLogging() | 
| 58 | #define ShutdownLogging() | 
| 59 | #define FlushLogging() | 
| 60 | #define LoggingOn(facility, level) 0 | 
| 61 | #define Logging2On(facility, level) 0 | 
| 62 | #define EnterLogLock() | 
| 63 | #define LeaveLogLock() | 
| 64 |  | 
| 65 | #else | 
| 66 |  | 
| 67 | extern VOID InitializeLogging(); | 
| 68 | extern VOID InitLogging(); | 
| 69 | extern VOID ShutdownLogging(); | 
| 70 | extern VOID FlushLogging(); | 
| 71 |  | 
| 72 | extern VOID LogSpew(DWORD facility, DWORD level, const char *fmt, ... ); | 
| 73 | extern VOID LogSpewValist(DWORD facility, DWORD level, const char *fmt, va_list args); | 
| 74 |  | 
| 75 | extern VOID LogSpew2(DWORD facility2, DWORD level, const char *fmt, ... ); | 
| 76 | extern VOID LogSpew2Valist(DWORD facility2, DWORD level, const char *fmt, va_list args); | 
| 77 |  | 
| 78 | extern VOID LogSpewAlwaysValist(const char *fmt, va_list args); | 
| 79 | extern VOID LogSpewAlways (const char *fmt, ... ); | 
| 80 | extern VOID EnterLogLock(); | 
| 81 | extern VOID LeaveLogLock(); | 
| 82 |  | 
| 83 | VOID AddLoggingFacility( DWORD facility ); | 
| 84 | VOID SetLoggingLevel( DWORD level ); | 
| 85 | bool LoggingEnabled(); | 
| 86 | bool LoggingOn(DWORD facility, DWORD level); | 
| 87 | bool Logging2On(DWORD facility, DWORD level); | 
| 88 |  | 
| 89 | #define LOG(x)      do { if (LoggingEnabled()) { LogSpew x; } } while (0) | 
| 90 |  | 
| 91 | #define LOG2(x)     do { if (LoggingEnabled()) { LogSpew2 x; } } while (0) | 
| 92 |  | 
| 93 | #endif | 
| 94 |  | 
| 95 | #ifdef __cplusplus | 
| 96 | #include "stresslog.h"		// special logging for retail code | 
| 97 | #endif | 
| 98 |  | 
| 99 | #endif //__LOG_H__ | 
| 100 |  |