Commit 1fffaf6a authored by Sergej Sawazki's avatar Sergej Sawazki Committed by Stephen Boyd

clk: si5351: Do not enable parent clocks on probe

The si5351 driver should not prepare or enable other clocks in the tree on
probe. Let the clients decide when to prepare or enable the clocks.

Cc: Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com>
Cc: Rabeeh Khoury <rabeeh@solid-run.com>
Signed-off-by: default avatarSergej Sawazki <ce3a@gmx.de>
[sboyd@codeaurora.org: Remove most of the .remove function too]
Signed-off-by: default avatarStephen Boyd <sboyd@codeaurora.org>
parent cdba9a4f
...@@ -1469,11 +1469,6 @@ static int si5351_i2c_probe(struct i2c_client *client, ...@@ -1469,11 +1469,6 @@ static int si5351_i2c_probe(struct i2c_client *client,
} }
} }
if (!IS_ERR(drvdata->pxtal))
clk_prepare_enable(drvdata->pxtal);
if (!IS_ERR(drvdata->pclkin))
clk_prepare_enable(drvdata->pclkin);
/* register xtal input clock gate */ /* register xtal input clock gate */
memset(&init, 0, sizeof(init)); memset(&init, 0, sizeof(init));
init.name = si5351_input_names[0]; init.name = si5351_input_names[0];
...@@ -1488,7 +1483,7 @@ static int si5351_i2c_probe(struct i2c_client *client, ...@@ -1488,7 +1483,7 @@ static int si5351_i2c_probe(struct i2c_client *client,
ret = devm_clk_hw_register(&client->dev, &drvdata->xtal); ret = devm_clk_hw_register(&client->dev, &drvdata->xtal);
if (ret) { if (ret) {
dev_err(&client->dev, "unable to register %s\n", init.name); dev_err(&client->dev, "unable to register %s\n", init.name);
goto err_clk; return ret;
} }
/* register clkin input clock gate */ /* register clkin input clock gate */
...@@ -1506,7 +1501,7 @@ static int si5351_i2c_probe(struct i2c_client *client, ...@@ -1506,7 +1501,7 @@ static int si5351_i2c_probe(struct i2c_client *client,
if (ret) { if (ret) {
dev_err(&client->dev, "unable to register %s\n", dev_err(&client->dev, "unable to register %s\n",
init.name); init.name);
goto err_clk; return ret;
} }
} }
...@@ -1528,7 +1523,7 @@ static int si5351_i2c_probe(struct i2c_client *client, ...@@ -1528,7 +1523,7 @@ static int si5351_i2c_probe(struct i2c_client *client,
ret = devm_clk_hw_register(&client->dev, &drvdata->pll[0].hw); ret = devm_clk_hw_register(&client->dev, &drvdata->pll[0].hw);
if (ret) { if (ret) {
dev_err(&client->dev, "unable to register %s\n", init.name); dev_err(&client->dev, "unable to register %s\n", init.name);
goto err_clk; return ret;
} }
/* register PLLB or VXCO (Si5351B) */ /* register PLLB or VXCO (Si5351B) */
...@@ -1552,7 +1547,7 @@ static int si5351_i2c_probe(struct i2c_client *client, ...@@ -1552,7 +1547,7 @@ static int si5351_i2c_probe(struct i2c_client *client,
ret = devm_clk_hw_register(&client->dev, &drvdata->pll[1].hw); ret = devm_clk_hw_register(&client->dev, &drvdata->pll[1].hw);
if (ret) { if (ret) {
dev_err(&client->dev, "unable to register %s\n", init.name); dev_err(&client->dev, "unable to register %s\n", init.name);
goto err_clk; return ret;
} }
/* register clk multisync and clk out divider */ /* register clk multisync and clk out divider */
...@@ -1571,7 +1566,7 @@ static int si5351_i2c_probe(struct i2c_client *client, ...@@ -1571,7 +1566,7 @@ static int si5351_i2c_probe(struct i2c_client *client,
if (WARN_ON(!drvdata->msynth || !drvdata->clkout)) { if (WARN_ON(!drvdata->msynth || !drvdata->clkout)) {
ret = -ENOMEM; ret = -ENOMEM;
goto err_clk; return ret;
} }
for (n = 0; n < num_clocks; n++) { for (n = 0; n < num_clocks; n++) {
...@@ -1591,7 +1586,7 @@ static int si5351_i2c_probe(struct i2c_client *client, ...@@ -1591,7 +1586,7 @@ static int si5351_i2c_probe(struct i2c_client *client,
if (ret) { if (ret) {
dev_err(&client->dev, "unable to register %s\n", dev_err(&client->dev, "unable to register %s\n",
init.name); init.name);
goto err_clk; return ret;
} }
} }
...@@ -1619,7 +1614,7 @@ static int si5351_i2c_probe(struct i2c_client *client, ...@@ -1619,7 +1614,7 @@ static int si5351_i2c_probe(struct i2c_client *client,
if (ret) { if (ret) {
dev_err(&client->dev, "unable to register %s\n", dev_err(&client->dev, "unable to register %s\n",
init.name); init.name);
goto err_clk; return ret;
} }
/* set initial clkout rate */ /* set initial clkout rate */
...@@ -1638,28 +1633,16 @@ static int si5351_i2c_probe(struct i2c_client *client, ...@@ -1638,28 +1633,16 @@ static int si5351_i2c_probe(struct i2c_client *client,
drvdata); drvdata);
if (ret) { if (ret) {
dev_err(&client->dev, "unable to add clk provider\n"); dev_err(&client->dev, "unable to add clk provider\n");
goto err_clk; return ret;
} }
return 0; return 0;
err_clk:
if (!IS_ERR(drvdata->pxtal))
clk_disable_unprepare(drvdata->pxtal);
if (!IS_ERR(drvdata->pclkin))
clk_disable_unprepare(drvdata->pclkin);
return ret;
} }
static int si5351_i2c_remove(struct i2c_client *client) static int si5351_i2c_remove(struct i2c_client *client)
{ {
struct si5351_driver_data *drvdata = i2c_get_clientdata(client);
of_clk_del_provider(client->dev.of_node); of_clk_del_provider(client->dev.of_node);
if (!IS_ERR(drvdata->pxtal))
clk_disable_unprepare(drvdata->pxtal);
if (!IS_ERR(drvdata->pclkin))
clk_disable_unprepare(drvdata->pclkin);
return 0; return 0;
} }
......
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