Windows ETW:内核使用者未收到 EventCallback 或 BufferCallback 事件

2024-01-18

我正在尝试监听 ETW 内核事件。

  • 第 1 步:致电OpenTrace http://msdn.microsoft.com/en-us/library/windows/desktop/aa364089%28v=vs.85%29.aspx,指定EventCallback http://msdn.microsoft.com/en-us/library/windows/desktop/aa363721%28v=vs.85%29.aspx和可选的BufferCallback http://msdn.microsoft.com/en-us/library/windows/desktop/aa363685%28v=vs.85%29.aspx在我调用期间将调用的函数ProcessTrace http://msdn.microsoft.com/en-us/library/windows/desktop/aa364093%28v=vs.85%29.aspx:

    var
        logFile: EVENT_TRACE_LOGFILE;
        currentTrace: TRACEHANDLE;
    begin
        ZeroMemory(@logFile, sizeof(logFile));
    
        logFile.LoggerName := KERNEL_LOGGER_NAME;
        logFile.LogFileName := 'C:\Users\Ian\foo.etl';
        logFile.ProcessTraceMode := 0;
        logFile.EventCallback := RealtimeEventCallback;
        logFile.BufferCallback := BufferCallback; //optional
    
        currentTrace := OpenTrace(@logFile);
        if (currentTrace = INVALID_PROCESSTRACE_HANDLE) or (currentTrace = -1) then
               RaiseLastWin32Error();
    
  • Step 2: 启用内核事件 http://msdn.microsoft.com/en-us/library/windows/desktop/aa363691%28v=vs.85%29.aspx。这是通过调用来完成的StartTrace http://msdn.microsoft.com/en-us/library/windows/desktop/aa364117%28v=vs.85%29.aspx。就我而言,我想跟踪内核中断 http://msdn.microsoft.com/en-us/library/windows/desktop/aa964780%28v=vs.85%29.aspx (EVENT_TRACE_FLAG_INTERRUPT http://msdn.microsoft.com/en-us/library/windows/desktop/aa363784%28v=vs.85%29.aspx) and 延迟过程调用 http://msdn.microsoft.com/en-us/library/windows/desktop/aa964748%28v=vs.85%29.aspx (EVENT_TRACE_FLAG_DPC http://msdn.microsoft.com/en-us/library/windows/desktop/aa363784%28v=vs.85%29.aspx):

    var
        sessionProperties: PEVENT_TRACE_PROPERTIES;
        bufferSize: Int64;
        th: TRACEHANDLE;
        loggerName: string;
        logFilePath: string;
    begin
        loggerName := KERNEL_LOGGER_NAME;
        logFilePath := 'C:\Users\Ian\foo.etl';
    
        bufferSize := sizeof(EVENT_TRACE_PROPERTIES)
            + 1024 //maximum session name is 1024 characters
            + 1024; //maximum log file name is 1024 characters
    
        sessionProperties := AllocMem(bufferSize);
        ZeroMemory(sessionProperties, bufferSize);
    
        sessionProperties.Wnode.BufferSize := bufferSize;
        sessionProperties.Wnode.ClientContext := 1; //QPC clock resolution
        sessionProperties.Wnode.Flags := WNODE_FLAG_TRACED_GUID;
        sessionProperties.Wnode.Guid := SystemTraceControlGuid;
        sessionProperties.EnableFlags := EVENT_TRACE_FLAG_INTERRUPT or EVENT_TRACE_FLAG_DPC;
        sessionProperties.LogFileMode := EVENT_TRACE_FILE_MODE_CIRCULAR;
        sessionProperties.MaximumFileSize := 5;  // 5 MB
        sessionProperties.LoggerNameOffset := sizeof(EVENT_TRACE_PROPERTIES);
        sessionProperties.LogFileNameOffset := sizeof(EVENT_TRACE_PROPERTIES)+1024;
    
        //Copy LoggerName to the offset address
        MoveMemory(Pointer(Cardinal(sessionProperties)+sessionProperties.LoggerNameOffset), PChar(loggerName), Length(loggerName)+1);
    
        //Copy LogFilePath to the offset address
        MoveMemory(Pointer(Cardinal(sessionProperties)+sessionProperties.LogFileNameOffset), PChar(logFilePath), Length(logFilePath)+1);
    
        hr := StartTrace({var}th, PChar(loggerName), sessionProperties);
        if (hr <> ERROR_SUCCESS) then
              raise EWin32Error.Create(SysErrorMessage(hr));
    

    并且日志已成功启动(我可以看到foo.etl开始增长到 5 MB 循环限制)。

  • 第 3 步:致电ProcessTrace http://msdn.microsoft.com/en-us/library/windows/desktop/aa364093%28v=vs.85%29.aspx,它会阻塞,直到将所有待处理事件传递给EventCallback http://msdn.microsoft.com/en-us/library/windows/desktop/aa363721%28v=vs.85%29.aspx步骤 1 中指定的处理程序:

    var
       res: LongWord;
    begin
       res := EventTrace.ProcessTrace(@currentTrace, 1, nil, nil);
       if (res <> ERROR_SUCCESS) then
          raise EWin32Error.Create(SysErrorMessage(res));
    

除了那个ProcessTrace重复地立即返回,并且不会调用回调 - 即使 etl 文件存在并且正在增长。


如果我更改日志记录基于文件 to Realtime记录:

  • 步骤1 -OpenTrace支持的变化realtime:

    logFile.ProcessTraceMode := PROCESS_TRACE_MODE_REAL_TIME;
    
  • 第2步 -StartTrace支持的变化realtime:

    sessionProperties.LogFileMode := EVENT_TRACE_REAL_TIME_MODE;
    

在这种情况下ProcessTrace never返回,但两者都没有EventCallback or BufferCallback曾经被召唤过。

我究竟做错了什么?


Update:我的回调函数:

function BufferCallback(Logfile: PEVENT_TRACE_LOGFILE): LongWord; stdcall;
begin
   ShowMessage('BufferCallback');
   Result := 1; //return true to keep processing rows
end;

procedure RealtimeEventCallback(pEvent: PEVENT_TRACE); stdcall;
begin
   ShowMessage('EventCallback');
   nEvents := nEvents+1;
end;

我发现了问题。

我使用的标题不是四字对齐的。

用 Delphi 的话说,关键字packed正在被使用。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Windows ETW:内核使用者未收到 EventCallback 或 BufferCallback 事件 的相关文章

  • 如何在 WINAPI 中获取 Windows 10 内部版本、修订号?

    我想使用 WINAPI 在 Windows 10 上获取构建版本 当前窗口版本 10 0 19042 685 我尝试使用 WMI 查询来获取它 select Version BuildNumber from Win32 OperatingS
  • 如何追踪“地址 00000000”的访问违规

    我知道如何创建 map 文件来在错误消息包含实际地址时跟踪访问冲突错误 但是如果错误消息说怎么办 Access violation at address 00000000 Read of address 00000000 我从哪里开始寻找这
  • 在 Delphi 2009 上安装最新版本的 Indy 10 [重复]

    这个问题在这里已经有答案了 是否有更新 Delphi 2009 中的 Indy 10 组件的分步指南 我读过正在卸载线程 https stackoverflow com questions 486210 what is the proper
  • 在TImageViewer中,如何获取用户点击图片的位置?

    在TImageViewer控件中 用户可以缩放或平移图片 我的问题是 当用户点击图片时 如何获取用户在图片上的点击位置 尤其是用户可以对图片进行放大 缩小或平移之后 如何获取对应的图片点击位置呢 As shown below How to
  • 如何为 C++ Visual Studio 2019 指定应用程序图标?

    我见过本文档 https learn microsoft com en us visualstudio ide how to specify an application icon visual basic csharp view vs 2
  • 当 Delphi 处于覆盖模式时,如何更改它的光标形状?

    当使用 Delphi 的任何版本时 我有时会碰巧按下插入键并打开覆盖模式 这通常是一个很大的麻烦 并且您进入覆盖模式的唯一指示是编辑器底部的小文本 当使用其他程序 首先想到的是 Notepad 时 当您处于插入模式时 文本光标是 当您处于覆
  • Delphi 5 的哈希表实现 [关闭]

    Closed 这个问题正在寻求书籍 工具 软件库等的推荐 不满足堆栈溢出指南 help closed questions 目前不接受答案 您知道 Delphi 5 的良好且免费的哈希表实现吗 我需要在哈希表中组织大量数据 并且我有点担心在网
  • 如何保证对象只有一个线程

    我有以下代码 class Service public void start creates thread which creates window and goes to message loop void stop sends WM C
  • Delphi 2010 - 从 XML 文档解码 Base64 编码图像

    我正在尝试从应用程序中的 XML 文档解码 base64 编码的 EMF 图像并将其呈现在屏幕上 但是 它似乎从未出现 如果我将 XML 文档中的数据复制 粘贴到 Notepad 中并使用Base64 Decode选项并将文件另存为 emf
  • 如何用不同的颜色绘制选定的列表框项目?

    是否可以更改 TListBox 中的项目选择焦点颜色和文本颜色 当项目中未启用主题或列表框样式设置为所有者绘制时 项目周围的选择将被涂成蓝色 我相信这是由系统的外观设置全局定义的 我想将所选项目的颜色更改为自定义颜色 举个例子 结果会是这样
  • 打印 TDBGrid [重复]

    这个问题在这里已经有答案了 如何在不安装或下载组件的情况下打印 DBGrid OR 如何将 DBGrid 的数据放入 RichEdit 以便我可以从那里打印它 数据感知控件从 DataSource 属性获取数据 并使用它 不过 您必须手动遍
  • 如何使 StringGrid 的列适合网格的宽度?

    我已经寻找解决方案很长时间了 但没有任何运气 有谁知道一个简单的方法来做到这一点 例如 我想拉伸网格的第二列以适应网格的宽度 Use the ColWidths财产 像这样 with StringGrid1 do ColWidths 1 C
  • 防止多个实例 - 但还要处理命令行参数?

    我正在从我的应用程序处理与 Windows 相关的扩展文件 因此 当您在 Windows 中双击文件时 它将执行我的程序 然后我从那里处理该文件 如下所示 procedure TMainForm FormCreate Sender TObj
  • win32上的64位Anaconda使用32位还是64位?

    我猜答案是 32 位 但我有点困惑为什么我什至可以在 win32 中安装 Anaconda 64 我曾经在 Anaconda 64 位上工作 但我刚刚意识到我的系统是 win32 这有时会产生一些异常 例如 请参阅我为 scipy 打开的这
  • 将图像加载到 TImageList 并读取它们?

    我试图通过将 jpg 转换为 bmp 然后将其保存到 imagelist1 来将 jpg 加载到图像列表中 从上到下的代码片段 Selectdir 有效 fileexists 部分有效 这用于加载文件夹中的所有图像 所有图像都以 0 jpg
  • 如何比较枚举类型集

    从某个时刻开始 我厌倦了编写设定条件 and or 因为对于更多的条件或更长的变量名 重新编写会变得笨拙且烦人 所以我开始写助手这样我就可以写ASet ContainsOne ceValue1 ceValue2 代替 ceValue1 in
  • 将目录压缩为单个文件的方法有哪些

    不知道怎么问 所以我会解释一下情况 我需要存储一些压缩文件 最初的想法是创建一个文件夹并存储所需数量的压缩文件 并创建一个文件来保存有关每个压缩文件的数据 但是 我不被允许创建许多文件 只能有一个 我决定创建一个压缩文件 其中包含有关进一步
  • 通过win32检测多个登录用户

    使用标准 win32 api 检测多个用户登录的最佳方法是什么 我对我们的软件产品进行了升级 当多个用户登录时 该产品无法运行 我知道这是应该避免的事情 因为它很烦人 但该产品非常复杂 您必须相信我 当我说确实没有其他解决方案时 谢谢 为了
  • H2161 重复资源[一个VCL项目可以有2个类名相同但命名空间不同的表单吗?]

    我尝试在 2 个不同的命名空间中创建具有相同类名的 2 个表单 FirstNameSpace ExampleFormName TExampleFormName SecondNameSpace ExampleFormName TExample
  • 高效列出目录中的所有子目录

    请参阅迄今为止所采取的建议的编辑 我正在尝试使用 WinAPI 和 C 列出给定目录中的所有目录 文件夹 现在我的算法又慢又低效 使用 FindFirstFileEx 打开我正在搜索的文件夹 然后我查看目录中的每个文件 使用 FindNex

随机推荐

  • Laravel Eloquent `take` 和 `orderBy`

    当我尝试使用每个 take 和 orderBy 查询时 模型返回一些记录 this gt hasMany App User gt take 3 this gt hasMany App User gt orderBy id desc 但是当我
  • 如何在CSS中制作具有透明度的径向渐变

    我想在透明度变化的地方制作一个径向渐变 我可以让它线性工作 但不是径向工作 background webkit gradient linear left top left bottom from rgba 50 50 50 0 8 to r
  • 具有高多边形网格的 OpenGL 3D 光线拾取

    如何在包含高多边形网格的模型的 3D 场景中实现 3D 光线拾取 迭代所有三角形来执行三角形线相交测试需要花费太多时间 我知道存在八叉树等方法 并且应该可以将这些方法用于场景中的模型 但我不知道应该如何在网格级别使用这些概念 但是 如果您在
  • GWT - 如何编译移动排列

    我知道如何使用延迟绑定为不同的用户代理编译 GWT 应用程序 但这似乎没有提供区分桌面 移动浏览器的方法 除了制作基于 gwt mobile webkit 的新应用程序之外 如何将现有的 GWT 应用程序转换为具有重新设计的移动界面 如果您
  • 如何使maven-compiler-plugin不隐藏错误源位置

    也许有一个maven compiler plugin这个选项 但我还没有找到 When javac直接运行并打印错误 在消息的第一行之后 它显示受影响的源行下一行上有一个插入符号指向错误位置 它看起来像这样 com invariantpro
  • 确保泛型类型在 Typescript 中仅具有原始属性

    我有一个采用泛型类型的函数 我需要确保该类型是 JSON 可序列化的 也称为仅原始属性 我的尝试是为 JSON 兼容类型定义一个接口 并强制我的泛型扩展此类型 type JSONPrimitive string number boolean
  • 如何通过按键终止 while 循环?

    我正在读取串行数据并使用 while 循环写入 csv 文件 我希望用户一旦觉得已经收集了足够的数据就能够终止 while 循环 while True do a bunch of serial stuff if the user press
  • swift 中 DispatchQueue 类型之间的区别

    据我了解 Swift 中有 3 种类型的 DispatchQueue 主要 连续剧 主线 全球 并发 后台线程并行工作 自定义 并发或串行 每一个都可能有效 异步或同步 第一个问题 主队列是否在工作仅 UI 线程并且不在另一个线程上工作 如
  • 为什么反应路由器在 vercel 上不起作用?

    我正在尝试将无服务器网络发布到 vercel 我想使用react router 这在我的计算机上运行良好 但是当我部署它时它不起作用 有人可以帮助我吗 我想在没有服务器的情况下完成 My main code import React fro
  • ServiceLocator 是一种反模式吗? [关闭]

    Closed 这个问题是基于意见的 help closed questions 目前不接受答案 最近我读过马克 西曼的文章 http blog ploeh dk 2010 02 03 ServiceLocatorisanAnti Patte
  • 如何在 Android 上设置 ImageView 的背景颜色?

    我尝试了一些方法 但没有任何效果 我试图更改 Android 上 ImageView 上的背景颜色 但没有任何反应 这是我的 xml
  • CSS3“提升角”不透明度阴影

    我一直在玩一些 CSS3 阴影效果 我非常喜欢 升角 效果 但在尝试向元素添加不透明度时遇到了问题 我的问题是 有没有办法在不透明的元素上创建 升角 效果 http jsfiddle net WAvZu http jsfiddle net
  • 为什么我的 Android 应用程序在类开头使用 findViewById(R.id.******) 初始化变量时会崩溃并出现 NullPointerException?

    此代码 带有注释的顶部块 成功运行 public class MainActivity extends AppCompatActivity EditText username EditText findViewById R id editT
  • 多列索引还需要单列索引吗?

    我陷入了一个设计不佳的系统中 现在我正在他们的数据库上做DBA 我有很多像下面这样的情况 伪代码 Table t1 c1 c2 c3 c4 key c1 key c2 key c1 c2 key c1 c2 c3 单列索引真的有必要吗 因为
  • 如何获取 Objective C(Foundation 框架)中命令行工具的可执行路径?

    我正在尝试找出一种方法来识别 Objective C 中命令行工具的可执行路径 因此 如果可执行文件是 Applications Utils MyTool 则该方法将返回 Applications Utils 我正在使用基础框架 称我为纯粹
  • Codeigniter 会话安全

    如何提高会话的安全性 this gt session gt userdata userid 我一直在为我的 ajax 调用而抛弃这个小坏男孩 有些情况我没有 然后我就想 使用 DOM 中的 id 真的安全吗 如果 DOM 被更改以破解用户帐
  • 恢复 Tensorflow 中新模型子集的变量?

    我正在做一个通过 Tensorflow 增强 4 层 DNN 到 5 层 DNN 的示例 我在 TF 中使用保存会话和恢复来制作它 因为 TF 教程中有一个简短的段落 例如 你可能已经训练了一个 4 层的神经网络 现在想要训练一个 5 层的
  • 具有相同函数名的包

    R 中具有相同函数名称的库似乎很烦人 解决以下问题的最简单方法是什么 Attaching package dplyr The following objects are masked from package stats filter la
  • 使用 LIFO 逻辑运行的 MailboxProcessor

    我正在学习 F 代理 MailboxProcessor 我正在处理一个相当非传统的问题 我有一名代理人 dataSource 这是流数据的来源 数据必须由一系列代理进行处理 dataProcessor 我们可以考虑dataProcessor
  • Windows ETW:内核使用者未收到 EventCallback 或 BufferCallback 事件

    我正在尝试监听 ETW 内核事件 第 1 步 致电OpenTrace http msdn microsoft com en us library windows desktop aa364089 28v vs 85 29 aspx 指定Ev