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