A library to interact with BPF kernel state.
Just simple, pure idiomatic Rust-based bindings to manage user-space state necessary for interacting with the kernel system. Some little helpers are added but not beyond the minimalism (avoids generics or extra dependencies).
In decreasing order of priority.
Non-Goals:
* Replacement for libbpf
* A C interface, to be re-evaluated later
* An async
style of implementation. It should be possible to achieve all
functionality with synchronous code. However, optional concurrency may be
introduced with async
where efficient.
* Binary analysis and manipulation of BPF programs
Note that the implementation does not need link directly against any libc
functions. Rather, it defines an expected interface in terms of free C
functions (sys::SysVTable
). The caller can fill it with functions loaded
statically or dynamically from a linker but also with another equivalent
implementation. Unfortunately, the data type definitions will have to be
compatible with the platform libc
in both cases, but it is a start to avoid
the hell of LD_PRELOAD
as a stupid, global mechanism for overwriting them.
Depending on libbpf
is quite heavy when only a fraction of it is needed. In
particular, connecting together networking functionality does not depend on
writing BPF. Also, the library is riddled with C-isms:
libbpf_netlink_send_recv
that's hidden in a lot of operations.Code that looks like so:
c
static int libbpf_netlink_send_recv(...) {
/* ... */
req->nh.nlmsg_seq = time(NULL);
They are fucking with us, no?