From: Uladzislau Rezki <urezki@gmail.com>
To: Johannes Weiner <hannes@cmpxchg.org>
Cc: Andrew Morton <akpm@linux-foundation.org>,
Uladzislau Rezki <urezki@gmail.com>,
Joshua Hahn <joshua.hahnjy@gmail.com>,
Michal Hocko <mhocko@suse.com>,
Roman Gushchin <roman.gushchin@linux.dev>,
Shakeel Butt <shakeel.butt@linux.dev>,
Muchun Song <muchun.song@linux.dev>,
linux-mm@kvack.org, cgroups@vger.kernel.org,
linux-kernel@vger.kernel.org
Subject: Re: [PATCH 2/2] mm: memcontrol: switch to native NR_VMALLOC vmstat counter
Date: Mon, 23 Feb 2026 16:12:48 +0100 [thread overview]
Message-ID: <aZxucOEcpJDzSBgg@pc636> (raw)
In-Reply-To: <20260220191035.3703800-2-hannes@cmpxchg.org>
On Fri, Feb 20, 2026 at 02:10:35PM -0500, Johannes Weiner wrote:
> Eliminates the custom memcg counter and results in a single,
> consolidated accounting call in vmalloc code.
>
> Signed-off-by: Johannes Weiner <hannes@cmpxchg.org>
> ---
> include/linux/memcontrol.h | 1 -
> mm/memcontrol.c | 4 ++--
> mm/vmalloc.c | 16 ++++------------
> 3 files changed, 6 insertions(+), 15 deletions(-)
>
> diff --git a/include/linux/memcontrol.h b/include/linux/memcontrol.h
> index 67f154de10bc..c7cc4e50e59a 100644
> --- a/include/linux/memcontrol.h
> +++ b/include/linux/memcontrol.h
> @@ -35,7 +35,6 @@ enum memcg_stat_item {
> MEMCG_SWAP = NR_VM_NODE_STAT_ITEMS,
> MEMCG_SOCK,
> MEMCG_PERCPU_B,
> - MEMCG_VMALLOC,
> MEMCG_KMEM,
> MEMCG_ZSWAP_B,
> MEMCG_ZSWAPPED,
> diff --git a/mm/memcontrol.c b/mm/memcontrol.c
> index 129eed3ff5bb..fef5bdd887e0 100644
> --- a/mm/memcontrol.c
> +++ b/mm/memcontrol.c
> @@ -317,6 +317,7 @@ static const unsigned int memcg_node_stat_items[] = {
> NR_SHMEM_THPS,
> NR_FILE_THPS,
> NR_ANON_THPS,
> + NR_VMALLOC,
> NR_KERNEL_STACK_KB,
> NR_PAGETABLE,
> NR_SECONDARY_PAGETABLE,
> @@ -339,7 +340,6 @@ static const unsigned int memcg_stat_items[] = {
> MEMCG_SWAP,
> MEMCG_SOCK,
> MEMCG_PERCPU_B,
> - MEMCG_VMALLOC,
> MEMCG_KMEM,
> MEMCG_ZSWAP_B,
> MEMCG_ZSWAPPED,
> @@ -1359,7 +1359,7 @@ static const struct memory_stat memory_stats[] = {
> { "sec_pagetables", NR_SECONDARY_PAGETABLE },
> { "percpu", MEMCG_PERCPU_B },
> { "sock", MEMCG_SOCK },
> - { "vmalloc", MEMCG_VMALLOC },
> + { "vmalloc", NR_VMALLOC },
> { "shmem", NR_SHMEM },
> #ifdef CONFIG_ZSWAP
> { "zswap", MEMCG_ZSWAP_B },
> diff --git a/mm/vmalloc.c b/mm/vmalloc.c
> index a49a46de9c4f..8773bc0c4734 100644
> --- a/mm/vmalloc.c
> +++ b/mm/vmalloc.c
> @@ -3446,9 +3446,6 @@ void vfree(const void *addr)
>
> if (unlikely(vm->flags & VM_FLUSH_RESET_PERMS))
> vm_reset_perms(vm);
> - /* All pages of vm should be charged to same memcg, so use first one. */
> - if (vm->nr_pages && !(vm->flags & VM_MAP_PUT_PAGES))
> - mod_memcg_page_state(vm->pages[0], MEMCG_VMALLOC, -vm->nr_pages);
> for (i = 0; i < vm->nr_pages; i++) {
> struct page *page = vm->pages[i];
>
> @@ -3458,7 +3455,7 @@ void vfree(const void *addr)
> * can be freed as an array of order-0 allocations
> */
> if (!(vm->flags & VM_MAP_PUT_PAGES))
> - dec_node_page_state(page, NR_VMALLOC);
> + mod_lruvec_page_state(page, NR_VMALLOC, -1);
> __free_page(page);
> cond_resched();
> }
> @@ -3649,7 +3646,7 @@ vm_area_alloc_pages(gfp_t gfp, int nid,
> continue;
> }
>
> - mod_node_page_state(page, NR_VMALLOC, 1 << large_order);
> + mod_lruvec_page_state(page, NR_VMALLOC, 1 << large_order);
>
> split_page(page, large_order);
> for (i = 0; i < (1U << large_order); i++)
> @@ -3696,7 +3693,7 @@ vm_area_alloc_pages(gfp_t gfp, int nid,
> pages + nr_allocated);
>
> for (i = nr_allocated; i < nr_allocated + nr; i++)
> - inc_node_page_state(pages[i], NR_VMALLOC);
> + mod_lruvec_page_state(pages[i], NR_VMALLOC, 1);
>
> nr_allocated += nr;
>
> @@ -3722,7 +3719,7 @@ vm_area_alloc_pages(gfp_t gfp, int nid,
> if (unlikely(!page))
> break;
>
> - mod_node_page_state(page, NR_VMALLOC, 1 << order);
> + mod_lruvec_page_state(page, NR_VMALLOC, 1 << order);
>
> /*
> * High-order allocations must be able to be treated as
> @@ -3866,11 +3863,6 @@ static void *__vmalloc_area_node(struct vm_struct *area, gfp_t gfp_mask,
> vmalloc_gfp_adjust(gfp_mask, page_order), node,
> page_order, nr_small_pages, area->pages);
>
> - /* All pages of vm should be charged to same memcg, so use first one. */
> - if (gfp_mask & __GFP_ACCOUNT && area->nr_pages)
> - mod_memcg_page_state(area->pages[0], MEMCG_VMALLOC,
> - area->nr_pages);
> -
> /*
> * If not enough pages were obtained to accomplish an
> * allocation request, free them via vfree() if any.
> --
> 2.53.0
>
LGTM:
Reviewed-by: Uladzislau Rezki (Sony) <urezki@gmail.com>
next prev parent reply other threads:[~2026-02-23 15:12 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-02-20 19:10 [PATCH 1/2] mm: vmalloc: streamline vmalloc memory accounting Johannes Weiner
2026-02-20 19:10 ` [PATCH 2/2] mm: memcontrol: switch to native NR_VMALLOC vmstat counter Johannes Weiner
2026-02-20 22:15 ` Shakeel Butt
2026-02-23 15:12 ` Uladzislau Rezki [this message]
2026-02-20 22:09 ` [PATCH 1/2] mm: vmalloc: streamline vmalloc memory accounting Shakeel Butt
2026-02-23 15:58 ` Johannes Weiner
2026-02-23 15:30 ` Uladzislau Rezki
2026-02-23 20:19 ` Johannes Weiner
2026-02-24 18:03 ` Uladzislau Rezki
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=aZxucOEcpJDzSBgg@pc636 \
--to=urezki@gmail.com \
--cc=akpm@linux-foundation.org \
--cc=cgroups@vger.kernel.org \
--cc=hannes@cmpxchg.org \
--cc=joshua.hahnjy@gmail.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mm@kvack.org \
--cc=mhocko@suse.com \
--cc=muchun.song@linux.dev \
--cc=roman.gushchin@linux.dev \
--cc=shakeel.butt@linux.dev \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.