Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp1759684ybz; Sat, 18 Apr 2020 07:55:53 -0700 (PDT) X-Google-Smtp-Source: APiQypI2vZghuT0LS4RTn5Ogrb88acznzaPv2uEY91OIfc6mQFi9yuUqaSH4fEWo2WL5h6ZAyJ9U X-Received: by 2002:a50:cf05:: with SMTP id c5mr7435597edk.330.1587221752974; Sat, 18 Apr 2020 07:55:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587221752; cv=none; d=google.com; s=arc-20160816; b=k/BYFC0ZnBdroHknndejbJ0aEb5nhHGrNNkK02eK8OqcBGQmRxiJRLpDZE3eO+QFWM TRpoIDQSdBCzCd5j49+wIBLXnXgm2HtdGujMaIXohFEda4niwCD3pjs8IQqA1n1VOqlT ZlY102yYdCl4xohUfkLHHxfMP+FSVdJlmBnqfKZdL/ytVUU5sbayoxkD3nhQ/SbC8sBV g2BmPkhkZJO1VwME4ywcGHAgTxhCkq9uulPtJc7fAz2bZu+kbs4xHJB4NyMs73zl2mvJ 31DmGQEv6FF+T5KFSi3OXKwvWJgT+aDtRkeOmvF43BYJiHIX5WdkTLWrxz275JjZR6Xq awPQ== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=5q+a5cGcg1/6adUbMTj7fH/yCKQyGg4J9vYvRZ75+6A=; b=kJrrLNCBjgXT0DI8PYjYpTwlLld1vmq9/iKCwhiPL5E4jJpA6lDwT+Smh3LVtYYcq4 4S9X0At5LsTruZHZi1ow/LXhqUOuvHGSRylkOUULvTgCca7Ukg/ai1TAWkpqE0OQaAqT K2UpQa68HnSx3Kvoti37VdbcQZ/YgU5q/jN8+pS31IA68PrWADQ8CLX88bgtgqCf7w9p Q36LVRVYAhNVqkx+4K+HENLuDBBhOXFI3nBpP/jK/aIlmnSbT8Di0nwQ9MHvmEgGOlex wW+D51QZqrcZwM3qKojtLnY9mmDwPkltmOPglfYTIeHjRNZaDLDAOWNZali8L+NXm6lI W7Lw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=AXnxeqi2; 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id h14si13955805ejd.424.2020.04.18.07.55.30; Sat, 18 Apr 2020 07:55:52 -0700 (PDT) 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=@kernel.org header.s=default header.b=AXnxeqi2; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729061AbgDROvc (ORCPT + 99 others); Sat, 18 Apr 2020 10:51:32 -0400 Received: from mail.kernel.org ([198.145.29.99]:52818 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728388AbgDROmh (ORCPT ); Sat, 18 Apr 2020 10:42:37 -0400 Received: from sasha-vm.mshome.net (c-73-47-72-35.hsd1.nh.comcast.net [73.47.72.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id A5D9D22245; Sat, 18 Apr 2020 14:42:36 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1587220957; bh=lSpX98LlHpBgkq+KsmD2J8feAmxZfyFHyjH3hCAT2tg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=AXnxeqi27dTCI1sP8p2exFdrcFSCM2MBgEpf7q+XYMnyxCnDF8YInv1pcyvRqFZ3L vy23XeIx2TfPZ9wOoBMAAnRVcE0Hd6TUPItyoEToHxEL9w1C53Ab3A23e584zsXzqs SMSt+nltTILqzGHVKNjXx35DlSAkFRRVBmwLAhtg= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: "Yan, Zheng" , Jeff Layton , Ilya Dryomov , Sasha Levin , ceph-devel@vger.kernel.org Subject: [PATCH AUTOSEL 4.19 08/47] ceph: don't skip updating wanted caps when cap is stale Date: Sat, 18 Apr 2020 10:41:48 -0400 Message-Id: <20200418144227.9802-8-sashal@kernel.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200418144227.9802-1-sashal@kernel.org> References: <20200418144227.9802-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: "Yan, Zheng" [ Upstream commit 0aa971b6fd3f92afef6afe24ef78d9bb14471519 ] 1. try_get_cap_refs() fails to get caps and finds that mds_wanted does not include what it wants. It returns -ESTALE. 2. ceph_get_caps() calls ceph_renew_caps(). ceph_renew_caps() finds that inode has cap, so it calls ceph_check_caps(). 3. ceph_check_caps() finds that issued caps (without checking if it's stale) already includes caps wanted by open file, so it skips updating wanted caps. Above events can cause an infinite loop inside ceph_get_caps(). Signed-off-by: "Yan, Zheng" Reviewed-by: Jeff Layton Signed-off-by: Ilya Dryomov Signed-off-by: Sasha Levin --- fs/ceph/caps.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/fs/ceph/caps.c b/fs/ceph/caps.c index 4c0b220e20bab..5241102b81a82 100644 --- a/fs/ceph/caps.c +++ b/fs/ceph/caps.c @@ -1972,8 +1972,12 @@ void ceph_check_caps(struct ceph_inode_info *ci, int flags, } /* want more caps from mds? */ - if (want & ~(cap->mds_wanted | cap->issued)) - goto ack; + if (want & ~cap->mds_wanted) { + if (want & ~(cap->mds_wanted | cap->issued)) + goto ack; + if (!__cap_is_valid(cap)) + goto ack; + } /* things we might delay */ if ((cap->issued & ~retain) == 0 && -- 2.20.1