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"

学习使用常用的windbg命令(u、dt、ln、x)的更多相关文章

  1. Linux学习之常用权限管理命令(二)

    (一)常用权限管理命令 (1)chmod命令 (2)chown (3)chgrp (4)umask (一)常用权限管理命令 (1)chmod命令 命令名称:chmod命令英文原意:change the ...

  2. Linux学习之常用文件处理命令(一)

    (一)文件命名规则 (二)常用文件处理命令 1.ls命令 2.cd命令 3.pwd命令 4.mkdir命令 5.touch命令 6.cp命令 7.mv命令 8.rm命令 9.cat命令 10.more ...

  3. 入门学习Linux常用必会命令实例详解

    Linux提供了大量的命令,利用它可以有效地完成大量的工作,如磁盘操作.文件存取.目录操作.进程管理.文件权限设定等.所以,在Linux系统上工作离不开使用系统提供的命令.要想真正理解Linux系统, ...

  4. Linux学习之常用系统工作命令(一)

     由于centos和RHEL互通,两个版本可以相互学习,所以截图有两个界面 Linux系统与win系列是两个几乎完全不同的操作系统,但是就应用范围来说,是win系统更胜一筹,然而,这反而也成为win系 ...

  5. docker学习笔记-常用镜像相关命令

    docker images # 1.使用 [root@iZbp13qr3mm4ucsjumrlgqZ ~]# docker images REPOSITORY TAG IMAGE ID CREATED ...

  6. 一张图学习vim常用命令

    一张图学习vim常用命令

  7. [基础学习]MySQL常用语句命令总结

    前言 相信平时大家在开发时都会使用MySQL数据库,它是目前比较火的一款数据库工具,对于大多数企业的业务来说,MySQL可以很完美地支持了. 很多时候我们都是借助mysql可视化工具操作mysql,虽 ...

  8. goland学习-go常用命令使用

    goland学习-go常用命令使用 1.跨平台编译:env GOOS=linux GOARCH=amd64 go build 2.获取go第三方包:go get -u github.com/go-sq ...

  9. 深度学习之常用linux命令总结

    深度学习中常用linux命令总结 1.创建文件夹 mkdir 文件名2.删除文件 rm -d 目录名 #删除一个空目录 rmdir 目录名 #删除一个空目录 rm -r 目录名 #删除一个非空目录 r ...

随机推荐

  1. C# 序列化理解 2(转)

    一.概述 序列化是把对象转变成流.相反的过程就是反序列化. 哪些场合用到这项技术呢? 1. 把对象保存到本地,下次运行程序时恢复这个对象. 2. 把对象传送到网络的另一台终端上,然后在此终端还原这个对 ...

  2. 类似web风格的 Winform 分页控件

    背景 最近做一个Winform的小程序,需要用到分页,由于之前一直在用 TonyPagerForWinForm.dll ,但该库没有源代码,网上找的也不全面,索性就准备自己改造一个.在园子里翻了一下, ...

  3. POJ2186 (强连通分量缩点后出度为0的分量内点个数)

    Popular Cows Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 27820   Accepted: 11208 De ...

  4. Linux下安装mantis配置指南【转】

    转自:http://blog.csdn.net/xabc3000/article/details/6858229 目录(?)[-] Linux下安装mantis配置指南 配置Linux下的Apache ...

  5. 基于vlc sdk的二次开发--环境搭建、编译

    前言 关于 搭建.编译VLC,不同的平台有不同的方法,可以参考wiki. 其中在windows下编译VLC有两种方式,MSYS+MinGW和CygWin.通过测试,最后决定采用MSYS+MinGW搭建 ...

  6. linux下rm命令删除文件名中包含特殊字符的文件【转】

    转自:http://blog.itpub.net/143526/viewspace-1060083/ 1. 删除带“-”的文件名的方法 2. 删除包含其它特殊字符的文件 3. 删除系统打不出的乱码文件 ...

  7. [ Python - 2 ] 常见内置函数

    1. abs(): 绝对值 In [1]: abs(-10) Out[1]: 10 2. all(): 当参数中任何一个值为False时,all() 都为False    all(iterable) ...

  8. JavaSript中数组方法是否对原数组产生影响

    JavaScript中数组方法有很多.某次面试被问到,concat()方法会对影响到原数组吗.当时记得不牢,犹豫地说"会吧...".于是决定总结一下哪些数组方法会对原数组产生影响. ...

  9. 最小生成树Prim算法Kruskal算法

    Prim算法采用与Dijkstra.Bellamn-Ford算法一样的“蓝白点”思想:白点代表已经进入最小生成树的点,蓝点代表未进入最小生成树的点. 算法分析 & 思想讲解: Prim算法每次 ...

  10. Selenium2+python自动化27-查看selenium API【转载】

    前言 前面都是点点滴滴的介绍selenium的一些api使用方法,那么selenium的api到底有多少呢?本篇就叫大家如何去查看selenium api,不求人,无需伸手找人要,在自己电脑就有. p ...