media: ov8856: Modify ov8856 register reading function to be simplified
authorBen Kao <ben.kao@intel.com>
Tue, 15 Jan 2019 09:36:07 +0000 (07:36 -0200)
committerMauro Carvalho Chehab <mchehab+samsung@kernel.org>
Fri, 25 Jan 2019 12:46:03 +0000 (10:46 -0200)
We use put_unaligned_be16() to be simplified for setting register address
in ov8856_read_reg() and use sizeof() to be better suited for bytes
copying.

Signed-off-by: Ben Kao <ben.kao@intel.com>
Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab+samsung@kernel.org>
drivers/media/i2c/ov8856.c

index c0d44082c00395a864157437a7675c5a4ac7efdd..dbf1095b9440288ce8ab92c99c593b8f5f96333c 100644 (file)
@@ -605,16 +605,17 @@ static int ov8856_read_reg(struct ov8856 *ov8856, u16 reg, u16 len, u32 *val)
 {
        struct i2c_client *client = v4l2_get_subdevdata(&ov8856->sd);
        struct i2c_msg msgs[2];
-       u8 addr_buf[2] = {reg >> 8, reg & 0xff};
-       u8 data_buf[4] = {0};
+       u8 addr_buf[2];
+       u8 data_buf[4] = {0};
        int ret;
 
        if (len > 4)
                return -EINVAL;
 
+       put_unaligned_be16(reg, addr_buf);
        msgs[0].addr = client->addr;
        msgs[0].flags = 0;
-       msgs[0].len = ARRAY_SIZE(addr_buf);
+       msgs[0].len = sizeof(addr_buf);
        msgs[0].buf = addr_buf;
        msgs[1].addr = client->addr;
        msgs[1].flags = I2C_M_RD;