Advanced Debugging
About AdvDbg Consult Train Services Products Tools Community Contact  
欢迎光临 高端调试 登录 | 注册 | FAQ
 
  ACPI调试
Linux内核调试
Windows内核调试
 
  调试战役
调试原理
新工具观察
 
  Linux
Windows Vista
Windows
 
  Linux驱动
WDF
WDM
 
  PCI Express
PCI/PCI-X
USB
无线通信协议
 
  64位CPU
ARM
IA-32
  CPU Info Center
 
  ACPI标准
系统认证
Desktop
服务器
 
  Embedded Linux
嵌入式开发工具
VxWorks
WinCE
嵌入式Windows
 
  格蠹调试套件(GDK)
  格蠹学院
  小朱书店
  老雷的微博
  《软件调试》
  《格蠹汇编》
  《软件调试(第二版)》
沪ICP备11027180号-1

《软件调试》答疑

帖子发起人: aa1ss2   发起时间: 2009-04-26 20:37 下午   回复: 4

Print Search
帖子排序:    
   2009-04-26, 20:37 下午
aa1ss2 离线,最后访问时间: 2009/4/14 11:30:54 aa1ss2

发帖数前75位
注册: 2009-03-24
发 贴: 14
勘误求证
Reply Quote
672页倒数第五行溢出后的数据应该是
2b2a2928

IP 地址: 已记录   报告
   2009-04-27, 20:47 下午
Raymond 离线,最后访问时间: 2020/7/3 3:40:25 格蠹老雷

发帖数前10位
注册: 2005-12-19
发 贴: 1,303
Re: 勘误求证
Reply Quote

为何?

0x391ec0开始是相邻的下一个空闲堆块,即HEAP_FREE_ENTRY结构,391ec8处是这个结构的FreeList字段;发生溢出前,FreeList字段的内容是0x390178-0x390178,也就是下一个空闲块的地址,0x390178-8是那个块的HEAP_FREE_ENTRY结构(因为FreeList字段在结构内的偏移是8);发生溢出后,FreeList字段变成了0x2b2a2928-0x2f2e2d2c,但是堆管理器不知道溢出,仍然把0x2b2a2928-8当作是下个空闲块的HEAP_FREE_ENTRY结构,但是读取这个地址时失败了,因此显示那句话:

 Unable to read nt!_HEAP_FREE_ENTRY structure at 2b2a2920

 


IP 地址: 已记录   报告
   2009-05-09, 11:37 上午
aa1ss2 离线,最后访问时间: 2009/4/14 11:30:54 aa1ss2

发帖数前75位
注册: 2009-03-24
发 贴: 14
Re: 勘误求证
Reply Quote
不好意思,这里是我看错了,这几章看到头有点昏了,特别是CRT那里.

另外有两个地方也有点问题.
719页的62行 Disposition 好像少了个n
722页的倒数第二行 ExecutePPHandler 好像多了两个P
IP 地址: 已记录   报告
   2009-05-10, 09:56 上午
Raymond 离线,最后访问时间: 2020/7/3 3:40:25 格蠹老雷

发帖数前10位
注册: 2005-12-19
发 贴: 1,303
Re: 勘误求证
Reply Quote
呵呵,仔细理解这些内容是需要花些功夫的,最好是边看边做(试验),很高兴看到你正是使用这种方法。
上面提到的719页和722页的问题,你说的对,我会尽快加到勘误中,多谢。
IP 地址: 已记录   报告
   2009-05-11, 11:01 上午
aa1ss2 离线,最后访问时间: 2009/4/14 11:30:54 aa1ss2

发帖数前75位
注册: 2009-03-24
发 贴: 14
Re: 勘误求证
Reply Quote
多谢老师鼓励,我会继续努力的.
IP 地址: 已记录   报告
高端调试 » 图书 » 《软件调试》答疑 » Re: 勘误求证

 
Legal Notice Privacy Statement Corporate Governance Corporate Governance
(C)2004-2020 ADVDBG.ORG All Rights Reserved.