summaryrefslogtreecommitdiff
path: root/internal/ioriotng.bpf.c
diff options
context:
space:
mode:
authorPaul Buetow <paul@buetow.org>2024-02-19 10:31:59 +0200
committerPaul Buetow <paul@buetow.org>2024-02-19 10:31:59 +0200
commit88483511d71a4f74e03580866be73769c407beee (patch)
tree6ce4e4db1f5c2f6a22e75da9b2bbc4ca20ed14dc /internal/ioriotng.bpf.c
parent5b29c78a69f4484995b7ceeabac9bcf538329697 (diff)
move all C code to internal/c
Diffstat (limited to 'internal/ioriotng.bpf.c')
-rw-r--r--internal/ioriotng.bpf.c136
1 files changed, 0 insertions, 136 deletions
diff --git a/internal/ioriotng.bpf.c b/internal/ioriotng.bpf.c
deleted file mode 100644
index 3948529..0000000
--- a/internal/ioriotng.bpf.c
+++ /dev/null
@@ -1,136 +0,0 @@
-//+build ignore
-
-#include "types/vmlinux.h"
-#include <bpf/bpf_helpers.h>
-#include "types/types.bpf.h"
-#include "types/maps.bpf.h"
-#include "flags/flags.bpf.h"
-
-static __always_inline int filter() {
- return (bpf_get_current_uid_gid() & 0xFFFFFFFF) != UID_FILTER;
-}
-
-SEC("tracepoint/syscalls/sys_enter_openat")
-int handle_enter_openat(struct trace_event_raw_sys_enter *ctx) {
- if (filter())
- return 0;
-
- struct openat_enter_event *ev = bpf_ringbuf_reserve(&event_map, sizeof(struct openat_enter_event), 0);
- if (!ev)
- return 0;
-
- ev->op_id = OPENAT_ENTER_OP_ID;
- ev->pid_tgid = bpf_get_current_pid_tgid();
- ev->time = bpf_ktime_get_ns();
-
- __builtin_memset(&(ev->filename), 0, sizeof(ev->filename) + sizeof(ev->comm));
- bpf_probe_read_user_str(ev->filename, sizeof(ev->filename), (void *)ctx->args[1]);
- bpf_get_current_comm(&ev->comm, sizeof(ev->comm));
- bpf_ringbuf_submit(ev, 0);
-
- return 0;
-}
-
-SEC("tracepoint/syscalls/sys_exit_openat")
-int handle_exit_openat(struct trace_event_raw_sys_exit *ctx) {
- if (filter())
- return 0;
-
- struct fd_event *ev = bpf_ringbuf_reserve(&event_map, sizeof(struct fd_event), 0);
- if (!ev)
- return 0;
-
- ev->op_id = OPENAT_EXIT_OP_ID;
- ev->pid_tgid = bpf_get_current_pid_tgid();
- ev->time = bpf_ktime_get_ns();
- ev->fd = ctx->ret;
-
- bpf_ringbuf_submit(ev, 0);
-
- return 0;
-}
-
-SEC("tracepoint/syscalls/sys_enter_open")
-int handle_enter_open(struct trace_event_raw_sys_enter *ctx) {
- return handle_enter_openat(ctx);
-}
-
-SEC("tracepoint/syscalls/sys_exit_open")
-int handle_exit_open(struct trace_event_raw_sys_exit *ctx) {
- return handle_exit_openat(ctx);
-}
-
-SEC("tracepoint/syscalls/sys_enter_close")
-int handle_enter_close(struct trace_event_raw_sys_enter *ctx) {
- if (filter())
- return 0;
-
- struct fd_event *ev = bpf_ringbuf_reserve(&event_map, sizeof(struct fd_event), 0);
- if (!ev)
- return 0;
-
- ev->op_id = CLOSE_ENTER_OP_ID;
- ev->pid_tgid = bpf_get_current_pid_tgid();
- ev->time = bpf_ktime_get_ns();
- ev->fd = (int)ctx->args[0];
-
- bpf_ringbuf_submit(ev, 0);
- return 0;
-}
-
-SEC("tracepoint/syscalls/sys_exit_close")
-int handle_exit_close(struct trace_event_raw_sys_enter *ctx) {
- if (filter())
- return 0;
-
- struct null_event *ev = bpf_ringbuf_reserve(&event_map, sizeof(struct null_event), 0);
- if (!ev)
- return 0;
-
- ev->op_id = CLOSE_EXIT_OP_ID;
- ev->pid_tgid = bpf_get_current_pid_tgid();
- ev->time = bpf_ktime_get_ns();
-
- bpf_ringbuf_submit(ev, 0);
-
- return 0;
-}
-
-SEC("tracepoint/syscalls/sys_enter_write")
-int handle_enter_write(struct trace_event_raw_sys_enter *ctx) {
- if (filter())
- return 0;
-
- struct fd_event *ev = bpf_ringbuf_reserve(&event_map, sizeof(struct fd_event), 0);
- if (!ev)
- return 0;
-
- ev->op_id = WRITE_ENTER_OP_ID;
- ev->pid_tgid = bpf_get_current_pid_tgid();
- ev->time = bpf_ktime_get_ns();
- ev->fd = (int)ctx->args[0];
-
- bpf_ringbuf_submit(ev, 0);
- return 0;
-}
-
-SEC("tracepoint/syscalls/sys_exit_write")
-int handle_exit_write(struct trace_event_raw_sys_enter *ctx) {
- if (filter())
- return 0;
-
- struct null_event *ev = bpf_ringbuf_reserve(&event_map, sizeof(struct null_event), 0);
- if (!ev)
- return 0;
-
- ev->op_id = WRITE_EXIT_OP_ID;
- ev->pid_tgid = bpf_get_current_pid_tgid();
- ev->time = bpf_ktime_get_ns();
-
- bpf_ringbuf_submit(ev, 0);
-
- return 0;
-}
-
-
-char LICENSE[] SEC("license") = "Dual BSD/GPL";