kernel_samsung_a53x/tools/testing
Yonghong Song d55932ee41 selftests/bpf: Fix flaky test btf_map_in_map/lookup_update
[ Upstream commit 14bb1e8c8d4ad5d9d2febb7d19c70a3cf536e1e5 ]

Recently, I frequently hit the following test failure:

  [root@arch-fb-vm1 bpf]# ./test_progs -n 33/1
  test_lookup_update:PASS:skel_open 0 nsec
  [...]
  test_lookup_update:PASS:sync_rcu 0 nsec
  test_lookup_update:FAIL:map1_leak inner_map1 leaked!
  #33/1    btf_map_in_map/lookup_update:FAIL
  #33      btf_map_in_map:FAIL

In the test, after map is closed and then after two rcu grace periods,
it is assumed that map_id is not available to user space.

But the above assumption cannot be guaranteed. After zero or one
or two rcu grace periods in different siturations, the actual
freeing-map-work is put into a workqueue. Later on, when the work
is dequeued, the map will be actually freed.
See bpf_map_put() in kernel/bpf/syscall.c.

By using workqueue, there is no ganrantee that map will be actually
freed after a couple of rcu grace periods. This patch removed
such map leak detection and then the test can pass consistently.

Signed-off-by: Yonghong Song <yonghong.song@linux.dev>
Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
Link: https://lore.kernel.org/bpf/20240322061353.632136-1-yonghong.song@linux.dev
Signed-off-by: Sasha Levin <sashal@kernel.org>
2024-11-19 14:19:06 +01:00
..
fault-injection Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
ktest ktest: force $buildonly = 1 for 'make_warnings_file' test type 2024-11-19 09:23:15 +01:00
kunit Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
kunit_mainline Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
nvdimm Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
radix-tree Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
scatterlist Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
selftests selftests/bpf: Fix flaky test btf_map_in_map/lookup_update 2024-11-19 14:19:06 +01:00
vsock Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00