Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp1008507pxa; Wed, 19 Aug 2020 23:20:05 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxv8Q79rtPQDUtHRUXFgtl7Tm8GKli55xVwiCpvbJmps7n1VHIapYV2+qMjd183gAKlBPyO X-Received: by 2002:a50:9316:: with SMTP id m22mr1527909eda.178.1597904405116; Wed, 19 Aug 2020 23:20:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1597904405; cv=none; d=google.com; s=arc-20160816; b=F2LmI41UEazs1LHteHkaKbeelA1ovAGgzNQs1ewkzcIvM/qdBPxrPMecl/eKTHgPAM oWVYt6bP7MHLJkgcLp8tv/ytEZGEViL7hmalz6BsSZ0W1KBPjuMSE48sBnyvir3egGDh xUv69enen7rsTyTNF5Mdezr2v6PE1jOobe49yaOBREzn3PLBAxWevJjOBHPDE/9iye/W BX4G+PT+G1oCQNFB24wl5iCBeqzM3m5zkrkvcmNC7rFVbTRnDqfRKn2slZIFTYMvR7yg hlTXwp8GBN37ofVJPQ5dBg4hU7w39stEpdw5/RCFkTOBk9WgcCwrbRiBlgJTGGmvCoqP Nytg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date; bh=YjMdVun/eas6gUDs3zqV4Ue+06rOB5Veg+5sbr9lX+M=; b=WxIwAXPdFQP410e9rfA22oh7Rg6K4qrVryBhPij34J/xF1Iydn4wiWURVfmyUxeGMr cnasX82/HrgkWcxymoPEubkk1/jCRfv9xMi3iue0Xv9tsq2saONP+qRsMndHAlXvW3t4 RzquxGd0t1bt3Gl/+pp+j0I7qK3wna8gGRQsIztQx50pqyMI86Qov0rI3vvYj9fWxBvs 8VuSewfZZQhWu31EY8JWHPvzY19o/koXVwYQHUHkdlc3CphXj9gjLrfwn8Kom2WPr9xg W+Yh+U4SNA50bckET0xFZTzca+jvioRiSdP8RED6JKBD0OTQGlJzUsY7auHPBzgE2Hpx s9yA== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s10si649470ejd.553.2020.08.19.23.19.40; Wed, 19 Aug 2020 23:20:05 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1725797AbgHTGSe (ORCPT + 99 others); Thu, 20 Aug 2020 02:18:34 -0400 Received: from mx2.suse.de ([195.135.220.15]:60524 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725768AbgHTGSe (ORCPT ); Thu, 20 Aug 2020 02:18:34 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.221.27]) by mx2.suse.de (Postfix) with ESMTP id C6C16B585; Thu, 20 Aug 2020 06:18:58 +0000 (UTC) Date: Thu, 20 Aug 2020 08:18:27 +0200 From: Michal Hocko To: Yu Zhao Cc: Andrew Morton , Alexander Duyck , Huang Ying , David Hildenbrand , Yang Shi , Qian Cai , Mel Gorman , Nicholas Piggin , =?iso-8859-1?B?Suly9G1l?= Glisse , Hugh Dickins , linux-mm@kvack.org, linux-kernel@vger.kernel.org, Joonsoo Kim Subject: Re: [PATCH v2 3/3] mm: remove superfluous __ClearPageWaiters() Message-ID: <20200820061652.GX5422@dhcp22.suse.cz> References: <20200818184704.3625199-1-yuzhao@google.com> <20200818184704.3625199-3-yuzhao@google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200818184704.3625199-3-yuzhao@google.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue 18-08-20 12:47:04, Yu Zhao wrote: > Presumably __ClearPageWaiters() was added to follow the previously > removed __ClearPageActive() pattern. I do not think so. Please have a look at 62906027091f ("mm: add PageWaiters indicating tasks are waiting for a page bit") and a discussion when the patch has been proposed. Sorry I do not have a link handy but I do remember that the handling was quite subtle. > Only flags that are in PAGE_FLAGS_CHECK_AT_FREE needs to be properly > cleared because otherwise we think there may be some kind of leak. > PG_waiters is not one of those flags and leaving the clearing to > PAGE_FLAGS_CHECK_AT_PREP is more appropriate. What is the point of this patch in the first place? Page waiters is quite subtle and I wouldn't touch it without having a very good reason. > Signed-off-by: Yu Zhao > --- > include/linux/page-flags.h | 2 +- > mm/filemap.c | 2 ++ > mm/memremap.c | 2 -- > mm/swap.c | 3 --- > 4 files changed, 3 insertions(+), 6 deletions(-) > > diff --git a/include/linux/page-flags.h b/include/linux/page-flags.h > index 6be1aa559b1e..dba80a2bdfba 100644 > --- a/include/linux/page-flags.h > +++ b/include/linux/page-flags.h > @@ -318,7 +318,7 @@ static inline int TestClearPage##uname(struct page *page) { return 0; } > TESTSETFLAG_FALSE(uname) TESTCLEARFLAG_FALSE(uname) > > __PAGEFLAG(Locked, locked, PF_NO_TAIL) > -PAGEFLAG(Waiters, waiters, PF_ONLY_HEAD) __CLEARPAGEFLAG(Waiters, waiters, PF_ONLY_HEAD) > +PAGEFLAG(Waiters, waiters, PF_ONLY_HEAD) > PAGEFLAG(Error, error, PF_NO_TAIL) TESTCLEARFLAG(Error, error, PF_NO_TAIL) > PAGEFLAG(Referenced, referenced, PF_HEAD) > TESTCLEARFLAG(Referenced, referenced, PF_HEAD) > diff --git a/mm/filemap.c b/mm/filemap.c > index 1aaea26556cc..75240c7ef73f 100644 > --- a/mm/filemap.c > +++ b/mm/filemap.c > @@ -1079,6 +1079,8 @@ static void wake_up_page_bit(struct page *page, int bit_nr) > * other pages on it. > * > * That's okay, it's a rare case. The next waker will clear it. > + * Otherwise the bit will be cleared by PAGE_FLAGS_CHECK_AT_PREP > + * when the page is being freed. > */ > } > spin_unlock_irqrestore(&q->lock, flags); > diff --git a/mm/memremap.c b/mm/memremap.c > index 3a06eb91cb59..a9d02ffaf9e3 100644 > --- a/mm/memremap.c > +++ b/mm/memremap.c > @@ -451,8 +451,6 @@ void free_devmap_managed_page(struct page *page) > return; > } > > - __ClearPageWaiters(page); > - > mem_cgroup_uncharge(page); > > /* > diff --git a/mm/swap.c b/mm/swap.c > index 999a84dbe12c..40bf20a75278 100644 > --- a/mm/swap.c > +++ b/mm/swap.c > @@ -90,7 +90,6 @@ static void __page_cache_release(struct page *page) > del_page_from_lru_list(page, lruvec, page_off_lru(page)); > spin_unlock_irqrestore(&pgdat->lru_lock, flags); > } > - __ClearPageWaiters(page); > } > > static void __put_single_page(struct page *page) > @@ -900,8 +899,6 @@ void release_pages(struct page **pages, int nr) > del_page_from_lru_list(page, lruvec, page_off_lru(page)); > } > > - __ClearPageWaiters(page); > - > list_add(&page->lru, &pages_to_free); > } > if (locked_pgdat) > -- > 2.28.0.220.ged08abb693-goog > -- Michal Hocko SUSE Labs