Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp9089484pxu; Mon, 28 Dec 2020 06:22:42 -0800 (PST) X-Google-Smtp-Source: ABdhPJwzLid31Gr5iFdm+QSaZk/MiRh8UXKTmav7+V9svb42N69b0ZgRzXbzIra6fffZKhc1/JP0 X-Received: by 2002:a17:906:971a:: with SMTP id k26mr42688313ejx.515.1609165362775; Mon, 28 Dec 2020 06:22:42 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1609165362; cv=none; d=google.com; s=arc-20160816; b=dvvR1X7aCxUWbL28jrZc6Y9tic5QHSohHslmAtWnRME53ry8kpjn3YVuC9SF3CKGVh qauUXvf4lrWXiNiXsO5pvkPdAW1GNmdP1i3h3vvZT36lQseMoqJYc3W9VY+w73UTFPN7 XK3qSDIWwDxLJDsaWVfCQKkcXjra1pdZ6pDgLFxUNFabmyn0XhWe6Z3bd+j3RG/657GU cKqwUB06mpiwTfTJYZWxioxyrO/05Z/PDBGUyp0B0fZ5HajiCYctVORXL4rw5YAuJUjX q1XgSeby/ieYbuD2D/RTROauqpdrf7lyQavU2EADiOsFwhrMB3DqgJf+N8PuU3baV9V+ uBYQ== 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=Djg4kTqh64eXtqWq90SEiHFcpaSJTQEWl3h0eH9M6Tk=; b=K1vRNtcU7sRWRMIigL2MoAjsSRR9y8J68rYVXtK17gJN7xiab765dbp1OozvwIdr64 YX4E2362ycksxn7VFrN+7SJ6FPRcaHCrOy8NbjjBrYemTDZp1qFRMR1wl3NAsIny34MK Avb06ca9k24t4UFmY3X0eq42vcsYA93yl3cimFuRrKyjcygm/UIMtbR9k5CnTdUj0GBq Jbm8VaAwCcq05UgVAvU2Xw+ZXlay2E1K8b6QfE5fDLTbxWNHiX33/pPz2tpE7ZCFNzbj TMw+eZZbv9iM/ScJ1wophxNAfHH4qKYMueHZoX+/iZcRFD7PwOWkAzawXFiWbaZ9IQx6 EmLQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="U/Rcu9Ui"; 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 lx7si11843893ejb.280.2020.12.28.06.22.20; Mon, 28 Dec 2020 06:22:42 -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="U/Rcu9Ui"; 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 S2441515AbgL1ORy (ORCPT + 99 others); Mon, 28 Dec 2020 09:17:54 -0500 Received: from mail.kernel.org ([198.145.29.99]:52738 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2441511AbgL1ORv (ORCPT ); Mon, 28 Dec 2020 09:17:51 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id 6059A205CB; Mon, 28 Dec 2020 14:17:35 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1609165056; bh=x3l4fW3BSwnZ31oyFfPlfxoebzrzZsMzNpf79VmZLqA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=U/Rcu9Ui4VT5IPGW9eGWl/AULjYWxDj6LERFoAzAuV40QBGSOXI2+7jPxkKf8xYbA MYteevTzuDrsFPXoxTpXkVGJtZp+nXn7U7d53wYm4mSPWB/ugQCjSAfWvIjeWTsZMV hW58PhrGB0vI2j6z0ioF/8rHrJK7sx63ykEkznG8= 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 5.10 377/717] nfs_common: need lock during iterate through the list Date: Mon, 28 Dec 2020 13:46:15 +0100 Message-Id: <20201228125039.071099462@linuxfoundation.org> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20201228125020.963311703@linuxfoundation.org> References: <20201228125020.963311703@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 b73d9dd37f73c..26f2a50eceac9 100644 --- a/fs/nfs_common/grace.c +++ b/fs/nfs_common/grace.c @@ -69,10 +69,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