首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >捕获Xperf中的调用堆栈和事件

捕获Xperf中的调用堆栈和事件
EN

Stack Overflow用户
提问于 2014-09-11 17:22:32
回答 2查看 2K关注 0票数 1

对这个愚蠢的问题很抱歉。我对Xperf很陌生。

我在64位Windows8.1上,我的应用程序也是x64.我希望使用Xperf捕获应用程序中的回调堆栈和我定义的事件。

我在我的申请中注册了GUID 35f7872e-9b6d-4a9b-a674-66f1edd66d5c

当我使用:

代码语言:javascript
复制
xperf -on PROC_THREAD+LOADER+Base -start UserSession -on 35f7872e-9b6d-4a9b-a674-66f1edd66d5c -BufferSize 1024 -stackwalk profile

我可以得到所有的事件,但没有调用堆栈。但是,如果删除-on 35f7872e-9b6d-4a9b-a674-66f1edd66d5c并将命令行改为:

代码语言:javascript
复制
xperf -on PROC_THREAD+LOADER+Base -start UserSession -BufferSize 1024 -stackwalk profile

这样,我可以捕获所有的调用堆栈,但没有定义的事件。

有人能告诉我,捕获调用堆栈和事件的正确命令行是什么?此外,如果您可以向我指出任何好的Xperf引用,它将更大。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-09-11 19:51:36

您需要将:::'stack'添加到命令行,以捕获用户模式事件的堆栈。

代码语言:javascript
复制
xperf -start UserSession -on 35f7872e-9b6d-4a9b-a674-66f1edd66d5c:::'stack'

很好的xperf参考是“Windows内部调试”这个博客一书。

票数 1
EN

Stack Overflow用户

发布于 2015-02-22 03:08:07

我对这个问题投了赞成票,尽管它的格式很差,因为它显示出一个常见的混乱根源。最初的问题是“如何记录调用堆栈”,但这不是一个很好的问题。xperf可以记录采样分析器、上下文开关、文件I/O、磁盘I/O、注册表活动或自定义事件的调用堆栈。这个问题没有具体说明记录了哪种类型的调用堆栈,这会导致一些混乱。

让我们看一下原始命令行。我已经通过删除PROC_THREAD+LOADER简化了它,因为基包含了这些。我还删除了-BufferSize 1024,因为我认为它放错了位置,我用名称替换了GUID --您应该给提供者一个名称并使用它。因此,我们有:

代码语言:javascript
复制
xperf -on Base -start UserSession -on MyProvider -stackwalk profile

需要注意的是,我们有两个"-on“指令。这意味着我们将开始两次会议。这相当于:

代码语言:javascript
复制
xperf -on Base
xperf -start UserSession -on MyProvider -stackwalk profile

第一个命令使用'Base‘提供程序启动或连接到内核记录器(没有会话名)。第二个命令使用"UserSession“提供程序启动一个名为"MyProvider”的用户会话。

现在我们可以看到问题了。在内核记录器的上下文中,“配置文件”只是-stackwalk的一个有效选项。要求用户会话在配置文件事件上记录调用堆栈是没有意义的,因为它没有记录配置文件事件!这就引出了OP问题的变体:

代码语言:javascript
复制
xperf -on Base -stackwalk profile
xperf -start UserSession -on MyProvider
@rem Run tests here
xperf -stop UserSession -stop -d trace.etl

但是等等!那么MyProvider中用户事件的调用堆栈呢?这就是第一个答案试图解释的--我们需要添加:‘堆栈’:

代码语言:javascript
复制
xperf -on Base -stackwalk profile
xperf -start UserSession -on MyProvider:::'stack'
@rem Run tests here
xperf -stop UserSession -stop -d trace.etl

这些调用堆栈将在WPA中的Generic视图中作为Stack列使用。有关可以记录调用堆栈的许多其他内容的列表,请参阅"xperf -help stackwalk“。请记住,只需要为您实际正在录制的事件请求调用堆栈。幸运的是基地包括了侧写所以我们没事。

哦,是的--如果您想设置缓冲区大小和缓冲区计数,一定要注意您要设置的是哪个会话(可能是两个会话)。

有关更多信息,特别是有关如何分析xperf跟踪的信息,请参见:https://randomascii.wordpress.com/category/xperf/

要想更容易地记录ETW跟踪,请参阅此用于控制跟踪记录的开源用户界面您可以轻松地将您自己的提供程序添加到正在记录的列表中:https://github.com/google/UIforETW/releases

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25793538

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档