Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp1284296ybv; Thu, 13 Feb 2020 19:59:14 -0800 (PST) X-Google-Smtp-Source: APXvYqzY1DpYf/tQSxsvFZgjTJrTyn6azmgRB3IH5Av0EdoXqamSWnQXo7Rf7N0kO+JcAuGbsHPj X-Received: by 2002:aca:fd94:: with SMTP id b142mr569406oii.11.1581652753896; Thu, 13 Feb 2020 19:59:13 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581652753; cv=none; d=google.com; s=arc-20160816; b=M36rgD5C9FLVGcCdQvw5X7PhwgWfgzolz2axRUN7lRvkRXMyOw9IZTAobDVGh8N6hy 870fgYBF4H+Z60rzNY9Qg7A2Lj9yraQgIqcpf5/wnoQVkHUlnrGVWTTug06a4lk+3RU+ 0YSgvvlMJZiSPJ16rr0ViUJAcqHiAXp+lWVBE72dTtHjQ3GweV0Vu9JqWV/jWOD9DqQN Ku1oCYSIswF8fA5KPIerCzojRTGXm/yf8a+6+KBoumIupw5dIaZ7kl4RH1Gdi561hVTE OiM2X1SOatZuYTtWuImYMK6yBWuCmco+N5mq+CmleHoyIRBCP2jCn2LTRIBW1G4ye61k eOSw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=GPXubr/quinVzIw7tgJ4F1V0vEAFblhURPf0OlN8qLA=; b=B6VoPkDRQzyrCZfnN+Ee1Y03F+k1YSYzAwt3gDwsTEOXVhUPp/GYLc5gL/GsqZ2Etl jf5n9+gJ/tn3KPdZ4jpZxa5Lu9JjJthVYxVrcGU8fVrnCFvCPA3Qz8CtMagAOim/ipU1 eKhF0mvz1iYmv932S+c3eszHql5zFeMvt4usLW+b2RwNwpxwyQWSvrppXdBwy4U3gcBj 5vbSFLKLBHbJKo51Tu9lhOpKTbmWqmfPjbfqtjJkjJkFNC942CiOs0WiC6XAgXV+OH0Q vnWhm5E8Bn7q2QAkyterMirh+liqe7Qyg0y/1Mbe3FKLWagao2tJyxyiZhb26mwCGlX9 mrmA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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 vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w207si2010890oia.226.2020.02.13.19.59.00; Thu, 13 Feb 2020 19:59:13 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728479AbgBND6v (ORCPT + 99 others); Thu, 13 Feb 2020 22:58:51 -0500 Received: from out30-130.freemail.mail.aliyun.com ([115.124.30.130]:45830 "EHLO out30-130.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728242AbgBND6v (ORCPT ); Thu, 13 Feb 2020 22:58:51 -0500 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R741e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e04400;MF=yang.shi@linux.alibaba.com;NM=1;PH=DS;RN=5;SR=0;TI=SMTPD_---0TpwAdAy_1581652722; Received: from US-143344MP.local(mailfrom:yang.shi@linux.alibaba.com fp:SMTPD_---0TpwAdAy_1581652722) by smtp.aliyun-inc.com(127.0.0.1); Fri, 14 Feb 2020 11:58:44 +0800 Subject: Re: [PATCH] mm: migrate.c: migrate PG_readahead flag To: Andrew Morton Cc: willy@infradead.org, mhocko@suse.com, linux-mm@kvack.org, linux-kernel@vger.kernel.org References: <1581640185-95731-1-git-send-email-yang.shi@linux.alibaba.com> <20200213185511.4660aca17553562d764dc7ea@linux-foundation.org> From: Yang Shi Message-ID: Date: Thu, 13 Feb 2020 19:58:40 -0800 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.12; rv:52.0) Gecko/20100101 Thunderbird/52.7.0 MIME-Version: 1.0 In-Reply-To: <20200213185511.4660aca17553562d764dc7ea@linux-foundation.org> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2/13/20 6:55 PM, Andrew Morton wrote: > On Fri, 14 Feb 2020 08:29:45 +0800 Yang Shi wrote: > >> Currently migration code doesn't migrate PG_readahead flag. >> Theoretically this would incur slight performance loss as the >> application might have to ramp its readahead back up again. Even though >> such problem happens, it might be hidden by something else since >> migration is typically triggered by compaction and NUMA balancing, any >> of which should be more noticeable. >> >> Migrate the flag after end_page_writeback() since it may clear >> PG_reclaim flag, which is the same bit as PG_readahead, for the new >> page. >> >> --- a/mm/migrate.c >> +++ b/mm/migrate.c >> @@ -647,6 +647,14 @@ void migrate_page_states(struct page *newpage, struct page *page) >> if (PageWriteback(newpage)) >> end_page_writeback(newpage); >> >> + /* >> + * PG_readahead share the same bit with PG_reclaim, the above >> + * end_page_writeback() may clear PG_readahead mistakenly, so set >> + * the bit after that. >> + */ >> + if (PageReadahead(page)) >> + SetPageReadahead(newpage); >> + >> copy_page_owner(page, newpage); >> > Why not The newpage may not have writeback set, migrating readahead flag should not depend on it. > > if (PageWriteback(newpage)) { > end_page_writeback(newpage); > /* > * PG_readahead share the same bit with PG_reclaim, the above > * end_page_writeback() may clear PG_readahead mistakenly, so > * set the bit after that. > */ > if (PageReadahead(page)) > SetPageReadahead(newpage); > } > > ?