Received: by 2002:a05:7412:31a9:b0:e2:908c:2ebd with SMTP id et41csp4454832rdb; Fri, 15 Sep 2023 02:47:08 -0700 (PDT) X-Google-Smtp-Source: AGHT+IEwL2TZRxUxlMt4WPDgpHwtZ2M6PiBsKRIpmup7E38vdHvx6CJ4/7k5Q+b3DiUxUEX0HN7G X-Received: by 2002:a05:6870:3906:b0:1d5:b2ba:bc93 with SMTP id b6-20020a056870390600b001d5b2babc93mr1395691oap.13.1694771228264; Fri, 15 Sep 2023 02:47:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1694771228; cv=none; d=google.com; s=arc-20160816; b=BiQGXyQG1Uxt5r+nRgHcGEcU+IyCXEJUZ41PYQQbNphdJhJL47iJOz37KkPqSO3dsn ZGuNUDDFmPi1JUHOHywocAApeGyL5aOYHAakBB1fP6GGGJdiRRNKRyyZN5lkZG7yOR+b w2Tg9E+rtEadmwvLeaAoHEs80uczbADUSKEUIEYweyPl2QiPr9UikpHt6NPO9cVh4mRU gM7MOOSoo//VbHYDGO+SnnIFAhNj8accsWKfBi1kA+SWqDlxDTn+/MeXnKWBtuq2FRK3 A7BX5IpsL83h6R/ACKEKrMXD8hOpvLfe32mh6itrsbjFYmNUGtnQMIs7MId/q2lQfHi9 02Hg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:subject:user-agent:mime-version:date:message-id; bh=ryJX4mCnDrhdpwid1dvScIUvBz+OA+XQGYdwpw/kAoE=; fh=YbLNOljfUMTdWY469T85obdJIn7wgRfnEO8M+ekBj60=; b=ku7EorR0aNB94UYDYai54r+G7dYD6DOqYouGPcl+8jzvJIVStCCcJYenoYvZ6j1tR6 r2zeTZ6VBatpV+Nxzqxh88+e+EeFo4q75BbjJyeceedKZKLMyWYrEbm/tMzi8ijt6LPE uBR26sTewBFLd+D+ePgS8Zc8N2eRTa5eRyJ/yXcwOfOUHs4NLzd/3qQYejGcjyM3YlwS VcG9Ux4MfXrHshUCLl9CcPQErImlxl0cs2ovNMxVymEe15xYGddvWxXTyzsZ5D2e+7Kh Ln+RoYLrYh3g1XiupNRw60nnP5gqkNgRoC7KW3FNNNRKRlVH0aaMt2dMGyjnqSdFqJHf cvqg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.31 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from morse.vger.email (morse.vger.email. [23.128.96.31]) by mx.google.com with ESMTPS id k3-20020a6568c3000000b0056f8fdb4430si3020613pgt.893.2023.09.15.02.47.07 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 15 Sep 2023 02:47:08 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.31 as permitted sender) client-ip=23.128.96.31; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.31 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by morse.vger.email (Postfix) with ESMTP id C2DA080DB4EF; Fri, 15 Sep 2023 02:43:43 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at morse.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233734AbjIOJnm (ORCPT + 99 others); Fri, 15 Sep 2023 05:43:42 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45374 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233117AbjIOJnl (ORCPT ); Fri, 15 Sep 2023 05:43:41 -0400 Received: from out30-101.freemail.mail.aliyun.com (out30-101.freemail.mail.aliyun.com [115.124.30.101]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 6A27130E0 for ; Fri, 15 Sep 2023 02:41:43 -0700 (PDT) X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R101e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=ay29a033018046050;MF=baolin.wang@linux.alibaba.com;NM=1;PH=DS;RN=17;SR=0;TI=SMTPD_---0Vs6lww._1694770898; Received: from 30.97.48.69(mailfrom:baolin.wang@linux.alibaba.com fp:SMTPD_---0Vs6lww._1694770898) by smtp.aliyun-inc.com; Fri, 15 Sep 2023 17:41:39 +0800 Message-ID: Date: Fri, 15 Sep 2023 17:41:45 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:102.0) Gecko/20100101 Thunderbird/102.15.0 Subject: Re: [RFC PATCH 4/4] mm/compaction: enable compacting >0 order folios. To: Zi Yan , linux-mm@kvack.org, linux-kernel@vger.kernel.org Cc: Ryan Roberts , Andrew Morton , "Matthew Wilcox (Oracle)" , David Hildenbrand , "Yin, Fengwei" , Yu Zhao , Vlastimil Babka , Johannes Weiner , Kemeng Shi , Mel Gorman , Rohan Puri , Mcgrof Chamberlain , Adam Manzanares , John Hubbard References: <20230912162815.440749-1-zi.yan@sent.com> <20230912162815.440749-5-zi.yan@sent.com> From: Baolin Wang In-Reply-To: <20230912162815.440749-5-zi.yan@sent.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-2.2 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,NICE_REPLY_A,SPF_HELO_NONE,SPF_PASS, UNPARSEABLE_RELAY autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on morse.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (morse.vger.email [0.0.0.0]); Fri, 15 Sep 2023 02:43:43 -0700 (PDT) On 9/13/2023 12:28 AM, Zi Yan wrote: > From: Zi Yan > > Since compaction code can compact >0 order folios, enable it during the > process. > > Signed-off-by: Zi Yan > --- > mm/compaction.c | 25 ++++++++++--------------- > 1 file changed, 10 insertions(+), 15 deletions(-) > > diff --git a/mm/compaction.c b/mm/compaction.c > index 4300d877b824..f72af74094de 100644 > --- a/mm/compaction.c > +++ b/mm/compaction.c > @@ -1087,11 +1087,17 @@ isolate_migratepages_block(struct compact_control *cc, unsigned long low_pfn, > if (PageCompound(page) && !cc->alloc_contig) { > const unsigned int order = compound_order(page); > > - if (likely(order <= MAX_ORDER)) { > - low_pfn += (1UL << order) - 1; > - nr_scanned += (1UL << order) - 1; > + /* > + * Compacting > pageblock_order pages does not improve > + * memory fragmentation. Also skip hugetlbfs pages. > + */ > + if (likely(order >= pageblock_order) || PageHuge(page)) { IMO, if the compound page order is larger than the requested cc->order, we should also fail the isolation, cause it also does not improve fragmentation, right? > + if (order <= MAX_ORDER) { > + low_pfn += (1UL << order) - 1; > + nr_scanned += (1UL << order) - 1; > + } > + goto isolate_fail; > } > - goto isolate_fail; > } > > /* > @@ -1214,17 +1220,6 @@ isolate_migratepages_block(struct compact_control *cc, unsigned long low_pfn, > goto isolate_abort; > } > } > - > - /* > - * folio become large since the non-locked check, > - * and it's on LRU. > - */ > - if (unlikely(folio_test_large(folio) && !cc->alloc_contig)) > - low_pfn += folio_nr_pages(folio) - 1; > - nr_scanned += folio_nr_pages(folio) - 1; > - folio_set_lru(folio); > - goto isolate_fail_put; > - } I do not think you can remove this validation, since previous validation is lockless. So under the lock, we need re-check if the compound page order is larger than pageblock_order or cc->order, that need fail to isolate. > } > > /* The folio is taken off the LRU */