Received: by 2002:a05:6a10:9e8c:0:0:0:0 with SMTP id y12csp227432pxx; Wed, 28 Oct 2020 03:25:38 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxFRjKMr2d7FuwpzMl99ERBBLQR9bKaW7FO9dllffLhUfiQNATjbJ642ez74C1tIuVHc9nN X-Received: by 2002:a05:6402:1bc9:: with SMTP id ch9mr7130871edb.386.1603880738128; Wed, 28 Oct 2020 03:25:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603880738; cv=none; d=google.com; s=arc-20160816; b=SKI8yNuWV7nv3gLAxNaQyGkoB2HxgoGbVbFPivGr6aKjIt2at4NVz9S5CGT/NUeMgY idK+vfvin2iFONAzbzUxJMJPe+NG3BJ84r9x6930WoxeCbLBTk2FRpGiClgQCKRunTzC Pli1og3H9J4WtzlV4SXCcl1TcawfoMDaHa31gv1P2znXZ81I5RHMRPQm4Khj0a8L3BkP grUGXIohqMOawKKHuDIl6VSZvgAs8nZckYlU2EtOmGAjxWr5XWTt+FIqLLjbw1oieHgo yWHEbSPGW8y8OEjqGI5QHUARNCnlAoBGR36LdCldZZzmx0T+KlS858TF1PDYCHDc8OXi ppbA== 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=SEJXGHkx91dgIJzvrddT8hpvbhj0eGgadSwDyKZjjrs=; b=YHSsMckbXO++aR4zxCSakf56+9ieBWocZq4DsJwL2CuVO9o+JRLs396WkMo4FmaThE 1smeVfaOEIOELXveHN8zIezS06M2UAwbSxdD7AGwYll5mh84qZ1+2czE1l511LcBtcpG oI2hUtAMyag1qwrRpkzySyUSpBtZriBMFZhI15gK/FNFjSQTmr+iTrGA6ZalLPPwMMLa eaVaz3D0h6RolWAtEknoULRR5g7eL5rBOVpaOMyLTtbXd7keSTTRxrz7CeLk5fkOneZ/ NGVhBCz+PZ9zS908X8wXso0TlzyPA09EAI2I32/UKm+PW8vv95IwU4ZvnAn/JGTkNkN0 6jPQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="ry7ok/rR"; 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 i19si2816688ejh.153.2020.10.28.03.25.15; Wed, 28 Oct 2020 03:25:38 -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="ry7ok/rR"; 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 S1761359AbgJ0OjF (ORCPT + 99 others); Tue, 27 Oct 2020 10:39:05 -0400 Received: from mail.kernel.org ([198.145.29.99]:38332 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1749963AbgJ0OjC (ORCPT ); Tue, 27 Oct 2020 10:39:02 -0400 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 BC4B0206B2; Tue, 27 Oct 2020 14:39:00 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1603809541; bh=5E/dz+y9kKxoogTzPYly+g0+uDIvBT/3ejMgCfqNrCk=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=ry7ok/rRmcd8u3vlICDuM+/PrO6kBZKZ+7Us/M5mSUHpB8bfW5QLxi7j6XaqSgUyb OJTXlTcRCeaF3oKp7xZvYhpOcn4EWMvN1vMmcTZDBKBN1eQJ2nSDNookPL5xFmG6YO ZJlwXDGvUGvHZoUC8Ez/z44Hb1/Fu2rTevFYGV44= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, "Darrick J. Wong" , Chandan Babu R , Sasha Levin Subject: [PATCH 5.4 215/408] xfs: fix high key handling in the rt allocators query_range function Date: Tue, 27 Oct 2020 14:52:33 +0100 Message-Id: <20201027135505.066990273@linuxfoundation.org> X-Mailer: git-send-email 2.29.1 In-Reply-To: <20201027135455.027547757@linuxfoundation.org> References: <20201027135455.027547757@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: Darrick J. Wong [ Upstream commit d88850bd5516a77c6f727e8b6cefb64e0cc929c7 ] Fix some off-by-one errors in xfs_rtalloc_query_range. The highest key in the realtime bitmap is always one less than the number of rt extents, which means that the key clamp at the start of the function is wrong. The 4th argument to xfs_rtfind_forw is the highest rt extent that we want to probe, which means that passing 1 less than the high key is wrong. Finally, drop the rem variable that controls the loop because we can compare the iteration point (rtstart) against the high key directly. The sordid history of this function is that the original commit (fb3c3) incorrectly passed (high_rec->ar_startblock - 1) as the 'limit' parameter to xfs_rtfind_forw. This was wrong because the "high key" is supposed to be the largest key for which the caller wants result rows, not the key for the first row that could possibly be outside the range that the caller wants to see. A subsequent attempt (8ad56) to strengthen the parameter checking added incorrect clamping of the parameters to the number of rt blocks in the system (despite the bitmap functions all taking units of rt extents) to avoid querying ranges past the end of rt bitmap file but failed to fix the incorrect _rtfind_forw parameter. The original _rtfind_forw parameter error then survived the conversion of the startblock and blockcount fields to rt extents (a0e5c), and the most recent off-by-one fix (a3a37) thought it was patching a problem when the end of the rt volume is not in use, but none of these fixes actually solved the original problem that the author was confused about the "limit" argument to xfs_rtfind_forw. Sadly, all four of these patches were written by this author and even his own usage of this function and rt testing were inadequate to get this fixed quickly. Original-problem: fb3c3de2f65c ("xfs: add a couple of queries to iterate free extents in the rtbitmap") Not-fixed-by: 8ad560d2565e ("xfs: strengthen rtalloc query range checks") Not-fixed-by: a0e5c435babd ("xfs: fix xfs_rtalloc_rec units") Fixes: a3a374bf1889 ("xfs: fix off-by-one error in xfs_rtalloc_query_range") Signed-off-by: Darrick J. Wong Reviewed-by: Chandan Babu R Signed-off-by: Sasha Levin --- fs/xfs/libxfs/xfs_rtbitmap.c | 11 ++++------- 1 file changed, 4 insertions(+), 7 deletions(-) diff --git a/fs/xfs/libxfs/xfs_rtbitmap.c b/fs/xfs/libxfs/xfs_rtbitmap.c index 8ea1efc97b41d..42085e70c01ac 100644 --- a/fs/xfs/libxfs/xfs_rtbitmap.c +++ b/fs/xfs/libxfs/xfs_rtbitmap.c @@ -1018,7 +1018,6 @@ xfs_rtalloc_query_range( struct xfs_mount *mp = tp->t_mountp; xfs_rtblock_t rtstart; xfs_rtblock_t rtend; - xfs_rtblock_t rem; int is_free; int error = 0; @@ -1027,13 +1026,12 @@ xfs_rtalloc_query_range( if (low_rec->ar_startext >= mp->m_sb.sb_rextents || low_rec->ar_startext == high_rec->ar_startext) return 0; - if (high_rec->ar_startext > mp->m_sb.sb_rextents) - high_rec->ar_startext = mp->m_sb.sb_rextents; + high_rec->ar_startext = min(high_rec->ar_startext, + mp->m_sb.sb_rextents - 1); /* Iterate the bitmap, looking for discrepancies. */ rtstart = low_rec->ar_startext; - rem = high_rec->ar_startext - rtstart; - while (rem) { + while (rtstart <= high_rec->ar_startext) { /* Is the first block free? */ error = xfs_rtcheck_range(mp, tp, rtstart, 1, 1, &rtend, &is_free); @@ -1042,7 +1040,7 @@ xfs_rtalloc_query_range( /* How long does the extent go for? */ error = xfs_rtfind_forw(mp, tp, rtstart, - high_rec->ar_startext - 1, &rtend); + high_rec->ar_startext, &rtend); if (error) break; @@ -1055,7 +1053,6 @@ xfs_rtalloc_query_range( break; } - rem -= rtend - rtstart + 1; rtstart = rtend + 1; } -- 2.25.1