// SPDX-License-Identifier: GPL-2.0 /* Copyright (c) 2020 Facebook */ /* "undefine" structs in vmlinux.h, because we "override" them below */ #define bpf_iter_meta bpf_iter_meta___not_used #define bpf_iter__task_file bpf_iter__task_file___not_used #include "vmlinux.h" #undef bpf_iter_meta #undef bpf_iter__task_file #include #include char _license[] SEC("license") = "GPL"; struct bpf_iter_meta { struct seq_file *seq; __u64 session_id; __u64 seq_num; } __attribute__((preserve_access_index)); struct bpf_iter__task_file { struct bpf_iter_meta *meta; struct task_struct *task; __u32 fd; struct file *file; } __attribute__((preserve_access_index)); SEC("iter/task_file") int dump_task_file(struct bpf_iter__task_file *ctx) { struct seq_file *seq = ctx->meta->seq; struct task_struct *task = ctx->task; __u32 fd = ctx->fd; struct file *file = ctx->file; if (task == (void *)0 || file == (void *)0) return 0; if (ctx->meta->seq_num == 0) BPF_SEQ_PRINTF(seq, " tgid gid fd file\n"); BPF_SEQ_PRINTF(seq, "%8d %8d %8d %lx\n", task->tgid, task->pid, fd, (long)file->f_op); return 0; }