Re: [RFC PATCH 00/17] virtual-bus

From: Gregory Haskins
Date: Fri Apr 03 2009 - 07:27:12 EST


Gerd Hoffmann wrote:
> Avi Kivity wrote:
>
>> There is no choice. Exiting from the guest to the kernel to userspace
>> is prohibitively expensive, you can't do that on every packet.
>>
>
> I didn't look at virtio-net very closely yet. I wonder why the
> notification is that a big issue though. It is easy to keep the number
> of notifications low without increasing latency:
>
> Check shared ring status when stuffing a request. If there are requests
> not (yet) consumed by the other end there is no need to send a
> notification. That scheme can even span multiple rings (nics with rx
> and tx for example).
>

FWIW: I employ this scheme. The shm-signal construct has a "dirty" and
"pending" flag (all on the same cacheline, which may or may not address
Andi's later point). The first time you dirty the shm, it sets both
flags. The consumer side has to clear "pending" before any subsequent
signals are sent. Normally the consumer side will also clear "enabled"
(as part of the bidir napi thing) to further disable signals.

-Greg



Attachment: signature.asc
Description: OpenPGP digital signature