aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFrederic Weisbecker <fweisbec@gmail.com>2010-04-14 17:42:18 -0400
committerIngo Molnar <mingo@elte.hu>2010-04-14 19:34:46 -0400
commit95476b64ab11d528de2557366ec584977c215b9e (patch)
treea01e04ca53b5ffd93f3149f6e9d18ab049268cd8
parentdf8290bf7ea6b3051e2f315579a6e829309ec1ed (diff)
perf: Fix hlist related build error
hlist helpers need to be available for all software events, not only trace events. Pull them out outside the ifdef CONFIG_EVENT_TRACING section. Fixes: kernel/perf_event.c:4573: error: implicit declaration of function 'swevent_hlist_put' kernel/perf_event.c:4614: error: implicit declaration of function 'swevent_hlist_get' kernel/perf_event.c:5534: error: implicit declaration of function 'swevent_hlist_release Reported-by: Ingo Molnar <mingo@elte.hu> Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com> Cc: Arnaldo Carvalho de Melo <acme@redhat.com> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Cc: Paul Mackerras <paulus@samba.org> LKML-Reference: <1271281338-23491-1-git-send-regression-fweisbec@gmail.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
-rw-r--r--kernel/perf_event.c60
1 files changed, 30 insertions, 30 deletions
diff --git a/kernel/perf_event.c b/kernel/perf_event.c
index 095101d685bc..07b7a435bf03 100644
--- a/kernel/perf_event.c
+++ b/kernel/perf_event.c
@@ -4313,36 +4313,6 @@ static const struct pmu perf_ops_task_clock = {
4313 .read = task_clock_perf_event_read, 4313 .read = task_clock_perf_event_read,
4314}; 4314};
4315 4315
4316#ifdef CONFIG_EVENT_TRACING
4317
4318void perf_tp_event(int event_id, u64 addr, u64 count, void *record,
4319 int entry_size, struct pt_regs *regs)
4320{
4321 struct perf_sample_data data;
4322 struct perf_raw_record raw = {
4323 .size = entry_size,
4324 .data = record,
4325 };
4326
4327 perf_sample_data_init(&data, addr);
4328 data.raw = &raw;
4329
4330 /* Trace events already protected against recursion */
4331 do_perf_sw_event(PERF_TYPE_TRACEPOINT, event_id, count, 1,
4332 &data, regs);
4333}
4334EXPORT_SYMBOL_GPL(perf_tp_event);
4335
4336static int perf_tp_event_match(struct perf_event *event,
4337 struct perf_sample_data *data)
4338{
4339 void *record = data->raw->data;
4340
4341 if (likely(!event->filter) || filter_match_preds(event->filter, record))
4342 return 1;
4343 return 0;
4344}
4345
4346static void swevent_hlist_release_rcu(struct rcu_head *rcu_head) 4316static void swevent_hlist_release_rcu(struct rcu_head *rcu_head)
4347{ 4317{
4348 struct swevent_hlist *hlist; 4318 struct swevent_hlist *hlist;
@@ -4442,6 +4412,36 @@ static int swevent_hlist_get(struct perf_event *event)
4442 return err; 4412 return err;
4443} 4413}
4444 4414
4415#ifdef CONFIG_EVENT_TRACING
4416
4417void perf_tp_event(int event_id, u64 addr, u64 count, void *record,
4418 int entry_size, struct pt_regs *regs)
4419{
4420 struct perf_sample_data data;
4421 struct perf_raw_record raw = {
4422 .size = entry_size,
4423 .data = record,
4424 };
4425
4426 perf_sample_data_init(&data, addr);
4427 data.raw = &raw;
4428
4429 /* Trace events already protected against recursion */
4430 do_perf_sw_event(PERF_TYPE_TRACEPOINT, event_id, count, 1,
4431 &data, regs);
4432}
4433EXPORT_SYMBOL_GPL(perf_tp_event);
4434
4435static int perf_tp_event_match(struct perf_event *event,
4436 struct perf_sample_data *data)
4437{
4438 void *record = data->raw->data;
4439
4440 if (likely(!event->filter) || filter_match_preds(event->filter, record))
4441 return 1;
4442 return 0;
4443}
4444
4445static void tp_perf_event_destroy(struct perf_event *event) 4445static void tp_perf_event_destroy(struct perf_event *event)
4446{ 4446{
4447 perf_trace_disable(event->attr.config); 4447 perf_trace_disable(event->attr.config);