Re: [PATCH 00/40] Memory allocation profiling
From: Suren Baghdasaryan <surenb@google.com>
Date: 2023-05-03 20:08:59
Also in:
cgroups, linux-arch, linux-doc, linux-fsdevel, linux-iommu, linux-mm, lkml
On Wed, May 3, 2023 at 12:49 PM Tejun Heo [off-list ref] wrote:
Hello, On Wed, May 03, 2023 at 12:41:08PM -0700, Suren Baghdasaryan wrote:quoted
On Wed, May 3, 2023 at 12:09 PM Tejun Heo [off-list ref] wrote:quoted
On Wed, May 03, 2023 at 08:58:51AM -1000, Tejun Heo wrote:quoted
On Wed, May 03, 2023 at 02:56:44PM -0400, Kent Overstreet wrote:quoted
On Wed, May 03, 2023 at 08:40:07AM -1000, Tejun Heo wrote:quoted
quoted
Yeah, easy / default visibility argument does make sense to me.So, a bit of addition here. If this is the thrust, the debugfs part seems rather redundant, right? That's trivially obtainable with tracing / bpf and in a more flexible and performant manner. Also, are we happy with recording just single depth for persistent tracking?IIUC, by single depth you mean no call stack capturing?Yes.quoted
If so, that's the idea behind the context capture feature so that we can enable it on specific allocations only after we determine there is something interesting there. So, with low-cost persistent tracking we can determine the suspects and then pay some more to investigate those suspects in more detail.Yeah, I was wondering whether it'd be useful to have that configurable so that it'd be possible for a user to say "I'm okay with the cost, please track more context per allocation".
I assume by "more context per allocation" you mean for a specific allocation, not for all allocations. So, in a sense you are asking if the context capture feature can be dropped from this series and implemented using some other means. Is that right?
Given that tracking the immediate caller is already a huge improvement and narrowing it down from there using existing tools shouldn't be that difficult, I don't think this is a blocker in any way. It just bothers me a bit that the code is structured so that source line is the main abstraction.quoted
quoted
quoted
quoted
Not sure what you're envisioning? I'd consider the debugfs interface pretty integral; it's much more discoverable for users, and it's hardly any code out of the whole patchset.You can do the same thing with a bpftrace one liner tho. That's rather difficult to beat.debugfs seemed like a natural choice for such information. If another interface is more appropriate I'm happy to explore that.quoted
Ah, shit, I'm an idiot. Sorry. I thought allocations was under /proc and allocations.ctx under debugfs. I meant allocations.ctx is redundant.Do you mean that we could display allocation context in debugfs/allocations file (for the allocations which we explicitly enabled context capturing)?Sorry about the fumbled communication. Here's what I mean: * Improving memory allocation visibility makes sense to me. To me, a more natural place for that feels like /proc/allocations next to other memory info files rather than under debugfs.
TBH I would love that if this approach is acceptable.
* The default visibility provided by "allocations" provides something which is more difficult or at least cumbersome to obtain using existing tracing tools. However, what's provided by "allocations.ctx" can be trivially obtained using kprobe and BPF and seems redundant.
Hmm. That might be a good way forward. Since context capture has already high performance overhead, maybe choosing not the most performant but more generic solution is the right answer here. I'll need to think about it some more but thanks for the idea!
Thanks. -- tejun