/* * 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 #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 #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_ */