From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751822AbZHXG5d (ORCPT ); Mon, 24 Aug 2009 02:57:33 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1751648AbZHXG5c (ORCPT ); Mon, 24 Aug 2009 02:57:32 -0400 Received: from casper.infradead.org ([85.118.1.10]:37622 "EHLO casper.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751587AbZHXG5c (ORCPT ); Mon, 24 Aug 2009 02:57:32 -0400 Subject: Re: [PATCH] tracing/profile: Fix profile_disable vs module_unload From: Peter Zijlstra To: Li Zefan Cc: Ingo Molnar , Steven Rostedt , Frederic Weisbecker , LKML In-Reply-To: <4A923197.4040708@cn.fujitsu.com> References: <4A9214E3.2070807@cn.fujitsu.com> <1251093660.7538.119.camel@twins> <4A923197.4040708@cn.fujitsu.com> Content-Type: text/plain Content-Transfer-Encoding: 7bit Date: Mon, 24 Aug 2009 08:56:52 +0200 Message-Id: <1251097012.7538.123.camel@twins> Mime-Version: 1.0 X-Mailer: Evolution 2.26.1 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 2009-08-24 at 14:22 +0800, Li Zefan wrote: > Peter Zijlstra wrote: > > On Mon, 2009-08-24 at 12:19 +0800, Li Zefan wrote: > >> If the correspoding module is unloaded before ftrace_profile_disable() > >> is called, event->profile_disable() won't be called, which can > >> cause oops: > >> > >> # insmod trace-events-sample.ko > >> # perf record -f -a -e sample:foo_bar sleep 3 & > >> # sleep 1 > >> # rmmod trace_events_sample > >> # insmod trace-events-sample.ko > >> OOPS! > >> > >> Signed-off-by: Li Zefan > > > > > > Hrmm, feel fragile, why don't we check if all a modules tracepoints are > > unused on unload? > > > > I don't think it's fragile. We are profiling via a module's > tracepoint, so we should pin the module, via module_get(). > If event->profile_enable() has been calld, we should make > sure it's profile_disable() will be called. What I call fragile is that everyone registering a tracepoint callback will now apparently need to worry about modules, _that_ is fragile. Either make module unload look at tracepoint users, or place the try_get_module() in the registration hooks so that regular users don't need to worry about it. But this is rediculous.