We have ctx->event_list that contains all events; no need to repeatedly iterate the group lists to find them all. Cc: Arnaldo Carvalho de Melo Cc: Mathieu Desnoyers Cc: Ingo Molnar Cc: Alexander Shishkin Cc: Dmitry Vyukov Cc: Oleg Nesterov Signed-off-by: Peter Zijlstra (Intel) --- kernel/events/core.c | 12 +----------- 1 file changed, 1 insertion(+), 11 deletions(-) --- a/kernel/events/core.c +++ b/kernel/events/core.c @@ -10567,21 +10567,11 @@ void perf_event_free_task(struct task_st WRITE_ONCE(ctx->task, TASK_TOMBSTONE); put_task_struct(task); /* cannot be last */ raw_spin_unlock_irq(&ctx->lock); -again: - list_for_each_entry_safe(event, tmp, &ctx->pinned_groups, - group_entry) - perf_free_event(event, ctx); - list_for_each_entry_safe(event, tmp, &ctx->flexible_groups, - group_entry) + list_for_each_entry_safe(event, tmp, &ctx->event_list, event_entry) perf_free_event(event, ctx); - if (!list_empty(&ctx->pinned_groups) || - !list_empty(&ctx->flexible_groups)) - goto again; - mutex_unlock(&ctx->mutex); - put_ctx(ctx); } }