-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'Introduce a new kfunc of bpf_task_under_cgroup'
Feng zhou says: ==================== Trace sched related functions, such as enqueue_task_fair, it is necessary to specify a task instead of the current task which within a given cgroup. ==================== Signed-off-by: Alexei Starovoitov <ast@kernel.org>
- Loading branch information
Showing
4 changed files
with
122 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
53 changes: 53 additions & 0 deletions
53
tools/testing/selftests/bpf/prog_tests/task_under_cgroup.c
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,53 @@ | ||
// SPDX-License-Identifier: GPL-2.0 | ||
/* Copyright (c) 2023 Bytedance */ | ||
|
||
#include <sys/syscall.h> | ||
#include <test_progs.h> | ||
#include <cgroup_helpers.h> | ||
#include "test_task_under_cgroup.skel.h" | ||
|
||
#define FOO "/foo" | ||
|
||
void test_task_under_cgroup(void) | ||
{ | ||
struct test_task_under_cgroup *skel; | ||
int ret, foo; | ||
pid_t pid; | ||
|
||
foo = test__join_cgroup(FOO); | ||
if (!ASSERT_OK(foo < 0, "cgroup_join_foo")) | ||
return; | ||
|
||
skel = test_task_under_cgroup__open(); | ||
if (!ASSERT_OK_PTR(skel, "test_task_under_cgroup__open")) | ||
goto cleanup; | ||
|
||
skel->rodata->local_pid = getpid(); | ||
skel->bss->remote_pid = getpid(); | ||
skel->rodata->cgid = get_cgroup_id(FOO); | ||
|
||
ret = test_task_under_cgroup__load(skel); | ||
if (!ASSERT_OK(ret, "test_task_under_cgroup__load")) | ||
goto cleanup; | ||
|
||
ret = test_task_under_cgroup__attach(skel); | ||
if (!ASSERT_OK(ret, "test_task_under_cgroup__attach")) | ||
goto cleanup; | ||
|
||
pid = fork(); | ||
if (pid == 0) | ||
exit(0); | ||
|
||
ret = (pid == -1); | ||
if (ASSERT_OK(ret, "fork process")) | ||
wait(NULL); | ||
|
||
test_task_under_cgroup__detach(skel); | ||
|
||
ASSERT_NEQ(skel->bss->remote_pid, skel->rodata->local_pid, | ||
"test task_under_cgroup"); | ||
|
||
cleanup: | ||
test_task_under_cgroup__destroy(skel); | ||
close(foo); | ||
} |
51 changes: 51 additions & 0 deletions
51
tools/testing/selftests/bpf/progs/test_task_under_cgroup.c
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
// SPDX-License-Identifier: GPL-2.0 | ||
/* Copyright (c) 2023 Bytedance */ | ||
|
||
#include <vmlinux.h> | ||
#include <bpf/bpf_tracing.h> | ||
#include <bpf/bpf_helpers.h> | ||
|
||
#include "bpf_misc.h" | ||
|
||
struct cgroup *bpf_cgroup_from_id(u64 cgid) __ksym; | ||
long bpf_task_under_cgroup(struct task_struct *task, struct cgroup *ancestor) __ksym; | ||
void bpf_cgroup_release(struct cgroup *p) __ksym; | ||
struct task_struct *bpf_task_acquire(struct task_struct *p) __ksym; | ||
void bpf_task_release(struct task_struct *p) __ksym; | ||
|
||
const volatile int local_pid; | ||
const volatile __u64 cgid; | ||
int remote_pid; | ||
|
||
SEC("tp_btf/task_newtask") | ||
int BPF_PROG(handle__task_newtask, struct task_struct *task, u64 clone_flags) | ||
{ | ||
struct cgroup *cgrp = NULL; | ||
struct task_struct *acquired; | ||
|
||
if (local_pid != (bpf_get_current_pid_tgid() >> 32)) | ||
return 0; | ||
|
||
acquired = bpf_task_acquire(task); | ||
if (!acquired) | ||
return 0; | ||
|
||
if (local_pid == acquired->tgid) | ||
goto out; | ||
|
||
cgrp = bpf_cgroup_from_id(cgid); | ||
if (!cgrp) | ||
goto out; | ||
|
||
if (bpf_task_under_cgroup(acquired, cgrp)) | ||
remote_pid = acquired->tgid; | ||
|
||
out: | ||
if (cgrp) | ||
bpf_cgroup_release(cgrp); | ||
bpf_task_release(acquired); | ||
|
||
return 0; | ||
} | ||
|
||
char _license[] SEC("license") = "GPL"; |