Commit | Line | Data |
---|---|---|
03089688 WD |
1 | /* |
2 | * Based on arch/arm/include/asm/pmu.h | |
3 | * | |
4 | * Copyright (C) 2009 picoChip Designs Ltd, Jamie Iles | |
5 | * Copyright (C) 2012 ARM Ltd. | |
6 | * | |
7 | * This program is free software; you can redistribute it and/or modify | |
8 | * it under the terms of the GNU General Public License version 2 as | |
9 | * published by the Free Software Foundation. | |
10 | * | |
11 | * This program is distributed in the hope that it will be useful, | |
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
14 | * GNU General Public License for more details. | |
15 | * | |
16 | * You should have received a copy of the GNU General Public License | |
17 | * along with this program. If not, see <http://www.gnu.org/licenses/>. | |
18 | */ | |
19 | #ifndef __ASM_PMU_H | |
20 | #define __ASM_PMU_H | |
21 | ||
22 | #ifdef CONFIG_HW_PERF_EVENTS | |
23 | ||
24 | /* The events for a given PMU register set. */ | |
25 | struct pmu_hw_events { | |
26 | /* | |
27 | * The events that are active on the PMU for the given index. | |
28 | */ | |
29 | struct perf_event **events; | |
30 | ||
31 | /* | |
32 | * A 1 bit for an index indicates that the counter is being used for | |
33 | * an event. A 0 means that the counter can be used. | |
34 | */ | |
35 | unsigned long *used_mask; | |
36 | ||
37 | /* | |
38 | * Hardware lock to serialize accesses to PMU registers. Needed for the | |
39 | * read/modify/write sequences. | |
40 | */ | |
41 | raw_spinlock_t pmu_lock; | |
42 | }; | |
43 | ||
44 | struct arm_pmu { | |
45 | struct pmu pmu; | |
46 | cpumask_t active_irqs; | |
d5efd9cc | 47 | int *irq_affinity; |
03089688 WD |
48 | const char *name; |
49 | irqreturn_t (*handle_irq)(int irq_num, void *dev); | |
50 | void (*enable)(struct hw_perf_event *evt, int idx); | |
51 | void (*disable)(struct hw_perf_event *evt, int idx); | |
52 | int (*get_event_idx)(struct pmu_hw_events *hw_events, | |
53 | struct hw_perf_event *hwc); | |
54 | int (*set_event_filter)(struct hw_perf_event *evt, | |
55 | struct perf_event_attr *attr); | |
56 | u32 (*read_counter)(int idx); | |
57 | void (*write_counter)(int idx, u32 val); | |
58 | void (*start)(void); | |
59 | void (*stop)(void); | |
60 | void (*reset)(void *); | |
61 | int (*map_event)(struct perf_event *event); | |
62 | int num_events; | |
63 | atomic_t active_events; | |
64 | struct mutex reserve_mutex; | |
65 | u64 max_period; | |
66 | struct platform_device *plat_device; | |
67 | struct pmu_hw_events *(*get_hw_events)(void); | |
68 | }; | |
69 | ||
70 | #define to_arm_pmu(p) (container_of(p, struct arm_pmu, pmu)) | |
71 | ||
72 | int __init armpmu_register(struct arm_pmu *armpmu, char *name, int type); | |
73 | ||
74 | u64 armpmu_event_update(struct perf_event *event, | |
75 | struct hw_perf_event *hwc, | |
76 | int idx); | |
77 | ||
78 | int armpmu_event_set_period(struct perf_event *event, | |
79 | struct hw_perf_event *hwc, | |
80 | int idx); | |
81 | ||
82 | #endif /* CONFIG_HW_PERF_EVENTS */ | |
83 | #endif /* __ASM_PMU_H */ |