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