]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/commit
MFC r340436
authorvmaffione <vmaffione@FreeBSD.org>
Tue, 4 Dec 2018 17:44:12 +0000 (17:44 +0000)
committervmaffione <vmaffione@FreeBSD.org>
Tue, 4 Dec 2018 17:44:12 +0000 (17:44 +0000)
commitb69ef3704ccf19c2818b807107cf8b8b6b2ee91f
treec508c1e69c5cd35fe98fc7faf7fac53b5a81bcf1
parent2889f6fc498ab04853661e2f57d23fbb150128d3
MFC r340436

vtnet: fix netmap support

netmap(4) support for vtnet(4) was incomplete and had multiple bugs.
This commit fixes those bugs to bring netmap on vtnet in a functional state.

Changelist:
  - handle errors returned by virtqueue_enqueue() properly (they were
    previously ignored)
  - make sure netmap XOR rest of the kernel access each virtqueue.
  - compute the number of netmap slots for TX and RX separately, according to
    whether indirect descriptors are used or not for a given virtqueue.
  - make sure sglist are freed according to their type (mbufs or netmap
    buffers)
  - add support for mulitiqueue and netmap host (aka sw) rings.
  - intercept VQ interrupts directly instead of intercepting them in txq_eof
    and rxq_eof. This simplifies the code and makes it easier to make sure
    taskqueues are not running for a VQ while it is in netmap mode.
  - implement vntet_netmap_config() to cope with changes in the number of queues.

Reviewed by:    bryanv
Approved by:    gnn (mentor)
Sponsored by:   Sunny Valley Networks
Differential Revision:  https://reviews.freebsd.org/D17916
sys/dev/netmap/if_vtnet_netmap.h
sys/dev/virtio/network/if_vtnet.c
sys/dev/virtio/network/if_vtnetvar.h