From: Pavel Begunkov <[email protected]>
To: Jens Axboe <[email protected]>,
Caleb Sander Mateos <[email protected]>
Cc: [email protected]
Subject: Re: [PATCH 2/2] io_uring/nop: use io_find_buf_node()
Date: Sat, 1 Mar 2025 03:02:33 +0000 [thread overview]
Message-ID: <[email protected]> (raw)
In-Reply-To: <[email protected]>
On 3/1/25 02:39, Jens Axboe wrote:
> On 2/28/25 7:36 PM, Pavel Begunkov wrote:
>> On 3/1/25 02:21, Jens Axboe wrote:
>>> On 2/28/25 7:15 PM, Pavel Begunkov wrote:
>>>> On 3/1/25 01:41, Pavel Begunkov wrote:
>>>>> On 3/1/25 00:16, Caleb Sander Mateos wrote:
>>>>>> Call io_find_buf_node() to avoid duplicating it in io_nop().
>>>>>
>>>>> IORING_NOP_FIXED_BUFFER interface looks odd, instead of pretending
>>>>> to use a buffer, it basically pokes directly into internal infra,
>>>>> it's not something userspace should be able to do.
>>>>>
>>>>> Jens, did use it anywhere? It's new, I'd rather kill it or align with
>>>>> how requests consume buffers, i.e. addr+len, and then do
>>>>> io_import_reg_buf() instead. That'd break the api though, but would
>>>>> anyone care?
>>>>
>>>> 3rd option is to ignore the flag and let the req succeed.
>>>
>>> Honestly what is the problem here? NOP isn't doing anything that
>>> other commands types can't or aren't already. So no, it should stay,
>>
>> It completely ignores any checking and buffer importing stopping
>> half way at looking at nodes, the behaviour other requests don't
>> do. We can also add a request that take a lock and releases it
>> back because other requests do that as well but as a part of some
>> useful sequence of actions.
>
> Let's not resort to hyperbole - it's useful to be able to test (and
That's not a hyperbole, it's a direct analogy.
> hence quantify) provided buffer usage. I used it while doing the
> resource node rework. We also have a NOP opcode to be able to test
> generic overhead for that very reason. For testing _io_uring_
> infrastructure it was already useful for me. Of course we should not add
> random things that test things like lock acquire and release, that's not
> the scope of NOP.
>
> Sure you could add import as well, but a) nop doesn't touch the data,
> and b) that's largely testing generic kernel infrastructure as well.
>
> The whole point of NOP is to be able to test io_uring infrastructure.
And now we add overhead to test overhead of the very path we
add overhead to, just splendid. It's intrusive, it looks into
guts of infra that can change, and the way not to be intrusive
is to follow the way others use the concept, which is why I'm
suggesting importing the buffer, and that would be another
direct analogy with the pure NOP (w/o flags).
--
Pavel Begunkov
next prev parent reply other threads:[~2025-03-01 3:01 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-03-01 0:16 [PATCH 1/2] io_uring/rsrc: declare io_find_buf_node() in header file Caleb Sander Mateos
2025-03-01 0:16 ` [PATCH 2/2] io_uring/nop: use io_find_buf_node() Caleb Sander Mateos
2025-03-01 1:41 ` Pavel Begunkov
2025-03-01 1:58 ` Caleb Sander Mateos
2025-03-01 2:10 ` Jens Axboe
2025-03-01 2:11 ` Pavel Begunkov
2025-03-01 2:15 ` Pavel Begunkov
2025-03-01 2:21 ` Jens Axboe
2025-03-01 2:36 ` Pavel Begunkov
2025-03-01 2:39 ` Jens Axboe
2025-03-01 3:02 ` Pavel Begunkov [this message]
2025-03-01 1:46 ` [PATCH 1/2] io_uring/rsrc: declare io_find_buf_node() in header file Pavel Begunkov
2025-03-01 2:04 ` Caleb Sander Mateos
2025-03-01 2:22 ` Jens Axboe
2025-03-01 2:31 ` Pavel Begunkov
2025-03-01 2:33 ` Jens Axboe
2025-03-01 2:23 ` Jens Axboe
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 \
[email protected] \
[email protected] \
[email protected] \
[email protected] \
[email protected] \
/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