Skip to content

Commit 0830937

Browse files
Peter ZijlstraIngo Molnar
authored andcommitted
perf: Fix cgroup vs jump_label problem
Li Zefan reported that the jump label code sleeps and we're calling it under a spinlock, *fail* ;-) Reported-by: Li Zefan <lizf@cn.fujitsu.com> Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl> LKML-Reference: <new-submission> Signed-off-by: Ingo Molnar <mingo@elte.hu>
1 parent 2d0f252 commit 0830937

File tree

1 file changed

+13
-13
lines changed

1 file changed

+13
-13
lines changed

kernel/perf_event.c

Lines changed: 13 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -820,16 +820,8 @@ list_add_event(struct perf_event *event, struct perf_event_context *ctx)
820820
list_add_tail(&event->group_entry, list);
821821
}
822822

823-
if (is_cgroup_event(event)) {
823+
if (is_cgroup_event(event))
824824
ctx->nr_cgroups++;
825-
/*
826-
* one more event:
827-
* - that has cgroup constraint on event->cpu
828-
* - that may need work on context switch
829-
*/
830-
atomic_inc(&per_cpu(perf_cgroup_events, event->cpu));
831-
jump_label_inc(&perf_sched_events);
832-
}
833825

834826
list_add_rcu(&event->event_entry, &ctx->event_list);
835827
if (!ctx->nr_events)
@@ -957,11 +949,8 @@ list_del_event(struct perf_event *event, struct perf_event_context *ctx)
957949

958950
event->attach_state &= ~PERF_ATTACH_CONTEXT;
959951

960-
if (is_cgroup_event(event)) {
952+
if (is_cgroup_event(event))
961953
ctx->nr_cgroups--;
962-
atomic_dec(&per_cpu(perf_cgroup_events, event->cpu));
963-
jump_label_dec(&perf_sched_events);
964-
}
965954

966955
ctx->nr_events--;
967956
if (event->attr.inherit_stat)
@@ -2903,6 +2892,10 @@ static void free_event(struct perf_event *event)
29032892
atomic_dec(&nr_task_events);
29042893
if (event->attr.sample_type & PERF_SAMPLE_CALLCHAIN)
29052894
put_callchain_buffers();
2895+
if (is_cgroup_event(event)) {
2896+
atomic_dec(&per_cpu(perf_cgroup_events, event->cpu));
2897+
jump_label_dec(&perf_sched_events);
2898+
}
29062899
}
29072900

29082901
if (event->buffer) {
@@ -6478,6 +6471,13 @@ SYSCALL_DEFINE5(perf_event_open,
64786471
err = perf_cgroup_connect(pid, event, &attr, group_leader);
64796472
if (err)
64806473
goto err_alloc;
6474+
/*
6475+
* one more event:
6476+
* - that has cgroup constraint on event->cpu
6477+
* - that may need work on context switch
6478+
*/
6479+
atomic_inc(&per_cpu(perf_cgroup_events, event->cpu));
6480+
jump_label_inc(&perf_sched_events);
64816481
}
64826482

64836483
/*

0 commit comments

Comments
 (0)