草庐IT

event-capturing

全部标签

c - 用 `perf record -g` 模拟 `perf_event_open`

我的目标是编写一些代码以在某个时间间隔记录所有CPU的当前调用堆栈。本质上,我想做与perfrecord相同的事情,但我自己使用perf_event_open。根据联机帮助页,我似乎需要使用PERF_SAMPLE_CALLCHAIN示例类型并使用mmap读取结果。也就是说,联机帮助页非常简洁,一些示例代码现在可以发挥很大作用。有人能指出我正确的方向吗? 最佳答案 了解这一点的最佳方法是阅读Linux内核源代码并了解如何自己模拟perfrecord-g。正如您正确识别的那样,perfevents的记录将从系统调用perf_event_

c - 用 `perf record -g` 模拟 `perf_event_open`

我的目标是编写一些代码以在某个时间间隔记录所有CPU的当前调用堆栈。本质上,我想做与perfrecord相同的事情,但我自己使用perf_event_open。根据联机帮助页,我似乎需要使用PERF_SAMPLE_CALLCHAIN示例类型并使用mmap读取结果。也就是说,联机帮助页非常简洁,一些示例代码现在可以发挥很大作用。有人能指出我正确的方向吗? 最佳答案 了解这一点的最佳方法是阅读Linux内核源代码并了解如何自己模拟perfrecord-g。正如您正确识别的那样,perfevents的记录将从系统调用perf_event_

linux - 如何更改 perf_event_open 最大采样率

我正在使用perf_event_open获取样本。我试着让每个人都说到点子上。但是perf_event_open不够快。我尝试使用以下命令更改采样率:echo10000000>/proc/sys/kernel/perf_event_max_sample_rate但是看起来我设置的值太大了。运行我的代码后,perf_event_max_sample_rate变回较低的值,例如12500。当我尝试更改更大的值时,例如20000000、50000000等,采样速度不会随着我更改的值而增加。有什么方法可以更快地改变perf_event_open采样速度吗? 最佳答案

linux - 如何更改 perf_event_open 最大采样率

我正在使用perf_event_open获取样本。我试着让每个人都说到点子上。但是perf_event_open不够快。我尝试使用以下命令更改采样率:echo10000000>/proc/sys/kernel/perf_event_max_sample_rate但是看起来我设置的值太大了。运行我的代码后,perf_event_max_sample_rate变回较低的值,例如12500。当我尝试更改更大的值时,例如20000000、50000000等,采样速度不会随着我更改的值而增加。有什么方法可以更快地改变perf_event_open采样速度吗? 最佳答案

linux - 无法从/dev/input/event* 获取鼠标 move 事件

使用evtest时无法获取鼠标move事件测试输入事件的工具。我只得到三个鼠标事件:leftclickevent:type=EV_KEY,code=272(LeftBtn),value=1/0rightclickevent:type=EV_KEY,code=273(RightBtn),value=1/0mousewheelevent:type=EV_REL,code=8(Wheel),value=-1没有鼠标move事件。那么我的鼠标move事件在哪里以及如何捕获它?ps:在安装了virtualBox-addition的VirtualBox-4中的Ubuntu11.04和Gentoo上

linux - 无法从/dev/input/event* 获取鼠标 move 事件

使用evtest时无法获取鼠标move事件测试输入事件的工具。我只得到三个鼠标事件:leftclickevent:type=EV_KEY,code=272(LeftBtn),value=1/0rightclickevent:type=EV_KEY,code=273(RightBtn),value=1/0mousewheelevent:type=EV_REL,code=8(Wheel),value=-1没有鼠标move事件。那么我的鼠标move事件在哪里以及如何捕获它?ps:在安装了virtualBox-addition的VirtualBox-4中的Ubuntu11.04和Gentoo上

linux - epoll_event结构体(epoll)中参数的意义

我正在使用epoll_ctl()和epoll_wait()系统调用。intepoll_ctl(intepfd,intop,intfd,structepoll_event*event);intepoll_wait(intepfd,structepoll_event*events,intmaxevents,inttimeout);structepoll_event{uint32_tevents;/*epollevents(bitmask)*/epoll_data_tdata;/*Userdata*/};typedefunionepoll_data{entercodehere`void*pt

linux - epoll_event结构体(epoll)中参数的意义

我正在使用epoll_ctl()和epoll_wait()系统调用。intepoll_ctl(intepfd,intop,intfd,structepoll_event*event);intepoll_wait(intepfd,structepoll_event*events,intmaxevents,inttimeout);structepoll_event{uint32_tevents;/*epollevents(bitmask)*/epoll_data_tdata;/*Userdata*/};typedefunionepoll_data{entercodehere`void*pt

c++ - Linux 管道 : Capturing realtime output of ping via popen

Linux/C/管道:如何使用popen(或类似的系统调用)捕获ping命令的输出。当前popen将等到ping完成。然后输出将一起转储。伪代码:fp=popen("pingx.x.x.x","r");while(!feof(pFp)){if(fgets(fp...)// 最佳答案 它不会等到ping完成。相反,在写入任何内容之前,ping会一直等到stdout缓冲区填满。避免这种情况的唯一方法涉及伪ttys。要么你应该放弃popen并自己编写代码来运行ping子进程并使用伪tty进行通信(这很容易使用非标准但广泛使用的forkpt

c++ - Linux 管道 : Capturing realtime output of ping via popen

Linux/C/管道:如何使用popen(或类似的系统调用)捕获ping命令的输出。当前popen将等到ping完成。然后输出将一起转储。伪代码:fp=popen("pingx.x.x.x","r");while(!feof(pFp)){if(fgets(fp...)// 最佳答案 它不会等到ping完成。相反,在写入任何内容之前,ping会一直等到stdout缓冲区填满。避免这种情况的唯一方法涉及伪ttys。要么你应该放弃popen并自己编写代码来运行ping子进程并使用伪tty进行通信(这很容易使用非标准但广泛使用的forkpt