aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux/perf_event.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/linux/perf_event.h')
-rw-r--r--include/linux/perf_event.h29
1 files changed, 10 insertions, 19 deletions
diff --git a/include/linux/perf_event.h b/include/linux/perf_event.h
index ddbb6a901f65..8adf70e9e3cc 100644
--- a/include/linux/perf_event.h
+++ b/include/linux/perf_event.h
@@ -1084,10 +1084,8 @@ extern void perf_pmu_unregister(struct pmu *pmu);
1084 1084
1085extern int perf_num_counters(void); 1085extern int perf_num_counters(void);
1086extern const char *perf_pmu_name(void); 1086extern const char *perf_pmu_name(void);
1087extern void __perf_event_task_sched_in(struct task_struct *prev, 1087extern void __perf_event_task_sched(struct task_struct *prev,
1088 struct task_struct *task); 1088 struct task_struct *next);
1089extern void __perf_event_task_sched_out(struct task_struct *prev,
1090 struct task_struct *next);
1091extern int perf_event_init_task(struct task_struct *child); 1089extern int perf_event_init_task(struct task_struct *child);
1092extern void perf_event_exit_task(struct task_struct *child); 1090extern void perf_event_exit_task(struct task_struct *child);
1093extern void perf_event_free_task(struct task_struct *task); 1091extern void perf_event_free_task(struct task_struct *task);
@@ -1132,11 +1130,14 @@ struct perf_sample_data {
1132 struct perf_branch_stack *br_stack; 1130 struct perf_branch_stack *br_stack;
1133}; 1131};
1134 1132
1135static inline void perf_sample_data_init(struct perf_sample_data *data, u64 addr) 1133static inline void perf_sample_data_init(struct perf_sample_data *data,
1134 u64 addr, u64 period)
1136{ 1135{
1136 /* remaining struct members initialized in perf_prepare_sample() */
1137 data->addr = addr; 1137 data->addr = addr;
1138 data->raw = NULL; 1138 data->raw = NULL;
1139 data->br_stack = NULL; 1139 data->br_stack = NULL;
1140 data->period = period;
1140} 1141}
1141 1142
1142extern void perf_output_sample(struct perf_output_handle *handle, 1143extern void perf_output_sample(struct perf_output_handle *handle,
@@ -1204,20 +1205,13 @@ perf_sw_event(u32 event_id, u64 nr, struct pt_regs *regs, u64 addr)
1204 1205
1205extern struct static_key_deferred perf_sched_events; 1206extern struct static_key_deferred perf_sched_events;
1206 1207
1207static inline void perf_event_task_sched_in(struct task_struct *prev, 1208static inline void perf_event_task_sched(struct task_struct *prev,
1208 struct task_struct *task) 1209 struct task_struct *task)
1209{ 1210{
1210 if (static_key_false(&perf_sched_events.key))
1211 __perf_event_task_sched_in(prev, task);
1212}
1213
1214static inline void perf_event_task_sched_out(struct task_struct *prev,
1215 struct task_struct *next)
1216{
1217 perf_sw_event(PERF_COUNT_SW_CONTEXT_SWITCHES, 1, NULL, 0); 1211 perf_sw_event(PERF_COUNT_SW_CONTEXT_SWITCHES, 1, NULL, 0);
1218 1212
1219 if (static_key_false(&perf_sched_events.key)) 1213 if (static_key_false(&perf_sched_events.key))
1220 __perf_event_task_sched_out(prev, next); 1214 __perf_event_task_sched(prev, task);
1221} 1215}
1222 1216
1223extern void perf_event_mmap(struct vm_area_struct *vma); 1217extern void perf_event_mmap(struct vm_area_struct *vma);
@@ -1292,11 +1286,8 @@ extern void perf_event_disable(struct perf_event *event);
1292extern void perf_event_task_tick(void); 1286extern void perf_event_task_tick(void);
1293#else 1287#else
1294static inline void 1288static inline void
1295perf_event_task_sched_in(struct task_struct *prev, 1289perf_event_task_sched(struct task_struct *prev,
1296 struct task_struct *task) { } 1290 struct task_struct *task) { }
1297static inline void
1298perf_event_task_sched_out(struct task_struct *prev,
1299 struct task_struct *next) { }
1300static inline int perf_event_init_task(struct task_struct *child) { return 0; } 1291static inline int perf_event_init_task(struct task_struct *child) { return 0; }
1301static inline void perf_event_exit_task(struct task_struct *child) { } 1292static inline void perf_event_exit_task(struct task_struct *child) { }
1302static inline void perf_event_free_task(struct task_struct *task) { } 1293static inline void perf_event_free_task(struct task_struct *task) { }