On 2021/7/2 17:42, Jesper Dangaard Brouer wrote: > > On 30/06/2021 11.17, Yunsheng Lin wrote: >> Currently page pool only support page recycling only when >> refcnt of page is one, which means it can not support the >> split page recycling implemented in the most ethernet driver. > > Cc. Alex Duyck as I consider him an expert in this area. Thanks. > > >> So add elevated refcnt support in page pool, and support >> allocating page frag to enable multi-frames-per-page based >> on the elevated refcnt support. >> >> As the elevated refcnt is per page, and there is no space >> for that in "struct page" now, so add a dynamically allocated >> "struct page_pool_info" to record page pool ptr and refcnt >> corrsponding to a page for now. Later, we can recycle the >> "struct page_pool_info" too, or use part of page memory to >> record pp_info. > > I'm not happy with allocating a memory (slab) object "struct page_pool_info" per page. > > This also gives us an extra level of indirection. I'm not happy with that either, if there is better way to avoid that, I will be happy to change it:) > > > You are also adding a page "frag" API inside page pool, which I'm not 100% convinced belongs inside page_pool APIs. > > Please notice the APIs that Alex Duyck added in mm/page_alloc.c: Actually, that is where the idea of using "page frag" come from. Aside from the performance improvement, there is memory usage decrease for 64K page size kernel, which means a 64K page can be used by 32 description with 2k buffer size, and that is a lot of memory saving for 64 page size kernel comparing to the current split page reusing implemented in the driver. > > __page_frag_cache_refill() + __page_frag_cache_drain() + page_frag_alloc_align() > > [...]