欢迎光临 高端调试
登录
|
注册
|
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
C/C++本地代码调试
帖子发起人:
saviola
发起时间:
2016-06-02 19:33 下午
回复:
4
高端调试
»
软件调试
»
C/C++本地代码调试
»
Re: 求助一个Crash Dump的INVALID_POINTER_READ问题
搜索论坛
帖子排序:
Oldest to newest
Newest to oldest
2016-06-02, 19:33 下午
saviola
注册: 2011-07-05
发 贴: 6
求助一个Crash Dump的INVALID_POINTER_READ问题
各位高手和老师们好!
近期遇到个无法解释的问题,程序Crash了,windbg了一下Dump,用.ecxr得到了exception状态时的指令。但是,它执行的指令不该触发异常啊,请看下这怎么解释?
0:005>
!analyze -v
FAULTING_IP:
ProgramName!FAsyncTask<FSceneRenderer::FAsyncVisibilityCull>::FinishThreadedWork+3
0199ac63 83bfb003000000 cmp dword ptr [edi+3B0h],0
EXCEPTION_RECORD: ffffffff -- (.exr 0xffffffffffffffff)
ExceptionAddress: 0199ac63 (ProgramName!FAsyncTask<FSceneRenderer::FAsyncVisibilityCull>::FinishThreadedWork+0x00000003)
ExceptionCode: c0000005 (Access violation)
ExceptionFlags: 00000000
NumberParameters: 2
Parameter[0]: 00000000
Parameter[1]: abe904dc
Attempt to read from address
abe904dc
DEFAULT_BUCKET_ID:
INVALID_POINTER_READ
0:005>
.ecxr
eax=00000000 ebx=0007781f ecx=abe9012c edx=00000002 esi=007cfd20 edi=abe9012c
eip=0199ac63 esp=077efcc4 ebp=077efce8 iopl=0 nv up ei pl zr na pe cy
cs=0023 ss=002b ds=002b es=002b fs=0053 gs=002b efl=00010247
ProgramName!FAsyncTask<FSceneRenderer::FAsyncVisibilityCull>::FinishThreadedWork+0x3:
0199ac63 83bfb003000000 cmp dword ptr [edi+3B0h],0 ds:002b:
abe904dc
=00000000
0:005>
!address
abe904dc
ProcessParametrs 00bd13e8 in range 00bd0000 00cd0000
Environment 00bd07f0 in range 00bd0000 00cd0000
abe90000 : abe90000 - 0001e000
Type 00020000 MEM_PRIVATE
Protect
00000004 PAGE_READWRITE
State 00001000 MEM_COMMIT
Usage RegionUsageIsVAD
0:005>
dd abe904dc-20h L10
abe904bc 00000000 00000001 00000001 00000028
abe904cc 00000000 00000000 00000000 00000000
abe904dc 00000000
00000000 02b041c4 abe90058
abe904ec 7f7fffff 00000025 00000008 55804600
这块内存完全是可以被读到内容的呀,是个正常的READWRITE Page,哪怕是指针指坏了不该读那儿,但不管怎样是能读到的呀!为什么异常了?
背景:这是个32位程序,跑在64位Windows上时偶发Crash时的Dump
好迷茫,求指教。万分感谢!
IP 地址: 已记录
报告
2016-08-14, 16:03 下午
HiJack
注册: 2013-12-27
发 贴: 21
Re: 求助一个Crash Dump的INVALID_POINTER_READ问题
你确认这个地址可读?
edi+3B0h
IP 地址: 已记录
报告
2016-08-22, 10:52 上午
格蠹老雷
注册: 2005-12-19
发 贴: 1,303
Re: 求助一个Crash Dump的INVALID_POINTER_READ问题
那个地址已经超出了32位进程的2GB用户态空间的边界了
IP 地址: 已记录
报告
2016-09-14, 12:46 下午
saviola
注册: 2011-07-05
发 贴: 6
Re: 求助一个Crash Dump的INVALID_POINTER_READ问题
感谢老大回复!
但这个程序是启用了Large Address Aware的,并且是运行在64位Win7上。虽为32bit app,应能访问3GB内地址的。所以应该不是>2GB地址不可读写的问题。
IP 地址: 已记录
报告
2016-09-14, 12:50 下午
saviola
注册: 2011-07-05
发 贴: 6
Re: 求助一个Crash Dump的INVALID_POINTER_READ问题
lhwqqq wrote:
你确认这个地址可读?
edi+3B0h
是的,!address已经告诉大家了。。。后面我dd也显示了data
edi=abe9012c
edi+3B0 = abe904dc
0:005>
!address abe904dc
ProcessParametrs 00bd13e8 in range 00bd0000 00cd0000
Environment 00bd07f0 in range 00bd0000 00cd0000
abe90000 : abe90000 - 0001e000
Type 00020000 MEM_PRIVATE
Protect 00000004 PAGE_READWRITE
State 00001000 MEM_COMMIT
Usage RegionUsageIsVAD
IP 地址: 已记录
报告
高端调试
»
软件调试
»
C/C++本地代码调试
»
Re: 求助一个Crash Dump的INVALID_POINTER_READ问题
请选择
论坛首页
|- 论坛搜索
|- 热门主题
|- 未回复的主题
用户选项
|- 登录
|- 注册
|- 找回密码
软件调试
|- Windows内核调试
|- C/C++本地代码调试
|- .Net程序调试
|- 脚本程序调试
|- Java程序调试
|- Linux内核调试
|- 《程序员》杂志调试专栏
|- WinDbg
|- GDB
|- 远程调试
|- 调试ACPI和BIOS
|- 特殊的调试任务
|- 转储分析
|- GDK7
内核探秘
|- Windows内核
|- Linux内核
系统架构
|- CPU架构
|- PCI/PCI Express架构
程序人生
|- 软件物语
|- 社区活动
|- 名人逸事
联盟论坛
|- 欢迎使用CnForums
没有银弹
|- BUG也精彩
|- 豆腐工程
|- 软件圈里十大怪
Windows Vista
|- 用调试利剑剖析VISTA内幕
|- 老专家如何破解新问题
|- 我的电脑谁说了算?
|- 资源
Office开发
|- Visio
驱动程序开发
|- Windows驱动开发
|- Linux驱动开发
|- Windows CE驱动开发
用户态开发
|- Windows本地代码(native)高级开发
|- Web应用开发
|- WinFX和.Net
|- Office开发
本站建设
|- 高端调试团队
|- 版面布局
|- 活动建议
|- 网站维护
64位计算
|- 64-bit Windows
|- 64-bit CPU
图书
|- 《软件调试》的示例程序
|- 《软件调试》的工具
|- 《软件调试》书友
|- 《软件调试》答疑
|- 《软件调试》勘误和意见
|- 《格蠹汇编》
|- 《软件调试》第二版卷1
|- 《软件调试》第二版卷2
云计算
|- IaaS
|- 云存储
|- 大数据
|- PaaS和SaaS
GPU
|- CUDA
|- OpenCL
|- HSA
|- 游戏开发与调试
(C)2004-2020 ADVDBG.ORG All Rights Reserved.