[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <651351db-e3ec-4944-8db5-e63290a578e8@gmail.com>
Date: Tue, 27 May 2025 06:30:12 +0100
From: Pavel Begunkov <asml.silence@...il.com>
To: Byungchul Park <byungchul@...com>
Cc: Mina Almasry <almasrymina@...gle.com>, willy@...radead.org,
netdev@...r.kernel.org, linux-kernel@...r.kernel.org, linux-mm@...ck.org,
kernel_team@...ynix.com, kuba@...nel.org, ilias.apalodimas@...aro.org,
harry.yoo@...cle.com, hawk@...nel.org, akpm@...ux-foundation.org,
davem@...emloft.net, john.fastabend@...il.com, andrew+netdev@...n.ch,
toke@...hat.com, tariqt@...dia.com, edumazet@...gle.com, pabeni@...hat.com,
saeedm@...dia.com, leon@...nel.org, ast@...nel.org, daniel@...earbox.net,
david@...hat.com, lorenzo.stoakes@...cle.com, Liam.Howlett@...cle.com,
vbabka@...e.cz, rppt@...nel.org, surenb@...gle.com, mhocko@...e.com,
horms@...nel.org, linux-rdma@...r.kernel.org, bpf@...r.kernel.org,
vishal.moola@...il.com
Subject: Re: [PATCH 18/18] mm, netmem: remove the page pool members in struct
page
On 5/27/25 02:02, Byungchul Park wrote:
...>> Patch 1:
>>
>> struct page {
>> unsigned long flags;
>> union {
>> struct_group_tagged(netmem_desc, netmem_desc) {
>> // same layout as before
>> ...
>> struct page_pool *pp;
>> ...
>> };
>
> This part will be gone shortly. The matters come from absence of this
> part.
Right, the problem is not having an explicit netmem_desc in struct
page and not using struct netmem_desc in all relevant helpers.
>> struct net_iov {
>> unsigned long flags_padding;
>> union {
>> struct {
>> // same layout as in page + build asserts;
>> ...
>> struct page_pool *pp;
>> ...
>> };
>> struct netmem_desc desc;
>> };
>> };
>>
>> struct netmem_desc *page_to_netmem_desc(struct page *page)
>> {
>> return &page->netmem_desc;
>
> page will not have any netmem things in it after this, that matters.
Ok, the question is where are you going to stash the fields?
We still need space to store them. Are you going to do the
indirection mm folks want?
AFAIK, the plan is that in the end pages will still have
netmem_desc but through an indirection. E.g.
static inline bool page_pool_page_is_pp(struct page *page)
{
return page->page_type == PAGE_PP_NET;
}
struct netmem_desc *page_to_netmem_desc(struct page *page)
{
return page->page_private;
}
--
Pavel Begunkov
Powered by blists - more mailing lists