[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20230913073846.1528938-1-yosryahmed@google.com>
Date: Wed, 13 Sep 2023 07:38:43 +0000
From: Yosry Ahmed <yosryahmed@...gle.com>
To: Andrew Morton <akpm@...ux-foundation.org>
Cc: Johannes Weiner <hannes@...xchg.org>,
Michal Hocko <mhocko@...nel.org>,
Roman Gushchin <roman.gushchin@...ux.dev>,
Shakeel Butt <shakeelb@...gle.com>,
Muchun Song <muchun.song@...ux.dev>,
Ivan Babrou <ivan@...udflare.com>, Tejun Heo <tj@...nel.org>,
"Michal Koutný" <mkoutny@...e.com>,
Waiman Long <longman@...hat.com>, kernel-team@...udflare.com,
Wei Xu <weixugc@...gle.com>, Greg Thelen <gthelen@...gle.com>,
linux-mm@...ck.org, cgroups@...r.kernel.org,
linux-kernel@...r.kernel.org, Yosry Ahmed <yosryahmed@...gle.com>
Subject: [PATCH 0/3] memcg: more sophisticated stats flushing
The current stats flushing approach is very simple. Everyone tries to
flush the entire tree, and only a single flusher is allowed. Concurrent
flushers just skip the flush completely. This approach has problems that
manifest in both flushing latency and stats accuracy (or freshness).
This series introduces a more sophisticated approach that aims to find a
better trade-off between accuracy and performance. Essentially we try to
get the best accuracy with the minimal amount of work done when possible
(fast path), and we fallback to more expensive or less accurate flushes
only when necessary. Details are in the commit message of patch 3, which
is really the core of this series.
Patches 1 & 2 are just cleanups with no functional change intended.
This series replaces v4 of "memcg: non-unified flushing for userspace
stats" series [1]. I did not send this as v5 as it completely deviates
from what that patchset is doing (but still trying to solve the same
problem). The approach followed in this series attempts to provide a
more generic framework for flushing for both userspace readers and
in-kernel flushers, to avoid having a lot of different flushing flavors.
It also benefits in-kernel flushers as well as userspace readers.
This series is a result of the discussions held in [1], and various
suggestions by Wei Xu <weixugc@...gle.com>.
[1] https://lore.kernel.org/lkml/20230831165611.2610118-1-yosryahmed@google.com/
Yosry Ahmed (3):
mm: memcg: change flush_next_time to flush_last_time
mm: memcg: rename stats_flush_threshold to stats_updates_order
mm: memcg: optimize stats flushing for latency and accuracy
include/linux/memcontrol.h | 4 +-
mm/memcontrol.c | 125 ++++++++++++++++++++++++++-----------
mm/vmscan.c | 2 +-
mm/workingset.c | 8 ++-
4 files changed, 98 insertions(+), 41 deletions(-)
--
2.42.0.283.g2d96d420d3-goog
Powered by blists - more mailing lists