media: ccs: Refactor register reading a little
authorSakari Ailus <sakari.ailus@linux.intel.com>
Wed, 2 Sep 2020 10:09:03 +0000 (12:09 +0200)
committerMauro Carvalho Chehab <mchehab+huawei@kernel.org>
Thu, 3 Dec 2020 11:27:31 +0000 (12:27 +0100)
Rework quirk and 8-bit only access functions with a single function that
takes arguments. This is later extensible to support yet more flags.

Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
drivers/media/i2c/ccs/ccs-reg-access.c

index a8e9a235bfb3a76e57eaad457b37435527a5fa79..abec746f3c93faa45374a91a35d05fb80847e153 100644 (file)
@@ -168,39 +168,36 @@ static int __ccs_read_addr(struct ccs_sensor *sensor, u32 reg, u32 *val,
        return 0;
 }
 
-int ccs_read_addr_no_quirk(struct ccs_sensor *sensor, u32 reg, u32 *val)
-{
-       return __ccs_read_addr(
-               sensor, reg, val,
-               ccs_needs_quirk(sensor, CCS_QUIRK_FLAG_8BIT_READ_ONLY));
-}
-
-static int ccs_read_addr_quirk(struct ccs_sensor *sensor, u32 reg, u32 *val,
-                              bool force8)
+static int ccs_read_addr_raw(struct ccs_sensor *sensor, u32 reg, u32 *val,
+                            bool force8, bool quirk)
 {
        int rval;
 
-       *val = 0;
-       rval = ccs_call_quirk(sensor, reg_access, false, &reg, val);
-       if (rval == -ENOIOCTLCMD)
-               return 0;
-       if (rval < 0)
-               return rval;
+       if (quirk) {
+               *val = 0;
+               rval = ccs_call_quirk(sensor, reg_access, false, &reg, val);
+               if (rval == -ENOIOCTLCMD)
+                       return 0;
+               if (rval < 0)
+                       return rval;
 
-       if (force8)
-               return __ccs_read_addr(sensor, reg, val, true);
+               if (force8)
+                       return __ccs_read_addr(sensor, reg, val, true);
+       }
 
-       return ccs_read_addr_no_quirk(sensor, reg, val);
+       return __ccs_read_addr(sensor, reg, val,
+                              ccs_needs_quirk(sensor,
+                                              CCS_QUIRK_FLAG_8BIT_READ_ONLY));
 }
 
 int ccs_read_addr(struct ccs_sensor *sensor, u32 reg, u32 *val)
 {
-       return ccs_read_addr_quirk(sensor, reg, val, false);
+       return ccs_read_addr_raw(sensor, reg, val, false, true);
 }
 
 int ccs_read_addr_8only(struct ccs_sensor *sensor, u32 reg, u32 *val)
 {
-       return ccs_read_addr_quirk(sensor, reg, val, true);
+       return ccs_read_addr_raw(sensor, reg, val, true, true);
 }
 
 int ccs_write_addr_no_quirk(struct ccs_sensor *sensor, u32 reg, u32 val)