Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp4475433ybz; Tue, 28 Apr 2020 11:56:42 -0700 (PDT) X-Google-Smtp-Source: APiQypL6o/Dsi/uI+5HQhifcwlsjHGvPCqkwC4gXpCFt0cGsgPA+3U+VW1tq9GHmF9BWRO+XTuJm X-Received: by 2002:aa7:c608:: with SMTP id h8mr24627634edq.232.1588100202751; Tue, 28 Apr 2020 11:56:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588100202; cv=none; d=google.com; s=arc-20160816; b=jAw4vcqgUhjkjLxlc5GmGgAQ3EqdwH+8VW0TCxmlwR5XR8cXM3vvUHNQGZsCY7yM1H 17KuThaqADB8n6nDDbi2blXzF3phIV9h/ycOrn//4/Ihlij125WyoPKpPX7DaZ38HaHh rJLY/Bz6G87VnpbMikx5UmqXuTWYmPd8WV4BN8RYccJBohkcLBV2rlRdcb8PK0ZMl8ea QdpjQ3z9KS5VdGu1MhpW/0uoCna5HZcgcxT8vxg/vpGCiNoZBpey4yTEQkdfs/Brf+FR dPdvQ1v3ZmWiet+BIb7XCBgOaS4jILPp2zMX6ARcqYFNQDP0Bm6ruw1mea4YQBuFU3IE hleQ== 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:date:subject:cc:to :from:dkim-signature; bh=B7tnGqVe8QAxTNHxSQflkt20uUc2DH0hbseq8OEpE+Q=; b=HRgOm1iMU+ok/uezFUlGvUYyW4RhXvYOm1fAIBlpJ8WqIduMJc823rb5TI/IWdADyJ fAtsrpCyY803O41w7R0ZZKguTnfYlHAMfa+kwBMjjnZsb/jAkiOmevEaw9wq8xrHMbck TIedMwA9145/ZkwAwR4sCwVjILpau0dRJwbz0UKr+BEiQZ/QSosuocgJ48RoEHvhUh7n VUWQyTj1FDoywmFQmYcFuLZtIUKu2enSRocbXA0GWtgN5HpHQUZBhX+KgaLRSWDMDsYh r2BdWGCnalM5qX4dEsLDj2KzYaOjOLbuwSC7MTSFY0PlvzTldG/oAlvlp37kKOGwQCxr gGow== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=MafLwsse; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id 34si2069856edc.238.2020.04.28.11.56.19; Tue, 28 Apr 2020 11:56:42 -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=MafLwsse; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730669AbgD1SzF (ORCPT + 99 others); Tue, 28 Apr 2020 14:55:05 -0400 Received: from mail.kernel.org ([198.145.29.99]:49406 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729894AbgD1SdF (ORCPT ); Tue, 28 Apr 2020 14:33:05 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 26B21217D8; Tue, 28 Apr 2020 18:33:05 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1588098785; bh=8guGU9y+ILvrWFEO3RhZZta5otVc4xMe8XB8SCTkjCc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=MafLwsseu5ebtdKzatlKCJAM1PNMR9Nff8YB/+4btekXQMKRjYusEF2A1wWRjqSzk /54cFepM5xW2MUbgesU5404zs0CpkzqOUcUqN5bq3wNkoQPmGR46OBparqUaoBUb3Z dBn97ppzA3vq13/72yI7MmhXwvo9FUEHa4/k9lSw= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, "Yan, Zheng" , Jeff Layton , Ilya Dryomov , Sasha Levin Subject: [PATCH 5.4 015/168] ceph: dont skip updating wanted caps when cap is stale Date: Tue, 28 Apr 2020 20:23:09 +0200 Message-Id: <20200428182233.626844888@linuxfoundation.org> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200428182231.704304409@linuxfoundation.org> References: <20200428182231.704304409@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 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 f5a38910a82bf..703945cce0e5d 100644 --- a/fs/ceph/caps.c +++ b/fs/ceph/caps.c @@ -1976,8 +1976,12 @@ retry_locked: } /* 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