Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2730813pxj; Mon, 31 May 2021 09:17:48 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxANREjFYzwQBB1WtJ0tEpvOhk3n2U1PiSWkgPBSXTdYlNctoyxIyiZey7i6CFcN1l/vniD X-Received: by 2002:a92:d247:: with SMTP id v7mr8841746ilg.243.1622477868024; Mon, 31 May 2021 09:17:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1622477868; cv=none; d=google.com; s=arc-20160816; b=YN4bkQOERroHAIE2mmaNuYZ6fTbpMRRAE7I7rVZLyZqmH4osFGRQDitZUOABB5b6KV 4jU7ZCd8QEAtVGhnQY+nUV+zQIIq4YqXWalMjQkAeTgWIx0aA2Ic5avpzZicj831LaS9 ASYtmTD/k2gPcJ6qcDylNIUPjbeY7/LmfsfcmezKeHp6tTCedvABqgsKoZ5zDikRME4x wVsZ+Obm1tZ2sOB5OhvpxVcHwCBsOQc7dOKqGrdztA/vpSW3udvKN+mJKXiZ+r9MMn+b e2l1AwdcEPHHfX5xt0fT4HmiRnYpzPgw1S4+rmn/QY1Avg3OP/ynrJn7M4Qg4nn4ydyC g4HQ== 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=zp9W/ENsbI/3ay6HZvth6TaRJ1A3F7YXqjvJFT+eOU8=; b=c3d/1l+TDIkyplQNpkDyr78wfrb+Id80I5WVRK/qtF2J4Un3V9bzaBF/YcWKL5685V hDyQuz+1sdwqC7w/Ait5baFiSAdKepwnZZE4HLjzdkdPT2jYGzaymIPxGSJOQn0Q8Eh6 T0O66FNZYS19Ku/GAziAKdzNqSwylYwjNplJRneCDFqJqfdlGSN9b1BjQtmPlIioTVl0 Et49/iNA3n3JdevXmPCKAfoq0SI2dV3S27aYh0y7AzuXVEXSDhZSXK4oGRfi5k046Pkp wT/77gmiF9/vJKGzoADsSjqAOJvGe+roiB886LWtux7K0NiNveCztdZV7p99/uPEQElI n6JA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="xL/+YUBT"; 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=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f4si15528709ilq.138.2021.05.31.09.17.35; Mon, 31 May 2021 09:17:48 -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=@linuxfoundation.org header.s=korg header.b="xL/+YUBT"; 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=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233738AbhEaQSk (ORCPT + 99 others); Mon, 31 May 2021 12:18:40 -0400 Received: from mail.kernel.org ([198.145.29.99]:36490 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233805AbhEaOlh (ORCPT ); Mon, 31 May 2021 10:41:37 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 2332561883; Mon, 31 May 2021 13:53:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1622469219; bh=HvEV8rv5k3A5x5JzTug7RpZ58CxkXYwa9Jnzi+dxA0A=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=xL/+YUBTrhiSZkhiNHDOMsnwHpFNAe8Pc/T7m4mXIzTFS+QnRjLasz76fMfsXZr7V eYfs6ngoXyzhX1XhY+yUc0SDSh6QrBE084ELzaH2ZeBtWufoKaFA/TeLWkGSzQ1xP7 rISNHww6spopx7ANsCx4irRMe0qqI/99u9aiQTfE= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Trond Myklebust Subject: [PATCH 5.12 114/296] NFS: Fix an Oopsable condition in __nfs_pageio_add_request() Date: Mon, 31 May 2021 15:12:49 +0200 Message-Id: <20210531130707.760057979@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210531130703.762129381@linuxfoundation.org> References: <20210531130703.762129381@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: Trond Myklebust commit 56517ab958b7c11030e626250c00b9b1a24b41eb upstream. Ensure that nfs_pageio_error_cleanup() resets the mirror array contents, so that the structure reflects the fact that it is now empty. Also change the test in nfs_pageio_do_add_request() to be more robust by checking whether or not the list is empty rather than relying on the value of pg_count. Fixes: a7d42ddb3099 ("nfs: add mirroring support to pgio layer") Signed-off-by: Trond Myklebust Signed-off-by: Greg Kroah-Hartman --- fs/nfs/pagelist.c | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) --- a/fs/nfs/pagelist.c +++ b/fs/nfs/pagelist.c @@ -1094,15 +1094,16 @@ nfs_pageio_do_add_request(struct nfs_pag struct nfs_page *prev = NULL; unsigned int size; - if (mirror->pg_count != 0) { - prev = nfs_list_entry(mirror->pg_list.prev); - } else { + if (list_empty(&mirror->pg_list)) { if (desc->pg_ops->pg_init) desc->pg_ops->pg_init(desc, req); if (desc->pg_error < 0) return 0; mirror->pg_base = req->wb_pgbase; - } + mirror->pg_count = 0; + mirror->pg_recoalesce = 0; + } else + prev = nfs_list_entry(mirror->pg_list.prev); if (desc->pg_maxretrans && req->wb_nio > desc->pg_maxretrans) { if (NFS_SERVER(desc->pg_inode)->flags & NFS_MOUNT_SOFTERR)