From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756811Ab2DTIcQ (ORCPT ); Fri, 20 Apr 2012 04:32:16 -0400 Received: from mail-vb0-f46.google.com ([209.85.212.46]:56533 "EHLO mail-vb0-f46.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756494Ab2DTIcN (ORCPT ); Fri, 20 Apr 2012 04:32:13 -0400 Date: Fri, 20 Apr 2012 16:32:02 +0800 From: Yong Zhang To: Stephen Boyd Cc: linux-kernel@vger.kernel.org, Tejun Heo , netdev@vger.kernel.org, Ben Dooks Subject: Re: [PATCH 1/2] workqueue: Catch more locking problems with flush_work() Message-ID: <20120420083202.GB17846@zhy> Reply-To: Yong Zhang References: <1334805958-29119-1-git-send-email-sboyd@codeaurora.org> <20120419081002.GB3963@zhy> <4F905B30.4080501@codeaurora.org> <20120420052633.GA16219@zhy> <20120420060101.GA16563@zhy> <4F9101A7.5010100@codeaurora.org> <20120420071759.GA17846@zhy> <4F911BCB.7010809@codeaurora.org> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <4F911BCB.7010809@codeaurora.org> User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Apr 20, 2012 at 01:18:19AM -0700, Stephen Boyd wrote: > On 4/20/2012 12:18 AM, Yong Zhang wrote: > > On Thu, Apr 19, 2012 at 11:26:47PM -0700, Stephen Boyd wrote: > >> complain in the case where the work is not queued. That case is not a > >> false positive. We will get a lockdep warning if the work is running > > IIRC, flush_work() is just a nop when a work is not queued nor running. > > Agreed, but it's better to always print a lockdep warning instead of > only when the deadlock is going to occur. It will IMHO. > > > > >> (when start_flush_work() returns true) solely with the > >> lock_map_acquire() on cwq->wq->lockdep_map. > > Yeah, that is the point we use lockdep to detect deadlock for workqueue. > > > > But when looking at start_flush_work(), for some case > > !(cwq->wq->saved_max_active == 1 || cwq->wq->flags & WQ_RESCUER), > > lock_map_acquire_read() is called, but recursive read is not added to > > the chain list. So when lock_map_acquire_read(&cwq->wq->lockdep_map) > > is called, deadlock will not be detected. I hope you don't hit that > > special case. > > Hmm. Originally I had what you suggested in my patch but I left it out > because I wasn't sure if it would cause false positives. > Do you see any > possibility for false positives? No, I don't. My test indeed show nothing (just build and boot). >I'll add it back in if not. It's great if you can try it :) Thanks, Yong