From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752765Ab1HYOmW (ORCPT ); Thu, 25 Aug 2011 10:42:22 -0400 Received: from merlin.infradead.org ([205.233.59.134]:55149 "EHLO merlin.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751360Ab1HYOmS convert rfc822-to-8bit (ORCPT ); Thu, 25 Aug 2011 10:42:18 -0400 Subject: Re: [PATCH] perf_event: fix slow and broken cgroup context switch code From: Peter Zijlstra To: Stephane Eranian Cc: linux-kernel@vger.kernel.org, mingo@elte.hu, ming.m.lin@intel.com, Oleg Nesterov , Jiri Olsa Date: Thu, 25 Aug 2011 16:42:01 +0200 In-Reply-To: References: <20110825135803.GA4697@quad> <1314282021.27911.12.camel@twins> Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 8BIT X-Mailer: Evolution 3.0.2- Message-ID: <1314283321.27911.25.camel@twins> Mime-Version: 1.0 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 2011-08-25 at 16:36 +0200, Stephane Eranian wrote: > On Thu, Aug 25, 2011 at 4:20 PM, Peter Zijlstra wrote: > > On Thu, 2011-08-25 at 15:58 +0200, Stephane Eranian wrote: > >> +static inline void perf_event_task_sched_out(struct task_struct > >> *prev, > >> + struct task_struct *next) > >> { > >> perf_sw_event(PERF_COUNT_SW_CONTEXT_SWITCHES, 1, NULL, 0); > >> > >> - __perf_event_task_sched_out(task, next); > >> + if (static_branch(&perf_sched_events)) > >> + __perf_event_task_sched_out(prev, next); > >> } > > > > Right, so the reason we removed the static branch from there is > > > > lkml.kernel.org/r/20110324164436.GC1930@jolsa.brq.redhat.com > > > > now I think the series 075e0b0085 to 64ce312618e should have cured that > > problem, and adding the static_branch() is now safe again. But there's > > no mention of any of this in the Changelog. > > > I realized I did not talk about the static_branch() change after I had > clicked on > Send. But to me, this looks natural to have the static branch in the ctxsw out > routine. This has to be symmetrical with ctxsw in . The static branch is about > avoiding perf ctxsw when there is no need for it, i.e., no per-thread > nor per-cgroup > events. Yeah, that argument is what got us into trouble initially :) But I think its ok now, we'll see if stuff explodes or not..