diff options
-rw-r--r-- | arch/powerpc/kernel/perf_counter.c | 9 | ||||
-rw-r--r-- | include/linux/perf_counter.h | 12 |
2 files changed, 17 insertions, 4 deletions
diff --git a/arch/powerpc/kernel/perf_counter.c b/arch/powerpc/kernel/perf_counter.c index 830ca9c4494c..6413d9c0313b 100644 --- a/arch/powerpc/kernel/perf_counter.c +++ b/arch/powerpc/kernel/perf_counter.c | |||
@@ -602,12 +602,13 @@ hw_perf_counter_init(struct perf_counter *counter) | |||
602 | return NULL; | 602 | return NULL; |
603 | if ((s64)counter->hw_event.irq_period < 0) | 603 | if ((s64)counter->hw_event.irq_period < 0) |
604 | return NULL; | 604 | return NULL; |
605 | ev = counter->hw_event.event_id; | 605 | if (!counter->hw_event.raw_type) { |
606 | if (!counter->hw_event.raw) { | 606 | ev = counter->hw_event.event_id; |
607 | if (ev >= ppmu->n_generic || | 607 | if (ev >= ppmu->n_generic || ppmu->generic_events[ev] == 0) |
608 | ppmu->generic_events[ev] == 0) | ||
609 | return NULL; | 608 | return NULL; |
610 | ev = ppmu->generic_events[ev]; | 609 | ev = ppmu->generic_events[ev]; |
610 | } else { | ||
611 | ev = counter->hw_event.raw_event_id; | ||
611 | } | 612 | } |
612 | counter->hw.config_base = ev; | 613 | counter->hw.config_base = ev; |
613 | counter->hw.idx = 0; | 614 | counter->hw.idx = 0; |
diff --git a/include/linux/perf_counter.h b/include/linux/perf_counter.h index a4b76c0175f3..98f5990be1e1 100644 --- a/include/linux/perf_counter.h +++ b/include/linux/perf_counter.h | |||
@@ -15,6 +15,7 @@ | |||
15 | 15 | ||
16 | #include <linux/types.h> | 16 | #include <linux/types.h> |
17 | #include <linux/ioctl.h> | 17 | #include <linux/ioctl.h> |
18 | #include <asm/byteorder.h> | ||
18 | 19 | ||
19 | /* | 20 | /* |
20 | * User-space ABI bits: | 21 | * User-space ABI bits: |
@@ -86,6 +87,7 @@ enum perf_counter_record_type { | |||
86 | */ | 87 | */ |
87 | struct perf_counter_hw_event { | 88 | struct perf_counter_hw_event { |
88 | union { | 89 | union { |
90 | #ifndef __BIG_ENDIAN_BITFIELD | ||
89 | struct { | 91 | struct { |
90 | __u64 event_id : 56, | 92 | __u64 event_id : 56, |
91 | type : 8; | 93 | type : 8; |
@@ -94,6 +96,16 @@ struct perf_counter_hw_event { | |||
94 | __u64 raw_event_id : 63, | 96 | __u64 raw_event_id : 63, |
95 | raw_type : 1; | 97 | raw_type : 1; |
96 | }; | 98 | }; |
99 | #else | ||
100 | struct { | ||
101 | __u64 type : 8, | ||
102 | event_id : 56; | ||
103 | }; | ||
104 | struct { | ||
105 | __u64 raw_type : 1, | ||
106 | raw_event_id : 63; | ||
107 | }; | ||
108 | #endif /* __BIT_ENDIAN_BITFIELD */ | ||
97 | __u64 event_config; | 109 | __u64 event_config; |
98 | }; | 110 | }; |
99 | 111 | ||