Commit 870aaff9 authored by Laura Abbott's avatar Laura Abbott Committed by Michael S. Tsirkin

vdpa: clean up get_config_size ret value handling

The return type of get_config_size is size_t so it makes
sense to change the type of the variable holding its result.

That said, this already got taken care of (differently, and arguably
not as well) by commit 3ed21c14 ("vdpa: check that offsets are
within bounds").

The added 'c->off > size' test in that commit will be done as an
unsigned comparison on 32-bit (safe due to not being signed).

On a 64-bit platform, it will be done as a signed comparison, but in
that case the comparison will be done in 64-bit, and 'c->off' being an
u32 it will be valid thanks to the extended range (ie both values will
be positive in 64 bits).

So this was a real bug, but it was already addressed and marked for stable.
Signed-off-by: default avatarLaura Abbott <labbott@kernel.org>
Reported-by: default avatarLuo Likang <luolikang@nsfocus.com>
Signed-off-by: default avatarMichael S. Tsirkin <mst@redhat.com>
parent 1861ba62
...@@ -195,7 +195,7 @@ static int vhost_vdpa_config_validate(struct vhost_vdpa *v, ...@@ -195,7 +195,7 @@ static int vhost_vdpa_config_validate(struct vhost_vdpa *v,
struct vhost_vdpa_config *c) struct vhost_vdpa_config *c)
{ {
struct vdpa_device *vdpa = v->vdpa; struct vdpa_device *vdpa = v->vdpa;
long size = vdpa->config->get_config_size(vdpa); size_t size = vdpa->config->get_config_size(vdpa);
if (c->len == 0 || c->off > size) if (c->len == 0 || c->off > size)
return -EINVAL; return -EINVAL;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment