On Tue, May 19, 2026 at 09:37:23AM +0300, Arseniy Krasnov wrote:
On 18/05/2026 14:08, Stefano Garzarella wrote:
On Mon, May 18, 2026 at 11:50:05AM +0100, David Laight wrote:
On Mon, 18 May 2026 11:54:19 +0200
Stefano Garzarella <[email protected]> wrote:
[...]
Hi guys! Just some replies after quick look:
>> > Surely that block should only be done if can_zcopy is true?
I guess no, since TCP also allocates uarg even if zerocopy is impossible -
it just sets uarg_to_msgzc(uarg)->zerocopy = 0;
>> > And shouldn't something unset it if info->op != VIRTIO_VSOCK_OP_RW ?
Hm, we can't enter block 'if (info->msg) {' when 'info->op' is not equal to
'VIRTIO_VSOCK_OP_RW',
because 'msg' is not NULL only for 'VIRTIO_VSOCK_OP_RW'. But anyway You point
to right thing - check for
'VIRTIO_VSOCK_OP_RW' could be removed here. Just with comment why.
>> > If the msg_zerocopy_realloc() fails then can't you just set can_zcopy to
false.
Here I guess it is better to follow TCP way to make same behaviour, because
exact
logic for MSG_ZEROCOPY is not documented. TCP also returns error and stops tx
loop.
>> >
>> > It info->msg->msg_buf is already set then I think you have to disable
zero-copy.
>> > The caller has already requested a callback - and you can't add another.
In TCP implementation if 'msg_ubuf' is set they just use it and check for
zerocopy in
the same way as 'msg_ubuf' is NULL.
>> >
>> > In any case by the end of this can_zcopy and have_uref are really the same
flag.
>>
Need to check it more. But 'can_zcopy' means that we fill frags in skb,
have_uref means that we
allocated completion (but it could be reported with not set
'SO_EE_CODE_ZEROCOPY_COPIED' if
'can_zcopy' was false).
@Stefano, I guess current implementation differs from TCP in two cases (at
least from first
view):
1) When 'msg_ubuf' is set: in TCP, already set 'msg_ubuf' is passed to
'skb_zerocopy_iter_stream()'
(if zerocopy is possible) where it is used as in vsock in call
'skb_zcopy_set()'. In vsock case if
'msg_ubuf' is not NULL we will pass just NULL to 'skb_zcopy_set()'. Yes this
is will be
no-effect call today (due to checks in 'skb_zcopy_set()'), but anyway - in
future may be not.
2) Also i see that 'skb_zerocopy_iter_stream()' in TCP version has some
extra checks which are
missed in vsock - we only just call '__zerocopy_sg_from_iter()' to fill skb
in zerocopy way.
But, I think, instead of trying to compare vsock and TCP versions best way is
to just copy
current TCP flow as close as possible:
https://git.kernel.org/pub/scm/linux/kernel/git/netdev/net.git/tree/net/ipv4/tcp.c#n1144
1) Use same flow of checks for 'msg_flags', 'msg_ubuf', SOCK_ZEROCOPY etc.
2) To copy data we can use 'skb_zerocopy_iter_stream()'.
3) The only thing that we don't need in vsock is dev mem related code from TCP
implementation.
I can take this task, but pls need some time - may be two/three weeks due to
another tasks.
What do You think?
If you can work on it, please go head. They seems all pre-existing, so
2/3 weeks are fine. Please let me know if you can't and I'll try to
allocate some time.
Thanks for the help!
Stefano