Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp1727076ybz; Sat, 18 Apr 2020 07:16:02 -0700 (PDT) X-Google-Smtp-Source: APiQypLSUoW7hwc9RlV0wd75OVD4rtMtxutT1xhdNC1ZVE99bVKN1EG8JQMdj2EoAeQfm/aWLMj+ X-Received: by 2002:a05:6402:b17:: with SMTP id bm23mr7506785edb.137.1587219362394; Sat, 18 Apr 2020 07:16:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587219362; cv=none; d=google.com; s=arc-20160816; b=hWG76K2hrXuH47414aKQDSISt4xS7JjYo+CxwGV+4ss1xh+z3JmkAqL40tTpE2nj7/ yA+ckgnIUzst0fXA1YlfaxkiAf2k9IpCDGIvcjU3PEhiZ5/vm9Y5zDogftle6kDRR1tl JGKAcXDOGKbdvGBIrVFAGEolKRm/OX1nc4Rme81I4ULB7s82y+ElAZy9J8dCFa4dFvPA GDhD7SIZ6V1jKVEdM/d9MmIPfKRYD7TjdeD2bUlvmqRO5t4zcO1YQE6vPWJoo+0Vg97s YPwnwtlyGnQUDY40HuAcR0HSA6jBNiHYdfEwXXR3XD2fYWHySQpY2yv80Tet8TObBYTJ K4jQ== 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=Nu574buBxwYd9MUtqfHq6Q+Cembi9D2wOU9GvRQfXdg=; b=j7RniwenPNN4ethX+LAeNpkbK4sh7pLFTXcKModDUWoC7J4gjRBA0QoSKWU2TA/XSU /kGQkVzo77q7aA6xOuWBqTtUGBcfEKpN7Y2sVsqknEWkNWWgmf8xIQseDvgvxDUdhzaJ 3mq3JrhEExmtBx8IYxR0egwPJDanV4tPuhBbbTacRNcvWp5Fbmd2Y4jPugJfLJtBxVip Ww9zUSJoeMyZ5zBZRx2XLjU7o8FXG2SUhdCPX6Ujg2BQ3XG7fw86AZ4cZq4K4o3FELdf 8xJAHa1WYUwr9/g2E5kM3jnGzCD1CrC2q1cuVuJLvbe8yF4Z387PdLZ19rP8CW3EHd5j KaVg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=pO7ODp7B; 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 v5si16074635ejh.81.2020.04.18.07.15.40; Sat, 18 Apr 2020 07:16:02 -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=pO7ODp7B; 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 S1726500AbgDROJe (ORCPT + 99 others); Sat, 18 Apr 2020 10:09:34 -0400 Received: from mail.kernel.org ([198.145.29.99]:36904 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726423AbgDROJ1 (ORCPT ); Sat, 18 Apr 2020 10:09:27 -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 B452622260; Sat, 18 Apr 2020 14:09:26 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1587218967; bh=vGj7oOkI4QUVbkPo0BS/gOiD5NfqXixQjx5CszSFFjA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=pO7ODp7BhxpTt86YkB4Mbdqr+Rg0AmwR6dqTaWjzrZypEm4qnylRWk1uJTFjCAG6V ZpPaihzHQg9NvGyb5Z4TFP5xUSJTl77W0mhflxdAJENXzzfbkkd1ONvO5n1AK0idK7 Eh5vKvCyThjy0lw0omhXR30TffDJUJVnKpSBgatc= 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 5.5 14/75] ceph: don't skip updating wanted caps when cap is stale Date: Sat, 18 Apr 2020 10:08:09 -0400 Message-Id: <20200418140910.8280-14-sashal@kernel.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200418140910.8280-1-sashal@kernel.org> References: <20200418140910.8280-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 9d09bb53c1ab4..a02f7970b6e85 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