Re: [PATCH v4 2/3] mm: Add support for kmem caches in DMA32 zone
From: Michal Hocko
Date: Wed Dec 05 2018 - 04:56:07 EST
On Wed 05-12-18 13:48:27, Nicolas Boichat wrote:
> In some cases (e.g. IOMMU ARMv7s page allocator), we need to allocate
> data structures smaller than a page with GFP_DMA32 flag.
>
> This change makes it possible to create a custom cache in DMA32 zone
> using kmem_cache_create, then allocate memory using kmem_cache_alloc.
>
> We do not create a DMA32 kmalloc cache array, as there are currently
> no users of kmalloc(..., GFP_DMA32). The new test in check_slab_flags
> ensures that such calls still fail (as they do before this change).
The changelog should be much more specific about decisions made here.
First of all it would be nice to mention the usecase.
Secondly, why do we need a new sysfs file? Who is going to consume it?
Then why do we need SLAB_MERGE_SAME to cover GFP_DMA32 as well? I
thought the whole point is to use dedicated slab cache. Who is this
going to merge with?
--
Michal Hocko
SUSE Labs