|
@@ -546,6 +546,23 @@ static RxFilterInfo *virtio_net_query_rxfilter(NetClientState *nc)
|
|
return info;
|
|
return info;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+static void virtio_net_queue_reset(VirtIODevice *vdev, uint32_t queue_index)
|
|
|
|
+{
|
|
|
|
+ VirtIONet *n = VIRTIO_NET(vdev);
|
|
|
|
+ NetClientState *nc = qemu_get_subqueue(n->nic, vq2q(queue_index));
|
|
|
|
+
|
|
|
|
+ if (!nc->peer) {
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (get_vhost_net(nc->peer) &&
|
|
|
|
+ nc->peer->info->type == NET_CLIENT_DRIVER_TAP) {
|
|
|
|
+ vhost_net_virtqueue_reset(vdev, nc, queue_index);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ flush_or_purge_queued_packets(nc);
|
|
|
|
+}
|
|
|
|
+
|
|
static void virtio_net_reset(VirtIODevice *vdev)
|
|
static void virtio_net_reset(VirtIODevice *vdev)
|
|
{
|
|
{
|
|
VirtIONet *n = VIRTIO_NET(vdev);
|
|
VirtIONet *n = VIRTIO_NET(vdev);
|
|
@@ -3827,6 +3844,7 @@ static void virtio_net_class_init(ObjectClass *klass, void *data)
|
|
vdc->set_features = virtio_net_set_features;
|
|
vdc->set_features = virtio_net_set_features;
|
|
vdc->bad_features = virtio_net_bad_features;
|
|
vdc->bad_features = virtio_net_bad_features;
|
|
vdc->reset = virtio_net_reset;
|
|
vdc->reset = virtio_net_reset;
|
|
|
|
+ vdc->queue_reset = virtio_net_queue_reset;
|
|
vdc->set_status = virtio_net_set_status;
|
|
vdc->set_status = virtio_net_set_status;
|
|
vdc->guest_notifier_mask = virtio_net_guest_notifier_mask;
|
|
vdc->guest_notifier_mask = virtio_net_guest_notifier_mask;
|
|
vdc->guest_notifier_pending = virtio_net_guest_notifier_pending;
|
|
vdc->guest_notifier_pending = virtio_net_guest_notifier_pending;
|