zoukankan      html  css  js  c++  java
  • WinDBG设置debug msg 输出信息级别

    在Vista之后,debug信息可以用DbgPrintEx或KdPrintEx有条件地输出。(之前的2003 server或xp等,则是无条件输出,需要自己封装,设定debug信息级别)

    DbgPrintEx在WinDBG中的信息级别按照如下方式定义:

  • If Level is equal to a number between 0 and 31, inclusive, it is interpreted as a bit shift. The importance bit field is set to the value 1 << Level. Thus choosing a value between 0 and 31 for Level results in a bit field with exactly one bit set. If Level is 0, the bit field is equivalent to 0x00000001;if Level is 31, the bit field is equivalent to 0x80000000.
  • If Level is a number between 32 and 0xFFFFFFFF inclusive, the importance bit field is set to the value of Level itself. 
  • 而常用的Level则有:
    #define   DPFLTR_ERROR_LEVEL     0
    #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中该方法可行

查看全文
  • 相关阅读:
    【1】排行榜算法设计
    基础问答【二】
    基础问答【一】
    【1】c语言
    (五)帧同步与状态同步
    (四)c++虚函数详解
    (三)git pull报错解决方案,Your local changes to the following files would be overwritten by merge
    (二)干货!获取该目录下,指定权限不为770的文件, 并设置权限为770
    【8】java新特性,双冒号 :: 的使用场景
    go(01) 基础语法
  • 原文地址:https://www.cnblogs.com/dust/p/1297080.html
  • Copyright © 2011-2022 走看看