From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from cn.fujitsu.com ([59.151.112.132]:41005 "EHLO heian.cn.fujitsu.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1755783AbcLUAdR (ORCPT ); Tue, 20 Dec 2016 19:33:17 -0500 Subject: Re: [PATCH 1/2] btrfs: drop trace_btrfs_all_work_done() from normal_work_helper() To: , Sebastian Andrzej Siewior , Chris Mason , Josef Bacik , David Sterba , , References: <20161214140530.6534-1-bigeasy@linutronix.de> <20161220172613.GQ3620@twin.jikos.cz> From: Qu Wenruo Message-ID: Date: Wed, 21 Dec 2016 08:33:03 +0800 MIME-Version: 1.0 In-Reply-To: <20161220172613.GQ3620@twin.jikos.cz> Content-Type: text/plain; charset="utf-8"; format=flowed Sender: linux-btrfs-owner@vger.kernel.org List-ID: At 12/21/2016 01:26 AM, David Sterba wrote: > Adding Qu to CC, > > On Wed, Dec 14, 2016 at 03:05:29PM +0100, Sebastian Andrzej Siewior wrote: >> For btrfs_scrubparity_helper() the ->func() is set to >> scrub_parity_bio_endio_worker(). This functions invokes >> scrub_free_parity() which kfrees() the `work' object. All is good as >> long as trace events are not enabled because we boom with a backtrace >> like this: >> | Workqueue: btrfs-endio btrfs_endio_helper >> | RIP: 0010:[] [] trace_event_raw_event_btrfs__work__done+0x4e/0xa0 >> | Call Trace: >> | [] btrfs_scrubparity_helper+0x59d/0x780 >> | [] btrfs_endio_helper+0x9/0x10 >> | [] process_one_work+0x26e/0x7b0 >> | [] worker_thread+0x46/0x560 >> | [] kthread+0xee/0x110 >> | [] ret_from_fork+0x2a/0x40 >> >> So in order to avoid this, I remove the trace point. >> >> Signed-off-by: Sebastian Andrzej Siewior >> --- >> fs/btrfs/async-thread.c | 2 -- >> 1 file changed, 2 deletions(-) >> >> diff --git a/fs/btrfs/async-thread.c b/fs/btrfs/async-thread.c >> index e0f071f6b5a7..d0dfc3d2e199 100644 >> --- a/fs/btrfs/async-thread.c >> +++ b/fs/btrfs/async-thread.c >> @@ -318,8 +318,6 @@ static void normal_work_helper(struct btrfs_work *work) >> set_bit(WORK_DONE_BIT, &work->flags); >> run_ordered_work(wq); >> } >> - if (!need_order) >> - trace_btrfs_all_work_done(work); > > The comment in the function says we can't touch 'work' after the > callbacks. I don't see any way to use it in a tracepoint here. The > "all_work_done" pairs with a preceding trace_btrfs_work_sched in the > same function or from within run_ordered_work, also called after the > free callback. The trace point only uses the pointer, and this helps us to pair with btrfs_work_queued/sched. But I still don't understand why backtrace is triggered. Since we're just recording a pointer, not touching it. Would you please explain the problem with more details on how it trigger the problem? > > So I think we should either remove the tracepoint completely or change > the arguments to take something else than a potentially freed 'work'. I'm mostly OK to remove the tracepoint, but such all_workd_done() trace should still help to determine if it's a workqueue stalled. Thanks, Qu > > I'm a bit puzzled by the comment in trace/events/btrfs.h > > http://lxr.free-electrons.com/source/include/trace/events/btrfs.h#L1165 > > /* For situiations that the work is freed */ > DECLARE_EVENT_CLASS(btrfs__work__done, > > so we're expecing a freed pointer anyway? That sounds wrong. > > I'll queue the patch for 4.10 as it fixes a crash. > >