// SPDX-License-Identifier: GPL-2.0 /* Copyright (c) 2024 Meta Platforms, Inc. and affiliates. */ #include <test_progs.h> #include <sys/mman.h> #include "mmap_inner_array.skel.h" void test_mmap_inner_array(void) { const long page_size = sysconf(_SC_PAGE_SIZE); struct mmap_inner_array *skel; int inner_array_fd, err; void *tmp; __u64 *val; skel = mmap_inner_array__open_and_load(); if (!ASSERT_OK_PTR(skel, "open_and_load")) return; inner_array_fd = bpf_map__fd(skel->maps.inner_array); tmp = mmap(NULL, page_size, PROT_READ | PROT_WRITE, MAP_SHARED, inner_array_fd, 0); if (!ASSERT_OK_PTR(tmp, "inner array mmap")) goto out; val = (void *)tmp; err = mmap_inner_array__attach(skel); if (!ASSERT_OK(err, "attach")) goto out_unmap; skel->bss->pid = getpid(); usleep(1); /* pid is set, pid_match == true and outer_map_match == false */ ASSERT_TRUE(skel->bss->pid_match, "pid match 1"); ASSERT_FALSE(skel->bss->outer_map_match, "outer map match 1"); ASSERT_FALSE(skel->bss->done, "done 1"); ASSERT_EQ(*val, 0, "value match 1"); err = bpf_map__update_elem(skel->maps.outer_map, &skel->bss->pid, sizeof(skel->bss->pid), &inner_array_fd, sizeof(inner_array_fd), BPF_ANY); if (!ASSERT_OK(err, "update elem")) goto out_unmap; usleep(1); /* outer map key is set, outer_map_match == true */ ASSERT_TRUE(skel->bss->pid_match, "pid match 2"); ASSERT_TRUE(skel->bss->outer_map_match, "outer map match 2"); ASSERT_TRUE(skel->bss->done, "done 2"); ASSERT_EQ(*val, skel->data->match_value, "value match 2"); out_unmap: munmap(tmp, page_size); out: mmap_inner_array__destroy(skel); }