net/queue: queue packets even if sender doesn't supply a callback
Now that we disable any receiver whose queue is full, we do not require senders to handle a zero return by supplying a sent callback. This is a second step towards allowing can_receive() handlers to return true even if no buffer space is available. Signed-off-by: Mark McLoughlin <markmc@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
parent
893379efd0
commit
839f368f2b
@ -186,7 +186,7 @@ ssize_t qemu_net_queue_send(NetQueue *queue,
|
|||||||
}
|
}
|
||||||
|
|
||||||
ret = qemu_net_queue_deliver(queue, sender, flags, data, size);
|
ret = qemu_net_queue_deliver(queue, sender, flags, data, size);
|
||||||
if (ret == 0 && sent_cb != NULL) {
|
if (ret == 0) {
|
||||||
qemu_net_queue_append(queue, sender, flags, data, size, sent_cb);
|
qemu_net_queue_append(queue, sender, flags, data, size, sent_cb);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -210,7 +210,7 @@ ssize_t qemu_net_queue_send_iov(NetQueue *queue,
|
|||||||
}
|
}
|
||||||
|
|
||||||
ret = qemu_net_queue_deliver_iov(queue, sender, flags, iov, iovcnt);
|
ret = qemu_net_queue_deliver_iov(queue, sender, flags, iov, iovcnt);
|
||||||
if (ret == 0 && sent_cb != NULL) {
|
if (ret == 0) {
|
||||||
qemu_net_queue_append_iov(queue, sender, flags, iov, iovcnt, sent_cb);
|
qemu_net_queue_append_iov(queue, sender, flags, iov, iovcnt, sent_cb);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -246,7 +246,7 @@ void qemu_net_queue_flush(NetQueue *queue)
|
|||||||
packet->flags,
|
packet->flags,
|
||||||
packet->data,
|
packet->data,
|
||||||
packet->size);
|
packet->size);
|
||||||
if (ret == 0 && packet->sent_cb != NULL) {
|
if (ret == 0) {
|
||||||
QTAILQ_INSERT_HEAD(&queue->packets, packet, entry);
|
QTAILQ_INSERT_HEAD(&queue->packets, packet, entry);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user