mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-07-26 20:03:54 -06:00
net: introduce qemu_receive_packet()
Some NIC supports loopback mode and this is done by calling nc->info->receive() directly which in fact suppresses the effort of reentrancy check that is done in qemu_net_queue_send(). Unfortunately we can't use qemu_net_queue_send() here since for loopback there's no sender as peer, so this patch introduce a qemu_receive_packet() which is used for implementing loopback mode for a NIC with this check. NIC that supports loopback mode will be converted to this helper. This is intended to address CVE-2021-3416. Cc: Prasad J Pandit <ppandit@redhat.com> Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com> Cc: qemu-stable@nongnu.org Signed-off-by: Jason Wang <jasowang@redhat.com>
This commit is contained in:
parent
3de46e6fc4
commit
705df5466c
4 changed files with 66 additions and 7 deletions
22
net/queue.c
22
net/queue.c
|
@ -182,6 +182,28 @@ static ssize_t qemu_net_queue_deliver_iov(NetQueue *queue,
|
|||
return ret;
|
||||
}
|
||||
|
||||
ssize_t qemu_net_queue_receive(NetQueue *queue,
|
||||
const uint8_t *data,
|
||||
size_t size)
|
||||
{
|
||||
if (queue->delivering) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
return qemu_net_queue_deliver(queue, NULL, 0, data, size);
|
||||
}
|
||||
|
||||
ssize_t qemu_net_queue_receive_iov(NetQueue *queue,
|
||||
const struct iovec *iov,
|
||||
int iovcnt)
|
||||
{
|
||||
if (queue->delivering) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
return qemu_net_queue_deliver_iov(queue, NULL, 0, iov, iovcnt);
|
||||
}
|
||||
|
||||
ssize_t qemu_net_queue_send(NetQueue *queue,
|
||||
NetClientState *sender,
|
||||
unsigned flags,
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue