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 @@ ...@@ -15,7 +15,6 @@
*/ */
#include <linux/bpf.h> #include <linux/bpf.h>
#include <linux/perf_event.h>
#include <unistd.h> #include <unistd.h>
#include <cstdio> #include <cstdio>
#include <cstring> #include <cstring>
...@@ -417,8 +416,6 @@ StatusTuple BPF::open_perf_event(const std::string& name, ...@@ -417,8 +416,6 @@ StatusTuple BPF::open_perf_event(const std::string& name,
name.c_str()); name.c_str());
perf_event_arrays_[name] = new BPFPerfEventArray(it->second); 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]; auto table = perf_event_arrays_[name];
TRY2(table->open_all_cpu(type, config)); TRY2(table->open_all_cpu(type, config));
return StatusTuple(0); return StatusTuple(0);
......
...@@ -107,7 +107,7 @@ BPFStackTable::~BPFStackTable() { ...@@ -107,7 +107,7 @@ BPFStackTable::~BPFStackTable() {
} }
void BPFStackTable::clear_table_non_atomic() { void BPFStackTable::clear_table_non_atomic() {
for (int i = 0; i < capacity(); i++) { for (int i = 0; size_t(i) < capacity(); i++) {
remove(&i); remove(&i);
} }
} }
......
...@@ -1054,7 +1054,8 @@ int bpf_attach_perf_event(int progfd, uint32_t ev_type, uint32_t ev_config, ...@@ -1054,7 +1054,8 @@ int bpf_attach_perf_event(int progfd, uint32_t ev_type, uint32_t ev_config,
struct perf_event_attr attr = {}; struct perf_event_attr attr = {};
attr.type = ev_type; attr.type = ev_type;
attr.config = ev_config; attr.config = ev_config;
attr.inherit = 1; if (pid > 0)
attr.inherit = 1;
if (sample_freq > 0) { if (sample_freq > 0) {
attr.freq = 1; attr.freq = 1;
attr.sample_freq = sample_freq; attr.sample_freq = sample_freq;
......
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