2021-05-31 18:57:50 +02:00
|
|
|
// SPDX-License-Identifier: GPL-2.0+
|
|
|
|
// static const char *__doc__ = " Trivial ktrace example";
|
|
|
|
|
|
|
|
#include <bpf/libbpf.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <errno.h>
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
2021-06-11 18:18:29 +02:00
|
|
|
#include <sys/stat.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
|
2021-05-31 18:57:50 +02:00
|
|
|
#define pr_err(fmt, ...) \
|
|
|
|
fprintf(stderr, "%s:%d - " fmt, __FILE__, __LINE__, ##__VA_ARGS__)
|
|
|
|
|
2021-06-11 18:18:29 +02:00
|
|
|
#define DEBUGFS "/sys/kernel/debug/tracing/"
|
|
|
|
|
|
|
|
void read_trace_pipe(void)
|
|
|
|
{
|
|
|
|
int trace_fd;
|
|
|
|
|
|
|
|
trace_fd = open(DEBUGFS "trace_pipe", O_RDONLY, 0);
|
|
|
|
if (trace_fd < 0)
|
|
|
|
return;
|
|
|
|
|
|
|
|
while (1) {
|
|
|
|
static char buf[4096];
|
|
|
|
ssize_t sz;
|
|
|
|
|
|
|
|
sz = read(trace_fd, buf, sizeof(buf) - 1);
|
|
|
|
if (sz > 0) {
|
|
|
|
buf[sz] = 0;
|
|
|
|
puts(buf);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2021-05-31 18:57:50 +02:00
|
|
|
int main(int argc, char **argv)
|
|
|
|
{
|
|
|
|
struct bpf_object *obj = NULL;
|
|
|
|
struct bpf_link *link = NULL;
|
|
|
|
struct bpf_program *prog;
|
|
|
|
char filename[256];
|
|
|
|
//char pin_file[256];
|
|
|
|
// char *pin_file;
|
|
|
|
char buf[100];
|
|
|
|
int err;
|
2021-06-11 18:18:29 +02:00
|
|
|
// int c;
|
2021-05-31 18:57:50 +02:00
|
|
|
|
|
|
|
snprintf(filename, sizeof(filename), "%s_kern.o", argv[0]);
|
|
|
|
|
2021-06-11 18:18:29 +02:00
|
|
|
obj = bpf_object__open_file(filename, NULL);
|
2021-05-31 18:57:50 +02:00
|
|
|
err = libbpf_get_error(obj);
|
|
|
|
if (err) {
|
|
|
|
libbpf_strerror(err, buf, sizeof(buf));
|
|
|
|
pr_err("Error(%d) opening file: %s\n", err, buf);
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
err = bpf_object__load(obj);
|
|
|
|
if (err) {
|
|
|
|
libbpf_strerror(err, buf, sizeof(buf));
|
|
|
|
pr_err("Error(%d) loading: %s\n", err, buf);
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
prog = bpf_program__next(NULL, obj);
|
|
|
|
if (!prog) {
|
|
|
|
pr_err("No program!\n");
|
|
|
|
err = -ENOENT;
|
|
|
|
goto out;
|
|
|
|
}
|
2021-06-24 11:40:41 +02:00
|
|
|
printf("Loaded BPF file %s\n", filename);
|
2021-05-31 18:57:50 +02:00
|
|
|
|
|
|
|
link = bpf_program__attach(prog);
|
|
|
|
err = libbpf_get_error(link);
|
|
|
|
if (err) {
|
|
|
|
libbpf_strerror(err, buf, sizeof(buf));
|
|
|
|
pr_err("Error(%d) attaching: %s\n", err, buf);
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
2021-06-24 11:40:41 +02:00
|
|
|
printf("Attached and reading trace_pipe\n");
|
|
|
|
printf(" - Press Ctrl-C to unload program again\n");
|
2021-06-11 18:18:29 +02:00
|
|
|
read_trace_pipe();
|
2021-05-31 18:57:50 +02:00
|
|
|
|
|
|
|
out:
|
|
|
|
bpf_link__destroy(link);
|
|
|
|
bpf_object__close(obj);
|
|
|
|
if (err)
|
|
|
|
return EXIT_FAILURE;
|
|
|
|
return EXIT_SUCCESS;
|
|
|
|
}
|