bpf inode local storage can be useful beyond LSM programs. For example,
bcc/libbpf-tools file* can use inode local storage to simplify the logic.
This set makes inode local storage available to tracing program.
1/4 is missing change for bpf task local storage. 2/4 move inode local
storage from security blob to inode.
Similar to task local storage in tracing program, it is necessary to add
recursion prevention logic for inode local storage. Patch 3/4 adds such
logic, and 4/4 add a test for the recursion prevention logic.
Changes v2 => v3:
1. Move bpf_inode_storage_free to i_callback(). (Martin)
2. Fix __bpf_inode_storage_get(). (Martin)
Changes v1 => v2:
1. Rebase.
2. Fix send-email mistake.
Song Liu (4):
bpf: lsm: Remove hook to bpf_task_storage_free
bpf: Make bpf inode storage available to tracing program
bpf: Add recursion prevention logic for inode storage
selftest/bpf: Test inode local storage recursion prevention
fs/inode.c | 2 +
include/linux/bpf.h | 9 +
include/linux/bpf_lsm.h | 29 ---
include/linux/fs.h | 4 +
kernel/bpf/Makefile | 3 +-
kernel/bpf/bpf_inode_storage.c | 185 +++++++++++++-----
kernel/bpf/bpf_lsm.c | 4 -
kernel/trace/bpf_trace.c | 8 +
security/bpf/hooks.c | 7 -
tools/testing/selftests/bpf/DENYLIST.s390x | 1 +
.../bpf/prog_tests/inode_local_storage.c | 72 +++++++
.../bpf/progs/inode_storage_recursion.c | 90 +++++++++
12 files changed, 321 insertions(+), 93 deletions(-)
create mode 100644 tools/testing/selftests/bpf/prog_tests/inode_local_storage.c
create mode 100644 tools/testing/selftests/bpf/progs/inode_storage_recursion.c
--
2.43.5