Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp467886pxu; Tue, 5 Jan 2021 16:52:04 -0800 (PST) X-Google-Smtp-Source: ABdhPJzdhcJrPL5FVhJtDsA3zvH7tXVThep6LxDUZx3hMPZ7/WlI3BPFfpAJ9bKGzK+vVJsV4UuT X-Received: by 2002:aa7:d608:: with SMTP id c8mr2202066edr.260.1609894324360; Tue, 05 Jan 2021 16:52:04 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1609894324; cv=none; d=google.com; s=arc-20160816; b=IuI/nKEm0ZeGIUCM4H6usMvkS1lgwDOPoDxeg1oF1Uja0N6rVAT0s/rIlYaeR0s0vl SewcrgYpFNrTSua61KdSWyiwGeP9FxCvVdXpflt3zLn29jGlHltnW1FC3H7OEK9IlGzX 1B0rxXYnCsD/Q8ZukSua10viYtRFqeoGlZxgPnWWWTrvgvNaMavl66gysyrFKNWCwiyr Pc3DYLFJVstPQY2IvVLbLrHigh/MmJHFaOQo7oyiUrjH8IBGwi7ZFmIaDpVh1/NUgLyG UsnHE7qu0SdWqMsEV70x8HOUvlU1zvPW509owdaioEQJywIoHL3SwpWkr3ILh3i90F0Q 4yxA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dmarc-filter:sender :dkim-signature; bh=pzrh7dwncd17lj6KkzA6WwnlG1QsGgiLO7PzX4xZ938=; b=wDfz5nroZhxBI5wliDjbBRFIPaTyM6THwS8HBr8J2pZXUdtfLd3f2qeUWoc5mPPIn3 nGkCN0H5lNJ7z6CNdpkAb+8j+1Kje3vWSdHdAqF39Ro1u+WwRcquX3p7ISlP7Oy3eMg8 DYI6OkUc9wBYqQJ1pqGVwWKgvlwBjIopkusNqapAoBOubD9EAkyNvsEeixAH9Wr+MA/w JBPZEoDG2ir5nnGVZl8Ua8MrdQ2/NbFtHv0tSCZ3UXZ+zPZm3cuKKvkSwfXVapXzaH4Z UzWKORR9EpPobs1Rt0e7Ze5znsk9iDVNOn5SC8IJD832dPn3cy1OFUePFmd76/xStZQn 62BQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=ZLhdmIOt; 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 dd19si291206edb.502.2021.01.05.16.51.41; Tue, 05 Jan 2021 16:52:04 -0800 (PST) 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; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=ZLhdmIOt; 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 S1727396AbhAFAo1 (ORCPT + 99 others); Tue, 5 Jan 2021 19:44:27 -0500 Received: from so254-31.mailgun.net ([198.61.254.31]:16530 "EHLO so254-31.mailgun.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727394AbhAFAo1 (ORCPT ); Tue, 5 Jan 2021 19:44:27 -0500 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1609893847; h=Content-Transfer-Encoding: MIME-Version: Message-Id: Date: Subject: Cc: To: From: Sender; bh=pzrh7dwncd17lj6KkzA6WwnlG1QsGgiLO7PzX4xZ938=; b=ZLhdmIOtlE7atH24/czrHOWrU+EJq5Ktmdk43tACy2U3PlBgIP6dbVN2QC/R2h/MFWzBHCxA O/1fVzi3RJ6lhoWrkxIzAf5HBSmbe+VIIvl/j4Nqv6ca3AMtWkdZEkE4Acadbe6lz8cMqAQb HyN0XG5d9MnkbwcLWfDWz/ToMsE= X-Mailgun-Sending-Ip: 198.61.254.31 X-Mailgun-Sid: WyI0MWYwYSIsICJsaW51eC1rZXJuZWxAdmdlci5rZXJuZWwub3JnIiwgImJlOWU0YSJd Received: from smtp.codeaurora.org (ec2-35-166-182-171.us-west-2.compute.amazonaws.com [35.166.182.171]) by smtp-out-n06.prod.us-west-2.postgun.com with SMTP id 5ff507bdd3eb3c36b4c12da6 (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Wed, 06 Jan 2021 00:43:41 GMT Sender: sudaraja=codeaurora.org@mg.codeaurora.org Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 7D329C433CA; Wed, 6 Jan 2021 00:43:41 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-caf-mail-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.9 required=2.0 tests=ALL_TRUSTED,BAYES_00,SPF_FAIL, URIBL_BLOCKED autolearn=no autolearn_force=no version=3.4.0 Received: from th-lint-014.qualcomm.com (i-global254.qualcomm.com [199.106.103.254]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: sudaraja) by smtp.codeaurora.org (Postfix) with ESMTPSA id 77EF6C433CA; Wed, 6 Jan 2021 00:43:40 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 77EF6C433CA Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; spf=fail smtp.mailfrom=sudaraja@codeaurora.org From: Sudarshan Rajagopalan To: akpm@linux-foundation.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org Cc: Sudarshan Rajagopalan Subject: [PATCH] mm: vmscan: support complete shrinker reclaim Date: Tue, 5 Jan 2021 16:43:38 -0800 Message-Id: <2d1f1dbb7e018ad02a9e7af36a8c86397a1598a7.1609892546.git.sudaraja@codeaurora.org> X-Mailer: git-send-email 2.25.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Ensure that shrinkers are given the option to completely drop their caches even when their caches are smaller than the batch size. This change helps improve memory headroom by ensuring that under significant memory pressure shrinkers can drop all of their caches. This change only attempts to more aggressively call the shrinkers during background memory reclaim, inorder to avoid hurting the performance of direct memory reclaim. Signed-off-by: Sudarshan Rajagopalan Cc: Andrew Morton --- mm/vmscan.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/mm/vmscan.c b/mm/vmscan.c index 9727dd8e2581..35973665ae64 100644 --- a/mm/vmscan.c +++ b/mm/vmscan.c @@ -424,6 +424,10 @@ static unsigned long do_shrink_slab(struct shrink_control *shrinkctl, long batch_size = shrinker->batch ? shrinker->batch : SHRINK_BATCH; long scanned = 0, next_deferred; + long min_cache_size = batch_size; + + if (current_is_kswapd()) + min_cache_size = 0; if (!(shrinker->flags & SHRINKER_NUMA_AWARE)) nid = 0; @@ -503,7 +507,7 @@ static unsigned long do_shrink_slab(struct shrink_control *shrinkctl, * scanning at high prio and therefore should try to reclaim as much as * possible. */ - while (total_scan >= batch_size || + while (total_scan > min_cache_size || total_scan >= freeable) { unsigned long ret; unsigned long nr_to_scan = min(batch_size, total_scan); -- Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, a Linux Foundation Collaborative Project