From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail-wm0-f70.google.com (mail-wm0-f70.google.com [74.125.82.70]) by kanga.kvack.org (Postfix) with ESMTP id 40F186B0005 for ; Fri, 22 Jul 2016 05:30:15 -0400 (EDT) Received: by mail-wm0-f70.google.com with SMTP id o80so30157626wme.1 for ; Fri, 22 Jul 2016 02:30:15 -0700 (PDT) Received: from mx2.suse.de (mx2.suse.de. [195.135.220.15]) by mx.google.com with ESMTPS id b22si9211938wmb.32.2016.07.22.02.30.14 for (version=TLS1 cipher=AES128-SHA bits=128/128); Fri, 22 Jul 2016 02:30:14 -0700 (PDT) Subject: Re: mm/compact: why use low watermark to determine whether compact is finished instead of use high watermark? References: <5791DFD4.5080207@huawei.com> <0b580155-d99a-f4a4-ef76-6166b41180aa@suse.cz> <5791E5B1.8060503@huawei.com> From: Vlastimil Babka Message-ID: <90c27726-945f-be2c-4df8-3e7162838583@suse.cz> Date: Fri, 22 Jul 2016 11:30:12 +0200 MIME-Version: 1.0 In-Reply-To: <5791E5B1.8060503@huawei.com> Content-Type: text/plain; charset=windows-1252; format=flowed Content-Transfer-Encoding: 7bit Sender: owner-linux-mm@kvack.org List-ID: To: Xishi Qiu Cc: "mel@csn.ul.ie" , David Rientjes , Joonsoo Kim , Mel Gorman , Linux MM , LKML On 07/22/2016 11:21 AM, Xishi Qiu wrote: > On 2016/7/22 17:04, Vlastimil Babka wrote: > >> On 07/22/2016 10:56 AM, Xishi Qiu wrote: >>> Hi, >>> >>> I find all the watermarks in mm/compaction.c are low_wmark_pages(), >>> so why not use high watermark to determine whether compact is finished? >> >> Why would you use high watermark? Quite the opposite, I want to move towards min watermark (precisely, the one in alloc_flags which is usually min) in this series: >> >> https://lkml.org/lkml/2016/6/24/222 >> >> especially: >> >> https://lkml.org/lkml/2016/6/24/214 >> >>> e.g. >>> __alloc_pages_nodemask() >>> get_page_from_freelist() >>> this is fast path, use use low_wmark_pages() in __zone_watermark_ok() >>> >>> __alloc_pages_slowpath() >>> this is slow path, usually use min_wmark_pages() >> >> Yes, and compaction should be finished when allocation can succeed, so match __alloc_pages_slowpath(). >> > > Sounds reasonable, but now we have kcompactd which called from kswapd, > so still use low wmark? kswapd uses high watermark (order-0) to make a buffer of free pages for both direct allocators and kcompactd. kcompactd will use min watermark for now. There used to be difference between min/low/high watermarks when checking high-orders, but now watermark only affects the check if there's enough total base pages, and high-order check then succeeds if there's at least one high(er)-order page. > Thanks, > Xishi Qiu > >>> >>> kswapd >>> balance_pgdat() >>> use high_wmark_pages() to determine whether zone is balanced >>> >>> Thanks, >>> Xishi Qiu >>> >> >> >> . >> > > > -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: email@kvack.org