| /* | 
 |  * ksdebug.h | 
 |  * | 
 |  * This file is part of the ReactOS PSDK package. | 
 |  * | 
 |  * Contributors: | 
 |  *   Created by Magnus Olsen. | 
 |  * | 
 |  * THIS SOFTWARE IS NOT COPYRIGHTED | 
 |  * | 
 |  * This source code is offered for use in the public domain. You may | 
 |  * use, modify or distribute it freely. | 
 |  * | 
 |  * This code is distributed in the hope that it will be useful but | 
 |  * WITHOUT ANY WARRANTY. ALL WARRANTIES, EXPRESS OR IMPLIED ARE HEREBY | 
 |  * DISCLAIMED. This includes but is not limited to warranties of | 
 |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | 
 |  * | 
 |  */ | 
 |  | 
 | #include <evntrace.h> | 
 |  | 
 | #if !defined(_KSDEBUG_) | 
 | #define _KSDEBUG_ | 
 |  | 
 | #if !defined(REMIND) | 
 | #define QUOTE(x) #x | 
 | #define QQUOTE(y) QUOTE(y) | 
 | #define REMIND(str) __FILE__ "(" QQUOTE(__LINE__) ") : " str | 
 | #endif | 
 |  | 
 | #if defined(__cplusplus) | 
 | extern "C" { | 
 | #endif | 
 |  | 
 | #if (DBG) | 
 |  | 
 | #if defined(IRPMJFUNCDESC) | 
 | static const PCHAR IrpMjFuncDesc[] = { | 
 |   "IRP_MJ_CREATE", | 
 |   "IRP_MJ_CREATE_NAMED_PIPE", | 
 |   "IRP_MJ_CLOSE", | 
 |   "IRP_MJ_READ", | 
 |   "IRP_MJ_WRITE", | 
 |   "IRP_MJ_QUERY_INFORMATION", | 
 |   "IRP_MJ_SET_INFORMATION", | 
 |   "IRP_MJ_QUERY_EA", | 
 |   "IRP_MJ_SET_EA", | 
 |   "IRP_MJ_FLUSH_BUFFERS", | 
 |   "IRP_MJ_QUERY_VOLUME_INFORMATION", | 
 |   "IRP_MJ_SET_VOLUME_INFORMATION", | 
 |   "IRP_MJ_DIRECTORY_CONTROL", | 
 |   "IRP_MJ_FILE_SYSTEM_CONTROL", | 
 |   "IRP_MJ_DEVICE_CONTROL", | 
 |   "IRP_MJ_INTERNAL_DEVICE_CONTROL", | 
 |   "IRP_MJ_SHUTDOWN", | 
 |   "IRP_MJ_LOCK_CONTROL", | 
 |   "IRP_MJ_CLEANUP", | 
 |   "IRP_MJ_CREATE_MAILSLOT", | 
 |   "IRP_MJ_QUERY_SECURITY", | 
 |   "IRP_MJ_SET_SECURITY", | 
 |   "IRP_MJ_SET_POWER", | 
 |   "IRP_MJ_QUERY_POWER" | 
 | }; | 
 | #endif /* defined(IRPMJFUNCDESC) */ | 
 |  | 
 | #endif /* DBG */ | 
 |  | 
 | #if defined(_NTDDK_) | 
 |  | 
 | #define DEBUGLVL_BLAB TRACE_LEVEL_VERBOSE | 
 | #define DEBUGLVL_VERBOSE TRACE_LEVEL_VERBOSE | 
 | #define DEBUGLVL_TERSE TRACE_LEVEL_INFORMATION | 
 | #define DEBUGLVL_ERROR TRACE_LEVEL_ERROR | 
 |  | 
 | #define DEBUGLVL_WARNING TRACE_LEVEL_WARNING | 
 | #define DEBUGLVL_INFO TRACE_LEVEL_INFORMATION | 
 |  | 
 | #if (DBG) | 
 | # if !defined( DEBUG_LEVEL ) | 
 | #   if defined( DEBUG_VARIABLE ) | 
 | #     if defined( KSDEBUG_INIT ) | 
 | 	ULONG DEBUG_VARIABLE = DEBUGLVL_TERSE; | 
 | #     else | 
 | 	extern ULONG DEBUG_VARIABLE; | 
 | #     endif | 
 | #   else | 
 | #	define DEBUG_VARIABLE DEBUGLVL_TERSE | 
 | #   endif | 
 | # else | 
 | #   if defined( DEBUG_VARIABLE ) | 
 | #     if defined( KSDEBUG_INIT ) | 
 | 	ULONG DEBUG_VARIABLE = DEBUG_LEVEL; | 
 | #     else | 
 | 	extern ULONG DEBUG_VARIABLE; | 
 | #     endif | 
 | #   else | 
 | #	define DEBUG_VARIABLE DEBUG_LEVEL | 
 | #   endif | 
 | # endif | 
 |  | 
 | #if (NTDDI_VERSION >= NTDDI_WINXP) | 
 | #  define _DbgPrintFEx(component, lvl, strings) {		\ | 
 |     if ((lvl) <= DEBUG_VARIABLE) {				\ | 
 |       DbgPrintEx(component, lvl, STR_MODULENAME);		\ | 
 |       DbgPrintEx(component, lvl, strings);			\ | 
 |       DbgPrintEx(component, lvl, "\n");				\ | 
 |       if ((lvl) == DEBUGLVL_ERROR) {				\ | 
 | 	DbgBreakPoint();					\ | 
 |       }								\ | 
 |     }								\ | 
 |   } | 
 | #endif /* (NTDDI_VERSION >= NTDDI_WINXP) */ | 
 |  | 
 | #  define _DbgPrintF(lvl, strings) {				\ | 
 |     if (((lvl)==DEBUG_VARIABLE) || (lvl < DEBUG_VARIABLE)) {	\ | 
 |       DbgPrint(STR_MODULENAME);					\ | 
 |       DbgPrint##strings;					\ | 
 |       DbgPrint("\n");						\ | 
 |       if ((lvl) == DEBUGLVL_ERROR) {				\ | 
 | 	DbgBreakPoint();					\ | 
 |       }								\ | 
 |     }								\ | 
 |   } | 
 |  | 
 | #else /* ! DBG */ | 
 |  | 
 | #define _DbgPrintF(lvl, strings) | 
 |  | 
 | #if (NTDDI_VERSION >= NTDDI_WINXP) | 
 | #define _DbgPrintFEx(component, lvl, strings) | 
 | #endif | 
 |  | 
 | #endif /* DBG */ | 
 |  | 
 | #endif /* defined(_NTDDK_) */ | 
 |  | 
 | #if defined(__cplusplus) | 
 | } | 
 | #endif | 
 |  | 
 | #endif /* _KSDEBUG_ */ |