Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753022AbXFYKpL (ORCPT ); Mon, 25 Jun 2007 06:45:11 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1751093AbXFYKpA (ORCPT ); Mon, 25 Jun 2007 06:45:00 -0400 Received: from mail.screens.ru ([213.234.233.54]:35258 "EHLO mail.screens.ru" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750781AbXFYKo7 (ORCPT ); Mon, 25 Jun 2007 06:44:59 -0400 Date: Mon, 25 Jun 2007 14:43:32 +0400 From: Oleg Nesterov To: "Rafael J. Wysocki" Cc: Andrew Morton , Nigel Cunningham , "Paul E. McKenney" , Pavel Machek , Uli Luckas , linux-kernel@vger.kernel.org Subject: Re: [PATCH -mm] PM: Prevent frozen user mode helpers from failing the freezing of tasks Message-ID: <20070625104332.GA147@tv-sign.ru> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline User-Agent: Mutt/1.5.11 Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1576 Lines: 45 Rafael J. Wysocki wrote: > > static int usermodehelper_pm_callback(struct notifier_block *nfb, > unsigned long action, > void *ignored) > { > + long retval; > + > switch (action) { > case PM_HIBERNATION_PREPARE: > case PM_SUSPEND_PREPARE: > usermodehelper_disabled = 1; > - return NOTIFY_OK; > + /* > + * From now on call_usermodehelper_exec() won't start any new > + * helpers, so it is sufficient if running_helpers turns out to > + * be zero at one point (it may be increased later, but that > + * doesn't matter). > + */ > + retval = wait_event_timeout(running_helpers_waitq, > + atomic_read(&running_helpers) == 0, > + RUNNING_HELPERS_TIMEOUT); > + if (retval) { > + return NOTIFY_OK; > + } else { > + usermodehelper_disabled = 0; > + return NOTIFY_BAD; I think this is racy. First, this needs smp_mb() between "usermodehelper_disabled = 1" and wait_event_timeout(). Second, call_usermodehelper's path should first increment the counter, and only then check usermodehelper_disabled, and it needs an mb() in between too. Otherwise, the helper can see usermodehelper_disabled == 0, then PM_SUSPEND_PREPARE comes and returns NOTIFY_OK, then the helper increments the counter and starts application. Sadly, you can't use srcu/qrcu because it doesn't handle timeouts. Oleg. - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/