[media] smiapp: Verify clock frequency after setting it, prevent changing it
authorSakari Ailus <sakari.ailus@linux.intel.com>
Tue, 29 Aug 2017 12:41:23 +0000 (09:41 -0300)
committerMauro Carvalho Chehab <mchehab@osg.samsung.com>
Wed, 4 Oct 2017 20:24:11 +0000 (17:24 -0300)
The external clock frequency was set by the driver but the obtained
frequency was never verified. Do that.

Being able to obtain the exact frequency is important as the value is used
for PLL calculations which may result in frequencies that violate the PLL
tree limits.

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

index d581625d782631db939a09adb4abe542f4a83871..55771826b446e418bc77f232eef33ace522337d9 100644 (file)
@@ -2870,6 +2870,7 @@ static int smiapp_probe(struct i2c_client *client,
 {
        struct smiapp_sensor *sensor;
        struct smiapp_hwconfig *hwcfg = smiapp_get_hwconfig(&client->dev);
+       unsigned long rate;
        unsigned int i;
        int rval;
 
@@ -2908,6 +2909,14 @@ static int smiapp_probe(struct i2c_client *client,
                return rval;
        }
 
+       rate = clk_get_rate(sensor->ext_clk);
+       if (rate != sensor->hwcfg->ext_clk) {
+               dev_err(&client->dev,
+                       "can't set clock freq, asked for %u but got %lu\n",
+                       sensor->hwcfg->ext_clk, rate);
+               return rval;
+       }
+
        sensor->xshutdown = devm_gpiod_get_optional(&client->dev, "xshutdown",
                                                    GPIOD_OUT_LOW);
        if (IS_ERR(sensor->xshutdown))