Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp3532041imu; Sun, 11 Nov 2018 17:18:51 -0800 (PST) X-Google-Smtp-Source: AJdET5dgpaH30FOneUt4IylG67LyVeoo1KRHTup1oMGrPXSn45f/DxsBk8ruW4DhVGsNrCB1VzHC X-Received: by 2002:a63:1204:: with SMTP id h4mr15708022pgl.51.1541985531906; Sun, 11 Nov 2018 17:18:51 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1541985531; cv=none; d=google.com; s=arc-20160816; b=T0yaGbi2z4h2AYEPLuebfp5jypB5tdauITzxNKbDKDhSgiEUMLopePI+AFD3iNeH8g pdkCfV0vT8ZW+JgpNCtY/RMoKw9Vjwgxv1w2cX1x9DQ3oq0uUeqv7/RSXMLSzgONcsNO U59mguz0yCo3VXZEpvw+cDd4bLm9/W0YKC2yuDN9oQ+6JJntBfr3Dd3G9jn/6DPei/Uz Nes4NsDRaVgS0NE3c2u/hH9PtYwx4+dBJpE3TumML7ervuYePT+icM+Aie/URhJs29q6 vRIMWgafxzN2jV6Zab3j7Fp/khwtcOzUC+K8D566OXBMpmSaPztcrFkanQESXJgUCYNb 2buA== 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:mime-version :user-agent:references:in-reply-to:message-id:cc:subject:date:to :from; bh=7tqzyewmNhLKvuKeYw3WBrImrKbhLufjXlw6UouDzWY=; b=HGkeO0whzSVYpCakip8scV7M5SWppnuHwjHy8knKN7BTgtiYY7ZtVPQB8/WXfEXQba mjxEhtrnx+SQNfyst/HJuB7PWmKQNHz+W2KwCQYRORqO+8WFPMCqNxE5b8LmXY+Vzs1R RkkDsYx6KNnb+83VQNl8ubMnF/+Co9ujtQPuV0rHxQqhatlxyJ9tNk/bccQbX+5jDhVt bSGGLUS/79pH6osbBH5GLi8LTCPZLTx9sK2SgN7YDgoD0oxwD2oFvUnL9WR1U6olfCwu 64/JRA2ghPVEPBThzMZKAxUYMLSS4x6r1k3xUTDQ5KlSz/D55hmUZJ/mTq3w7hixvl6p nFVQ== ARC-Authentication-Results: i=1; mx.google.com; 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 70-v6si18035873pfz.20.2018.11.11.17.18.37; Sun, 11 Nov 2018 17:18:51 -0800 (PST) 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; 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 S1730149AbeKLLIT (ORCPT + 99 others); Mon, 12 Nov 2018 06:08:19 -0500 Received: from mx2.suse.de ([195.135.220.15]:56894 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726674AbeKLLIS (ORCPT ); Mon, 12 Nov 2018 06:08:18 -0500 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay1.suse.de (unknown [195.135.220.254]) by mx1.suse.de (Postfix) with ESMTP id 1C641ADE3; Mon, 12 Nov 2018 01:17:35 +0000 (UTC) From: NeilBrown To: Jeff Layton , Alexander Viro Date: Mon, 12 Nov 2018 12:14:49 +1100 Subject: [PATCH 08/12] fs/locks: always delete_block after waiting. Cc: "J. Bruce Fields" , Martin Wilck , linux-fsdevel@vger.kernel.org, Frank Filz , linux-kernel@vger.kernel.org Message-ID: <154198528917.14364.12807627735259492190.stgit@noble> In-Reply-To: <154198490921.14364.13726904731989686092.stgit@noble> References: <154198490921.14364.13726904731989686092.stgit@noble> User-Agent: StGit/0.17.1-dirty MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Now that requests can block other requests, we need to be careful to always clean up those blocked requests. Any time that we wait for a request, we might have other requests attached, and when we stop waiting, we must clean them up. If the lock was granted, the requests might have been moved to the new lock, though when merged with a pre-exiting lock, this might not happen. In all cases we don't want blocked locks to remain attached, so we remove them to be safe. Signed-off-by: NeilBrown --- fs/locks.c | 24 +++++++++--------------- 1 file changed, 9 insertions(+), 15 deletions(-) diff --git a/fs/locks.c b/fs/locks.c index c1b79293007b..8d9d79e7a565 100644 --- a/fs/locks.c +++ b/fs/locks.c @@ -1272,12 +1272,10 @@ static int posix_lock_inode_wait(struct inode *inode, struct file_lock *fl) if (error != FILE_LOCK_DEFERRED) break; error = wait_event_interruptible(fl->fl_wait, !fl->fl_blocker); - if (!error) - continue; - - locks_delete_block(fl); - break; + if (error) + break; } + locks_delete_block(fl); return error; } @@ -1966,12 +1964,10 @@ static int flock_lock_inode_wait(struct inode *inode, struct file_lock *fl) if (error != FILE_LOCK_DEFERRED) break; error = wait_event_interruptible(fl->fl_wait, !fl->fl_blocker); - if (!error) - continue; - - locks_delete_block(fl); - break; + if (error) + break; } + locks_delete_block(fl); return error; } @@ -2245,12 +2241,10 @@ static int do_lock_file_wait(struct file *filp, unsigned int cmd, if (error != FILE_LOCK_DEFERRED) break; error = wait_event_interruptible(fl->fl_wait, !fl->fl_blocker); - if (!error) - continue; - - locks_delete_block(fl); - break; + if (error) + break; } + locks_delete_block(fl); return error; }