提交 10939b10 编写于 作者: V Vivek Gautam 提交者: Kishon Vijay Abraham I

phy: qcom-qmp: Adapt to clk_bulk_* APIs

Move from using array of clocks to clk_bulk_* APIs that
are available now.
Signed-off-by: NVivek Gautam <vivek.gautam@codeaurora.org>
Signed-off-by: NManu Gautam <mgautam@codeaurora.org>
Signed-off-by: NKishon Vijay Abraham I <kishon@ti.com>
上级 f8ba22a3
...@@ -555,7 +555,7 @@ struct qcom_qmp { ...@@ -555,7 +555,7 @@ struct qcom_qmp {
struct device *dev; struct device *dev;
void __iomem *serdes; void __iomem *serdes;
struct clk **clks; struct clk_bulk_data *clks;
struct reset_control **resets; struct reset_control **resets;
struct regulator_bulk_data *vregs; struct regulator_bulk_data *vregs;
...@@ -857,22 +857,19 @@ static int qcom_qmp_phy_init(struct phy *phy) ...@@ -857,22 +857,19 @@ static int qcom_qmp_phy_init(struct phy *phy)
void __iomem *pcs = qphy->pcs; void __iomem *pcs = qphy->pcs;
void __iomem *status; void __iomem *status;
unsigned int mask, val; unsigned int mask, val;
int ret, i; int ret;
dev_vdbg(qmp->dev, "Initializing QMP phy\n"); dev_vdbg(qmp->dev, "Initializing QMP phy\n");
for (i = 0; i < qmp->cfg->num_clks; i++) { ret = clk_bulk_prepare_enable(cfg->num_clks, qmp->clks);
ret = clk_prepare_enable(qmp->clks[i]); if (ret) {
if (ret) { dev_err(qmp->dev, "failed to enable clks, err=%d\n", ret);
dev_err(qmp->dev, "failed to enable %s clk, err=%d\n", return ret;
qmp->cfg->clk_list[i], ret);
goto err_clk;
}
} }
ret = qcom_qmp_phy_com_init(qmp); ret = qcom_qmp_phy_com_init(qmp);
if (ret) if (ret)
goto err_clk; goto err_com_init;
if (cfg->has_lane_rst) { if (cfg->has_lane_rst) {
ret = reset_control_deassert(qphy->lane_rst); ret = reset_control_deassert(qphy->lane_rst);
...@@ -920,9 +917,8 @@ static int qcom_qmp_phy_init(struct phy *phy) ...@@ -920,9 +917,8 @@ static int qcom_qmp_phy_init(struct phy *phy)
reset_control_assert(qphy->lane_rst); reset_control_assert(qphy->lane_rst);
err_lane_rst: err_lane_rst:
qcom_qmp_phy_com_exit(qmp); qcom_qmp_phy_com_exit(qmp);
err_clk: err_com_init:
while (--i >= 0) clk_bulk_disable_unprepare(cfg->num_clks, qmp->clks);
clk_disable_unprepare(qmp->clks[i]);
return ret; return ret;
} }
...@@ -932,7 +928,6 @@ static int qcom_qmp_phy_exit(struct phy *phy) ...@@ -932,7 +928,6 @@ static int qcom_qmp_phy_exit(struct phy *phy)
struct qmp_phy *qphy = phy_get_drvdata(phy); struct qmp_phy *qphy = phy_get_drvdata(phy);
struct qcom_qmp *qmp = qphy->qmp; struct qcom_qmp *qmp = qphy->qmp;
const struct qmp_phy_cfg *cfg = qmp->cfg; const struct qmp_phy_cfg *cfg = qmp->cfg;
int i = cfg->num_clks;
clk_disable_unprepare(qphy->pipe_clk); clk_disable_unprepare(qphy->pipe_clk);
...@@ -950,8 +945,7 @@ static int qcom_qmp_phy_exit(struct phy *phy) ...@@ -950,8 +945,7 @@ static int qcom_qmp_phy_exit(struct phy *phy)
qcom_qmp_phy_com_exit(qmp); qcom_qmp_phy_com_exit(qmp);
while (--i >= 0) clk_bulk_disable_unprepare(cfg->num_clks, qmp->clks);
clk_disable_unprepare(qmp->clks[i]);
return 0; return 0;
} }
...@@ -1000,29 +994,17 @@ static int qcom_qmp_phy_reset_init(struct device *dev) ...@@ -1000,29 +994,17 @@ static int qcom_qmp_phy_reset_init(struct device *dev)
static int qcom_qmp_phy_clk_init(struct device *dev) static int qcom_qmp_phy_clk_init(struct device *dev)
{ {
struct qcom_qmp *qmp = dev_get_drvdata(dev); struct qcom_qmp *qmp = dev_get_drvdata(dev);
int ret, i; int num = qmp->cfg->num_clks;
int i;
qmp->clks = devm_kcalloc(dev, qmp->cfg->num_clks, qmp->clks = devm_kcalloc(dev, num, sizeof(*qmp->clks), GFP_KERNEL);
sizeof(*qmp->clks), GFP_KERNEL);
if (!qmp->clks) if (!qmp->clks)
return -ENOMEM; return -ENOMEM;
for (i = 0; i < qmp->cfg->num_clks; i++) { for (i = 0; i < num; i++)
struct clk *_clk; qmp->clks[i].id = qmp->cfg->clk_list[i];
const char *name = qmp->cfg->clk_list[i];
_clk = devm_clk_get(dev, name);
if (IS_ERR(_clk)) {
ret = PTR_ERR(_clk);
if (ret != -EPROBE_DEFER)
dev_err(dev, "failed to get %s clk, %d\n",
name, ret);
return ret;
}
qmp->clks[i] = _clk;
}
return 0; return devm_clk_bulk_get(dev, num, qmp->clks);
} }
/* /*
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册