[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <22c64602-db2f-de36-ea54-5701f109368e@huawei.com>
Date: Thu, 4 Feb 2021 10:20:05 +0800
From: Miaohe Lin <linmiaohe@...wei.com>
To: Peter Xu <peterx@...hat.com>
CC: Wei Zhang <wzam@...zon.com>, Matthew Wilcox <willy@...radead.org>,
"Linus Torvalds" <torvalds@...ux-foundation.org>,
Jason Gunthorpe <jgg@...pe.ca>,
"Gal Pressman" <galpress@...zon.com>,
Christoph Hellwig <hch@....de>,
"Andrea Arcangeli" <aarcange@...hat.com>, Jan Kara <jack@...e.cz>,
Kirill Shutemov <kirill@...temov.name>,
David Gibson <david@...son.dropbear.id.au>,
"Mike Rapoport" <rppt@...ux.vnet.ibm.com>,
Mike Kravetz <mike.kravetz@...cle.com>,
Kirill Tkhai <ktkhai@...tuozzo.com>,
Jann Horn <jannh@...gle.com>,
"Andrew Morton" <akpm@...ux-foundation.org>,
<linux-kernel@...r.kernel.org>, Linux-MM <linux-mm@...ck.org>
Subject: Re: [PATCH 2/4] hugetlg: Break earlier in add_reservation_in_range()
when we can
Hi:
On 2021/2/4 5:08, Peter Xu wrote:
> All the regions maintained in hugetlb reserved map is inclusive on "from" but
> exclusive on "to". We can break earlier even if rg->from==t because it already
> means no possible intersection.
>
> This does not need a Fixes in all cases because when it happens (rg->from==t)
> we'll not break out of the loop while we should, however the next thing we'd do
> is still add the last file_region we'd need and quit the loop in the next
> round. So this change is not a bugfix (since the old code should still run
> okay iiuc), but we'd better still touch it up to make it logically sane.
>
I think the difference is when we handle the rg->from == t case. Previous one is in the loop, now below the
loop. But the result should be same.
Thanks.
Reviewed-by: Miaohe Lin <linmiaohe@...wei.com>
> Signed-off-by: Peter Xu <peterx@...hat.com>
> ---
> mm/hugetlb.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/mm/hugetlb.c b/mm/hugetlb.c
> index d2859c2aecc9..9e6ea96bf33b 100644
> --- a/mm/hugetlb.c
> +++ b/mm/hugetlb.c
> @@ -377,7 +377,7 @@ static long add_reservation_in_range(struct resv_map *resv, long f, long t,
> /* When we find a region that starts beyond our range, we've
> * finished.
> */
> - if (rg->from > t)
> + if (rg->from >= t)
> break;
>
> /* Add an entry for last_accounted_offset -> rg->from, and
>
Powered by blists - more mailing lists