All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH bpf-next 0/4] bpf: Introduce deferred task context execution
@ 2025-08-06 14:45 Mykyta Yatsenko
  2025-08-06 14:45 ` [PATCH bpf-next 1/4] bpf: bpf task work plumbing Mykyta Yatsenko
                   ` (3 more replies)
  0 siblings, 4 replies; 15+ messages in thread
From: Mykyta Yatsenko @ 2025-08-06 14:45 UTC (permalink / raw)
  To: bpf, ast, andrii, daniel, kafai, kernel-team, eddyz87; +Cc: Mykyta Yatsenko

From: Mykyta Yatsenko <yatsenko@meta.com>

This patch introduces a new mechanism for BPF programs to schedule
deferred execution in the context of a specific task using the kernel’s
task_work infrastructure.

The new bpf_task_work interface enables BPF use cases that
require sleepable subprogram execution within task context, for example,
scheduling sleepable function from the context that does not
allow sleepable, such as NMI.

Introduced kfuncs bpf_task_work_schedule_signal() and
bpf_task_work_schedule_resume() for scheduling BPF callbacks correspond
to different modes used by task_work (TWA_SIGNAL or
TWA_RESUME/TWA_NMI_CURRENT).

The implementation leverages BPF maps for storing callback metadata.
Indirectly call task_work_add() via irq_work to avoid locking in
potentially NMI context. State transitions are managed via an atomic
state machine (bpf_task_work_state) to ensure correctness under
concurrent usage and deletion.

Mykyta Yatsenko (4):
  bpf: bpf task work plumbing
  bpf: extract map key pointer calculation
  bpf: task work scheduling kfuncs
  selftests/bpf: BPF task work scheduling tests

 include/linux/bpf.h                           |  11 +
 include/uapi/linux/bpf.h                      |   4 +
 kernel/bpf/arraymap.c                         |   8 +-
 kernel/bpf/btf.c                              |  15 +
 kernel/bpf/hashtab.c                          |  22 +-
 kernel/bpf/helpers.c                          | 260 ++++++++++++++++--
 kernel/bpf/syscall.c                          |  23 +-
 kernel/bpf/verifier.c                         | 131 ++++++++-
 tools/include/uapi/linux/bpf.h                |   4 +
 .../selftests/bpf/prog_tests/test_task_work.c | 149 ++++++++++
 tools/testing/selftests/bpf/progs/task_work.c | 108 ++++++++
 .../selftests/bpf/progs/task_work_fail.c      |  98 +++++++
 12 files changed, 800 insertions(+), 33 deletions(-)
 create mode 100644 tools/testing/selftests/bpf/prog_tests/test_task_work.c
 create mode 100644 tools/testing/selftests/bpf/progs/task_work.c
 create mode 100644 tools/testing/selftests/bpf/progs/task_work_fail.c

-- 
2.50.1


^ permalink raw reply	[flat|nested] 15+ messages in thread

end of thread, other threads:[~2025-08-15 18:25 UTC | newest]

Thread overview: 15+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-08-06 14:45 [PATCH bpf-next 0/4] bpf: Introduce deferred task context execution Mykyta Yatsenko
2025-08-06 14:45 ` [PATCH bpf-next 1/4] bpf: bpf task work plumbing Mykyta Yatsenko
2025-08-07 17:53   ` Kumar Kartikeya Dwivedi
2025-08-15 18:25     ` Mykyta Yatsenko
2025-08-06 14:45 ` [PATCH bpf-next 2/4] bpf: extract map key pointer calculation Mykyta Yatsenko
2025-08-07 19:01   ` Kumar Kartikeya Dwivedi
2025-08-06 14:45 ` [PATCH bpf-next 3/4] bpf: task work scheduling kfuncs Mykyta Yatsenko
2025-08-07 17:27   ` Alexei Starovoitov
2025-08-08  0:30     ` Mykyta Yatsenko
2025-08-07 18:55   ` Kumar Kartikeya Dwivedi
2025-08-08  0:44     ` Mykyta Yatsenko
2025-08-09  3:04       ` Kumar Kartikeya Dwivedi
2025-08-11 20:13         ` Mykyta Yatsenko
2025-08-11 20:17           ` Kumar Kartikeya Dwivedi
2025-08-06 14:45 ` [PATCH bpf-next 4/4] selftests/bpf: BPF task work scheduling tests Mykyta Yatsenko

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.