Received: by 10.213.65.68 with SMTP id h4csp2901802imn; Mon, 2 Apr 2018 16:41:31 -0700 (PDT) X-Google-Smtp-Source: AIpwx49g9+eEi7+zvxlHUlvzkLJ6aLe749z+fPgiXUYNT62jOOyqrshfrVnRqfREntbCER3vGqzZ X-Received: by 10.99.122.22 with SMTP id v22mr7255128pgc.300.1522712491515; Mon, 02 Apr 2018 16:41:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522712491; cv=none; d=google.com; s=arc-20160816; b=hE3mnBvNGmMzb6zRk5O5KA8+xBdKPasgESNj0HVf9U4PZk0BVS1Zsbxa3PTbeRVYz0 dqwy6D2cL+oTuDZdz49UKTzs9ebEg0JCHaMRe2hP9InSHIXVYvegrgFnuaETeAq3rnf9 Tk+/WO/lYfOg38X9Fpq+t8CvPMtCws7cY1h1b6ktbjhtN3euzHlvzQGdydvcMs+GYBCA 2whuQLLsg59tB1VPpJH+OR5P0/b1XLKH6uKYEJvxEbW9Cbx7b++sqdOqnRPQgJalCo8X WeAQJ1G5qKMY9ea1i2CHK8cf5cnEOhZ9bYVh058iO2dGc/YouQSTGfhjtPI3WBoy38oj +aLw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature :dkim-signature:arc-authentication-results; bh=qWOL860cWVHGd5xlVTltZee+4nF5ptgJoKkN7mTvDw0=; b=IqiexbAQmXX3Z5C2Z7DcscsSUVanQ1KdXgIz9DD1OiwzJ/Yms82FFfzxddompFFvF+ ScHO9eZZhV4Q0BNm8R9Z3+vnj9L2V8F4RfE/TU4MmvoGgXfQnTyKIEhPRXz/WGNdTPyD 8rVQuxkaFIoXDnm9PJyAsy3UI2iQUqFvRyDqbehkdmTIY8snCwTfouea5AhvQJ3b34fR ZnVyyQ+PLuaG7XlVNC7lu7oJ+ziiMSpXJLee1Ii1cNddqR7KXrp5YRe2tdAVFqF2tiIt JlBPK/VVQV1AcZzVhNDPXeFeqA+0fdqY02ICGMz3rtKUJ9hAazm9G4OeI6KYyq683dJA JkNw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@themaw.net header.s=fm2 header.b=GSB++nlg; dkim=pass header.i=@messagingengine.com header.s=fm2 header.b=hLDejNAQ; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d13-v6si1472313plr.373.2018.04.02.16.41.17; Mon, 02 Apr 2018 16:41:31 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@themaw.net header.s=fm2 header.b=GSB++nlg; dkim=pass header.i=@messagingengine.com header.s=fm2 header.b=hLDejNAQ; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754817AbeDBXjv (ORCPT + 99 others); Mon, 2 Apr 2018 19:39:51 -0400 Received: from out5-smtp.messagingengine.com ([66.111.4.29]:47829 "EHLO out5-smtp.messagingengine.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754754AbeDBXjk (ORCPT ); Mon, 2 Apr 2018 19:39:40 -0400 Received: from compute1.internal (compute1.nyi.internal [10.202.2.41]) by mailout.nyi.internal (Postfix) with ESMTP id 07C32211D9; Mon, 2 Apr 2018 19:39:40 -0400 (EDT) Received: from mailfrontend1 ([10.202.2.162]) by compute1.internal (MEProxy); Mon, 02 Apr 2018 19:39:40 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=themaw.net; h=cc :content-transfer-encoding:content-type:date:from:in-reply-to :message-id:mime-version:references:subject:to:x-me-sender :x-me-sender:x-sasl-enc; s=fm2; bh=qWOL860cWVHGd5xlVTltZee+4nF5p tgJoKkN7mTvDw0=; b=GSB++nlgdnYBlGnJzpLDCGuwQPb3kKPnHDpEwCBpgMFQ9 z4lnOeJm6BjuaSS7IIdCDf0CgVA/gsnhEkst2KAfP29lLqA1KJdTlRmBgd/12FCL Z2ckjNGxWNl/ro4jFB+iZAM2IWAAq+vZxH0n6zFMYOmsHHiugKMefj1mggzZerVY xBTr7RsCaIZbooUygQQDr8ds6AMij+itQ4fDYnhldkI8/gFhZnPXatcK/zUZJb4G VBkOJwRXAP6DPoGyCQWvpWZUjWV8fl/0GHmCs+ZahWI+UHsAE8i+f9uIgPmPy1JH XMXFsgtJ3fssCHMNA8RXHx691kQmL4QSionuGA53A== DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d= messagingengine.com; h=cc:content-transfer-encoding:content-type :date:from:in-reply-to:message-id:mime-version:references :subject:to:x-me-sender:x-me-sender:x-sasl-enc; s=fm2; bh=qWOL86 0cWVHGd5xlVTltZee+4nF5ptgJoKkN7mTvDw0=; b=hLDejNAQSf9YqRa++2iXxB F4KrPjQEnhdn8m2cb9m6lBTx03KMlrEA31kNaJHvxMQtcTWi3ZTvcaEz7WfJeNt3 lVzO56+9JzzRnbpdS3G0Oqsr70EZAd0KSrTIze2U/4atUcCpBZMAuATHG5EVUMXq cXIUFUTDbGKZeJAhynSmCfdFVgDChzuElzJYpzAy5Kxb/Smc4fv5OwMXYgTZyJN8 Hh26BiwUz/7/dwKUaYgdaKTbI5cShY978MsRLRkaufr1IACJnNs6PEHx3KvDRJAc dOeB51/Las442zkCevE6VZ07QXAj9/XYy4FtBU3B34Ya7q+zrH6dq0LR9wpaZNag == X-ME-Sender: Received: from [192.168.1.28] (106-68-173-233.dyn.iinet.net.au [106.68.173.233]) by mail.messagingengine.com (Postfix) with ESMTPA id E6105E443C; Mon, 2 Apr 2018 19:39:36 -0400 (EDT) Subject: Re: [PATCH] autofs4: use wake_up() instead of wake_up_interruptible To: Andrei Vagin , Andrew Morton Cc: Andrei Vagin , autofs@vger.kernel.org, linux-kernel@vger.kernel.org, Matthew Wilcox , Stephen Rothwell References: <20180331022839.21277-1-avagin@openvz.org> <8d578e49-c1a0-a38d-3b91-f0a07de0089b@themaw.net> <20180401062117.GA27067@outlook.office365.com> From: Ian Kent Message-ID: <46f1c699-21bd-3615-0d2c-52ea3ac565e2@themaw.net> Date: Tue, 3 Apr 2018 07:39:33 +0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: <20180401062117.GA27067@outlook.office365.com> Content-Type: text/plain; charset=koi8-r Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 01/04/18 14:21, Andrei Vagin wrote: > On Sun, Apr 01, 2018 at 10:01:41AM +0800, Ian Kent wrote: >> On 01/04/18 09:31, Ian Kent wrote: >>> On 31/03/18 10:28, Andrei Vagin wrote: >>>> In "autofs4: use wait_event_killable", wait_event_interruptible() was >>>> replaced by wait_event_killable(), but in this case we have to use >>>> wake_up() instead of wake_up_interruptible(). >>> >>> Why do you believe wake_up() is needed rather than wake_up_interruptible()? >>> >>> Now that I'm thinking about the wake up I'm wondering if this is in fact >>> what's needed. Rather, I think maybe wake_up_all() is probably the only >>> one that will actually do what's needed. >> >> Ok, so that 1 is the number of exclusive waiters. >> So what is the difference between the two wake_up calls in this case? > > In CRIU, we have the autofs test: > https://github.com/checkpoint-restore/criu/blob/master/test/zdtm/static/autofs.c > > We run CRIU tests on the linux-next kernels and a few days ago this test > started to fail, actually it hangs up. > > I found that wake_up_interruptible() doesn't wake up a thread, which is > waiting. > > try_to_wake_up() has the argument "state", it is the mask of task states > that can be woken. > > For wake_up_interruptible(), state is TASK_INTERRUPTIBLE. > For wake_up(). state is TASK_NORMAL (TASK_INTERRUPTIBLE | TASK_UNINTERRUPTIBLE) > > If we use wait_event_killable(), the task sleeps in the TASK_KILLABLE > state, so wake_up_interruptible() isn't suitable in this case. > > #define TASK_KILLABLE (TASK_WAKEKILL | TASK_UNINTERRUPTIBLE) > > I checked that our test passes with this patch. I mean that we had a > real problem and we checked that it is fixed by this patch. Ahh, I see, wake_up_*() functions do just what they say, they skip TASK_UNINTERRUPTIBLE tasks. Now it makes sense. Acked-by: Ian Kent Andrew could you a take this patch as well please. > > Thanks, > Andrei > >> >>> >>> There's an individual wait queue for each mount, there can be multiple >>> waiters for a mount, they all should be woken up when the daemon signals >>> mount completion. >>> >>>> >>>> Cc: Matthew Wilcox >>>> Cc: Ian Kent >>>> Cc: Andrew Morton >>>> Cc: Stephen Rothwell >>>> Signed-off-by: Andrei Vagin >>>> --- >>>> fs/autofs4/waitq.c | 2 +- >>>> 1 file changed, 1 insertion(+), 1 deletion(-) >>>> >>>> diff --git a/fs/autofs4/waitq.c b/fs/autofs4/waitq.c >>>> index c160e9b3aa0f..be9c3dc048ab 100644 >>>> --- a/fs/autofs4/waitq.c >>>> +++ b/fs/autofs4/waitq.c >>>> @@ -549,7 +549,7 @@ int autofs4_wait_release(struct autofs_sb_info *sbi, autofs_wqt_t wait_queue_tok >>>> kfree(wq->name.name); >>>> wq->name.name = NULL; /* Do not wait on this queue */ >>>> wq->status = status; >>>> - wake_up_interruptible(&wq->queue); >>>> + wake_up(&wq->queue); >>>> if (!--wq->wait_ctr) >>>> kfree(wq); >>>> mutex_unlock(&sbi->wq_mutex); >>>> >>> >>