Commit e9e2e88f authored by Ruan Jinjie's avatar Ruan Jinjie Committed by Hans Verkuil

media: ov2640: Use the devm_clk_get_enabled() helper function

With devm_clk_get_enabled() the call to clk_disable_unprepare() can be
dropped from the error path and the remove callback.
Signed-off-by: default avatarRuan Jinjie <ruanjinjie@huawei.com>
Signed-off-by: default avatarSakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: default avatarHans Verkuil <hverkuil-cisco@xs4all.nl>
parent 17f2370a
...@@ -1205,17 +1205,14 @@ static int ov2640_probe(struct i2c_client *client) ...@@ -1205,17 +1205,14 @@ static int ov2640_probe(struct i2c_client *client)
return -ENOMEM; return -ENOMEM;
if (client->dev.of_node) { if (client->dev.of_node) {
priv->clk = devm_clk_get(&client->dev, "xvclk"); priv->clk = devm_clk_get_enabled(&client->dev, "xvclk");
if (IS_ERR(priv->clk)) if (IS_ERR(priv->clk))
return PTR_ERR(priv->clk); return PTR_ERR(priv->clk);
ret = clk_prepare_enable(priv->clk);
if (ret)
return ret;
} }
ret = ov2640_probe_dt(client, priv); ret = ov2640_probe_dt(client, priv);
if (ret) if (ret)
goto err_clk; return ret;
priv->win = ov2640_select_win(SVGA_WIDTH, SVGA_HEIGHT); priv->win = ov2640_select_win(SVGA_WIDTH, SVGA_HEIGHT);
priv->cfmt_code = MEDIA_BUS_FMT_UYVY8_2X8; priv->cfmt_code = MEDIA_BUS_FMT_UYVY8_2X8;
...@@ -1264,8 +1261,6 @@ static int ov2640_probe(struct i2c_client *client) ...@@ -1264,8 +1261,6 @@ static int ov2640_probe(struct i2c_client *client)
err_hdl: err_hdl:
v4l2_ctrl_handler_free(&priv->hdl); v4l2_ctrl_handler_free(&priv->hdl);
mutex_destroy(&priv->lock); mutex_destroy(&priv->lock);
err_clk:
clk_disable_unprepare(priv->clk);
return ret; return ret;
} }
...@@ -1278,7 +1273,6 @@ static void ov2640_remove(struct i2c_client *client) ...@@ -1278,7 +1273,6 @@ static void ov2640_remove(struct i2c_client *client)
mutex_destroy(&priv->lock); mutex_destroy(&priv->lock);
media_entity_cleanup(&priv->subdev.entity); media_entity_cleanup(&priv->subdev.entity);
v4l2_device_unregister_subdev(&priv->subdev); v4l2_device_unregister_subdev(&priv->subdev);
clk_disable_unprepare(priv->clk);
} }
static const struct i2c_device_id ov2640_id[] = { static const struct i2c_device_id ov2640_id[] = {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment