Re: [PATCH] mm/page_owner: print largest memory consumer when OOM panic occurs

From: Qian Cai
Date: Wed Dec 25 2019 - 08:53:40 EST




> On Dec 25, 2019, at 4:29 AM, Miles Chen <miles.chen@xxxxxxxxxxxx> wrote:
>
> For example, we're implementing our iommu driver and there are many
> alloc_pages() in drivers/iommu.
> This approach helps us located some memory leakages in our
> implementation.

Not sure if you have code that can share but I canât imagine there are many places that would have a single call site in the driver doing alloc_pages() over and over again. For example, there is only two alloc_pages() in intel-iommu.c with one is only in the cold path, so even if alloc_pgtable_page() one do leaking, it is still up to there air if your patch will catch it because it may not a single call site and it needs to leak significant amount of memory to be the greatest consumer where it is just not so realistic. For debugging point of view, IMO it is better to annotate this one alloc_pages() call when in doubt, so that kmemleak would catch it instead.