Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp4927561yba; Mon, 13 May 2019 02:10:18 -0700 (PDT) X-Google-Smtp-Source: APXvYqwSzQitjI3SgqtVC/lVv1TYLNB15Oub4nAU8PlPjZCZ1RZb2WkfUuVpHL34yc1xQKYRNDwf X-Received: by 2002:a62:128a:: with SMTP id 10mr30953151pfs.225.1557738618318; Mon, 13 May 2019 02:10:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1557738618; cv=none; d=google.com; s=arc-20160816; b=BoD90U6AUSICs+0JO4d5fsR0Ppo8/Wb1ZhJnQKctvKfGScb9S360gL/OHoRyRzYIzq zfYAzhsGWer1jRFaohTJyNQjQLTGYxQoiJitQn8WESh/ZoDVmrqc/FjW5ArRKWQ+mT+w RdvlavS46g8fFs4Dx+GHyyG72n5mKzC87R+sorbgSNmeShnlFb7wXi5drwrqAmviT8f5 vHgns0KFTC8oO9GO/ONIKj4rzeqKuE1mPguAazQeylSYZf+9ZA9dJD1EujbIHwZ9U60h Gyjg56brqjBy08rpurgewfW6w2vXkPy5VNaxoKXH6XbZ/9G1Wipjpp2Hi8J+rf0fVyJM nmaA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=QB6GAhhsTuzw1SqdRHzIftQoSJ+6UduFS7YRtFpo+0Y=; b=bW/lMfN08JJDUDfexTBXTmmEJFMQMjCRMfTyd6wfPsDKjurBl8/EAeBS8g2mt4R5N4 LYLEHMIKlUkGo77DTBfUumC9XdAbXzkbjevU2BFSIcj+/ro/EkFBCVpPbcc3kBMSka1D 5F4uRoHZn0zxXmAN8nYYBAdeXxDhGl7y9NX0PY8LpcaDUCuyDdxQbSJx2pi8fJ5azGcj eCViSEIR7X6WCDEunTI7jQAqDkF7Tf8Z6hnVsNKj1qUl6uUk7vxgGkIuBIMY/WIF9yuz TwwysXlk+mcCAX/U0ZW32UfbcXWLUL27BcHxcH5K1exK9A2MvkcjXi38fvGeFZkSkPXs Sh+Q== 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p70si15282407pgp.450.2019.05.13.02.10.02; Mon, 13 May 2019 02:10:18 -0700 (PDT) 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727879AbfEMIJc (ORCPT + 99 others); Mon, 13 May 2019 04:09:32 -0400 Received: from mx2.suse.de ([195.135.220.15]:45696 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1725928AbfEMIJc (ORCPT ); Mon, 13 May 2019 04:09:32 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx1.suse.de (Postfix) with ESMTP id C4E52ADAB; Mon, 13 May 2019 08:09:30 +0000 (UTC) Date: Mon, 13 May 2019 10:09:29 +0200 From: Michal Hocko To: Yang Shi Cc: ying.huang@intel.com, hannes@cmpxchg.org, mgorman@techsingularity.net, kirill.shutemov@linux.intel.com, hughd@google.com, shakeelb@google.com, william.kucharski@oracle.com, akpm@linux-foundation.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: Re: [v2 PATCH] mm: vmscan: correct nr_reclaimed for THP Message-ID: <20190513080929.GC24036@dhcp22.suse.cz> References: <1557505420-21809-1-git-send-email-yang.shi@linux.alibaba.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1557505420-21809-1-git-send-email-yang.shi@linux.alibaba.com> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sat 11-05-19 00:23:40, Yang Shi wrote: > Since commit bd4c82c22c36 ("mm, THP, swap: delay splitting THP after > swapped out"), THP can be swapped out in a whole. But, nr_reclaimed > still gets inc'ed by one even though a whole THP (512 pages) gets > swapped out. > > This doesn't make too much sense to memory reclaim. For example, direct > reclaim may just need reclaim SWAP_CLUSTER_MAX pages, reclaiming one THP > could fulfill it. But, if nr_reclaimed is not increased correctly, > direct reclaim may just waste time to reclaim more pages, > SWAP_CLUSTER_MAX * 512 pages in worst case. You are technically right here. This has been a known issue for a while. I am wondering whether somebody actually noticed some misbehavior. Swapping out is a rare event and you have to have a considerable number of THPs to notice. > This change may result in more reclaimed pages than scanned pages showed > by /proc/vmstat since scanning one head page would reclaim 512 base pages. This is quite nasty and confusing. I am worried that having those two unsynced begs for subtle issues. Can we account THP as scanning 512 base pages as well? > Cc: "Huang, Ying" > Cc: Johannes Weiner > Cc: Michal Hocko > Cc: Mel Gorman > Cc: "Kirill A . Shutemov" > Cc: Hugh Dickins > Reviewed-by: Shakeel Butt > Signed-off-by: Yang Shi > --- > v2: Added Shakeel's Reviewed-by > Use hpage_nr_pages instead of compound_order per Huang Ying and William Kucharski > > mm/vmscan.c | 6 +++++- > 1 file changed, 5 insertions(+), 1 deletion(-) > > diff --git a/mm/vmscan.c b/mm/vmscan.c > index fd9de50..4226d6b 100644 > --- a/mm/vmscan.c > +++ b/mm/vmscan.c > @@ -1446,7 +1446,11 @@ static unsigned long shrink_page_list(struct list_head *page_list, > > unlock_page(page); > free_it: > - nr_reclaimed++; > + /* > + * THP may get swapped out in a whole, need account > + * all base pages. > + */ > + nr_reclaimed += hpage_nr_pages(page); > > /* > * Is there need to periodically free_page_list? It would > -- > 1.8.3.1 > -- Michal Hocko SUSE Labs