On Thu, Dec 14, 2023 at 4:07 AM Dave Tucker <dave@xxxxxxxxxxxxx> wrote: > > Current output from auditd is as follows: > > time->Wed Dec 13 21:39:24 2023 > type=BPF msg=audit(1702503564.519:11241): prog-id=439 op=LOAD > > This only tells you that a BPF program was loaded, but without > any context. If we include the pid, uid and comm we get output as > follows: > > time->Wed Dec 13 21:59:59 2023 > type=BPF msg=audit(1702504799.156:99528): pid=27279 uid=0 > comm="new_name" prog-id=50092 op=UNLOAD would emitting program name be useful as well? > > With pid, uid a system administrator has much better context > over which processes and user loaded which eBPF programs. > comm is useful since processes may be short-lived. > > Signed-off-by: Dave Tucker <dave@xxxxxxxxxxxxx> > --- > kernel/bpf/syscall.c | 12 +++++++++++- > 1 file changed, 11 insertions(+), 1 deletion(-) > > diff --git a/kernel/bpf/syscall.c b/kernel/bpf/syscall.c > index 06320d9abf33..71f418edc014 100644 > --- a/kernel/bpf/syscall.c > +++ b/kernel/bpf/syscall.c > @@ -35,6 +35,7 @@ > #include <linux/rcupdate_trace.h> > #include <linux/memcontrol.h> > #include <linux/trace_events.h> > +#include <linux/uidgid.h> > > #include <net/netfilter/nf_bpf_link.h> > #include <net/netkit.h> > @@ -2110,6 +2111,8 @@ static void bpf_audit_prog(const struct bpf_prog *prog, unsigned int op) > { > struct audit_context *ctx = NULL; > struct audit_buffer *ab; > + const struct cred *cred; > + char comm[sizeof(current->comm)]; > > if (WARN_ON_ONCE(op >= BPF_AUDIT_MAX)) > return; > @@ -2120,7 +2123,14 @@ static void bpf_audit_prog(const struct bpf_prog *prog, unsigned int op) > ab = audit_log_start(ctx, GFP_ATOMIC, AUDIT_BPF); > if (unlikely(!ab)) > return; > - audit_log_format(ab, "prog-id=%u op=%s", > + cred = current_cred(); > + > + audit_log_format(ab, "pid=%u uid=%u", > + task_pid_nr(current), > + from_kuid(&init_user_ns, cred->uid)); > + audit_log_format(ab, " comm="); > + audit_log_untrustedstring(ab, get_task_comm(comm, current)); > + audit_log_format(ab, " prog-id=%u op=%s", > prog->aux->id, bpf_audit_str[op]); > audit_log_end(ab); > } > -- > 2.43.0 >