Commit 7174d93c authored by Derek's avatar Derek

keep 'enum bpf_attach_type' inside libbpf.h, renamed it to bpf_probe_attach_type

using static buf size in libbpf.c. for uprobe, set buf size to PATH_MAX
parent 6e082078
...@@ -147,7 +147,7 @@ StatusTuple BPF::detach_all() { ...@@ -147,7 +147,7 @@ StatusTuple BPF::detach_all() {
StatusTuple BPF::attach_kprobe(const std::string& kernel_func, StatusTuple BPF::attach_kprobe(const std::string& kernel_func,
const std::string& probe_func, const std::string& probe_func,
int attach_type, bpf_probe_attach_type attach_type,
pid_t pid, int cpu, int group_fd, pid_t pid, int cpu, int group_fd,
perf_reader_cb cb, void* cb_cookie) { perf_reader_cb cb, void* cb_cookie) {
std::string probe_event = get_kprobe_event(kernel_func, attach_type); std::string probe_event = get_kprobe_event(kernel_func, attach_type);
...@@ -179,7 +179,7 @@ StatusTuple BPF::attach_uprobe(const std::string& binary_path, ...@@ -179,7 +179,7 @@ StatusTuple BPF::attach_uprobe(const std::string& binary_path,
const std::string& symbol, const std::string& symbol,
const std::string& probe_func, const std::string& probe_func,
uint64_t symbol_addr, uint64_t symbol_addr,
int attach_type, bpf_probe_attach_type attach_type,
pid_t pid, int cpu, int group_fd, pid_t pid, int cpu, int group_fd,
perf_reader_cb cb, void* cb_cookie) { perf_reader_cb cb, void* cb_cookie) {
bcc_symbol sym = bcc_symbol(); bcc_symbol sym = bcc_symbol();
...@@ -318,7 +318,7 @@ StatusTuple BPF::attach_perf_event(uint32_t ev_type, uint32_t ev_config, ...@@ -318,7 +318,7 @@ StatusTuple BPF::attach_perf_event(uint32_t ev_type, uint32_t ev_config,
} }
StatusTuple BPF::detach_kprobe(const std::string& kernel_func, StatusTuple BPF::detach_kprobe(const std::string& kernel_func,
int attach_type) { bpf_probe_attach_type attach_type) {
std::string event = get_kprobe_event(kernel_func, attach_type); std::string event = get_kprobe_event(kernel_func, attach_type);
auto it = kprobes_.find(event); auto it = kprobes_.find(event);
...@@ -334,7 +334,7 @@ StatusTuple BPF::detach_kprobe(const std::string& kernel_func, ...@@ -334,7 +334,7 @@ StatusTuple BPF::detach_kprobe(const std::string& kernel_func,
StatusTuple BPF::detach_uprobe(const std::string& binary_path, StatusTuple BPF::detach_uprobe(const std::string& binary_path,
const std::string& symbol, uint64_t symbol_addr, const std::string& symbol, uint64_t symbol_addr,
int attach_type) { bpf_probe_attach_type attach_type) {
bcc_symbol sym = bcc_symbol(); bcc_symbol sym = bcc_symbol();
TRY2(check_binary_symbol(binary_path, symbol, symbol_addr, &sym)); TRY2(check_binary_symbol(binary_path, symbol, symbol_addr, &sym));
...@@ -416,7 +416,7 @@ void BPF::poll_perf_buffer(const std::string& name, int timeout) { ...@@ -416,7 +416,7 @@ void BPF::poll_perf_buffer(const std::string& name, int timeout) {
} }
StatusTuple BPF::load_func(const std::string& func_name, StatusTuple BPF::load_func(const std::string& func_name,
enum bpf_prog_type type, int& fd) { bpf_prog_type type, int& fd) {
if (funcs_.find(func_name) != funcs_.end()) { if (funcs_.find(func_name) != funcs_.end()) {
fd = funcs_[func_name]; fd = funcs_[func_name];
return StatusTuple(0); return StatusTuple(0);
...@@ -466,14 +466,14 @@ StatusTuple BPF::check_binary_symbol(const std::string& binary_path, ...@@ -466,14 +466,14 @@ StatusTuple BPF::check_binary_symbol(const std::string& binary_path,
} }
std::string BPF::get_kprobe_event(const std::string& kernel_func, std::string BPF::get_kprobe_event(const std::string& kernel_func,
int type) { bpf_probe_attach_type type) {
std::string res = attach_type_prefix(type) + "_"; std::string res = attach_type_prefix(type) + "_";
res += sanitize_str(kernel_func, &BPF::kprobe_event_validator); res += sanitize_str(kernel_func, &BPF::kprobe_event_validator);
return res; return res;
} }
std::string BPF::get_uprobe_event(const std::string& binary_path, std::string BPF::get_uprobe_event(const std::string& binary_path,
uint64_t offset, int type) { uint64_t offset, bpf_probe_attach_type type) {
std::string res = attach_type_prefix(type) + "_"; std::string res = attach_type_prefix(type) + "_";
res += sanitize_str(binary_path, &BPF::uprobe_path_validator); res += sanitize_str(binary_path, &BPF::uprobe_path_validator);
res += "_0x" + uint_to_hex(offset); res += "_0x" + uint_to_hex(offset);
......
...@@ -51,23 +51,23 @@ public: ...@@ -51,23 +51,23 @@ public:
StatusTuple attach_kprobe( StatusTuple attach_kprobe(
const std::string& kernel_func, const std::string& probe_func, const std::string& kernel_func, const std::string& probe_func,
int attach_type = BPF_PROBE_ENTRY, bpf_probe_attach_type = probe_entry,
pid_t pid = -1, int cpu = 0, int group_fd = -1, pid_t pid = -1, int cpu = 0, int group_fd = -1,
perf_reader_cb cb = nullptr, void* cb_cookie = nullptr); perf_reader_cb cb = nullptr, void* cb_cookie = nullptr);
StatusTuple detach_kprobe( StatusTuple detach_kprobe(
const std::string& kernel_func, const std::string& kernel_func,
int attach_type = BPF_PROBE_ENTRY); bpf_probe_attach_type attach_type = probe_entry);
StatusTuple attach_uprobe( StatusTuple attach_uprobe(
const std::string& binary_path, const std::string& symbol, const std::string& binary_path, const std::string& symbol,
const std::string& probe_func, uint64_t symbol_addr = 0, const std::string& probe_func, uint64_t symbol_addr = 0,
int attach_type = BPF_PROBE_ENTRY, bpf_probe_attach_type attach_type = probe_entry,
pid_t pid = -1, int cpu = 0, int group_fd = -1, pid_t pid = -1, int cpu = 0, int group_fd = -1,
perf_reader_cb cb = nullptr, void* cb_cookie = nullptr); perf_reader_cb cb = nullptr, void* cb_cookie = nullptr);
StatusTuple detach_uprobe( StatusTuple detach_uprobe(
const std::string& binary_path, const std::string& symbol, const std::string& binary_path, const std::string& symbol,
uint64_t symbol_addr = 0, uint64_t symbol_addr = 0,
int attach_type = BPF_PROBE_ENTRY); bpf_probe_attach_type attach_type = probe_entry);
StatusTuple attach_usdt(const USDT& usdt, pid_t pid = -1, int cpu = 0, StatusTuple attach_usdt(const USDT& usdt, pid_t pid = -1, int cpu = 0,
int group_fd = -1); int group_fd = -1);
StatusTuple detach_usdt(const USDT& usdt); StatusTuple detach_usdt(const USDT& usdt);
...@@ -106,9 +106,9 @@ private: ...@@ -106,9 +106,9 @@ private:
StatusTuple unload_func(const std::string& func_name); StatusTuple unload_func(const std::string& func_name);
std::string get_kprobe_event(const std::string& kernel_func, std::string get_kprobe_event(const std::string& kernel_func,
int attach_type); bpf_probe_attach_type type);
std::string get_uprobe_event(const std::string& binary_path, uint64_t offset, std::string get_uprobe_event(const std::string& binary_path, uint64_t offset,
int attach_type); bpf_probe_attach_type type);
StatusTuple detach_kprobe_event(const std::string& event, open_probe_t& attr); StatusTuple detach_kprobe_event(const std::string& event, open_probe_t& attr);
StatusTuple detach_uprobe_event(const std::string& event, open_probe_t& attr); StatusTuple detach_uprobe_event(const std::string& event, open_probe_t& attr);
...@@ -116,21 +116,21 @@ private: ...@@ -116,21 +116,21 @@ private:
open_probe_t& attr); open_probe_t& attr);
StatusTuple detach_perf_event_all_cpu(open_probe_t& attr); StatusTuple detach_perf_event_all_cpu(open_probe_t& attr);
std::string attach_type_debug(int attach_type) { std::string attach_type_debug(bpf_probe_attach_type type) {
switch (attach_type) { switch (type) {
case BPF_PROBE_ENTRY: case probe_entry:
return ""; return "";
case BPF_PROBE_RETURN: case probe_return:
return "return "; return "return ";
} }
return "ERROR"; return "ERROR";
} }
std::string attach_type_prefix(int attach_type) { std::string attach_type_prefix(bpf_probe_attach_type type) {
switch (attach_type) { switch (type) {
case BPF_PROBE_ENTRY: case probe_entry:
return "p"; return "p";
case BPF_PROBE_RETURN: case probe_return:
return "r"; return "r";
} }
return "ERROR"; return "ERROR";
......
...@@ -338,16 +338,17 @@ static int bpf_attach_tracing_event(int progfd, const char *event_path, ...@@ -338,16 +338,17 @@ static int bpf_attach_tracing_event(int progfd, const char *event_path,
return 0; return 0;
} }
void * bpf_attach_kprobe(int progfd, int attach_type, const char *ev_name, void * bpf_attach_kprobe(int progfd, enum bpf_probe_attach_type attach_type, const char *ev_name,
const char *fn_name, const char *fn_name,
pid_t pid, int cpu, int group_fd, pid_t pid, int cpu, int group_fd,
perf_reader_cb cb, void *cb_cookie) perf_reader_cb cb, void *cb_cookie)
{ {
int kfd; int kfd;
char buf[strlen(ev_name)+256]; char buf[256];
char new_name[strlen(ev_name)+32]; char new_name[128];
struct perf_reader *reader = NULL; struct perf_reader *reader = NULL;
static char *event_type = "kprobe"; static char *event_type = "kprobe";
int n;
snprintf(new_name, sizeof(new_name), "%s_bcc_%d", ev_name, getpid()); snprintf(new_name, sizeof(new_name), "%s_bcc_%d", ev_name, getpid());
reader = perf_reader_new(cb, NULL, cb_cookie); reader = perf_reader_new(cb, NULL, cb_cookie);
...@@ -375,11 +376,10 @@ void * bpf_attach_kprobe(int progfd, int attach_type, const char *ev_name, ...@@ -375,11 +376,10 @@ void * bpf_attach_kprobe(int progfd, int attach_type, const char *ev_name,
snprintf(buf, sizeof(buf), "/sys/kernel/debug/tracing/instances/%s", new_name); snprintf(buf, sizeof(buf), "/sys/kernel/debug/tracing/instances/%s", new_name);
if (mkdir(buf, 0755) == -1) if (mkdir(buf, 0755) == -1)
goto retry; goto retry;
snprintf(buf, sizeof(buf), "/sys/kernel/debug/tracing/instances/%s/events/%ss/%s", n = snprintf(buf, sizeof(buf), "/sys/kernel/debug/tracing/instances/%s/events/%ss/%s",
new_name, event_type, new_name); new_name, event_type, new_name);
if (bpf_attach_tracing_event(progfd, buf, reader, pid, cpu, group_fd) == 0) { if (n < sizeof(buf) && bpf_attach_tracing_event(progfd, buf, reader, pid, cpu, group_fd) == 0)
goto out; goto out;
}
snprintf(buf, sizeof(buf), "/sys/kernel/debug/tracing/instances/%s", new_name); snprintf(buf, sizeof(buf), "/sys/kernel/debug/tracing/instances/%s", new_name);
rmdir(buf); rmdir(buf);
} }
...@@ -396,16 +396,17 @@ error: ...@@ -396,16 +396,17 @@ error:
} }
void * bpf_attach_uprobe(int progfd, int attach_type, const char *ev_name, void * bpf_attach_uprobe(int progfd, enum bpf_probe_attach_type attach_type, const char *ev_name,
const char *binary_path, uint64_t offset, const char *binary_path, uint64_t offset,
pid_t pid, int cpu, int group_fd, pid_t pid, int cpu, int group_fd,
perf_reader_cb cb, void *cb_cookie) perf_reader_cb cb, void *cb_cookie)
{ {
int kfd; int kfd;
char buf[strlen(binary_path)+strlen(ev_name)+256]; char buf[PATH_MAX];
char new_name[strlen(ev_name)+32]; char new_name[128];
struct perf_reader *reader = NULL; struct perf_reader *reader = NULL;
static char *event_type = "uprobe"; static char *event_type = "uprobe";
int n;
snprintf(new_name, sizeof(new_name), "%s_bcc_%d", ev_name, getpid()); snprintf(new_name, sizeof(new_name), "%s_bcc_%d", ev_name, getpid());
reader = perf_reader_new(cb, NULL, cb_cookie); reader = perf_reader_new(cb, NULL, cb_cookie);
...@@ -419,8 +420,12 @@ void * bpf_attach_uprobe(int progfd, int attach_type, const char *ev_name, ...@@ -419,8 +420,12 @@ void * bpf_attach_uprobe(int progfd, int attach_type, const char *ev_name,
goto error; goto error;
} }
snprintf(buf, sizeof(buf), "%c:%ss/%s %s:0x%lx", attach_type==BPF_PROBE_ENTRY ? 'p' : 'r', n = snprintf(buf, sizeof(buf), "%c:%ss/%s %s:0x%lx", attach_type==BPF_PROBE_ENTRY ? 'p' : 'r',
event_type, new_name, binary_path, offset); event_type, new_name, binary_path, offset);
if (n >= sizeof(buf)) {
close(kfd);
goto error;
}
if (write(kfd, buf, strlen(buf)) < 0) { if (write(kfd, buf, strlen(buf)) < 0) {
if (errno == EINVAL) if (errno == EINVAL)
fprintf(stderr, "check dmesg output for possible cause\n"); fprintf(stderr, "check dmesg output for possible cause\n");
...@@ -443,7 +448,7 @@ error: ...@@ -443,7 +448,7 @@ error:
static int bpf_detach_probe(const char *ev_name, const char *event_type) static int bpf_detach_probe(const char *ev_name, const char *event_type)
{ {
int kfd; int kfd;
char buf[strlen(ev_name)+256]; char buf[256];
snprintf(buf, sizeof(buf), "/sys/kernel/debug/tracing/%s_events", event_type); snprintf(buf, sizeof(buf), "/sys/kernel/debug/tracing/%s_events", event_type);
kfd = open(buf, O_WRONLY | O_APPEND, 0); kfd = open(buf, O_WRONLY | O_APPEND, 0);
if (kfd < 0) { if (kfd < 0) {
...@@ -464,7 +469,7 @@ static int bpf_detach_probe(const char *ev_name, const char *event_type) ...@@ -464,7 +469,7 @@ static int bpf_detach_probe(const char *ev_name, const char *event_type)
int bpf_detach_kprobe(const char *ev_name) int bpf_detach_kprobe(const char *ev_name)
{ {
char buf[strlen(ev_name)+256]; char buf[256];
int ret = bpf_detach_probe(ev_name, "kprobe"); int ret = bpf_detach_probe(ev_name, "kprobe");
snprintf(buf, sizeof(buf), "/sys/kernel/debug/tracing/instances/%s_bcc_%d", ev_name, getpid()); snprintf(buf, sizeof(buf), "/sys/kernel/debug/tracing/instances/%s_bcc_%d", ev_name, getpid());
if (access(buf, F_OK) != -1) { if (access(buf, F_OK) != -1) {
......
...@@ -24,6 +24,10 @@ ...@@ -24,6 +24,10 @@
extern "C" { extern "C" {
#endif #endif
enum bpf_probe_attach_type {
probe_entry,
probe_return
};
#define BPF_PROBE_ENTRY 0 #define BPF_PROBE_ENTRY 0
#define BPF_PROBE_RETURN 1 #define BPF_PROBE_RETURN 1
...@@ -47,14 +51,14 @@ typedef void (*perf_reader_cb)(void *cb_cookie, int pid, uint64_t callchain_num, ...@@ -47,14 +51,14 @@ typedef void (*perf_reader_cb)(void *cb_cookie, int pid, uint64_t callchain_num,
void *callchain); void *callchain);
typedef void (*perf_reader_raw_cb)(void *cb_cookie, void *raw, int raw_size); typedef void (*perf_reader_raw_cb)(void *cb_cookie, void *raw, int raw_size);
void * bpf_attach_kprobe(int progfd, int attach_type, const char *ev_name, void * bpf_attach_kprobe(int progfd, enum bpf_probe_attach_type attach_type, const char *ev_name,
const char *fn_name, const char *fn_name,
pid_t pid, int cpu, int group_fd, pid_t pid, int cpu, int group_fd,
perf_reader_cb cb, void *cb_cookie); perf_reader_cb cb, void *cb_cookie);
int bpf_detach_kprobe(const char *ev_name); int bpf_detach_kprobe(const char *ev_name);
void * bpf_attach_uprobe(int progfd, int attach_type, const char *ev_name, void * bpf_attach_uprobe(int progfd, enum bpf_probe_attach_type attach_type, const char *ev_name,
const char *binary_path, uint64_t offset, const char *binary_path, uint64_t offset,
pid_t pid, int cpu, int group_fd, pid_t pid, int cpu, int group_fd,
perf_reader_cb cb, void *cb_cookie); perf_reader_cb cb, void *cb_cookie);
......
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