WinDBG设置debug msg 输出信息级别
在Vista之后,debug信息可以用DbgPrintEx或KdPrintEx有条件地输出。(之前的2003 server或xp等,则是无条件输出,需要自己封装,设定debug信息级别)
DbgPrintEx在WinDBG中的信息级别按照如下方式定义:
而常用的Level则有:
#define DPFLTR_WARNING_LEVEL 1
#define DPFLTR_TRACE_LEVEL 2
#define DPFLTR_INFO_LEVEL 3
#define DPFLTR_MASK 0x8000000
在WinDBG中可以动态修改Debug信息的输出级别,方式如下:
kd> ed Kd_IHVVIDEO_Mask 0x8
即在WinDBG的命令模式下设置Kd_XXX_Mask,如上条命令中IHVVIDEO表示设置显卡driver的mask。
注意这里设定的mask还需要ORed WIN2000 system-wide mask(0x1)。
Debug信息的过滤方式:
1> 如果level小于等于31,判断(1<<level & Kd_IHVVIDEO_Mask)是否为0,不为0则输出
2> 如果level大于31,则直接判断(level & Kd_IHVVIDEO_Mask),从而决定是否输出
BTW:在WinDBG v6.6中似乎不行,但WinDBG v6.7中该方法可行