From: Yunsheng Lin <linyunsheng@huawei.com>
To: Luiz Capitulino <luizcap@redhat.com>, <linux-mm@kvack.org>,
<mgorman@techsingularity.net>, <willy@infradead.org>
Cc: <david@redhat.com>, <linux-kernel@vger.kernel.org>,
<lcapitulino@gmail.com>
Subject: Re: [PATCH v2 1/2] mm: alloc_pages_bulk_noprof: drop page_list argument
Date: Fri, 3 Jan 2025 19:21:58 +0800 [thread overview]
Message-ID: <0edbfcf5-db26-441f-ae9c-f85985cb8b68@huawei.com> (raw)
In-Reply-To: <bd7a48d4-ec7b-4c9a-bf0e-dffc6286d08d@redhat.com>
On 2025/1/3 0:38, Luiz Capitulino wrote:
> On 2024-12-25 07:36, Yunsheng Lin wrote:
>> On 2024/12/24 6:00, Luiz Capitulino wrote:
>>
>>> /*
>>> - * __alloc_pages_bulk - Allocate a number of order-0 pages to a list or array
>>> + * __alloc_pages_bulk - Allocate a number of order-0 pages to an array
>>> * @gfp: GFP flags for the allocation
>>> * @preferred_nid: The preferred NUMA node ID to allocate from
>>> * @nodemask: Set of nodes to allocate from, may be NULL
>>> - * @nr_pages: The number of pages desired on the list or array
>>> - * @page_list: Optional list to store the allocated pages
>>> - * @page_array: Optional array to store the pages
>>> + * @nr_pages: The number of pages desired in the array
>>> + * @page_array: Array to store the pages
>>> *
>>> * This is a batched version of the page allocator that attempts to
>>> - * allocate nr_pages quickly. Pages are added to page_list if page_list
>>> - * is not NULL, otherwise it is assumed that the page_array is valid.
>>> + * allocate nr_pages quickly. Pages are added to the page_array.
>>> *
>>> - * For lists, nr_pages is the number of pages that should be allocated.
>>> - *
>>> - * For arrays, only NULL elements are populated with pages and nr_pages
>>> + * Note that only NULL elements are populated with pages and nr_pages
>>
>> It is not really related to this patch, but while we are at this, the above
>> seems like an odd behavior. By roughly looking at all the callers of that
>> API, it seems like only the below callers rely on that?
>> fs/erofs/zutil.c: z_erofs_gbuf_growsize()
>> fs/xfs/xfs_buf.c: xfs_buf_alloc_pages()
>>
>> It seems it is quite straight forward to change the above callers to not
>> rely on the above behavior, and we might be able to avoid more checking
>> by removing the above behavior?
>
> Hi Yunsheng,
>
> Assuming the use-case is valid, I think we might want to keep common code
> in the API vs. duplicating it in callers?
I was thinking maybe adding a wrapper/helper around the __alloc_pages_bulk()
to avoid the overhead for other usecase and make the semantics more obvious
if it is an valid use-case.
>
> In any case, even if we decide to go for your suggestion, I'd prefer not
> to grow the scope of this series since this could delay its inclusion.
> Dropping the list-API (and dead code) is actually important so IMHO it
> should go in first.
Sure.
>
next prev parent reply other threads:[~2025-01-03 11:22 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-12-23 22:00 [PATCH v2 0/2] mm: alloc_pages_bulk: small API refactor Luiz Capitulino
2024-12-23 22:00 ` [PATCH v2 1/2] mm: alloc_pages_bulk_noprof: drop page_list argument Luiz Capitulino
2024-12-25 12:36 ` Yunsheng Lin
2025-01-02 16:38 ` Luiz Capitulino
2025-01-03 11:21 ` Yunsheng Lin [this message]
2025-01-03 14:12 ` Luiz Capitulino
2025-01-02 20:00 ` Mel Gorman
2025-01-03 11:29 ` Yunsheng Lin
2025-01-03 14:27 ` Mel Gorman
2025-01-03 14:46 ` Luiz Capitulino
2025-01-08 13:39 ` David Hildenbrand
2024-12-23 22:00 ` [PATCH v2 2/2] mm: alloc_pages_bulk: rename API Luiz Capitulino
2025-01-08 13:40 ` David Hildenbrand
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=0edbfcf5-db26-441f-ae9c-f85985cb8b68@huawei.com \
--to=linyunsheng@huawei.com \
--cc=david@redhat.com \
--cc=lcapitulino@gmail.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mm@kvack.org \
--cc=luizcap@redhat.com \
--cc=mgorman@techsingularity.net \
--cc=willy@infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox