[media] smiapp: Fix determining the need for 8-bit read access
authorSakari Ailus <sakari.ailus@linux.intel.com>
Sat, 12 Apr 2014 19:41:12 +0000 (16:41 -0300)
committerMauro Carvalho Chehab <m.chehab@samsung.com>
Wed, 23 Apr 2014 14:10:27 +0000 (11:10 -0300)
8-bit reads are needed in some cases; however the condition used was wrong.
Regular access (register width) was used if:

len == SMIAPP_REG_8BIT && !only8

This causes 8-bit read access to be used always. The operator should be ||
instead: regular access can be used for 8-bit reads OR if allowed otherwise.

Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: Mauro Carvalho Chehab <m.chehab@samsung.com>
drivers/media/i2c/smiapp/smiapp-regs.c

index 5d0151a0bf18bc2ffd27d1f6d1a9e89c3ab4191f..c2db20538ebb9d8e2d5fbd76368b5ccdc5f96804 100644 (file)
@@ -172,7 +172,7 @@ static int __smiapp_read(struct smiapp_sensor *sensor, u32 reg, u32 *val,
            && len != SMIAPP_REG_32BIT)
                return -EINVAL;
 
-       if (len == SMIAPP_REG_8BIT && !only8)
+       if (len == SMIAPP_REG_8BIT || !only8)
                rval = ____smiapp_read(sensor, (u16)reg, len, val);
        else
                rval = ____smiapp_read_8only(sensor, (u16)reg, len, val);