Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp831808pxb; Tue, 3 Nov 2020 13:49:39 -0800 (PST) X-Google-Smtp-Source: ABdhPJyA3u7M6Zh3gnnvD67KYdz6ZeKDUbBIrlVxXvMvV/LGUQGpt+GIX05all6IqWoJzTSQ2aml X-Received: by 2002:a17:906:66d2:: with SMTP id k18mr21324229ejp.113.1604440178841; Tue, 03 Nov 2020 13:49:38 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604440178; cv=none; d=google.com; s=arc-20160816; b=IQvYQnz0VuWdudBU/C69V7RDDnovAnZJ/OKtPdyCVSyVN3E6Xk3H7KgoWBZlabbcUN A/y2ofnZUQ9wVdvA1xRk70CsA1UT54og4nzezhDPA/S4lBZuNoVgJ9zNPBbcUrt4I7q6 vhaAta+CMv5NOb3rkLG0+1YCeIkIhXMBYk8poHrEbTruHFM15j/Nn8HRVM9guB/PJ+sn PFGMLn31pbJks7w5VQudPhaJ0uyTiLOCo2874mgWpySn2QB9NzLRBYBLycI5G9hkdvpn aXWB9NVpSx5NpgF9CioK4+luohAFgJpMeRZWiZL6E4JSPTOOX0YBQMxKAY7XeJYar6aw Pt6g== 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=1F1rhEg7bfIqCBVIiywP9tcXRTyggbOLxMn5W+sabqg=; b=fymzKOC0wauCeBgj4ePAHJrZJdg+uu+6QC4q5ukT+5sJXS+9O0HaSrvu1ILTYaq3zM Fne47zCsAVWoVwV2dQt/5itD5lsyYI4qMAI2eu8wnuaxziwnPfjTeqgzxKihU6+2BAYp Tu89FvnihtqUvDukNOn4VL/YySDB9maC+LIckLFRgibGCselKZxx+uUO0FQzWeZt5vkJ Nbe3Qg4v8viZOnmMs/Fz/naqk5ZHezJv55OQlK1/v3qWXczZlaQ6MaRzpU7I58rbYWdG HpjlNAc+TbmHzDkSCmm3PeHEXL09bi/bfdXmU+kPyB00Dps8VOrsoDo1T9LYk045Rgcf FD4A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=DLoijzkt; 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=fail (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 w25si4912863edl.217.2020.11.03.13.49.16; Tue, 03 Nov 2020 13:49:38 -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=@kernel.org header.s=default header.b=DLoijzkt; 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=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731990AbgKCUvm (ORCPT + 99 others); Tue, 3 Nov 2020 15:51:42 -0500 Received: from mail.kernel.org ([198.145.29.99]:47080 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731979AbgKCUvj (ORCPT ); Tue, 3 Nov 2020 15:51:39 -0500 Received: from localhost (83-86-74-64.cable.dynamic.v4.ziggo.nl [83.86.74.64]) (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 BFB1D20719; Tue, 3 Nov 2020 20:51:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1604436699; bh=WO/ScDgnIcLpusW7IfzMoFEU6c2HkLknbh+ilnrtuzo=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=DLoijzkt9AxhEWNhXObaPh//PL5qAdmVh3jtnGezPE//3e8GadSrkpscKjXFtd4W0 fGJKGX3yKjScnOg+8n/pif6qROPzFFJGXaIqE3H56UBwc37zRyVhzjc72vho5CJ1Um O6kI0Foixoi/wKBzqLonoGK2ng7t+yQEgJ605zcw= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, "Matthew Wilcox (Oracle)" , David Howells , Linus Torvalds Subject: [PATCH 5.9 364/391] cachefiles: Handle readpage error correctly Date: Tue, 3 Nov 2020 21:36:55 +0100 Message-Id: <20201103203411.707063589@linuxfoundation.org> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20201103203348.153465465@linuxfoundation.org> References: <20201103203348.153465465@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: Matthew Wilcox (Oracle) commit 9480b4e75b7108ee68ecf5bc6b4bd68e8031c521 upstream. If ->readpage returns an error, it has already unlocked the page. Fixes: 5e929b33c393 ("CacheFiles: Handle truncate unlocking the page we're reading") Cc: stable@vger.kernel.org Signed-off-by: Matthew Wilcox (Oracle) Signed-off-by: David Howells Signed-off-by: Linus Torvalds Signed-off-by: Greg Kroah-Hartman --- fs/cachefiles/rdwr.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) --- a/fs/cachefiles/rdwr.c +++ b/fs/cachefiles/rdwr.c @@ -121,7 +121,7 @@ static int cachefiles_read_reissue(struc _debug("reissue read"); ret = bmapping->a_ops->readpage(NULL, backpage); if (ret < 0) - goto unlock_discard; + goto discard; } /* but the page may have been read before the monitor was installed, so @@ -138,6 +138,7 @@ static int cachefiles_read_reissue(struc unlock_discard: unlock_page(backpage); +discard: spin_lock_irq(&object->work_lock); list_del(&monitor->op_link); spin_unlock_irq(&object->work_lock);