Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755412AbYFBXVr (ORCPT ); Mon, 2 Jun 2008 19:21:47 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1753919AbYFBXVi (ORCPT ); Mon, 2 Jun 2008 19:21:38 -0400 Received: from tomts25-srv.bellnexxia.net ([209.226.175.188]:42947 "EHLO tomts25-srv.bellnexxia.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753288AbYFBXVh (ORCPT ); Mon, 2 Jun 2008 19:21:37 -0400 X-IronPort-Anti-Spam-Filtered: true X-IronPort-Anti-Spam-Result: ApsEANMbREhMQW6j/2dsb2JhbACBVa1D Date: Mon, 2 Jun 2008 19:21:35 -0400 From: Mathieu Desnoyers To: Peter Zijlstra Cc: Hideo AOKI , mingo@elte.hu, Masami Hiramatsu , linux-kernel@vger.kernel.org Subject: Re: Kernel marker has no performance impact on ia64. Message-ID: <20080602232135.GA20173@Krystal> References: <48447052.3030300@redhat.com> <1212445965.6269.22.camel@lappy.programming.kicks-ass.net> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Transfer-Encoding: 7bit Content-Disposition: inline In-Reply-To: <1212445965.6269.22.camel@lappy.programming.kicks-ass.net> X-Editor: vi X-Info: http://krystal.dyndns.org:8080 X-Operating-System: Linux/2.6.21.3-grsec (i686) X-Uptime: 19:11:24 up 94 days, 19:22, 4 users, load average: 0.40, 0.54, 0.54 User-Agent: Mutt/1.5.16 (2007-06-11) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2818 Lines: 62 * Peter Zijlstra (peterz@infradead.org) wrote: > On Mon, 2008-06-02 at 18:12 -0400, Hideo AOKI wrote: > > Hello, > > > > I evaluated overhead of kernel marker using linux-2.6-sched-fixes > > git tree, which includes several markers for LTTng, using an ia64 > > server. > > > > While the immediate trace mark feature isn't implemented on ia64, > > there is no major performance regression. So, I think that we > > don't have any issues to propose merging marker point patches > > into Linus's tree from the viewpoint of performance impact. > > Performance is atm the least of the concerns regarding this work. > > I'm still convinced markers are too ugly to live. > > I also worry greatly about the fact that its too easy to expose too much > to user-space. There are no clear rules and the free form marker format > just begs for an inconsistent mess to arise. > > IMHO the current free-form trace_mark() should be removed from the tree > - its great for ad-hoc debugging but its a disaster waiting to happen > for anything else. Anybody doing ad-hoc debugging can patch it in > themselves if needed. > > Regular trace points can be custom made; this has the advantages that it > raises the implementation barrier and hopefully that encourages some > thought in the process. It also avoid the code from growing into > something that looks like someone had a long night of debugging. > Maybe we could settle for an intermediate solution : I agree with you that defining the trace points in headers, like you did for the scheduler, makes the code much cleaner and makes things much easier to maintain afterward. However, having the trace_mark mechanism underneath helps a lot in plugging a generic tracer (actually, if we can settle the marker issue, I've got a kernel tracer, LTTng, that I've been waiting for quite a while to push to mainline that I would like to post someday). So I would be in favor of requiring tracing statements to be described in static inline functions, in header files, that could preferably call trace_mark() and optionally also call other in-kernel tracers directly. Ideally, we could re-use the immediate values infrastructure to control activation of these trace points with minimal impact on the system. One of my goal is to provide a mechanism that can feed both non-debug and debug information to a generic tracing mechanism to allow system-wide analysis of the kernel, both for production system and kernel debugging. Mathieu -- Mathieu Desnoyers OpenPGP key fingerprint: 8CD5 52C3 8E3C 4140 715F BA06 3F25 A8FE 3BAE 9A68 -- 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/