1 // SPDX-License-Identifier: GPL-2.0
2 /* Copyright (c) 2022 Meta Platforms, Inc. and affiliates. */
5 #include <bpf/bpf_helpers.h>
8 #define HASHMAP_SZ 4194304
11 __uint(type, BPF_MAP_TYPE_ARRAY_OF_MAPS);
12 __uint(max_entries, 1000);
15 __array(values, struct {
16 __uint(type, BPF_MAP_TYPE_TASK_STORAGE);
17 __uint(map_flags, BPF_F_NO_PREALLOC);
21 } array_of_local_storage_maps SEC(".maps");
24 __uint(type, BPF_MAP_TYPE_ARRAY_OF_MAPS);
25 __uint(max_entries, 1000);
28 __array(values, struct {
29 __uint(type, BPF_MAP_TYPE_HASH);
30 __uint(max_entries, HASHMAP_SZ);
34 } array_of_hash_maps SEC(".maps");
39 /* set from user-space */
40 const volatile unsigned int use_hashmap;
41 const volatile unsigned int hashmap_num_keys;
42 const volatile unsigned int num_maps;
43 const volatile unsigned int interleave;
46 struct task_struct *task;
48 long loop_important_hits;
51 static int do_lookup(unsigned int elem, struct loop_ctx *lctx)
53 void *map, *inner_map;
57 map = &array_of_hash_maps;
59 map = &array_of_local_storage_maps;
61 inner_map = bpf_map_lookup_elem(map, &elem);
66 idx = bpf_get_prandom_u32() % hashmap_num_keys;
67 bpf_map_lookup_elem(inner_map, &idx);
69 bpf_task_storage_get(inner_map, lctx->task, &idx,
70 BPF_LOCAL_STORAGE_GET_F_CREATE);
75 lctx->loop_important_hits++;
79 static long loop(u32 index, void *ctx)
81 struct loop_ctx *lctx = (struct loop_ctx *)ctx;
82 unsigned int map_idx = index % num_maps;
84 do_lookup(map_idx, lctx);
85 if (interleave && map_idx % 3 == 0)
90 SEC("fentry/" SYS_PREFIX "sys_getpgid")
91 int get_local(void *ctx)
95 lctx.task = bpf_get_current_task_btf();
97 lctx.loop_important_hits = 0;
98 bpf_loop(10000, &loop, &lctx, 0);
99 __sync_add_and_fetch(&hits, lctx.loop_hits);
100 __sync_add_and_fetch(&important_hits, lctx.loop_important_hits);
104 char _license[] SEC("license") = "GPL";