From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1761536Ab3BNRzA (ORCPT ); Thu, 14 Feb 2013 12:55:00 -0500 Received: from mail-wg0-f48.google.com ([74.125.82.48]:39311 "EHLO mail-wg0-f48.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1758259Ab3BNRy6 (ORCPT ); Thu, 14 Feb 2013 12:54:58 -0500 From: Grant Likely Subject: Re: [PATCH] driver core: add wait event for deferred probe To: Haojian Zhuang , Arnd Bergmann Cc: Andrew Morton , Greg Kroah-Hartman , viro@zeniv.linux.org.uk, Rusty Russell , hpa@linux.intel.com, Jim Cromie , linux-kernel@vger.kernel.org, Russell King - ARM Linux , Linus Walleij , broonie@opensource.wolfsonmicro.com, Patch Tracking In-Reply-To: References: <1360429077-14616-1-git-send-email-haojian.zhuang@linaro.org> <201302141557.18308.arnd@arndb.de> <201302141650.21144.arnd@arndb.de> Date: Thu, 14 Feb 2013 17:54:56 +0000 Message-Id: <20130214175456.729453E12FB@localhost> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 15 Feb 2013 00:58:23 +0800, Haojian Zhuang wrote: > On 15 February 2013 00:50, Arnd Bergmann wrote: > > On Thursday 14 February 2013, Haojian Zhuang wrote: > >> On 14 February 2013 23:57, Arnd Bergmann wrote: > >> > On Thursday 14 February 2013, Haojian Zhuang wrote: > >> >> If you can change it into code in below, it could work. Otherwise, it > >> >> always fails. > >> >> driver_deferred_probe_enable = true; > >> >> driver_deferred_probe_trigger(); > >> >> + deferred_probe_work_func(NULL); > >> >> return 0; > >> >> > >> >> Because deferred_probe_work_func() depends on that deferred_probe is added > >> >> into deferred_probe_active_list. If driver_deferred_probe_trigger() isn't called > >> >> first, the deferred uart probe can't be added into active list. So even you call > >> >> work_func at here, it doesn't help. > >> >> > >> > > >> > Would that not cause two instances of the work function to run at the same time? > >> > That sounds like a source for a lot of problems. > >> > > >> > Arnd > >> > >> Two instances of the work function? I'm sorry that I don't > >> understanding your meaning. > >> Could you help explain your question? > > > > I mean you end up calling the work function directly, while it gets run as part > > of the work queue on a different CPU at the same time. I just noticed that > > there is actually locking in place in deferred_probe_work_func that prevents > > any actual bugs, but you are still adding extra overhead here. > > > > Maybe just add > > > > flush_workqueue(deferred_wq); > > > > here? > > > > Arnd > > It's fine to me. Since both of them are flushing workqueue. > > Tested-by: Hahaha. I just came to the same conclusion. I'll craft a proper patch and send it off. g.