]> git.hungrycats.org Git - linux/commitdiff
V4L/DVB: v4l: soc_camera: fix bound checking of mbus_fmt[] index
authorBaruch Siach <baruch@tkos.co.il>
Fri, 19 Feb 2010 17:09:25 +0000 (14:09 -0300)
committerGreg Kroah-Hartman <gregkh@suse.de>
Mon, 15 Mar 2010 16:06:09 +0000 (09:06 -0700)
commit 84f3751d6a6f766780dee509433bf7b3dfcdf465 upstream.

When code <= V4L2_MBUS_FMT_FIXED soc_mbus_get_fmtdesc returns a pointer to
mbus_fmt[x], where x < 0. Fix this.

Signed-off-by: Baruch Siach <baruch@tkos.co.il>
Signed-off-by: Guennadi Liakhovetski <g.liakhovetski@gmx.de>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
drivers/media/video/soc_mediabus.c

index f8d5c87dc2aafff0854006d4dbea5d3dcadd218a..a4c0ef4b9d3b936599d75f4eab15a514efba6f32 100644 (file)
@@ -134,7 +134,8 @@ EXPORT_SYMBOL(soc_mbus_bytes_per_line);
 const struct soc_mbus_pixelfmt *soc_mbus_get_fmtdesc(
        enum v4l2_mbus_pixelcode code)
 {
-       if ((unsigned int)(code - V4L2_MBUS_FMT_FIXED) > ARRAY_SIZE(mbus_fmt))
+       if (code - V4L2_MBUS_FMT_FIXED > ARRAY_SIZE(mbus_fmt) ||
+           code <= V4L2_MBUS_FMT_FIXED)
                return NULL;
        return mbus_fmt + code - V4L2_MBUS_FMT_FIXED - 1;
 }