Windows 性能分析器缺少 ImageId 事件

rol*_*rer 5 windows delphi debugging windows-performance-analyzer

我有一个应用程序,我想使用 Windows 性能分析器对其进行分析。一切正常,但我没有从我的应用程序中获得任何合理的堆栈跟踪。

有问题的应用程序是一个演示应用程序。这是为了给我一个很好的感觉,如果全部检查出来。然后我想分析另一个应用程序。因为我可以完全控制我的演示应用程序,所以我包含了一些标记函数,它们应该显示在堆栈跟踪中。

在 Windwos 7 1上运行应用程序时,Process Explorer 会显示我想要分析的部件的正确堆栈跟踪。这是第 7 - 9 行中带有标记函数的堆栈跟踪:

进程资源管理器堆栈跟踪

由于我在 Windows 10 VM 2 中安装了所有性能分析工具,因此我开始在那里进行分析。首先要注意:Process Explorer 没有显示正确的堆栈跟踪。我实现的标记功能无处可寻。

尽管如此,我还是使用UIforETWWindows Performance Recorder记录了性能轨迹。在 WPA 中打开它们并专注于目标应用程序时,这是堆栈跟踪:

WPA 堆栈跟踪

我感兴趣的所有信息都丢失了。堆栈显示为<Application>.exe!<Missing ImageId event>

我做错了什么?


如果这给你一个提示,这里是安装的相关软件:

1:Windows 7 计算机安装了 Visual Studio (C#)。

2:Windows 10 虚拟机没有 Visual Studio,但安装了 WinDBG(预览版)和 Windows Performance Toolkit。

我标记了,因为目标应用程序是用 Delphi 编写的。

小智 6

Windows 10 WPA(以及 Windows 8.1,在较小程度上)不再支持旧的调试符号格式;它现在只支持自 MSVC 7 以来一直是标准的“RSDS”格式。使用旧符号文件格式的 PE 文件(例如,VB6 生成 NB10 PDB 文件)将导致“Missing ImageId event”错误。

(该消息本身在技术上是不正确的;即使在跟踪文件中也可能有一个 ImageId,但它正在寻找一个 ImageId/DbgID_RSDS 事件,该事件无法为非 RSDS PDB 生成)