Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754534AbZIJVSW (ORCPT ); Thu, 10 Sep 2009 17:18:22 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1754470AbZIJVSV (ORCPT ); Thu, 10 Sep 2009 17:18:21 -0400 Received: from casper.infradead.org ([85.118.1.10]:37008 "EHLO casper.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754495AbZIJVSV (ORCPT ); Thu, 10 Sep 2009 17:18:21 -0400 Subject: Re: [PATCH 3/5] hw-breakpoints: Rewrite the hw-breakpoints layer on top of perf counters From: Peter Zijlstra To: Frederic Weisbecker Cc: "K.Prasad" , Ingo Molnar , LKML , Alan Stern , Arnaldo Carvalho de Melo , Steven Rostedt , Jan Kiszka , Jiri Slaby , Li Zefan , Avi Kivity , Paul Mackerras , Mike Galbraith , Masami Hiramatsu In-Reply-To: <20090910185304.GD6421@nowhere> References: <1252571367-25876-1-git-send-email-fweisbec@gmail.com> <1252571367-25876-4-git-send-email-fweisbec@gmail.com> <20090910142540.GA3512@in.ibm.com> <20090910185304.GD6421@nowhere> Content-Type: text/plain Date: Thu, 10 Sep 2009 23:18:01 +0200 Message-Id: <1252617481.7205.106.camel@laptop> Mime-Version: 1.0 X-Mailer: Evolution 2.26.1 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1850 Lines: 39 On Thu, 2009-09-10 at 20:53 +0200, Frederic Weisbecker wrote: > On Thu, Sep 10, 2009 at 07:55:40PM +0530, K.Prasad wrote: > > On Thu, Sep 10, 2009 at 10:29:25AM +0200, Frederic Weisbecker wrote: > > > This patch rebase the implementation of the breakpoints API on top of > > > perf counters instances. > > > > > > The core breakpoint API has changed a bit: > > > > > > - register_kernel_hw_breakpoint() now takes a cpu as a parameter. For > > > now it doesn't support all cpu wide breakpoints but this may be > > > implemented soon. > > > > Is there a reason why perf doesn't support counters effective on all > > CPUs (and all processes)? > > Atleast, it is vital for debugging aspects of hw-breakpoints...say to > > answer "Who all did a 'write' on the kernel variable that turned corrupt", etc. > > > > The implementation to iteratively register a breakpoint on all CPUs would > > (as in trace_ksym.c) result in unclean semantics for the end user, when, a > > register_kernel_<> request fails on a given CPU and all previously > > registered breakpoints have to be reverted (but the user might have > > received a few breakpoint triggers by then as a result of the successful > > ones...i.e. register request fails, but still received 'some' output). > > > (Please shrink the end of the message if you don't answer in further parts. > I'm especially a bad example of what not to do :-) > > Yeah it would be very convenient to have that. Is it possible considering > the current internal design of perf? Create the counters disabled? Maybe even group them to allow 'atomic' enable/disable. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/