]> www.infradead.org Git - linux-platform-drivers-x86.git/commitdiff
vdpa/mlx5: fix param validation in mlx5_vdpa_get_config()
authorStefano Garzarella <sgarzare@redhat.com>
Mon, 8 Feb 2021 16:17:41 +0000 (17:17 +0100)
committerMichael S. Tsirkin <mst@redhat.com>
Tue, 23 Feb 2021 12:52:59 +0000 (07:52 -0500)
It's legal to have 'offset + len' equal to
sizeof(struct virtio_net_config), since 'ndev->config' is a
'struct virtio_net_config', so we can safely copy its content under
this condition.

Fixes: 1a86b377aa21 ("vdpa/mlx5: Add VDPA driver for supported mlx5 devices")
Cc: stable@vger.kernel.org
Signed-off-by: Stefano Garzarella <sgarzare@redhat.com>
Link: https://lore.kernel.org/r/20210208161741.104939-1-sgarzare@redhat.com
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
Acked-by: Jason Wang <jasowang@redhat.com>
Acked-by: Eli Cohen <elic@nvidia.com>
drivers/vdpa/mlx5/net/mlx5_vnet.c

index dc88559a8d49cfbefb395896256609cf5ed677bc..10e9b09932eb8a46358c733b7b779267262302f4 100644 (file)
@@ -1820,7 +1820,7 @@ static void mlx5_vdpa_get_config(struct vdpa_device *vdev, unsigned int offset,
        struct mlx5_vdpa_dev *mvdev = to_mvdev(vdev);
        struct mlx5_vdpa_net *ndev = to_mlx5_vdpa_ndev(mvdev);
 
-       if (offset + len < sizeof(struct virtio_net_config))
+       if (offset + len <= sizeof(struct virtio_net_config))
                memcpy(buf, (u8 *)&ndev->config + offset, len);
 }