Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp9181267pxu; Mon, 28 Dec 2020 08:36:04 -0800 (PST) X-Google-Smtp-Source: ABdhPJy08bBwQfYAx6Cz67GRj3hCCnIthD9xjMz8j6gEGup2qUDFhcMEhHckpn9P4BGyWZc7+Eu0 X-Received: by 2002:a17:907:2052:: with SMTP id pg18mr42872303ejb.153.1609173364791; Mon, 28 Dec 2020 08:36:04 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1609173364; cv=none; d=google.com; s=arc-20160816; b=Bj7OzDLCxG4oZveOVvLKRFYDCHwVCECxqPiiu4JOpxNu0qdllcL4FuC+M/3/GV1jZa d7rry1Txqjyf9FC2bd8l7ZwDLEPYJXL4WWPFXXeEAXVpgday2MIiqntHKEezldlEKdyV ZTMb9ODpNoe6/7uqQhu4zVvn55K8BIfnQ+TdqVhHWeyIkAmhoFcw6P4vH0xsivT0aIIB vjUU2slfvb0RKbNlNazbeZNrcYJ+kVqSWtwKe7YU3nFG4YX+YbhsPcGUqyYmrBMO7reC Hl3H3mAHr7EuU/g/VoC007Z4DFlOvuqGSqVwubKctaaGec+6ZFxumMr7xwy4t3Uoq4no 9nVw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=bwvs74EVwRl9OGHXUgn8/7umUh0pB1YsRj06s2xrHMo=; b=MTlSYMjkAAHGbxi/js2dtnnGXk38gqnJCVVleDRWVWkVc/6BhVfs97JVrmD1IPPl/0 ZcNN4dtUInv7R5y0yeSYyDbtpMmPuHntgRjaeSU2q9SjK3DNo4fmiWYAf1t6bvxqns1V IS1Rg/+ixegwqToH2G6DqNq2J658GDHYI+PUF+/KzbPOg8xWRc99JVY5HWfQlSGnz3AG 8xr1aBbsiGt0J17URZ3/rN5mhlUmftavEn7FiReK9lS2LYLowjf5jssPTUrqb9TrewHl l0LTzdVtApra99OiXnCMZYnf4zpnuFRofEBoq/iSHCLZpFqxcWOX5NDAM9dsNiT+C5Ph Wmjw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=rUtlvtat; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id t11si22489341edc.101.2020.12.28.08.35.40; Mon, 28 Dec 2020 08:36:04 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=rUtlvtat; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730314AbgL1Qde (ORCPT + 99 others); Mon, 28 Dec 2020 11:33:34 -0500 Received: from mail.kernel.org ([198.145.29.99]:59368 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730286AbgL1NDt (ORCPT ); Mon, 28 Dec 2020 08:03:49 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id E2E9722582; Mon, 28 Dec 2020 13:03:32 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1609160613; bh=owhsRuGIO55+9gnazWXkz4HofZ08rWMcjfMjujq6K8o=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=rUtlvtatFAgylhrr9HSjjJqnLRkiOz3LMg16VwP8w/wrM+HtqRBkfp5m8wD1H0R5u BM81gP+4y2f4jsWLNVcX/3resjd8szxOURi6nVw2rKgKm6dbgRTDXJ8sC7pcIZwZpT qVcxaYyCFAdWVWUqnR3RPYmvBUaN20tMhwG80V2I= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, =?UTF-8?q?=C2=A0Cheng=C2=A0Lin=C2=A0?= , =?UTF-8?q?=C2=A0Yi=C2=A0Wang=C2=A0?= , Chuck Lever , Sasha Levin Subject: [PATCH 4.9 110/175] nfs_common: need lock during iterate through the list Date: Mon, 28 Dec 2020 13:49:23 +0100 Message-Id: <20201228124858.583653141@linuxfoundation.org> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20201228124853.216621466@linuxfoundation.org> References: <20201228124853.216621466@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Cheng Lin [ Upstream commit 4a9d81caf841cd2c0ae36abec9c2963bf21d0284 ] If the elem is deleted during be iterated on it, the iteration process will fall into an endless loop. kernel: NMI watchdog: BUG: soft lockup - CPU#4 stuck for 22s! [nfsd:17137] PID: 17137  TASK: ffff8818d93c0000  CPU: 4   COMMAND: "nfsd"     [exception RIP: __state_in_grace+76]     RIP: ffffffffc00e817c  RSP: ffff8818d3aefc98  RFLAGS: 00000246     RAX: ffff881dc0c38298  RBX: ffffffff81b03580  RCX: ffff881dc02c9f50     RDX: ffff881e3fce8500  RSI: 0000000000000001  RDI: ffffffff81b03580     RBP: ffff8818d3aefca0   R8: 0000000000000020   R9: ffff8818d3aefd40     R10: ffff88017fc03800  R11: ffff8818e83933c0  R12: ffff8818d3aefd40     R13: 0000000000000000  R14: ffff8818e8391068  R15: ffff8818fa6e4000     CS: 0010  SS: 0018  #0 [ffff8818d3aefc98] opens_in_grace at ffffffffc00e81e3 [grace]  #1 [ffff8818d3aefca8] nfs4_preprocess_stateid_op at ffffffffc02a3e6c [nfsd]  #2 [ffff8818d3aefd18] nfsd4_write at ffffffffc028ed5b [nfsd]  #3 [ffff8818d3aefd80] nfsd4_proc_compound at ffffffffc0290a0d [nfsd]  #4 [ffff8818d3aefdd0] nfsd_dispatch at ffffffffc027b800 [nfsd]  #5 [ffff8818d3aefe08] svc_process_common at ffffffffc02017f3 [sunrpc]  #6 [ffff8818d3aefe70] svc_process at ffffffffc0201ce3 [sunrpc]  #7 [ffff8818d3aefe98] nfsd at ffffffffc027b117 [nfsd]  #8 [ffff8818d3aefec8] kthread at ffffffff810b88c1  #9 [ffff8818d3aeff50] ret_from_fork at ffffffff816d1607 The troublemake elem: crash> lock_manager ffff881dc0c38298 struct lock_manager {   list = {     next = 0xffff881dc0c38298,     prev = 0xffff881dc0c38298   },   block_opens = false } Fixes: c87fb4a378f9 ("lockd: NLM grace period shouldn't block NFSv4 opens") Signed-off-by: Cheng Lin  Signed-off-by: Yi Wang  Signed-off-by: Chuck Lever Signed-off-by: Sasha Levin --- fs/nfs_common/grace.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/fs/nfs_common/grace.c b/fs/nfs_common/grace.c index 77d136ac89099..c21fca0dcba74 100644 --- a/fs/nfs_common/grace.c +++ b/fs/nfs_common/grace.c @@ -75,10 +75,14 @@ __state_in_grace(struct net *net, bool open) if (!open) return !list_empty(grace_list); + spin_lock(&grace_lock); list_for_each_entry(lm, grace_list, list) { - if (lm->block_opens) + if (lm->block_opens) { + spin_unlock(&grace_lock); return true; + } } + spin_unlock(&grace_lock); return false; } -- 2.27.0