qemu-discuss
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Question] [vhost] Creating a vhost-user-vsock backend


From: Jakob Bohm
Subject: Re: [Question] [vhost] Creating a vhost-user-vsock backend
Date: Wed, 4 Sep 2024 14:52:32 +0200

On 2024-09-03 20:18, DUO Labs wrote:
*Note: As it turns out, I posted this on the wrong mailing list at first, so I'm reposting it here*

I've been studying the example given in `contrib/vhost-user-blk`, and trying to match the code to what is in the standard (https://docs.oasis-open.org/virtio/virtio/v1.3/csd01/virtio-v1.3-csd01.html#x1-3050002), so I can use the code to create my own vhost-user-vsock server.

I think I almost understand it, but I don't get exactly how do you correlate out_sg and in_sg to the header and ancillary data (for virtio-blk, it would either be the data to be written or a buffer to read data into, and vsock would be similar), respectively.

In virtio-blk, I see that there's an inhdr, and outhdr, but vsock doesn't have that, so I'm not sure how to map the same concept. Similarly, does `elem->out_sg[0]` always map to the header, and `elem->out_sg[1]` always map to the ancillary data? What about when you are reading into a buffer --- should it always be read into `elem->in_sg[0]`, or is that only for virtio-blk?

If you are trying to make a custom virtio network adapter, please note
that the splitting of packets in network adapter I/O tends to vary
largely by packet origin, OS and driver.  Historically, MS-DOS drivers
would often make the first fragment of incoming packets contain just
enough data to make initial processing decisions for 99% of packets,
while the first fragment of locally generated packets would reflect
the steps the packet generation passed through, so it might include
the HTTP header, the TCP header, just the IP header or even just the
MAC header or even reflect.  However for reliability, any network
adapter design needs to deal with absolutely arbitrary splitting by
the software running above it in the network stack.

Split I/O is mainly a DMA optimization to save byte copies in software,
this even applies to block devices.  The hardware that would output a
fixed speed bit stream to a disk or network would queue up the bits to
be output with no pause at the buffer split point, and vice versa at
the receive end.

Enjoy

Jakob
--
Jakob Bohm, CIO, Partner, WiseMo A/S.  https://www.wisemo.com
Transformervej 29, 2860 Søborg, Denmark.  Direct +45 31 13 16 10
This public discussion message is non-binding and may contain errors.
WiseMo - Remote Service Management for PCs, Phones and Embedded




reply via email to

[Prev in Thread] Current Thread [Next in Thread]