Windows 性能分析器缺少 ImageId 事件

Windows Performance Analyzer Missing ImageId Event

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

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

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

因为我在 Windows 10 VM2 中安装了所有性能分析工具,所以我开始在那里进行分析。首先要注意:Process Explorer 不显示正确的堆栈跟踪。我实现的标记功能找不到了

不过,我使用 UIforETWWindows Performance Recorder 记录了性能轨迹。在 WPA 中打开它们并关注目标应用程序时,这是堆栈跟踪:

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

我做错了什么?


如果这给了你提示,这里是相关软件,已安装:

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

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

我标记了,因为目标应用写在Delphi.

Windows 10 WPA(以及 Windows 8.1,在较小程度上)放弃了对旧调试符号格式的支持;它现在仅支持自 MSVC 7 以来已成为标准的 "RSDS" 格式。使用旧符号文件格式的 PE 文件(例如,VB6 生成 NB10 PDB 文件)将导致 "Missing ImageId event" 错误。

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

<Missing ImageId event> 当会话未与提供解析符号所需的一些信息的“NT 内核记录器”合并时,也会报告。

停止会话的“正确”方法是:

xperf.exe -stop my_trace -stop -d merged_trace.etl

请注意,第二个 -stop 必须停止 另一个 会话(隐式“NT Kernel Logger”),-d 将两者合并到 merged_trace.etl.