Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp614640ybl; Fri, 24 Jan 2020 06:28:54 -0800 (PST) X-Google-Smtp-Source: APXvYqz3nyvm3+I+3xa59o13tzn9jpuWOjMh/GCEXU3MKVD6+roRep5t9W6Gq+Ec7VPJ1taKwPiL X-Received: by 2002:aca:4c4f:: with SMTP id z76mr2191699oia.21.1579876134807; Fri, 24 Jan 2020 06:28:54 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579876134; cv=none; d=google.com; s=arc-20160816; b=Qao9SpP1e+efQoUIgxXfV7AftplWwDoz5x0It/aDjFTypmFemAgbu5aShp3WAXB6Nz dm/lKb9tKo+02iolJBAmqbHY4OJK19ejQ68RWPB4aagWWY2Yefllmey1xCflQjQ10N65 BX0cVWFGD4l3ax+d0U+O5/63z+IYFHS2ViuPJzIoBf/myNRT5cnkm684K/ngjJ0YQHWt g5cwzai4YSo6a1DL4LNrqg6H5IOMV1c9Ll8Jw7bHgO87RDHRgnYtUIs7IWVpSKOhBeqM vNcWFqBfH6nZXVOIJkvRaSrJpPqa7eEuRUkzTvtZdCLioZ8kZSMSW7/epRcCBFtIEJHR HFdQ== 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=MeQ2PE5gvUcmT0k9IrTbqt/TM5464Xy9jw4LEEx0DME=; b=Vo8a8tjqc56OixwsXDNQDHMhxwdOK6wlOxFgx3H64RexFqZsj+XlzmEwYqtRm+B2Oa LMmeufqZLXvz9mcaxg7odtC/g+dS3qPnkGtl8IP5G/1ZxywaCWDYFHs7AjcNlUqlvQVY DMzPeKcCV8C5I87yBIyhlbWj6TWogwPvX0Xz4agl0xLxhqVZVaGWyAeWB5zwnMTkEM04 SHBMNwAQn0hwphCKyHVIh91rzVN2yFVImpsySDHgDOEI74GL8vDJBp4wvOKVT6nGkc7v nmgfvczrQCecqByNdFOcAeyzur3WHpc9cRzFhcgXv4hpF70EjnATv/pBIuJBHrSVppHj Xdbg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=LVN6O3ee; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w6si2800217oti.4.2020.01.24.06.28.41; Fri, 24 Jan 2020 06:28:54 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=LVN6O3ee; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2390814AbgAXLVK (ORCPT + 99 others); Fri, 24 Jan 2020 06:21:10 -0500 Received: from mail.kernel.org ([198.145.29.99]:59100 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2391016AbgAXLVI (ORCPT ); Fri, 24 Jan 2020 06:21:08 -0500 Received: from localhost (ip-213-127-102-57.ip.prioritytelecom.net [213.127.102.57]) (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 EC1D8206D4; Fri, 24 Jan 2020 11:21:06 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1579864868; bh=JrqLKDLYLNi+x0503eUJhT4fVkYEoBvfduJguyc3OGg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=LVN6O3eeYnZnX7xu4rKezsF2/GBWxOoSUMhGPakra/Uz9hydakdrTY0K88Bv15Rh4 x2q3EkZmzGncdD0nGLBBBUF3JO2WaocLIpWhdbDWe4KifOagBDmq0Us4CXJjF/g4u0 pdqHiOl2i5Ar8XNs9q8LXTNU543tg7UueNdmRyss= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, David Howells , Sasha Levin Subject: [PATCH 4.19 376/639] afs: Dont invalidate callback if AFS_VNODE_DIR_VALID not set Date: Fri, 24 Jan 2020 10:29:06 +0100 Message-Id: <20200124093134.113405191@linuxfoundation.org> X-Mailer: git-send-email 2.25.0 In-Reply-To: <20200124093047.008739095@linuxfoundation.org> References: <20200124093047.008739095@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: David Howells [ Upstream commit d9052dda8a39069312218f913d22d99c48d90004 ] Don't invalidate the callback promise on a directory if the AFS_VNODE_DIR_VALID flag is not set (which indicates that the directory contents are invalid, due to edit failure, callback break, page reclaim). The directory will be reloaded next time the directory is accessed, so clearing the callback flag at this point may race with a reload of the directory and cancel it's recorded callback promise. Fixes: f3ddee8dc4e2 ("afs: Fix directory handling") Signed-off-by: David Howells Signed-off-by: Sasha Levin --- fs/afs/inode.c | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/fs/afs/inode.c b/fs/afs/inode.c index 718fab2f151a1..e6f11da5461be 100644 --- a/fs/afs/inode.c +++ b/fs/afs/inode.c @@ -398,12 +398,9 @@ int afs_validate(struct afs_vnode *vnode, struct key *key) vnode->cb_s_break = vnode->cb_interest->server->cb_s_break; vnode->cb_v_break = vnode->volume->cb_v_break; valid = false; - } else if (vnode->status.type == AFS_FTYPE_DIR && - (!test_bit(AFS_VNODE_DIR_VALID, &vnode->flags) || - vnode->cb_expires_at - 10 <= now)) { + } else if (test_bit(AFS_VNODE_ZAP_DATA, &vnode->flags)) { valid = false; - } else if (test_bit(AFS_VNODE_ZAP_DATA, &vnode->flags) || - vnode->cb_expires_at - 10 <= now) { + } else if (vnode->cb_expires_at - 10 <= now) { valid = false; } else { valid = true; -- 2.20.1