diff options
Diffstat (limited to 'arch/arm/kernel/perf_event.c')
-rw-r--r-- | arch/arm/kernel/perf_event.c | 27 |
1 files changed, 22 insertions, 5 deletions
diff --git a/arch/arm/kernel/perf_event.c b/arch/arm/kernel/perf_event.c index 789d846a9184..a6bc431cde70 100644 --- a/arch/arm/kernel/perf_event.c +++ b/arch/arm/kernel/perf_event.c | |||
@@ -16,6 +16,8 @@ | |||
16 | #include <linux/platform_device.h> | 16 | #include <linux/platform_device.h> |
17 | #include <linux/pm_runtime.h> | 17 | #include <linux/pm_runtime.h> |
18 | #include <linux/uaccess.h> | 18 | #include <linux/uaccess.h> |
19 | #include <linux/irq.h> | ||
20 | #include <linux/irqdesc.h> | ||
19 | 21 | ||
20 | #include <asm/irq_regs.h> | 22 | #include <asm/irq_regs.h> |
21 | #include <asm/pmu.h> | 23 | #include <asm/pmu.h> |
@@ -205,6 +207,8 @@ armpmu_del(struct perf_event *event, int flags) | |||
205 | armpmu_stop(event, PERF_EF_UPDATE); | 207 | armpmu_stop(event, PERF_EF_UPDATE); |
206 | hw_events->events[idx] = NULL; | 208 | hw_events->events[idx] = NULL; |
207 | clear_bit(idx, hw_events->used_mask); | 209 | clear_bit(idx, hw_events->used_mask); |
210 | if (armpmu->clear_event_idx) | ||
211 | armpmu->clear_event_idx(hw_events, event); | ||
208 | 212 | ||
209 | perf_event_update_userpage(event); | 213 | perf_event_update_userpage(event); |
210 | } | 214 | } |
@@ -295,14 +299,27 @@ validate_group(struct perf_event *event) | |||
295 | 299 | ||
296 | static irqreturn_t armpmu_dispatch_irq(int irq, void *dev) | 300 | static irqreturn_t armpmu_dispatch_irq(int irq, void *dev) |
297 | { | 301 | { |
298 | struct arm_pmu *armpmu = (struct arm_pmu *) dev; | 302 | struct arm_pmu *armpmu; |
299 | struct platform_device *plat_device = armpmu->plat_device; | 303 | struct platform_device *plat_device; |
300 | struct arm_pmu_platdata *plat = dev_get_platdata(&plat_device->dev); | 304 | struct arm_pmu_platdata *plat; |
305 | int ret; | ||
306 | u64 start_clock, finish_clock; | ||
301 | 307 | ||
308 | if (irq_is_percpu(irq)) | ||
309 | dev = *(void **)dev; | ||
310 | armpmu = dev; | ||
311 | plat_device = armpmu->plat_device; | ||
312 | plat = dev_get_platdata(&plat_device->dev); | ||
313 | |||
314 | start_clock = sched_clock(); | ||
302 | if (plat && plat->handle_irq) | 315 | if (plat && plat->handle_irq) |
303 | return plat->handle_irq(irq, dev, armpmu->handle_irq); | 316 | ret = plat->handle_irq(irq, dev, armpmu->handle_irq); |
304 | else | 317 | else |
305 | return armpmu->handle_irq(irq, dev); | 318 | ret = armpmu->handle_irq(irq, dev); |
319 | finish_clock = sched_clock(); | ||
320 | |||
321 | perf_sample_event_took(finish_clock - start_clock); | ||
322 | return ret; | ||
306 | } | 323 | } |
307 | 324 | ||
308 | static void | 325 | static void |