mm: memcontrol: use __account_obj_stock() in the !locked path

Make __account_obj_stock() usable for the case where the local trylock
failed.  Then switch refill_obj_stock() over to it.

This consolidates the mod_objcg_mlstate() call into one place and will
make the next patch easier to follow.

Link: https://lkml.kernel.org/r/20260302195305.620713-5-hannes@cmpxchg.org
Signed-off-by: Johannes Weiner <hannes@cmpxchg.org>
Acked-by: Shakeel Butt <shakeel.butt@linux.dev>
Acked-by: Roman Gushchin <roman.gushchin@linux.dev>
Reviewed-by: Vlastimil Babka (SUSE) <vbabka@kernel.org>
Reviewed-by: Hao Li <hao.li@linux.dev>
Cc: Johannes Weiner <jweiner@meta.com>
Cc: Michal Hocko <mhocko@kernel.org>
Cc: Muchun Song <muchun.song@linux.dev>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
master
Johannes Weiner 2026-03-02 14:50:17 -05:00 committed by Andrew Morton
parent edb6abd31b
commit 4665aa7e65
1 changed files with 5 additions and 1 deletions

View File

@ -2969,6 +2969,9 @@ static void __account_obj_stock(struct obj_cgroup *objcg,
{
int *bytes;
if (!stock)
goto direct;
/*
* Save vmstat data in stock and skip vmstat array update unless
* accumulating over a page of vmstat data or when pgdat changes.
@ -3008,6 +3011,7 @@ static void __account_obj_stock(struct obj_cgroup *objcg,
nr = 0;
}
}
direct:
if (nr)
mod_objcg_mlstate(objcg, pgdat, idx, nr);
}
@ -3124,7 +3128,7 @@ static void refill_obj_stock(struct obj_cgroup *objcg, unsigned int nr_bytes,
stock = trylock_stock();
if (!stock) {
if (pgdat)
mod_objcg_mlstate(objcg, pgdat, idx, nr_acct);
__account_obj_stock(objcg, NULL, nr_acct, pgdat, idx);
nr_pages = nr_bytes >> PAGE_SHIFT;
nr_bytes = nr_bytes & (PAGE_SIZE - 1);
atomic_add(nr_bytes, &objcg->nr_charged_bytes);