diff options
-rw-r--r-- | arch/powerpc/perf/hv-common.h | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/arch/powerpc/perf/hv-common.h b/arch/powerpc/perf/hv-common.h index 7e615bd38bca..5d79cecbd73d 100644 --- a/arch/powerpc/perf/hv-common.h +++ b/arch/powerpc/perf/hv-common.h | |||
@@ -1,6 +1,7 @@ | |||
1 | #ifndef LINUX_POWERPC_PERF_HV_COMMON_H_ | 1 | #ifndef LINUX_POWERPC_PERF_HV_COMMON_H_ |
2 | #define LINUX_POWERPC_PERF_HV_COMMON_H_ | 2 | #define LINUX_POWERPC_PERF_HV_COMMON_H_ |
3 | 3 | ||
4 | #include <linux/perf_event.h> | ||
4 | #include <linux/types.h> | 5 | #include <linux/types.h> |
5 | 6 | ||
6 | struct hv_perf_caps { | 7 | struct hv_perf_caps { |
@@ -14,4 +15,22 @@ struct hv_perf_caps { | |||
14 | 15 | ||
15 | unsigned long hv_perf_caps_get(struct hv_perf_caps *caps); | 16 | unsigned long hv_perf_caps_get(struct hv_perf_caps *caps); |
16 | 17 | ||
18 | |||
19 | #define EVENT_DEFINE_RANGE_FORMAT(name, attr_var, bit_start, bit_end) \ | ||
20 | PMU_FORMAT_ATTR(name, #attr_var ":" #bit_start "-" #bit_end); \ | ||
21 | EVENT_DEFINE_RANGE(name, attr_var, bit_start, bit_end) | ||
22 | |||
23 | #define EVENT_DEFINE_RANGE(name, attr_var, bit_start, bit_end) \ | ||
24 | static u64 event_get_##name##_max(void) \ | ||
25 | { \ | ||
26 | BUILD_BUG_ON((bit_start > bit_end) \ | ||
27 | || (bit_end >= (sizeof(1ull) * 8))); \ | ||
28 | return (((1ull << (bit_end - bit_start)) - 1) << 1) + 1; \ | ||
29 | } \ | ||
30 | static u64 event_get_##name(struct perf_event *event) \ | ||
31 | { \ | ||
32 | return (event->attr.attr_var >> (bit_start)) & \ | ||
33 | event_get_##name##_max(); \ | ||
34 | } | ||
35 | |||
17 | #endif | 36 | #endif |