From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-3.6 required=3.0 tests=DKIM_INVALID,DKIM_SIGNED, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI,SPF_HELO_NONE, SPF_PASS autolearn=no autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id C6E0FC352A4 for ; Wed, 12 Feb 2020 18:28:55 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id 8AF9620714 for ; Wed, 12 Feb 2020 18:28:55 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=fail reason="signature verification failed" (2048-bit key) header.d=infradead.org header.i=@infradead.org header.b="RmgrHctQ" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 8AF9620714 Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=infradead.org Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=owner-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix) id 23E9E6B048B; Wed, 12 Feb 2020 13:28:55 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 1EEED6B048D; Wed, 12 Feb 2020 13:28:55 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 0DEFE6B048E; Wed, 12 Feb 2020 13:28:55 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0215.hostedemail.com [216.40.44.215]) by kanga.kvack.org (Postfix) with ESMTP id EACE76B048B for ; Wed, 12 Feb 2020 13:28:54 -0500 (EST) Received: from smtpin01.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay02.hostedemail.com (Postfix) with ESMTP id A3D74442B for ; Wed, 12 Feb 2020 18:28:54 +0000 (UTC) X-FDA: 76482311388.01.smell82_138a40c5f6c53 X-HE-Tag: smell82_138a40c5f6c53 X-Filterd-Recvd-Size: 3770 Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) by imf35.hostedemail.com (Postfix) with ESMTP for ; Wed, 12 Feb 2020 18:28:54 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20170209; h=In-Reply-To:Content-Type:MIME-Version :References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description; bh=fiNTQReZCzf5ki8UYp8YB655RFJQRv4FxAcgm3ILX0E=; b=RmgrHctQbwrh8Lc+P+PsTV6h86 Wt8LzgxQUJAa+pRJNwMUjfeXLGKLjrKcj8cifXoiBqcXyyd9TeSTuMLnO5esIVqWGiiuVkBtMnnK1 0EneixQ2IE91dH7HMlub64wkcZs5RLSgJ0VFC6080stpAmmtnq2wPXSPgn/6s8YVnRNuCadYCAFTh ugTrY67xV1duRfOnCNScwnj/rcGL9FnbLAOqcXF7r7oRZDl/I89XC31w3vmcVTPlyRwNA77l6J3uR w6/74p0x74Q71bVEilT4ySQ8gTumNNXdgo/wX800NCmW+wmQsY8m3PPmB9yZr33obTxk13ypPLTPN Fv7bfZ+g==; Received: from willy by bombadil.infradead.org with local (Exim 4.92.3 #3 (Red Hat Linux)) id 1j1wkl-0001AR-8g; Wed, 12 Feb 2020 18:28:51 +0000 Date: Wed, 12 Feb 2020 10:28:51 -0800 From: Matthew Wilcox To: Minchan Kim Cc: Jan Kara , Andrew Morton , linux-mm , Josef Bacik , Johannes Weiner , LKML Subject: Re: [PATCH] mm: fix long time stall from mm_populate Message-ID: <20200212182851.GG7778@bombadil.infradead.org> References: <20200211011021.GP8731@bombadil.infradead.org> <20200211035004.GA242563@google.com> <20200211035412.GR8731@bombadil.infradead.org> <20200211042536.GB242563@google.com> <20200211122323.GS8731@bombadil.infradead.org> <20200211163404.GC242563@google.com> <20200211172803.GA7778@bombadil.infradead.org> <20200211175731.GA185752@google.com> <20200212101804.GD25573@quack2.suse.cz> <20200212174015.GB93795@google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200212174015.GB93795@google.com> X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: On Wed, Feb 12, 2020 at 09:40:15AM -0800, Minchan Kim wrote: > How about this? > > diff --git a/include/linux/page-flags.h b/include/linux/page-flags.h > index 1bf83c8fcaa7..d07d602476df 100644 > --- a/include/linux/page-flags.h > +++ b/include/linux/page-flags.h > @@ -363,8 +363,28 @@ PAGEFLAG(MappedToDisk, mappedtodisk, PF_NO_TAIL) > /* PG_readahead is only used for reads; PG_reclaim is only for writes */ > PAGEFLAG(Reclaim, reclaim, PF_NO_TAIL) > TESTCLEARFLAG(Reclaim, reclaim, PF_NO_TAIL) > -PAGEFLAG(Readahead, reclaim, PF_NO_COMPOUND) > - TESTCLEARFLAG(Readahead, reclaim, PF_NO_COMPOUND) > + > +SETPAGEFLAG(Readahead, reclaim, PF_NO_COMPOUND) > +CLEARPAGEFLAG(Readahead, reclaim, PF_NO_COMPOUND) > + > +/* > + * Since PG_readahead is shared with PG_reclaim of the page flags, > + * PageReadahead should double check whether it's readahead marker > + * or PG_reclaim. It could be done by PageWriteback check because > + * PG_reclaim is always with PG_writeback. > + */ > +static inline int PageReadahead(struct page *page) > +{ > + VM_BUG_ON_PGFLAGS(PageCompound(page), page); > + return test_bit(PG_reclaim, &(page)->flags) && !PageWriteback(page); Why not ... return page->flags & (1UL << PG_reclaim | 1UL << PG_writeback) == (1UL << PG_reclaim); > +static inline int TestClearPageReadahead(struct page *page) > +{ > + VM_BUG_ON_PGFLAGS(PageCompound(page), page); > + > + return test_and_clear_bit(PG_reclaim, &page->flags) && !PageWriteback(page); That's definitely wrong. It'll clear PageReclaim and then pretend it did nothing wrong. return !PageWriteback(page) || test_and_clear_bit(PG_reclaim, &page->flags);