PERF EVENT 硬件篇

简介: 简介 本文将通过以 X86 为例子介绍硬件 PMU 如何为 linux kernel perf_event 子系统提供硬件性能采集功能 理解硬件 MSR (Model Specify Register) 可以理解为CPU硬件的专用寄存器,下述的所有寄存器都是这个类型 汇编指令 rdmsr/wrm.

简介

本文将通过以 X86 为例子介绍硬件 PMU 如何为 linux kernel perf_event 子系统提供硬件性能采集功能

理解硬件

MSR (Model Specify Register)

可以理解为CPU硬件的专用寄存器,下述的所有寄存器都是这个类型

汇编指令 rdmsr/wrmsr

wrmsr 0x38d 1234 # addr value

如果是 pmc 还可以用 rdpmc 指令

rdpmc [0~7] # input ECX output EDX:EAX

在硬件 pmu 的操作过程中大多类似以下模式

  1. 写入 pmc 对应的状态 msr,决定要打开哪个硬件事件
  2. 通过读取 pmc 获取之前定义的硬件事件数值

PMCx 与 PERFEVTSELx

通用事件寄存器,成对出现,由 PERFEVTSEL 配置事件,PMC 读取事件数值。在现代 x86 产品中被称之为通用 pmu 设备,一般为4个,如果关闭虚拟化可以使用8个

FIXED_CTRx 与 FIXED_CTR_CTRL

专用寄存器,通过唯一的 FIXED_CTR_CTRL 来开启对应的 FIXED_CTRx。无事件控制,每个 FIXED_CTRx 只能记录对应的硬件事件

RDT (Resource Direct Tech) 是一种全新的性能采集方式,有点与上述两种寄存器有所不同,但是在软件接口上会更简洁。支持 L3 cache 相关资源使用计数

它的操作过程不用定义事件类型,只要以下步骤

  1. 通过 PQR_ASSOC msr寄存器写入 rmid 就已经开始统计相关事件的计数
  2. 通过QM_EVTSEL 输入要读取的事件 id 和 rmid
  3. 最后通过 QM_CTR 即可获得数据

可以看出它不再以单独的CPU为维度,用户可以自定义 rmid,可以用 task,也可以用 cpuid,甚至多者混合

操作

linux 系统提供了 msr 内核模块,允许用户可以在用户态直接操作 msr

ls /dev/cpu/0/msr

msr 都是 per-cpu 的设备,所以需要指定具体 cpu。 通过 lseek 来定位 msr,通过 write/read 来读写

通过这种方式来获取 cpu 性能是 bypass 内核,同样无法利用到 perf_event 子系统提供的一系列功能,比如关联某个 task, cgroup,也无法在有限的 pmu 个数中产生分时复用

总结

硬件 PMU 的实现就是提供了一系列的可操作 MSR, 通过 MSR 操作可以灵活定义要监控的内容,但是 linux kernel 中通过实现 perf_event 子系统对用户态提供了一套简洁通用的操作界面

其他

PERF_EVENT 系列文章

  1. PERF EVENT API篇
  2. PERF EVENT 硬件篇
  3. PERF EVENT 内核篇
  4. PERF EVENT 硬件篇续
目录
相关文章
|
JavaScript
Event Bus
本文主要通过简单的实例学习了Vue中有关于 EventBus 相关的知识点。主要涉及了 EventBus 如何实例化,又是如何通过 $emit` 发送频道信号,又是如何通过 `$on 来接收频道信号。最后简单介绍了如何创建全局的 EventBus 。从实例中我们可以了解到, EventBus 可以较好的实现兄弟组件之间的数据通讯。
71 2
|
3月前
|
Linux
perf_event_open学习 —— 缓冲区管理
perf_event_open学习 —— 缓冲区管理
|
3月前
|
Linux C语言 网络架构
perf_event_open学习 —— 手册学习
perf_event_open学习 —— 手册学习
|
3月前
|
Linux
将perf跟funcgraph-retval结合起来使用
将perf跟funcgraph-retval结合起来使用
|
3月前
|
监控 Linux C++
perf_event_open学习 —— mmap方式读取
perf_event_open学习 —— mmap方式读取
|
数据可视化 Linux 调度
译 | Linux perf_events Off-CPU Time Flame Graph
译 | Linux perf_events Off-CPU Time Flame Graph
114 0
|
负载均衡 Cloud Native Linux
Linux Command Perf 性能剖析
Linux Command Perf 性能剖析
Linux Command Perf 性能剖析
|
传感器 算法 Linux
Perf Subsystem —— 基于PMI实现的NMI Watchdog
## 背景 任务能否被及时响应,对内核来说,至关重用。Linux kernel实现了softlockup和hardlockup,用于检测系统是否出现了长时间无响应。 > A ‘softlockup’ is defined as a bug that causes the kernel to loop in kernel mode for more than 20 seconds, with
2168 1
|
Linux
PERF EVENT 硬件篇续 -- core/offcore/uncore
简介 在上篇中,我们简单介绍 PERF EVENT 如何在硬件层面给予测量性能的能力,在这篇中我们继续针对硬件性能事件的类型做进一步介绍以理清我们日常在沟通中会遇到的一些概念。 在上篇介绍中我们介绍了三种事件捕捉实现 通用事件 PMCx & PERFEVETSELx 专用事件 FIXED_CTRx.
6466 0