/* SPDX-License-Identifier: (LGPL-2.1 OR BSD-2-Clause) */
#ifndef __LIBPERF_BPF_PERF_H
#define __LIBPERF_BPF_PERF_H

#include <linux/types.h>  /* for __u32 */

/*
 * bpf_perf uses a hashmap, the attr_map, to track all the leader programs.
 * The hashmap is pinned in bpffs. flock() on this file is used to ensure
 * no concurrent access to the attr_map.  The key of attr_map is struct
 * perf_event_attr, and the value is struct perf_event_attr_map_entry.
 *
 * struct perf_event_attr_map_entry contains two __u32 IDs, bpf_link of the
 * leader prog, and the diff_map. Each perf-stat session holds a reference
 * to the bpf_link to make sure the leader prog is attached to sched_switch
 * tracepoint.
 *
 * Since the hashmap only contains IDs of the bpf_link and diff_map, it
 * does not hold any references to the leader program. Once all perf-stat
 * sessions of these events exit, the leader prog, its maps, and the
 * perf_events will be freed.
 */
struct perf_event_attr_map_entry {
	__u32 link_id;
	__u32 diff_map_id;
};

/* default attr_map name */
#define BPF_PERF_DEFAULT_ATTR_MAP_PATH "perf_attr_map"

#endif /* __LIBPERF_BPF_PERF_H */