media: imx274: simplify imx274_write_table()
authorLuca Ceresoli <luca@lucaceresoli.net>
Mon, 11 Jun 2018 11:35:36 +0000 (07:35 -0400)
committerMauro Carvalho Chehab <mchehab+samsung@kernel.org>
Wed, 4 Jul 2018 11:26:57 +0000 (07:26 -0400)
imx274_write_table() is a mere wrapper (and the only user) to
imx274_regmap_util_write_table_8(). Remove this useless indirection by
merging the two functions into one.

Also get rid of the wait_ms_addr and end_addr parameters since it does
not make any sense to give them any values other than
IMX274_TABLE_WAIT_MS and IMX274_TABLE_END.

Signed-off-by: Luca Ceresoli <luca@lucaceresoli.net>
Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab+samsung@kernel.org>
drivers/media/i2c/imx274.c

index ceeec97cd33034b967fb1d9332ad849a7d957b62..48343c2ade83c38c04f609d3fd53d490f5c81ef9 100644 (file)
@@ -597,20 +597,18 @@ static inline struct stimx274 *to_imx274(struct v4l2_subdev *sd)
 }
 
 /*
- * imx274_regmap_util_write_table_8 - Function for writing register table
- * @regmap: Pointer to device reg map structure
- * @table: Table containing register values
- * @wait_ms_addr: Flag for performing delay
- * @end_addr: Flag for incating end of table
+ * Writing a register table
+ *
+ * @priv: Pointer to device
+ * @table: Table containing register values (with optional delays)
  *
  * This is used to write register table into sensor's reg map.
  *
  * Return: 0 on success, errors otherwise
  */
-static int imx274_regmap_util_write_table_8(struct regmap *regmap,
-                                           const struct reg_8 table[],
-                                           u16 wait_ms_addr, u16 end_addr)
+static int imx274_write_table(struct stimx274 *priv, const struct reg_8 table[])
 {
+       struct regmap *regmap = priv->regmap;
        int err = 0;
        const struct reg_8 *next;
        u8 val;
@@ -622,8 +620,8 @@ static int imx274_regmap_util_write_table_8(struct regmap *regmap,
 
        for (next = table;; next++) {
                if ((next->addr != range_start + range_count) ||
-                   (next->addr == end_addr) ||
-                   (next->addr == wait_ms_addr) ||
+                   (next->addr == IMX274_TABLE_END) ||
+                   (next->addr == IMX274_TABLE_WAIT_MS) ||
                    (range_count == max_range_vals)) {
                        if (range_count == 1)
                                err = regmap_write(regmap,
@@ -642,10 +640,10 @@ static int imx274_regmap_util_write_table_8(struct regmap *regmap,
                        range_count = 0;
 
                        /* Handle special address values */
-                       if (next->addr == end_addr)
+                       if (next->addr == IMX274_TABLE_END)
                                break;
 
-                       if (next->addr == wait_ms_addr) {
+                       if (next->addr == IMX274_TABLE_WAIT_MS) {
                                msleep_range(next->val);
                                continue;
                        }
@@ -692,12 +690,6 @@ static inline int imx274_write_reg(struct stimx274 *priv, u16 addr, u8 val)
        return err;
 }
 
-static int imx274_write_table(struct stimx274 *priv, const struct reg_8 table[])
-{
-       return imx274_regmap_util_write_table_8(priv->regmap,
-               table, IMX274_TABLE_WAIT_MS, IMX274_TABLE_END);
-}
-
 /*
  * Set mode registers to start stream.
  * @priv: Pointer to device structure