前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >使用Windbg调试内核

使用Windbg调试内核

作者头像
战神伽罗
发布2019-07-24 08:42:24
1.5K0
发布2019-07-24 08:42:24
举报

Windbg是微软开发的免费源码级调试工具。Windbg可以用于Kernel模式调试和用户模式调试,还可以调试Dump文件。

1.从http://www.microsoft.com/whdc/devtools/debugging/installx86.mspx下载Install Debugging Tools for Windows 32-bit Version

2.从http://www.microsoft.com/whdc/devtools/debugging/symbolpkg.mspx下载Windows Symbol Packages,安装到D:\Program Files\Symbols

3.启动Windbg,File->Symbol File Path填写以上Symbols安装路径:

D:\Program Files\Symbols

4.File->Kernel Debug->Local,在下面执行lkd> !process出现以下错误:

NT symbols are incorrect, please fix symbols

这个可能是D:\Program Files\Symbols\exe\ntoskrnl.pdb破损所致。

解决方案:将第3步中的Symbol File Path填写为:

D:\Program Files\Symbols;

SRV*D:\Program Files\Symbols*http://msdl.microsoft.com/download/symbols

按照这样设置,WinDbg将先从本地文件夹D:\Program Files\Symbols中查找Symbol,如果找不到,则自动从MS的Symbol Server上下载所需要的Symbol,并且在本地D:\Program Files\Symbols文件夹下维持一份拷贝。

5.内核调试

FileàOpenExecutableà可以选择一个可执行文件进行调试; FileàAttache to a Processà可以选择一个运行中的进程,并对其进行调试;

FileàKernel DebugàLocalà可以选择本地内核调试。

一旦连接到了内核调试模式中,你可以使用众多的内核扩展命令(以“!”开头)来显示内核数据结构的内容。

6.用内核扩展命令查看常见内核对象数据结构(每条命令以分号隔开)

(1)进程:lkd> !process [0 0];dt nt!_eprocess;dt nt!_kprocess;

(2)线程:lkd> !thread;dt nt!_ethread;dt nt!_kthread;

(3)I/O请求包:lkd> dt nt!_irp;!irpfind;

(4)常见同步对象:lkd> dt nt!_kevent;lkd> dt nt!_kmutant;lkd> dt nt!_ksemaphore;

(5)作业:lkd> !job;会话(lkd> !session);内存管理(lkd> !vm)的命令等。

显示内核符号中所包含的类型信息的内核结构列表àlkd> dt nt!_*,若需递归显示子结构请使用“-r”开关。在.hh后面添加关键字,将显示该命令的帮助,例如:lkd>.hh irp。

详情参考:Debugging Tools For Windows help referenceàDebuggersàDebugger ReferenceàDebugger Extension Commands。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档