From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757259AbZFCM6g (ORCPT ); Wed, 3 Jun 2009 08:58:36 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1755922AbZFCM62 (ORCPT ); Wed, 3 Jun 2009 08:58:28 -0400 Received: from mx2.redhat.com ([66.187.237.31]:59019 "EHLO mx2.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753668AbZFCM61 (ORCPT ); Wed, 3 Jun 2009 08:58:27 -0400 Subject: Re: trace: fix multiple use of __print_flags and __print_symbolic From: Steven Whitehouse To: Li Zefan Cc: Steven Rostedt , linux-kernel@vger.kernel.org, cluster-devel@redhat.com, Christoph Hellwig , Ingo Molnar In-Reply-To: <4A26474C.1000900@cn.fujitsu.com> References: <1244019900.29604.588.camel@localhost.localdomain> <4A26474C.1000900@cn.fujitsu.com> Content-Type: text/plain Organization: Red Hat (UK) Ltd (Registered in England and Wales, No. 3798903) Registered office: Red Hat UK Ltd, Amberley Place, 107-111 Peascod Street, Windsor, Berkshire, SL4 ITE Date: Wed, 03 Jun 2009 13:57:55 +0100 Message-Id: <1244033875.29604.599.camel@localhost.localdomain> Mime-Version: 1.0 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi On Wed, 2009-06-03 at 17:50 +0800, Li Zefan wrote: > Steven Whitehouse wrote: > > When using multiple calls to __print_symbolic and __print_flags in > > the same tracer, I noticed that the output was incorrect. I think > > the following patch is the correct fix (it works for me) but please > > check it carefully since I'm not that familiar with this code, > > and I may well have made a mistake somewhere. > > > > I don't see there's bug in __print_symbolic() or __print_flags(): > > enum print_line_t > ftrace_raw_output_##call(struct trace_iterator *iter, int flags) > { > ... > p = &get_cpu_var(ftrace_event_seq); > /* here we call ftrace_print_flags_seq(p, ...) */ > ret = trace_seq_printf(s, #call ": " print); > put_cpu(); > ... > } > > ftrace_event_seq is percpu data, and here is used with preempt-disabled, > so there shouldn't be problem of concurrent accessing. > I've double checked this now, and I'm seeing results like: glock_workqueue-2482 [001] 809.956985: gfs2_glock_state_change: 8.7 glock 2:33119 state EX => EX tgt:EX dmt:EX flags:EX glock_workqueue-2482 [001] 809.957155: gfs2_glock_state_change: 8.7 glock 2:33119 state NL => NL tgt:NL dmt:NL flags:NL glock_workqueue-2482 [001] 809.959473: gfs2_glock_state_change: 8.7 glock 1:2 state NL => NL tgt:NL dmt:NL flags:NL glock_workqueue-2482 [001] 809.959556: gfs2_glock_state_change: 8.7 glock 2:33119 state EX => EX tgt:EX dmt:EX flags:EX glock_workqueue-2482 [001] 810.008773: gfs2_glock_state_change: 8.7 glock 1:0 state EX => EX tgt:EX dmt:EX flags:EX without the patch, which is clearly wrong, Steve.