Hi Marvin,

> -----Original Message-----
> From: Liu, Yong <yong....@intel.com>
> Sent: Wednesday, March 3, 2021 3:28 PM
> To: maxime.coque...@redhat.com; Xia, Chenbo <chenbo....@intel.com>
> Cc: dev@dpdk.org; Liu, Yong <yong....@intel.com>; sta...@dpdk.org
> Subject: [PATCH] vhost: fix accessing uninitialized variables
> 
> This patch fixs coverity issue by adding initialization step before
> using temporary virtio header.
> 
> Coverity issue: 366181, 366123
> Fixes: fb3815cc614d ("vhost: handle virtually non-contiguous buffers in Rx-
> mrg")
> Cc: sta...@dpdk.org
> 
> Signed-off-by: Marvin Liu <yong....@intel.com>
> 
> diff --git a/lib/librte_vhost/virtio_net.c b/lib/librte_vhost/virtio_net.c
> index 583bf379c6..fe464b3088 100644
> --- a/lib/librte_vhost/virtio_net.c
> +++ b/lib/librte_vhost/virtio_net.c
> @@ -808,9 +808,10 @@ copy_mbuf_to_desc(struct virtio_net *dev, struct
> vhost_virtqueue *vq,

You should apply the same fix to async_mbuf_to_desc.
Maybe you did not notice: one coverity issue is in copy_mbuf_to_desc, but 
another
in async_mbuf_to_desc :)

Thanks,
Chenbo

> 
>       hdr_mbuf = m;
>       hdr_addr = buf_addr;
> -     if (unlikely(buf_len < dev->vhost_hlen))
> +     if (unlikely(buf_len < dev->vhost_hlen)) {
> +             memset(&tmp_hdr, 0, sizeof(struct virtio_net_hdr_mrg_rxbuf));
>               hdr = &tmp_hdr;
> -     else
> +     } else
>               hdr = (struct virtio_net_hdr_mrg_rxbuf *)(uintptr_t)hdr_addr;
> 
>       VHOST_LOG_DATA(DEBUG, "(%d) RX: num merge buffers %d\n",
> --
> 2.17.1

Reply via email to