// SPDX-License-Identifier: GPL-2.0 /* Copyright (c) 2020, Oracle and/or its affiliates. */ #include "bpf_iter.h" #include <bpf/bpf_helpers.h> #include <bpf/bpf_core_read.h> #include <errno.h> char _license[] SEC("license") = "GPL"; long tasks = 0; long seq_err = 0; bool skip = false; SEC("iter/task") int dump_task_struct(struct bpf_iter__task *ctx) { struct seq_file *seq = ctx->meta->seq; struct task_struct *task = ctx->task; static struct btf_ptr ptr = { }; long ret; #if __has_builtin(__builtin_btf_type_id) ptr.type_id = bpf_core_type_id_kernel(struct task_struct); ptr.ptr = task; if (ctx->meta->seq_num == 0) BPF_SEQ_PRINTF(seq, "Raw BTF task\n"); ret = bpf_seq_printf_btf(seq, &ptr, sizeof(ptr), 0); switch (ret) { case 0: tasks++; break; case -ERANGE: /* NULL task or task->fs, don't count it as an error. */ break; case -E2BIG: return 1; default: seq_err = ret; break; } #else skip = true; #endif return 0; }