From: Steven Rostedt Subject: Re: [BUG] ext4 trace events cause NULL pointer dereferences Date: Wed, 21 Jul 2010 10:16:06 -0400 Message-ID: <1279721766.4818.39.camel@gandalf.stny.rr.com> References: <4C401CE3.7010004@cn.fujitsu.com> <20100721222508.8704.A69D9226@jp.fujitsu.com> Mime-Version: 1.0 Content-Type: text/plain; charset="ISO-8859-15" Content-Transfer-Encoding: 7bit Cc: Li Zefan , Theodore Ts'o , LKML , linux-ext4@vger.kernel.org, Frederic Weisbecker , Mathieu Desnoyers To: KOSAKI Motohiro Return-path: Received: from hrndva-omtalb.mail.rr.com ([71.74.56.122]:45514 "EHLO hrndva-omtalb.mail.rr.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755624Ab0GUOQJ (ORCPT ); Wed, 21 Jul 2010 10:16:09 -0400 In-Reply-To: <20100721222508.8704.A69D9226@jp.fujitsu.com> Sender: linux-ext4-owner@vger.kernel.org List-ID: On Wed, 2010-07-21 at 22:31 +0900, KOSAKI Motohiro wrote: > Hi Steven, > if (ac) > trace_ext4_mb_release_group_pa(ac, pa); > > But, I don't think this is proper fix because we don't want any overhead > if the tracepoint is disabled. > > So, How do we check NULL in TP_fast_assign()? You could do: TP_fast_assign( if (ac) { __entry->dev = ac->ac_sb->s_dev; __entry->ino = ac->ac_inode->i_ino; __entry->pa_pstart = pa->pa_pstart; __entry->pa_len = pa->pa_len; } ), But this just makes the __entry null and wastes the ring buffer. I may be able to add a __discard_entry that may help. Then we could do something like this: if (ac) { __entry->dev = ac->ac_sb->s_dev; __entry->ino = ac->ac_inode->i_ino; __entry->pa_pstart = pa->pa_pstart; __entry->pa_len = pa->pa_len; } else __discard_entry; Does this seem reasonable? But for now, the wasting the entry seems to be the only choice we have, or to do as you suggested and have the "if (ac) trace_...", but I don't like that. -- Steve