netmap: if_vtnet: avoid netmap ring wraparound
netmap assumes the one "slot" is left unused to distinguish the empty ring and full ring conditions. This assumption was violated by vtnet_netmap_rxq_populate(). MFC after: 1 week
This commit is contained in:
parent
d276a7d391
commit
6f03286739
@ -275,8 +275,8 @@ vtnet_netmap_rxq_populate(struct vtnet_rxq *rxq)
|
||||
/* Expose all the RX netmap buffers we can. In case of no indirect
|
||||
* buffers, the number of netmap slots in the RX ring matches the
|
||||
* maximum number of 2-elements sglist that the RX virtqueue can
|
||||
* accommodate. */
|
||||
error = vtnet_netmap_kring_refill(kring, na->num_rx_desc);
|
||||
* accommodate (minus 1 to avoid netmap ring wraparound). */
|
||||
error = vtnet_netmap_kring_refill(kring, na->num_rx_desc - 1);
|
||||
virtqueue_notify(rxq->vtnrx_vq);
|
||||
|
||||
return error < 0 ? ENXIO : 0;
|
||||
|
Loading…
Reference in New Issue
Block a user