之前我曾经使用windbg进行用户模式调试,但我怀疑我对我的系统做了一些事情,因为我不记得使用例如扩展命令!堆之前有问题.

我可以清楚地看到ntdll是一个加载的模块:

77760000 778e0000   ntdll      (pdb symbols)          C:\Program Files (x86)\Windows Kits\8.1\Debuggers\x86\sym\wntdll.pdb\FA9C48F9C11D4E0894B8970DECD92C972\wntdll.pdb

0:001> lmvm ntdll
start    end        module name
77760000 778e0000   ntdll      (pdb symbols)          C:\Program Files     (x86)\Windows Kits\8.1\Debuggers\x86\sym\wntdll.pdb    \FA9C48F9C11D4E0894B8970DECD92C972\wntdll.pdb
    Loaded symbol image file: C:\Windows\SysWOW64\ntdll.dll
    Image path: C:\Windows\SysWOW64\ntdll.dll
    Image name: ntdll.dll
    Timestamp:        Wed Jul 15 13:53:36 2015 (55A69E20)
    CheckSum:         00142A8B
    ImageSize:        00180000
    File version:     6.1.7601.18933
    Product version:  6.1.7601.18933
    File flags:       0 (Mask 3F)
    File OS:          40004 NT Win32
    File type:        2.0 Dll
    File date:        00000000.00000000
    Translations:     0409.04b0
    CompanyName:      Microsoft Corporation
    ProductName:      Microsoft® Windows® Operating System
    InternalName:     ntdll.dll
    OriginalFilename: ntdll.dll
    ProductVersion:   6.1.7601.18933
    FiLeversion:      6.1.7601.18933 (win7sp1_gdr.150715-0600)
    FileDescription:  NT Layer DLL
    Legalcopyright:   © Microsoft Corporation. All rights reserved.

0:001> !chksym ntdll

C:\Windows\SysWOW64\ntdll.dll
    Timestamp: 55A69E20
  SizeOfImage: 180000
          pdb: wntdll.pdb
      pdb sig: FA9C48F9-C11D-4E08-94B8-970DECD92C97
          age: 2

Loaded pdb is C:\Program Files (x86)\Windows Kits\8.1\Debuggers\x86\sym\wntdll.pdb\FA9C48F9C11D4E0894B8970DECD92C972\wntdll.pdb

wntdll.pdb
      pdb sig: FA9C48F9-C11D-4E08-94B8-970DECD92C97
          age: 2

MATCH: wntdll.pdb and C:\Windows\SysWOW64\ntdll.dll<code>

当我尝试使用我的堆扩展时,我得到:

0:001> !heap -stat
*************************************************************************
***                                                                   ***
***                                                                   ***
***    Either you specified an unqualified symbol,or your debugger   ***
***    doesn't have full symbol information.  Unqualified symbol      ***
***    resolution is turned off by default. Please either specify a   ***
***    fully qualified symbol module!symbolname,or enable resolution ***
***    of unqualified symbols by typing ".symopt- 100". Note that   ***
***    enabling unqualified symbol resolution with network symbol     ***
***    server shares in the symbol path may cause the debugger to     ***
***    appear to hang for long periods of time when an incorrect      ***
***    symbol name is typed or the network symbol server is down.     ***
***                                                                   ***
***    For some commands to work properly,your symbol path           ***
***    must point to .pdb files that have full type information.      ***
***                                                                   ***
***    Certain .pdb files (such as the public OS symbols) do not      ***
***    contain the required information.  Contact the group that      ***
***    provided you with these symbols if you need this command to    ***
***    work.                                                          ***
***                                                                   ***
***    Type referenced: ntdll!_PEB                                    ***
***                                                                   ***

.symopt- 100也没有帮助

如果我尝试使用临界区扩展,我会收到类似的错误:

Bad symbols for NTDLL (error 3). Aborting.

我已经读过如果你在32位和64位之间不匹配,或者如果你没有在第一位正确设置符号但我已经使用.symfix并且可以强制我的符号重新加载.reload / f,我在x86进程或32位转储上使用x86调试器,所以我看不出这些问题是如何发挥作用的.

我已经完全开始了新的和卸载的windbg,并从MSDN重新安装了Windows的调试工具,但仍然遇到了同样的问题.当然我错过了一些明显的东西?

MS正在摆脱最新Windows 7 PDB中的所有类型信息.这打破了!堆.这是关于它的推特谈话,由Alex Ionescu发起,他是“Windows Internals,Sixth Edition”的合着者: https://twitter.com/aionescu/status/634028737458114560

更新:2015年10月12日:使用PDB Type Theft python脚本可能的解决方法,该脚本将类型信息从一个PDB复制到另一个PDB.用法是从较旧的PDB复制类型信息,该PDB具有在以后的PDB中删除的类型信息.此链接包含所有详细信息:http://h30499.www3.hp.com/t5/HP-Security-Research-Blog/PDB-Type-Theft/ba-p/6801065#.Vhv2gPm6fmE

更新时间:2015年10月22日:在Microsoft补丁日(2015-10-13)和KB3088195中,符号再次可用.但是,没有提供破损版本的符号,因此上述内容可能仍然有用.

windows – ntdll模块在windbg中无法正确加载,但为什么?的更多相关文章

  1. python pdb调试器及使用方法

    这篇文章主要介绍了python pdb调试器及使用方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  2. Qt创建者CDB无法进入

    Qt5.12.2适用于msvc2017,QtCreator9.0.1,已安装VisualStudio2019。对于虚拟方法和std,我进入了一个无法正常工作的特性,例如:我在smartObject->virtualMethod()行,按F11获取QScopedPointer的源文件:我按shift+F11并再次到达第smartObject->virtualMethod()行,然后再按F11并到达下一行,而不是进入virtualMethod()体。

  3. windows – 如何从.PDB文件创建.MAP文件

    我想创建一个简单的.MAP文件,列出PDB文件中的地址和符号名称.我的自然倾向是寻找一个名为“pdb2map”的工具,但我得到的大部分结果似乎都是指包含在Microsoft.NET和MicrosoftWindows调试应用程序中的CD中的示例程序,遗憾的是它也不是发布在’网上.有人知道这个的好工具吗?

  4. windows – 如何学习WinDbg? (回复:看似简单的挂起过程)

    我正在尝试确定流程为何悬而未决并且正在学习各种工具,例如ProcessExplorer,ProcessMonitor和WinDbg.无论如何,我正在尝试使用WinDbg并在附加到我的进程后,调试器说:如果我运行!我应该如何使用WinDbg简单地附加到流程并进行分析?(另外,有没有关于开始使用此级别的调试和WinDbg的好书/教程?)WinDbg是一个用户和内核模式调试器,但它本身并不真正理解托管代码,因此!syncblk命令查看这些内容.如果已加载SOSEX,则!

  5. .net – Windbg期待mscordacwks.dll的不同版本

    我在尝试使用windbg调试minidump文件时遇到了一个非常奇怪的问题.我在自己的机器上试过这个通过在目标机器上运行windbg,从中获取minidump,但结果在两种情况下都是相同的.在开始我加载所需的dll,如下所示,请注意,如果我将症状设置为微软符号服务器,则会出现同样的问题.0:000>.symfixc:\sos0:000>.loadC:\Windows\Microsoft.NET\Framework64\v4.0.30319\sos检查链条的一切看起来都不错,所以我现在去运行!

  6. windows – WinDbg远程调试器协议

    我想为dbgsrv.exe构建一个客户端.我想知道它使用的协议是否有规范,是否有任何(开源?

  7. windbg – 如何从内存转储中提取DLL文件?

    我有一个内存转储.如何提取加载到进程中的一个dll?我的意思是实际上将dll文件保存到磁盘中您可以在windbg目录中使用sos.dll.首先,在windbg中加载sos.dll:然后使用!SaveAllModule来提取特定磁盘位置上的模块:

  8. windows – 有没有办法在暂停状态下启动进程?

    我想在暂停状态下启动进程.有没有办法只使用WindowsXP附带的标准工具?

  9. windows-7 – 无论如何都要阻止Windows 7在更新后执行强制重启?

    反正有没有阻止Windows7在更新后执行强制重启?

  10. Windows – WinDbg中的“Break指令异常”是什么?

    在托管堆栈中,有一个明确的错误,Microsoft.VisualStudio.NativeMethods.ThrowOnFailure..但是这意味着com异常会导致break指令异常?!

随机推荐

  1. static – 在页面之间共享数据的最佳实践

    我想知道在UWP的页面之间发送像’selectedItem’等变量的最佳做法是什么?创建一个每个页面都知道的静态全局变量类是一个好主意吗?

  2. .net – 为Windows窗体控件提供百分比宽度/高度

    WindowsForm开发的新手,但在Web开发方面经验丰富.有没有办法为Windows窗体控件指定百分比宽度/高度,以便在用户调整窗口大小时扩展/缩小?当窗口调整大小时,可以编写代码来改变控件的宽度/高度,但我希望有更好的方法,比如在HTML/CSS中.在那儿?

  3. 使用Windows Azure查询表存储数据

    我需要使用特定帐户吗?>将应用程序部署到Azure服务后,如何查询数据?GoogleAppEngine有一个数据查看器/查询工具,Azure有类似的东西吗?>您可以看到的sqlExpressintance仅在开发结构中,并且一旦您表示没有等效,所以请小心使用它.>您可以尝试使用Linqpad查询表格.看看JamieThomson的thispost.

  4. windows – SetupDiGetClassDevs是否与文档中的设备实例ID一起使用?

    有没有更好的方法可以使用DBT_DEVICEARRIVAL事件中的数据获取设备的更多信息?您似乎必须指定DIGCF_ALLCLASSES标志以查找与给定设备实例ID匹配的所有类,或者指定ClassGuid并使用DIGCF_DEFAULT标志.这对我有用:带输出:

  5. Windows Live ID是OpenID提供商吗?

    不,WindowsLiveID不是OpenID提供商.他们使用专有协议.自从他们的“测试版”期结束以来,他们从未宣布计划继续它.

  6. 如果我在代码中进行了更改,是否需要重新安装Windows服务?

    我写了一个Windows服务并安装它.现在我对代码进行了一些更改并重新构建了解决方案.我还应该重新安装服务吗?不,只需停止它,替换文件,然后重新启动它.

  7. 带有双引号的字符串回显使用Windows批处理输出文件

    我正在尝试使用Windows批处理文件重写配置文件.我循环遍历文件的行并查找我想要用指定的新行替换的行.我有一个’函数’将行写入文件问题是%Text%是一个嵌入双引号的字符串.然后失败了.可能还有其他角色也会导致失败.如何才能使用配置文件中的所有文本?尝试将所有“在文本中替换为^”.^是转义字符,因此“将被视为常规字符你可以尝试以下方法:其他可能导致错误的字符是:

  8. .net – 将控制台应用程序转换为服务?

    我正在寻找不同的优势/劣势,将我们长期使用的控制台应用程序转换为Windows服务.我们为ActiveMQ使用了一个叫做java服务包装器的东西,我相信人们告诉我你可以用它包装任何东西.这并不是说你应该用它包装任何东西;我们遇到了这个问题.控制台应用程序是一个.NET控制台应用程序,默认情况下会将大量信息记录到控制台,尽管这是可配置的.任何推荐?我们应该在VisualStudio中将其重建为服务吗?我使用“-install”/“-uninstall”开关执行此操作.例如,seehere.

  9. windows – 捕获外部程序的STDOUT和STDERR *同时*它正在执行(Ruby)

    哦,我在Windows上:-(实际上,它比我想象的要简单,这看起来很完美:…是的,它适用于Windows!

  10. windows – 当我试图批量打印变量时,为什么我得到“Echo is on”

    我想要执行一个简单的批处理文件脚本:当我在XP中运行时,它给了我预期的输出,但是当我在Vista或Windows7中运行它时,我在尝试打印值时得到“EchoisOn”.以下是程序的输出:摆脱集合表达式中的空格.等号(=)的两侧可以并且应该没有空格BTW:我通常在@echo关闭的情况下启动所有批处理文件,并以@echo结束它们,所以我可以避免将代码与批处理文件的输出混合.它只是使您的批处理文件输出更好,更清洁.

返回
顶部