Contributors: 2
	  
        
          | Author | Tokens | Token Proportion | Commits | Commit Proportion | 
	  
	  
        
        
          | Anton Protopopov | 282 | 97.92% | 1 | 50.00% | 
        
          | Andrii Nakryiko | 6 | 2.08% | 1 | 50.00% | 
	  
	  
        
          | Total | 288 |  | 2 |  | 
	  
    
 
// SPDX-License-Identifier: GPL-2.0
/* Copyright (c) 2023 Isovalent */
#include "vmlinux.h"
#include <bpf/bpf_helpers.h>
#include "bpf_misc.h"
char _license[] SEC("license") = "GPL";
struct {
	__uint(type, BPF_MAP_TYPE_HASH);
} hash_map_bench SEC(".maps");
/* The number of slots to store times */
#define NR_SLOTS 32
#define NR_CPUS 256
#define CPU_MASK (NR_CPUS-1)
/* Configured by userspace */
u64 nr_entries;
u64 nr_loops;
u32 __attribute__((__aligned__(8))) key[NR_CPUS];
/* Filled by us */
u64 __attribute__((__aligned__(256))) percpu_times_index[NR_CPUS];
u64 __attribute__((__aligned__(256))) percpu_times[NR_CPUS][NR_SLOTS];
static inline void patch_key(u32 i)
{
#if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
	key[0] = i + 1;
#else
	key[0] = __builtin_bswap32(i + 1);
#endif
	/* the rest of key is random and is configured by userspace */
}
static int lookup_callback(__u32 index, u32 *unused)
{
	patch_key(index);
	return bpf_map_lookup_elem(&hash_map_bench, key) ? 0 : 1;
}
static int loop_lookup_callback(__u32 index, u32 *unused)
{
	return bpf_loop(nr_entries, lookup_callback, NULL, 0) ? 0 : 1;
}
SEC("fentry/" SYS_PREFIX "sys_getpgid")
int benchmark(void *ctx)
{
	u32 cpu = bpf_get_smp_processor_id();
	u32 times_index;
	u64 start_time;
	times_index = percpu_times_index[cpu & CPU_MASK] % NR_SLOTS;
	start_time = bpf_ktime_get_ns();
	bpf_loop(nr_loops, loop_lookup_callback, NULL, 0);
	percpu_times[cpu & CPU_MASK][times_index] = bpf_ktime_get_ns() - start_time;
	percpu_times_index[cpu & CPU_MASK] += 1;
	return 0;
}