mbox series

[bpf-next,v2,0/3] Parameterize task iterators.

Message ID 20220801232649.2306614-1-kuifeng@fb.com (mailing list archive)
Headers show
Series Parameterize task iterators. | expand

Message

Kui-Feng Lee Aug. 1, 2022, 11:26 p.m. UTC
Allow creating an iterator that loops through resources of one task/thread.

People could only create iterators to loop through all resources of
files, vma, and tasks in the system, even though they were interested in only the
resources of a specific task or process.  Passing the addintional
parameters, people can now create an iterator to go through all
resources or only the resources of a task.

Major Changes:

 - Add new parameters in bpf_iter_link_info to indicate to go through
   all tasks or to go through a specific task.

 - Change the implementations of BPF iterators of vma, files, and
   tasks to allow going through only the resources of a specific task.

 - Provide the arguments of parameterized task iterators in
   bpf_link_info.

Kui-Feng Lee (3):
  bpf: Parameterize task iterators.
  bpf: Handle bpf_link_info for the parameterized task BPF iterators.
  selftests/bpf: Test parameterized task BPF iterators.

 include/linux/bpf.h                           |   4 +
 include/uapi/linux/bpf.h                      |  27 ++++
 kernel/bpf/task_iter.c                        | 103 ++++++++++---
 tools/include/uapi/linux/bpf.h                |  27 ++++
 .../selftests/bpf/prog_tests/bpf_iter.c       | 143 +++++++++++++++---
 .../selftests/bpf/prog_tests/btf_dump.c       |   2 +-
 .../selftests/bpf/progs/bpf_iter_task.c       |   9 ++
 .../selftests/bpf/progs/bpf_iter_task_file.c  |   7 +
 .../selftests/bpf/progs/bpf_iter_task_vma.c   |   6 +-
 9 files changed, 282 insertions(+), 46 deletions(-)

Comments

Kui-Feng Lee Aug. 1, 2022, 11:35 p.m. UTC | #1
On Mon, 2022-08-01 at 16:26 -0700, Kui-Feng Lee wrote:
> Allow creating an iterator that loops through resources of one
> task/thread.
> 
> People could only create iterators to loop through all resources of
> files, vma, and tasks in the system, even though they were interested
> in only the
> resources of a specific task or process.  Passing the addintional
> parameters, people can now create an iterator to go through all
> resources or only the resources of a task.
> 
> Major Changes:
> 
>  - Add new parameters in bpf_iter_link_info to indicate to go through
>    all tasks or to go through a specific task.
> 
>  - Change the implementations of BPF iterators of vma, files, and
>    tasks to allow going through only the resources of a specific
> task.
> 
>  - Provide the arguments of parameterized task iterators in
>    bpf_link_info.

The major changes since v1:
 - Fix the issue of task_seq_get_next() returning NULL for being called
twice or more.
 - Use pidfd instead of pid/tid while keep the 'type'.


> 
> Kui-Feng Lee (3):
>   bpf: Parameterize task iterators.
>   bpf: Handle bpf_link_info for the parameterized task BPF iterators.
>   selftests/bpf: Test parameterized task BPF iterators.
> 
>  include/linux/bpf.h                           |   4 +
>  include/uapi/linux/bpf.h                      |  27 ++++
>  kernel/bpf/task_iter.c                        | 103 ++++++++++---
>  tools/include/uapi/linux/bpf.h                |  27 ++++
>  .../selftests/bpf/prog_tests/bpf_iter.c       | 143 +++++++++++++++-
> --
>  .../selftests/bpf/prog_tests/btf_dump.c       |   2 +-
>  .../selftests/bpf/progs/bpf_iter_task.c       |   9 ++
>  .../selftests/bpf/progs/bpf_iter_task_file.c  |   7 +
>  .../selftests/bpf/progs/bpf_iter_task_vma.c   |   6 +-
>  9 files changed, 282 insertions(+), 46 deletions(-)
>