Commit 99978d23 authored by Teng Qin's avatar Teng Qin

Fix perf event API implementations

- Set `inherit = 1` only for per-task perf event. Inspired from change
  https://github.com/torvalds/linux/commit/81b9cf8028a17bdbdaa0da80b735b32150d4e89e
- Kernel now support more events (see #1448). Also it's checked in
  `bpf_attach_perf_event` already. Remove the check from C++ API
parent bebb9c8c
......@@ -15,7 +15,6 @@
*/
#include <linux/bpf.h>
#include <linux/perf_event.h>
#include <unistd.h>
#include <cstdio>
#include <cstring>
......@@ -417,8 +416,6 @@ StatusTuple BPF::open_perf_event(const std::string& name,
name.c_str());
perf_event_arrays_[name] = new BPFPerfEventArray(it->second);
}
if (type != PERF_TYPE_RAW && type != PERF_TYPE_HARDWARE)
return StatusTuple(-1, "open_perf_event unsupported type");
auto table = perf_event_arrays_[name];
TRY2(table->open_all_cpu(type, config));
return StatusTuple(0);
......
......@@ -107,7 +107,7 @@ BPFStackTable::~BPFStackTable() {
}
void BPFStackTable::clear_table_non_atomic() {
for (int i = 0; i < capacity(); i++) {
for (int i = 0; size_t(i) < capacity(); i++) {
remove(&i);
}
}
......
......@@ -1054,6 +1054,7 @@ int bpf_attach_perf_event(int progfd, uint32_t ev_type, uint32_t ev_config,
struct perf_event_attr attr = {};
attr.type = ev_type;
attr.config = ev_config;
if (pid > 0)
attr.inherit = 1;
if (sample_freq > 0) {
attr.freq = 1;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment