aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorCody P Schafer <cody@linux.vnet.ibm.com>2014-03-14 01:00:40 -0400
committerBenjamin Herrenschmidt <benh@kernel.crashing.org>2014-03-23 18:48:31 -0400
commit7b43c67950f0985be257f5fb7d656557e24d92d9 (patch)
treee4dee9548f8c52c49043c65ddae4d4ca77265440
parent2d1b21ad7d1574c7aaa5b9acdb3a02fd37a11c01 (diff)
powerpc/perf: Add macros for defining event fields & formats
Add two macros which generate functions to extract the relevent bits from event->attr.config{,1,2}. EVENT_DEFINE_RANGE() defines an accessor for a range of bits in the event, as well as a "max" function that gives the maximum value of the field based on the bit width. EVENT_DEFINE_RANGE_FORMAT() defines the accessor & max routine and also a format attribute for use in the PMU's attr_groups. Signed-off-by: Cody P Schafer <cody@linux.vnet.ibm.com> [mpe: move to powerpc, ugly but descriptive macro names] Signed-off-by: Michael Ellerman <mpe@ellerman.id.au> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
-rw-r--r--arch/powerpc/perf/hv-common.h19
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
6struct hv_perf_caps { 7struct hv_perf_caps {
@@ -14,4 +15,22 @@ struct hv_perf_caps {
14 15
15unsigned long hv_perf_caps_get(struct hv_perf_caps *caps); 16unsigned 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) \
20PMU_FORMAT_ATTR(name, #attr_var ":" #bit_start "-" #bit_end); \
21EVENT_DEFINE_RANGE(name, attr_var, bit_start, bit_end)
22
23#define EVENT_DEFINE_RANGE(name, attr_var, bit_start, bit_end) \
24static 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} \
30static 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