On Thu, 2018-08-16 at 19:47 +0100, Luca Boccassi wrote:
> From: Brian Russell <bruss...@brocade.com>
> 
> In virtio_read_caps and vtpci_msix_detect, rte_pci_read_config
> returns
> the number of bytes read from PCI config or < 0 on error.
> If less than the expected number of bytes are read then log the
> failure and return rather than carrying on with garbage.
> 
> Fixes: 6ba1f63b5ab0 ("virtio: support specification 1.0")
> 
> Signed-off-by: Brian Russell <bruss...@brocade.com>
> Signed-off-by: Luca Boccassi <bl...@debian.org>
> ---
> v2: handle additional rte_pci_read_config incomplete reads
> 
>  drivers/net/virtio/virtio_pci.c | 35 +++++++++++++++++++++--------
> ----
>  1 file changed, 22 insertions(+), 13 deletions(-)
> 
> diff --git a/drivers/net/virtio/virtio_pci.c
> b/drivers/net/virtio/virtio_pci.c
> index 6bd22e54a6..ff6f96f361 100644
> --- a/drivers/net/virtio/virtio_pci.c
> +++ b/drivers/net/virtio/virtio_pci.c
...
> @@ -610,9 +613,13 @@ virtio_read_caps(struct rte_pci_device *dev,
> struct virtio_hw *hw)
>                       hw->common_cfg = get_cfg_addr(dev, &cap);
>                       break;
>               case VIRTIO_PCI_CAP_NOTIFY_CFG:
> -                     rte_pci_read_config(dev, &hw-
> >notify_off_multiplier,
> -                                     4, pos + sizeof(cap));
> -                     hw->notify_base = get_cfg_addr(dev, &cap);
> +                     /* Avoid half-reads into hw */
> +                     ret = rte_pci_read_config(dev, &multiplier,
> 4,
> +                                     pos + sizeof(cap));
> +                     if (ret == 4) {
> +                             hw->notify_off_multiplier =
> multiplier;
> +                             hw->notify_base = get_cfg_addr(dev,
> &cap);
> +                     }
>                       break;
>               case VIRTIO_PCI_CAP_DEVICE_CFG:
>                       hw->dev_cfg = get_cfg_addr(dev, &cap);

Tiwei: not 100% sure what's the best way to handle a failure here, this
will avoid writing to *hw in case of errors. Let me know if this is OK.

-- 
Kind regards,
Luca Boccassi

Reply via email to