zoukankan      html  css  js  c++  java
  • 学习使用常用的windbg命令(u、dt、ln、x)

    http://blog.csdn.net/wesley2005/article/details/51501514

    目录:

    (1) u命令(反汇编)

    (2) dt命令(查看数据结构

    (3) ln命令(查找就近的符号)

    (4) x命令(显示模块的符号)

    (5) k命令(显示调用栈)

    (6) d命令(以数据方式显示)

    (7) b命令(断点)

    (8) lm lmvm (显示模块信息)

    (9) .reload (重加载模块)

    (10) !process !thread .process .thread (查看进程线程信息)

    (11) !object (查看对象信息)

    (12) !devnode (查看设备对象)

    (13) g命令 (继续执行)

    (14) operators (MASM)(汇编下的操作符,poi,by,&等,条件断点最有用)

    (15) e命令 (写内存数据)

    (16) !ca命令 (查看session的ControlArea)

    (17) r命令 (查看修改寄存器)

    详细

    (1)u命令(反汇编)

    uf ICSF!SfDirectoryControl

    可以查看整个函数的汇编代码

    u ICSF!SfDirectoryControl ICSF!SfDirectoryControl+0X30

    可以看到30个字节的汇编指令

    ub ICSF!SfDirectoryControl L30

    可以查看SfDirectoryControl 之上的30字节的汇编指令

    (2)dt命令(查看数据结构)

    dt nt!_IRP -r2
    可以查看二级结构,

    从而知道IoGetCurrentIrpStackLocation宏实际取的是_IRP.Tail(0x040).Overlay(0x000).CurrentStackLocation(0x020)。

    也就是说,IRP+0X60里存放的就是_IO_STACK_LOCATION的地址

    实例:

    dt nt!_IRP poi(ebp+0x0c) -r2               *注释:dispatch中,ebp+0ch存放的就是IRP参数的地址

    显示结果(省略一部分):

    +0x040 Tail             : __unnamed
          +0x000 Overlay          : __unnamed
             +0x000 DeviceQueueEntry : _KDEVICE_QUEUE_ENTRY
             +0x000 DriverContext    : [4] (null) 
             +0x010 Thread           : 0x822934d8 _ETHREAD
             +0x014 AuxiliaryBuffer : 0x8225bc30 "???"
             +0x018 ListEntry        : _LIST_ENTRY [ 0x0 - 0x0 ]
             +0x020 CurrentStackLocation : _IO_STACK_LOCATION
             +0x020 PacketType       : 0x822f29ac
             +0x024 OriginalFileObject : 0x822ecde8 _FILE_OBJECT
    然后,就可以得到irpSp的地址0x822f29ac了。

    (3)ln命令(查找就近的符号)

    0: kd> ln 804e23a2
    (804e23a2)   nt!IopfCallDriver   |  (804e2417)   nt!KiInsertTimerTable
    Exact matches:

    (4)x命令(显示模块的符号)

    x nt!*

    则显示nt的所有符号

    (5)k命令(显示调用栈)

    kd

    直接显示所有的栈情况

    kb

    显示前3个参数

    kp

    显示调用栈,及所有参数值和它们的类型

    kc

    只显示调用栈的模块名和地址(不显示调用栈的地址)

    (6)d命令(以数据方式显示)

    da

    显示ascii码

    dc

    按单字节显示字符

    db

    按单字节显示

    dd

    按4字节显示

    dD

    按8字节显示(64位下常用)

    df

    按浮点显示

    dp

    按4字节或者8字节显示(取决于是32位系统还是64位系统)

    dw

    按2字节显示

    dW

    按2字节显示字符

    dyb

    按二进制位显示(一字节一组)

    dyd

    按二进制位显示(4字节一组)

    (7)b命令(断点)

    bp 0040108c

    bp Myexe!main+5c

    bp source.c:31

    在指定地址下断点

    bp Myexe!main+5c "j 0!=eax 'dd @eax;gc';'gc'")

    下条件断点,如何写表达式可参考本博文的operators (MASM)

    bl

    显示所有断点

    bc 1

    bc 1-4

    bc *

    删除断点

    bd 1

    bd 1-4

    bd *

    使断点失效

    ba r4 DSPD!g_Global

    下硬件断点

    bu DSPD!DriverEntry

    下延迟断点(在驱动镜像加载时,下断点)

    bm DSPD!openf*

    下模糊断点

    (8)lm lmvm (显示模块信息)

    lm

    显示所有加载模块

    lmvm DSPrivateData64

    显示指定模块的详细信息

     (9) .reload (重加载模块)

    .reload DSPrivateData64.sys

    .reload /f /i DSPrivateData64.sys    (/f强制加载, /i忽略pdb不匹配)

    .reload /u DSPrivateData64.sys       (卸载模块)

    (10) !process !thread .process .thread(查看进程线程信息)

    !process 0 0

    显示所有进程

    !process 0x843423 0

    显示进程信息

    .process 0x843423

    切换到指定进程

    .process /i 0x843423

    输入g命令后切换到指定进程

    .thread 0x87668432

    切换到指定线程

    !thread 0x87668432 0

    查看线程信息

    (11) !object (查看对象信息)

    !object

    查看指定对象的信息

    (12) !devnode (查看设备对象)

    !devnode 0 1

    查看所有的设备对象

    (13) g命令 (继续执行)

    g    

    继续执行

    gu

    执行到本函数返回

    (14)operators(MASM)(汇编操作符,poi,by,&等,条件断点最有用)

    可查看windbg帮助的operators (MASM)

    poi(@ebp)        

    地址(ebp)指向的指针。在kernel调试下,是目标机环境。user调试下,是编译环境。

    by(0x8423D435)   

    地址指向的字节

    $vvalid(AddressLength)

    指定范围的内存是否有效

    & ! | 等,$scmp等

    (15)e命令 (写内存数据)

    eb 0x838de64c 1

    向指定地址内存按单字节写入

    ew (2字节)

    ed (4字节)

    ep (指针)

    eq (8字节) 

    ea (ASCII字符串)

    eu (UNICODE字符串)

    eza (ASCII字符串,NULL结尾)

    ezu (UNICODE字符串,NULL结尾)

     (16) !ca命令 (查看section的ControlArea)

    kd> !ca ff8636e8

    ControlArea @ff8636e8
      Segment:    e1b74548    Flink              0   Blink:               0
      Section Ref        0    Pfn Ref           6c   Mapped Views:        1
      User Ref           1    Subsections        5   Flush Count:         0
      File Object ff86df88    ModWriteCount      0   System Views:        0
      WaitForDel         0    Paged Usage      380   NonPaged Usage       e0
      Flags (10000a0) Image File HadUserReference 

    (17) r命令 (查看修改寄存器)

    kd>reax

    eax=00000000

    查看寄存器,也可以用,r@eax等

    kd>reax=1

    eax=00000001

    设置寄存器的值

    常在断点中使用,比如

    kd> bp vDiskBus!InitManager+0xb3 " r@eax=0;gc"

  • 相关阅读:
    flask框架(一):初入
    .py文件打包成.exe文件
    gtk+-3.21.4 static build step in windows XP
    cairo-1.14.6 static compiler msys mingw32
    ffmpeg-20160811-bin.7z
    gtk+2.24.0-glib-2.28.1-staticLib-mingw32-x86-2016-08-10.7z
    ffmpeg-20160806-bin.7z
    glib-2.49.4-msys-x86-staticLib.7z
    Tesseract-OCR text2image.exe [ x86 支持 XP ]
    ffmpeg-20160803-bin.7z
  • 原文地址:https://www.cnblogs.com/zengkefu/p/6938071.html
Copyright © 2011-2022 走看看