diff options
| author | Jakub Kicinski <kuba@kernel.org> | 2023-01-04 20:17:19 -0800 | 
|---|---|---|
| committer | Jakub Kicinski <kuba@kernel.org> | 2023-01-04 20:17:19 -0800 | 
| commit | 49d9601b8187f202bb7f6f43026ef6acf4c7a178 (patch) | |
| tree | fe0a52292559020d379a45e6a4084c158709f0e9 /tools/testing/selftests/bpf/prog_tests/bpf_iter.c | |
| parent | 558016722e9d5bc0ac79c246ccd14a8a4eb028d4 (diff) | |
| parent | 45435d8da71f9f3e6860e6e6ea9667b6ec17ec64 (diff) | |
Merge tag 'for-netdev' of https://git.kernel.org/pub/scm/linux/kernel/git/bpf/bpf
Alexei Starovoitov says:
====================
bpf 2023-01-04
We've added 5 non-merge commits during the last 8 day(s) which contain
a total of 5 files changed, 112 insertions(+), 18 deletions(-).
The main changes are:
1) Always use maximal size for copy_array in the verifier to fix
   KASAN tracking, from Kees.
2) Fix bpf task iterator walking through dead tasks, from Kui-Feng.
3) Make sure livepatch and bpf fexit can coexist, from Chuang.
* tag 'for-netdev' of https://git.kernel.org/pub/scm/linux/kernel/git/bpf/bpf:
  bpf: Always use maximal size for copy_array()
  selftests/bpf: add a test for iter/task_vma for short-lived processes
  bpf: keep a reference to the mm, in case the task is dead.
  selftests/bpf: Temporarily disable part of btf_dump:var_data test.
  bpf: Fix panic due to wrong pageattr of im->image
====================
Link: https://lore.kernel.org/r/20230104215500.79435-1-alexei.starovoitov@gmail.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Diffstat (limited to 'tools/testing/selftests/bpf/prog_tests/bpf_iter.c')
| -rw-r--r-- | tools/testing/selftests/bpf/prog_tests/bpf_iter.c | 73 | 
1 files changed, 73 insertions, 0 deletions
| diff --git a/tools/testing/selftests/bpf/prog_tests/bpf_iter.c b/tools/testing/selftests/bpf/prog_tests/bpf_iter.c index 6f8ed61fc4b4..3af6450763e9 100644 --- a/tools/testing/selftests/bpf/prog_tests/bpf_iter.c +++ b/tools/testing/selftests/bpf/prog_tests/bpf_iter.c @@ -1465,6 +1465,77 @@ out:  	bpf_iter_task_vma__destroy(skel);  } +static void test_task_vma_dead_task(void) +{ +	struct bpf_iter_task_vma *skel; +	int wstatus, child_pid = -1; +	time_t start_tm, cur_tm; +	int err, iter_fd = -1; +	int wait_sec = 3; + +	skel = bpf_iter_task_vma__open(); +	if (!ASSERT_OK_PTR(skel, "bpf_iter_task_vma__open")) +		return; + +	skel->bss->pid = getpid(); + +	err = bpf_iter_task_vma__load(skel); +	if (!ASSERT_OK(err, "bpf_iter_task_vma__load")) +		goto out; + +	skel->links.proc_maps = bpf_program__attach_iter( +		skel->progs.proc_maps, NULL); + +	if (!ASSERT_OK_PTR(skel->links.proc_maps, "bpf_program__attach_iter")) { +		skel->links.proc_maps = NULL; +		goto out; +	} + +	start_tm = time(NULL); +	cur_tm = start_tm; + +	child_pid = fork(); +	if (child_pid == 0) { +		/* Fork short-lived processes in the background. */ +		while (cur_tm < start_tm + wait_sec) { +			system("echo > /dev/null"); +			cur_tm = time(NULL); +		} +		exit(0); +	} + +	if (!ASSERT_GE(child_pid, 0, "fork_child")) +		goto out; + +	while (cur_tm < start_tm + wait_sec) { +		iter_fd = bpf_iter_create(bpf_link__fd(skel->links.proc_maps)); +		if (!ASSERT_GE(iter_fd, 0, "create_iter")) +			goto out; + +		/* Drain all data from iter_fd. */ +		while (cur_tm < start_tm + wait_sec) { +			err = read_fd_into_buffer(iter_fd, task_vma_output, CMP_BUFFER_SIZE); +			if (!ASSERT_GE(err, 0, "read_iter_fd")) +				goto out; + +			cur_tm = time(NULL); + +			if (err == 0) +				break; +		} + +		close(iter_fd); +		iter_fd = -1; +	} + +	check_bpf_link_info(skel->progs.proc_maps); + +out: +	waitpid(child_pid, &wstatus, 0); +	close(iter_fd); +	bpf_iter_task_vma__destroy(skel); +} +  void test_bpf_sockmap_map_iter_fd(void)  {  	struct bpf_iter_sockmap *skel; @@ -1586,6 +1657,8 @@ void test_bpf_iter(void)  		test_task_file();  	if (test__start_subtest("task_vma"))  		test_task_vma(); +	if (test__start_subtest("task_vma_dead_task")) +		test_task_vma_dead_task();  	if (test__start_subtest("task_btf"))  		test_task_btf();  	if (test__start_subtest("tcp4")) | 
