From: Vlastimil Babka <vbabka@suse.cz>
To: Yosry Ahmed <yosryahmed@google.com>
Cc: Shakeel Butt <shakeel.butt@linux.dev>,
Andrew Morton <akpm@linux-foundation.org>,
Johannes Weiner <hannes@cmpxchg.org>,
Michal Hocko <mhocko@kernel.org>,
Roman Gushchin <roman.gushchin@linux.dev>,
Muchun Song <muchun.song@linux.dev>,
David Rientjes <rientjes@google.com>,
Hyeonggon Yoo <42.hyeyoo@gmail.com>,
Eric Dumazet <edumazet@google.com>,
"David S . Miller" <davem@davemloft.net>,
Jakub Kicinski <kuba@kernel.org>, Paolo Abeni <pabeni@redhat.com>,
linux-mm@kvack.org, linux-kernel@vger.kernel.org,
Meta kernel team <kernel-team@meta.com>,
cgroups@vger.kernel.org, netdev@vger.kernel.org
Subject: Re: [PATCH v4] memcg: add charging of already allocated slab objects
Date: Fri, 6 Sep 2024 19:28:56 +0200 [thread overview]
Message-ID: <e7ec0800-f551-4b32-ad26-f625f88962f1@suse.cz> (raw)
In-Reply-To: <CAJD7tkZ+PYqvq6oUHtrtq1JE670A+kUBcOAbtRVudp1JBPkCwA@mail.gmail.com>
On 9/6/24 19:19, Yosry Ahmed wrote:
> [..]
>> I felt it could be improved more, so ended up with this. Thoughts?
>>
>> /**
>> * kmem_cache_charge - memcg charge an already allocated slab memory
>> * @objp: address of the slab object to memcg charge
>> * @gfpflags: describe the allocation context
>> *
>> * kmem_cache_charge allows charging a slab object to the current memcg,
>> * primarily in cases where charging at allocation time might not be possible
>> * because the target memcg is not known (i.e. softirq context)
>> *
>> * The objp should be pointer returned by the slab allocator functions like
>> * kmalloc (with __GFP_ACCOUNT in flags) or kmem_cache_alloc. The memcg charge
>
> Aren't allocations done with kmalloc(__GFP_ACCOUNT) already accounted?
> Why would we need to call kmem_cache_charge() for those?
AFAIU current_obj_cgroup() returns NULL because we're in the interrupt
context and no remote memcg context has been set. Thus the charging is
skipped. The patch commit log describes such scenario for network receive.
But in case of kmalloc() the allocation must have been still attempted with
__GFP_ACCOUNT so a kmalloc-cg cache is used even if the charging fails.
If there's another usage for kmem_cache_charge() where the memcg is
available but we don't want to charge immediately on purpose (such as the
Linus' idea for struct file), we might need to find another way to tell
kmalloc() to use the kmalloc-cg cache but not charge immediately...
> I am assuming what you are referring to is kmalloc() allocations that
> are not fulfilled from KMALLOC_NORMAL caches, but I am not sure how to
> capture this here.
>
>> * behavior can be controlled through gfpflags parameter, which affects how the
>> * necessary internal metadata can be allocated. Including __GFP_NOFAIL denotes
>> * that overcharging is requested instead of failure, but is not applied for the
>> * internal metadata allocation.
>> *
>> * There are several cases where it will return true even if the charging was
>> * not done:
>> * More specifically:
>> *
>> * 1. For !CONFIG_MEMCG or cgroup_disable=memory systems.
>> * 2. Already charged slab objects.
>> * 3. For slab objects from KMALLOC_NORMAL caches - allocated by kmalloc()
>> * without __GFP_ACCOUNT
>> * 4. Allocating internal metadata has failed
>> *
>> * Return: true if charge was successful otherwise false.
>> */
>>
>> >> > +
>> >> > + /* Ignore KMALLOC_NORMAL cache to avoid circular dependency. */
>> >>
>> >> Is it possible to point to the commit that has the explanation here?
>> >> The one you pointed me to before? Otherwise it's not really obvious
>> >> where the circular dependency comes from (at least to me).
>> >>
>> >
>> > Not sure about the commit reference. We can add more text here.
>> > Vlastimil, how much detail do you prefer?
>>
>> What about:
>>
>> /*
>> * Ignore KMALLOC_NORMAL cache to avoid possible circular dependency
>> * of slab_obj_exts being allocated from the same slab and thus the slab
>> * becoming effectively unfreeable.
>> */
>>
>>
>> > thanks,
>> > Shakeel
>>
next prev parent reply other threads:[~2024-09-06 17:29 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-09-05 17:34 Shakeel Butt
2024-09-05 17:48 ` Yosry Ahmed
2024-09-05 18:48 ` Shakeel Butt
2024-09-06 8:52 ` Vlastimil Babka
2024-09-06 16:03 ` Shakeel Butt
2024-09-06 17:19 ` Yosry Ahmed
2024-09-06 17:28 ` Vlastimil Babka [this message]
2024-09-06 17:38 ` Yosry Ahmed
2024-09-09 7:59 ` Vlastimil Babka
2024-09-09 17:20 ` Yosry Ahmed
2024-09-06 19:04 ` Shakeel Butt
2024-09-10 8:26 ` Paolo Abeni
2024-09-10 9:19 ` Vlastimil Babka
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=e7ec0800-f551-4b32-ad26-f625f88962f1@suse.cz \
--to=vbabka@suse.cz \
--cc=42.hyeyoo@gmail.com \
--cc=akpm@linux-foundation.org \
--cc=cgroups@vger.kernel.org \
--cc=davem@davemloft.net \
--cc=edumazet@google.com \
--cc=hannes@cmpxchg.org \
--cc=kernel-team@meta.com \
--cc=kuba@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mm@kvack.org \
--cc=mhocko@kernel.org \
--cc=muchun.song@linux.dev \
--cc=netdev@vger.kernel.org \
--cc=pabeni@redhat.com \
--cc=rientjes@google.com \
--cc=roman.gushchin@linux.dev \
--cc=shakeel.butt@linux.dev \
--cc=yosryahmed@google.com \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox