Received: by 2002:ac0:98c7:0:0:0:0:0 with SMTP id g7-v6csp1604167imd; Sun, 4 Nov 2018 06:09:57 -0800 (PST) X-Google-Smtp-Source: AJdET5eRA8P6Kk7dMfbSNVDmhCGaN2US7SaSx3d9Ny5Es3euZjaQBfIeKiB5bN8fmqpjV20wqeQr X-Received: by 2002:a17:902:28e7:: with SMTP id f94-v6mr18737054plb.297.1541340597673; Sun, 04 Nov 2018 06:09:57 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1541340597; cv=none; d=google.com; s=arc-20160816; b=T63ZnC9ENAvFv+Sfm6+9/ZJ2MDiALjKY27TBRP48mXIPc02gn0nzUIEzTUNrar7XiA 5ZPw4ea5ynLqHjoDW9HR2LVg5bvXbEdlIJtRRsHfBgQS5oY1Eq8rJcZeitQvSz5MVi16 tBCRG2V0e3gD/VFdgCa5v19bQWXE8NrGkKxjuegwN41huUn8YEAwLaAIGmNqyUZWZgYS 6M7ltPYWMI2mdDBGID5OyYZFwM73BBJiLjqM7d2F3ZL9ZIscnc4YrcZLH3d1IcKllGxV 8671TzS4LngO/p9p8SKU+o5VF/xCQ3jTzv1IqmjO3DmK7lc8fFi7B76zFO+yR9guRSdH 6nNA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature; bh=lYYfv6n2nF3gHC3xyzSlawdDD1qw2lhIl2WFMV3Ad/w=; b=t8aSjCdM5IbJCQiuBHo1xjZl6p5B+NRjBqxphlG4tdYP5LI4cCSDOQCwIpbFlZPcZn CBQXrI4Jm/Q4yzNul5KavE/OGJ62FfBCURfGiJP6qSYJ/s9mzhAsiGpdk6omPMPP/1Gg GUX0pHt/2UfDJUTsOHGOwDHMapX8BvrZBZJVzx4xGIeNYYAPmdjZPTIHCWUOQRyJsdjH /F0ftafldwqPTHoujU00UFTEKu9SMihZBf5lg1N8g3meW3fCl1YJ9paFeguWb1owfdDi pMdcOv9BoF2b6Wcnb8TMQ+Mb0sClbGXl4o5rFvNuKTj+mODRQX01mj7PBVJGhNj7YAO/ gQGA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=r83HQcNd; 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=pass (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 o19-v6si18805307pgb.196.2018.11.04.06.09.42; Sun, 04 Nov 2018 06:09:57 -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; dkim=pass header.i=@kernel.org header.s=default header.b=r83HQcNd; 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=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729944AbeKDXHA (ORCPT + 99 others); Sun, 4 Nov 2018 18:07:00 -0500 Received: from mail.kernel.org ([198.145.29.99]:44136 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729898AbeKDXG7 (ORCPT ); Sun, 4 Nov 2018 18:06:59 -0500 Received: from sasha-vm.mshome.net (c-73-47-72-35.hsd1.nh.comcast.net [73.47.72.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id F367A20866; Sun, 4 Nov 2018 13:51:53 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1541339515; bh=goa8PjvyKggqGIrvQvtX0YWGuJPLnQBHobPpvTN8qtA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=r83HQcNdZdo0kktZ8DQBL2OPYN7c54t5FFWRuv/kWNGpOdazzmK9PQmugbknEt904 MnYbmg0vA+uwl9rxxppqcck+jJWCq6GRjsA0dwu5NpTC2iMt2/pby+AjW20cqDHPb1 UsWLvSN1LjAOt7VTJkE/gVj2YqOdzrzQihgShh2c= From: Sasha Levin To: stable@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Roman Gushchin , Johannes Weiner , Michal Hocko , Tejun Heo , Rik van Riel , Konstantin Khlebnikov , Matthew Wilcox , Andrew Morton , Linus Torvalds , Sasha Levin Subject: [PATCH AUTOSEL 4.19 07/57] mm: don't miss the last page because of round-off error Date: Sun, 4 Nov 2018 08:50:54 -0500 Message-Id: <20181104135144.88324-7-sashal@kernel.org> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20181104135144.88324-1-sashal@kernel.org> References: <20181104135144.88324-1-sashal@kernel.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Roman Gushchin [ Upstream commit 68600f623d69da428c6163275f97ca126e1a8ec5 ] I've noticed, that dying memory cgroups are often pinned in memory by a single pagecache page. Even under moderate memory pressure they sometimes stayed in such state for a long time. That looked strange. My investigation showed that the problem is caused by applying the LRU pressure balancing math: scan = div64_u64(scan * fraction[lru], denominator), where denominator = fraction[anon] + fraction[file] + 1. Because fraction[lru] is always less than denominator, if the initial scan size is 1, the result is always 0. This means the last page is not scanned and has no chances to be reclaimed. Fix this by rounding up the result of the division. In practice this change significantly improves the speed of dying cgroups reclaim. [guro@fb.com: prevent double calculation of DIV64_U64_ROUND_UP() arguments] Link: http://lkml.kernel.org/r/20180829213311.GA13501@castle Link: http://lkml.kernel.org/r/20180827162621.30187-3-guro@fb.com Signed-off-by: Roman Gushchin Reviewed-by: Andrew Morton Cc: Johannes Weiner Cc: Michal Hocko Cc: Tejun Heo Cc: Rik van Riel Cc: Konstantin Khlebnikov Cc: Matthew Wilcox Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds Signed-off-by: Sasha Levin --- include/linux/math64.h | 3 +++ mm/vmscan.c | 6 ++++-- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/include/linux/math64.h b/include/linux/math64.h index 837f2f2d1d34..bb2c84afb80c 100644 --- a/include/linux/math64.h +++ b/include/linux/math64.h @@ -281,4 +281,7 @@ static inline u64 mul_u64_u32_div(u64 a, u32 mul, u32 divisor) } #endif /* mul_u64_u32_div */ +#define DIV64_U64_ROUND_UP(ll, d) \ + ({ u64 _tmp = (d); div64_u64((ll) + _tmp - 1, _tmp); }) + #endif /* _LINUX_MATH64_H */ diff --git a/mm/vmscan.c b/mm/vmscan.c index c5ef7240cbcb..961401c46334 100644 --- a/mm/vmscan.c +++ b/mm/vmscan.c @@ -2456,9 +2456,11 @@ static void get_scan_count(struct lruvec *lruvec, struct mem_cgroup *memcg, /* * Scan types proportional to swappiness and * their relative recent reclaim efficiency. + * Make sure we don't miss the last page + * because of a round-off error. */ - scan = div64_u64(scan * fraction[file], - denominator); + scan = DIV64_U64_ROUND_UP(scan * fraction[file], + denominator); break; case SCAN_FILE: case SCAN_ANON: -- 2.17.1