hc
2024-12-19 9370bb92b2d16684ee45cf24e879c93c509162da
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef LINUX_POWERPC_PERF_HV_COMMON_H_
#define LINUX_POWERPC_PERF_HV_COMMON_H_
 
#include <linux/perf_event.h>
#include <linux/types.h>
 
struct hv_perf_caps {
   u16 version;
   u16 collect_privileged:1,
       ga:1,
       expanded:1,
       lab:1,
       unused:12;
};
 
unsigned long hv_perf_caps_get(struct hv_perf_caps *caps);
 
 
#define EVENT_DEFINE_RANGE_FORMAT(name, attr_var, bit_start, bit_end)    \
PMU_FORMAT_ATTR(name, #attr_var ":" #bit_start "-" #bit_end);        \
EVENT_DEFINE_RANGE(name, attr_var, bit_start, bit_end)
 
/*
 * The EVENT_DEFINE_RANGE_FORMAT() macro above includes helper functions
 * for the fields (eg: event_get_starting_index()). For some fields we
 * need the bit-range definition, but no the helper functions. Define a
 * lite version of the above macro without the helpers and silence
 * compiler warnings unused static functions.
 */
#define EVENT_DEFINE_RANGE_FORMAT_LITE(name, attr_var, bit_start, bit_end) \
PMU_FORMAT_ATTR(name, #attr_var ":" #bit_start "-" #bit_end);
 
#define EVENT_DEFINE_RANGE(name, attr_var, bit_start, bit_end)    \
static u64 event_get_##name##_max(void)                    \
{                                    \
   BUILD_BUG_ON((bit_start > bit_end)                \
           || (bit_end >= (sizeof(1ull) * 8)));        \
   return (((1ull << (bit_end - bit_start)) - 1) << 1) + 1;    \
}                                    \
static u64 event_get_##name(struct perf_event *event)            \
{                                    \
   return (event->attr.attr_var >> (bit_start)) &            \
       event_get_##name##_max();                \
}
 
#endif