Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp9250689pxu; Mon, 28 Dec 2020 10:26:40 -0800 (PST) X-Google-Smtp-Source: ABdhPJz0H9qs7BP+O432krelq0ISH/HFAYofQlQSAgFTEQnTGk5GKwyQTNyyB6DSxiBHrJPSVwMn X-Received: by 2002:a17:906:d62:: with SMTP id s2mr42677824ejh.61.1609180000487; Mon, 28 Dec 2020 10:26:40 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1609180000; cv=none; d=google.com; s=arc-20160816; b=qbB4zRDLZeGxk5PH4+m1IbjFaeYajDtYxk9J4seIGjiMFi5FWsNsBsrT6lLJWEc8wZ caT3zj7cdXJklcjtggY0WywvrFXnrx0YX/TDYa13VoM5nldsxNwZJMqPkys3zLbK1SUA BhPP5Z+/VgvHSh5xaGySX7o77WZresaQ+nsztdo8seGov06E3uIFkk4WLW5r/G/4G2gL ngmi/KlPXPbiXIT3AizgGoXisErSDnkzow1CC2wmxmuB2jLNzjkbPfD0atimoIyHEw4Z pgnYtORPtzCYOq9OkT209wfsUd8ENdRR/T9rGHeou1oBrcAkXRvmvNgKffN3T5IUOZDz 1k1g== 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=LI2gCiAoBkxif/q39J2nFGBxo2cjvpB+v1uy7W5pVa8=; b=gukUldsJ6aBHqI8xzLR7iaRxCyif/D/gwVGDajwGptQQioVD2oZfPqGFjklOtobBAK A5ADLSkzybk9qK6V8aqV9HEZe0OO0UtePJR2nalEZlnfDQqMHCSMPYK7i56b1Jk3pO+9 9SbyPXCyBndXVuVuBNTIP+sdyfuTK8jPKCvwQemK8bI46CHoGFE46scYnoqIzamZe14a dTouX+8xZ8qd5iaM3EI9gPYztFJ2d+yb5QB6Z4n13GF5c7FE9Ec0P/gCmcDZ9jMVIXkI nw4rjB4ULkztLq9Xnfuh5d5zqhoKz8ITe7VL5xBmqQwj10sxNxvOfIAag2VuBFDCLUMN pjlA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=AseL3nCy; 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 c6si5711928ejb.666.2020.12.28.10.26.18; Mon, 28 Dec 2020 10:26:40 -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=AseL3nCy; 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 S2391017AbgL1NcU (ORCPT + 99 others); Mon, 28 Dec 2020 08:32:20 -0500 Received: from mail.kernel.org ([198.145.29.99]:59522 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390904AbgL1Nbk (ORCPT ); Mon, 28 Dec 2020 08:31:40 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id 34AF622582; Mon, 28 Dec 2020 13:31:24 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1609162284; bh=pgPDyJjVhjtYio3T+0gwUvG97Ch/mcpMPCIIM3a5YkE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=AseL3nCykohNHZcm+w/zkw80JQgqWrSodfUtLD8GI/Bdi8BiDIP3fCkgTUSsgDtSk oyiAV88TWX9Snhr5uYm4DtInoEqWnub6ZbSYO7/G7ubKGgOYydOTaE5HT2OpxrHn2/ YM61m1HwZTOpmHNa2k9lw/JbZdsBoVn0958QrvRc= 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.19 220/346] nfs_common: need lock during iterate through the list Date: Mon, 28 Dec 2020 13:48:59 +0100 Message-Id: <20201228124930.417711089@linuxfoundation.org> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20201228124919.745526410@linuxfoundation.org> References: <20201228124919.745526410@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 5be08f02a76bc..4f90c444907f5 100644 --- a/fs/nfs_common/grace.c +++ b/fs/nfs_common/grace.c @@ -68,10 +68,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