Commit 89bd296b authored by Vivek Gautam's avatar Vivek Gautam Committed by Martin K. Petersen

phy: qcom-ufs: Cleanup clock and regulator initialization

Different menthods pass around generic phy pointer to
extract device pointer. Instead, pass the device pointer
directly between function calls.
Signed-off-by: default avatarVivek Gautam <vivek.gautam@codeaurora.org>
Reviewed-by: default avatarSubhash Jadavani <subhashj@codeaurora.org>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent add78fc0
...@@ -142,10 +142,8 @@ struct ufs_qcom_phy *get_ufs_qcom_phy(struct phy *generic_phy); ...@@ -142,10 +142,8 @@ struct ufs_qcom_phy *get_ufs_qcom_phy(struct phy *generic_phy);
int ufs_qcom_phy_power_on(struct phy *generic_phy); int ufs_qcom_phy_power_on(struct phy *generic_phy);
int ufs_qcom_phy_power_off(struct phy *generic_phy); int ufs_qcom_phy_power_off(struct phy *generic_phy);
int ufs_qcom_phy_exit(struct phy *generic_phy); int ufs_qcom_phy_exit(struct phy *generic_phy);
int ufs_qcom_phy_init_clks(struct phy *generic_phy, int ufs_qcom_phy_init_clks(struct ufs_qcom_phy *phy_common);
struct ufs_qcom_phy *phy_common); int ufs_qcom_phy_init_vregulators(struct ufs_qcom_phy *phy_common);
int ufs_qcom_phy_init_vregulators(struct phy *generic_phy,
struct ufs_qcom_phy *phy_common);
int ufs_qcom_phy_remove(struct phy *generic_phy, int ufs_qcom_phy_remove(struct phy *generic_phy,
struct ufs_qcom_phy *ufs_qcom_phy); struct ufs_qcom_phy *ufs_qcom_phy);
struct phy *ufs_qcom_phy_generic_probe(struct platform_device *pdev, struct phy *ufs_qcom_phy_generic_probe(struct platform_device *pdev,
......
...@@ -48,14 +48,14 @@ static int ufs_qcom_phy_qmp_14nm_init(struct phy *generic_phy) ...@@ -48,14 +48,14 @@ static int ufs_qcom_phy_qmp_14nm_init(struct phy *generic_phy)
struct ufs_qcom_phy *phy_common = &phy->common_cfg; struct ufs_qcom_phy *phy_common = &phy->common_cfg;
int err; int err;
err = ufs_qcom_phy_init_clks(generic_phy, phy_common); err = ufs_qcom_phy_init_clks(phy_common);
if (err) { if (err) {
dev_err(phy_common->dev, "%s: ufs_qcom_phy_init_clks() failed %d\n", dev_err(phy_common->dev, "%s: ufs_qcom_phy_init_clks() failed %d\n",
__func__, err); __func__, err);
goto out; goto out;
} }
err = ufs_qcom_phy_init_vregulators(generic_phy, phy_common); err = ufs_qcom_phy_init_vregulators(phy_common);
if (err) { if (err) {
dev_err(phy_common->dev, "%s: ufs_qcom_phy_init_vregulators() failed %d\n", dev_err(phy_common->dev, "%s: ufs_qcom_phy_init_vregulators() failed %d\n",
__func__, err); __func__, err);
......
...@@ -67,14 +67,14 @@ static int ufs_qcom_phy_qmp_20nm_init(struct phy *generic_phy) ...@@ -67,14 +67,14 @@ static int ufs_qcom_phy_qmp_20nm_init(struct phy *generic_phy)
struct ufs_qcom_phy *phy_common = &phy->common_cfg; struct ufs_qcom_phy *phy_common = &phy->common_cfg;
int err = 0; int err = 0;
err = ufs_qcom_phy_init_clks(generic_phy, phy_common); err = ufs_qcom_phy_init_clks(phy_common);
if (err) { if (err) {
dev_err(phy_common->dev, "%s: ufs_qcom_phy_init_clks() failed %d\n", dev_err(phy_common->dev, "%s: ufs_qcom_phy_init_clks() failed %d\n",
__func__, err); __func__, err);
goto out; goto out;
} }
err = ufs_qcom_phy_init_vregulators(generic_phy, phy_common); err = ufs_qcom_phy_init_vregulators(phy_common);
if (err) { if (err) {
dev_err(phy_common->dev, "%s: ufs_qcom_phy_init_vregulators() failed %d\n", dev_err(phy_common->dev, "%s: ufs_qcom_phy_init_vregulators() failed %d\n",
__func__, err); __func__, err);
......
...@@ -22,9 +22,9 @@ ...@@ -22,9 +22,9 @@
#define VDDP_REF_CLK_MIN_UV 1200000 #define VDDP_REF_CLK_MIN_UV 1200000
#define VDDP_REF_CLK_MAX_UV 1200000 #define VDDP_REF_CLK_MAX_UV 1200000
static int __ufs_qcom_phy_init_vreg(struct phy *, struct ufs_qcom_phy_vreg *, static int __ufs_qcom_phy_init_vreg(struct device *, struct ufs_qcom_phy_vreg *,
const char *, bool); const char *, bool);
static int ufs_qcom_phy_init_vreg(struct phy *, struct ufs_qcom_phy_vreg *, static int ufs_qcom_phy_init_vreg(struct device *, struct ufs_qcom_phy_vreg *,
const char *); const char *);
static int ufs_qcom_phy_base_init(struct platform_device *pdev, static int ufs_qcom_phy_base_init(struct platform_device *pdev,
struct ufs_qcom_phy *phy_common); struct ufs_qcom_phy *phy_common);
...@@ -154,13 +154,11 @@ int ufs_qcom_phy_base_init(struct platform_device *pdev, ...@@ -154,13 +154,11 @@ int ufs_qcom_phy_base_init(struct platform_device *pdev,
return 0; return 0;
} }
static int __ufs_qcom_phy_clk_get(struct phy *phy, static int __ufs_qcom_phy_clk_get(struct device *dev,
const char *name, struct clk **clk_out, bool err_print) const char *name, struct clk **clk_out, bool err_print)
{ {
struct clk *clk; struct clk *clk;
int err = 0; int err = 0;
struct ufs_qcom_phy *ufs_qcom_phy = get_ufs_qcom_phy(phy);
struct device *dev = ufs_qcom_phy->dev;
clk = devm_clk_get(dev, name); clk = devm_clk_get(dev, name);
if (IS_ERR(clk)) { if (IS_ERR(clk)) {
...@@ -174,30 +172,27 @@ static int __ufs_qcom_phy_clk_get(struct phy *phy, ...@@ -174,30 +172,27 @@ static int __ufs_qcom_phy_clk_get(struct phy *phy,
return err; return err;
} }
static static int ufs_qcom_phy_clk_get(struct device *dev,
int ufs_qcom_phy_clk_get(struct phy *phy,
const char *name, struct clk **clk_out) const char *name, struct clk **clk_out)
{ {
return __ufs_qcom_phy_clk_get(phy, name, clk_out, true); return __ufs_qcom_phy_clk_get(dev, name, clk_out, true);
} }
int int ufs_qcom_phy_init_clks(struct ufs_qcom_phy *phy_common)
ufs_qcom_phy_init_clks(struct phy *generic_phy,
struct ufs_qcom_phy *phy_common)
{ {
int err; int err;
err = ufs_qcom_phy_clk_get(generic_phy, "tx_iface_clk", err = ufs_qcom_phy_clk_get(phy_common->dev, "tx_iface_clk",
&phy_common->tx_iface_clk); &phy_common->tx_iface_clk);
if (err) if (err)
goto out; goto out;
err = ufs_qcom_phy_clk_get(generic_phy, "rx_iface_clk", err = ufs_qcom_phy_clk_get(phy_common->dev, "rx_iface_clk",
&phy_common->rx_iface_clk); &phy_common->rx_iface_clk);
if (err) if (err)
goto out; goto out;
err = ufs_qcom_phy_clk_get(generic_phy, "ref_clk_src", err = ufs_qcom_phy_clk_get(phy_common->dev, "ref_clk_src",
&phy_common->ref_clk_src); &phy_common->ref_clk_src);
if (err) if (err)
goto out; goto out;
...@@ -206,10 +201,10 @@ ufs_qcom_phy_init_clks(struct phy *generic_phy, ...@@ -206,10 +201,10 @@ ufs_qcom_phy_init_clks(struct phy *generic_phy,
* "ref_clk_parent" is optional hence don't abort init if it's not * "ref_clk_parent" is optional hence don't abort init if it's not
* found. * found.
*/ */
__ufs_qcom_phy_clk_get(generic_phy, "ref_clk_parent", __ufs_qcom_phy_clk_get(phy_common->dev, "ref_clk_parent",
&phy_common->ref_clk_parent, false); &phy_common->ref_clk_parent, false);
err = ufs_qcom_phy_clk_get(generic_phy, "ref_clk", err = ufs_qcom_phy_clk_get(phy_common->dev, "ref_clk",
&phy_common->ref_clk); &phy_common->ref_clk);
out: out:
...@@ -217,37 +212,33 @@ ufs_qcom_phy_init_clks(struct phy *generic_phy, ...@@ -217,37 +212,33 @@ ufs_qcom_phy_init_clks(struct phy *generic_phy,
} }
EXPORT_SYMBOL_GPL(ufs_qcom_phy_init_clks); EXPORT_SYMBOL_GPL(ufs_qcom_phy_init_clks);
int int ufs_qcom_phy_init_vregulators(struct ufs_qcom_phy *phy_common)
ufs_qcom_phy_init_vregulators(struct phy *generic_phy,
struct ufs_qcom_phy *phy_common)
{ {
int err; int err;
err = ufs_qcom_phy_init_vreg(generic_phy, &phy_common->vdda_pll, err = ufs_qcom_phy_init_vreg(phy_common->dev, &phy_common->vdda_pll,
"vdda-pll"); "vdda-pll");
if (err) if (err)
goto out; goto out;
err = ufs_qcom_phy_init_vreg(generic_phy, &phy_common->vdda_phy, err = ufs_qcom_phy_init_vreg(phy_common->dev, &phy_common->vdda_phy,
"vdda-phy"); "vdda-phy");
if (err) if (err)
goto out; goto out;
/* vddp-ref-clk-* properties are optional */ /* vddp-ref-clk-* properties are optional */
__ufs_qcom_phy_init_vreg(generic_phy, &phy_common->vddp_ref_clk, __ufs_qcom_phy_init_vreg(phy_common->dev, &phy_common->vddp_ref_clk,
"vddp-ref-clk", true); "vddp-ref-clk", true);
out: out:
return err; return err;
} }
EXPORT_SYMBOL_GPL(ufs_qcom_phy_init_vregulators); EXPORT_SYMBOL_GPL(ufs_qcom_phy_init_vregulators);
static int __ufs_qcom_phy_init_vreg(struct phy *phy, static int __ufs_qcom_phy_init_vreg(struct device *dev,
struct ufs_qcom_phy_vreg *vreg, const char *name, bool optional) struct ufs_qcom_phy_vreg *vreg, const char *name, bool optional)
{ {
int err = 0; int err = 0;
struct ufs_qcom_phy *ufs_qcom_phy = get_ufs_qcom_phy(phy);
struct device *dev = ufs_qcom_phy->dev;
char prop_name[MAX_PROP_NAME]; char prop_name[MAX_PROP_NAME];
...@@ -304,14 +295,13 @@ static int __ufs_qcom_phy_init_vreg(struct phy *phy, ...@@ -304,14 +295,13 @@ static int __ufs_qcom_phy_init_vreg(struct phy *phy,
return err; return err;
} }
static int ufs_qcom_phy_init_vreg(struct phy *phy, static int ufs_qcom_phy_init_vreg(struct device *dev,
struct ufs_qcom_phy_vreg *vreg, const char *name) struct ufs_qcom_phy_vreg *vreg, const char *name)
{ {
return __ufs_qcom_phy_init_vreg(phy, vreg, name, false); return __ufs_qcom_phy_init_vreg(dev, vreg, name, false);
} }
static static int ufs_qcom_phy_cfg_vreg(struct device *dev,
int ufs_qcom_phy_cfg_vreg(struct phy *phy,
struct ufs_qcom_phy_vreg *vreg, bool on) struct ufs_qcom_phy_vreg *vreg, bool on)
{ {
int ret = 0; int ret = 0;
...@@ -319,8 +309,6 @@ int ufs_qcom_phy_cfg_vreg(struct phy *phy, ...@@ -319,8 +309,6 @@ int ufs_qcom_phy_cfg_vreg(struct phy *phy,
const char *name = vreg->name; const char *name = vreg->name;
int min_uV; int min_uV;
int uA_load; int uA_load;
struct ufs_qcom_phy *ufs_qcom_phy = get_ufs_qcom_phy(phy);
struct device *dev = ufs_qcom_phy->dev;
if (regulator_count_voltages(reg) > 0) { if (regulator_count_voltages(reg) > 0) {
min_uV = on ? vreg->min_uV : 0; min_uV = on ? vreg->min_uV : 0;
...@@ -348,18 +336,15 @@ int ufs_qcom_phy_cfg_vreg(struct phy *phy, ...@@ -348,18 +336,15 @@ int ufs_qcom_phy_cfg_vreg(struct phy *phy,
return ret; return ret;
} }
static static int ufs_qcom_phy_enable_vreg(struct device *dev,
int ufs_qcom_phy_enable_vreg(struct phy *phy,
struct ufs_qcom_phy_vreg *vreg) struct ufs_qcom_phy_vreg *vreg)
{ {
struct ufs_qcom_phy *ufs_qcom_phy = get_ufs_qcom_phy(phy);
struct device *dev = ufs_qcom_phy->dev;
int ret = 0; int ret = 0;
if (!vreg || vreg->enabled) if (!vreg || vreg->enabled)
goto out; goto out;
ret = ufs_qcom_phy_cfg_vreg(phy, vreg, true); ret = ufs_qcom_phy_cfg_vreg(dev, vreg, true);
if (ret) { if (ret) {
dev_err(dev, "%s: ufs_qcom_phy_cfg_vreg() failed, err=%d\n", dev_err(dev, "%s: ufs_qcom_phy_cfg_vreg() failed, err=%d\n",
__func__, ret); __func__, ret);
...@@ -430,12 +415,9 @@ int ufs_qcom_phy_enable_ref_clk(struct phy *generic_phy) ...@@ -430,12 +415,9 @@ int ufs_qcom_phy_enable_ref_clk(struct phy *generic_phy)
} }
EXPORT_SYMBOL_GPL(ufs_qcom_phy_enable_ref_clk); EXPORT_SYMBOL_GPL(ufs_qcom_phy_enable_ref_clk);
static static int ufs_qcom_phy_disable_vreg(struct device *dev,
int ufs_qcom_phy_disable_vreg(struct phy *phy,
struct ufs_qcom_phy_vreg *vreg) struct ufs_qcom_phy_vreg *vreg)
{ {
struct ufs_qcom_phy *ufs_qcom_phy = get_ufs_qcom_phy(phy);
struct device *dev = ufs_qcom_phy->dev;
int ret = 0; int ret = 0;
if (!vreg || !vreg->enabled || vreg->is_always_on) if (!vreg || !vreg->enabled || vreg->is_always_on)
...@@ -445,7 +427,7 @@ int ufs_qcom_phy_disable_vreg(struct phy *phy, ...@@ -445,7 +427,7 @@ int ufs_qcom_phy_disable_vreg(struct phy *phy,
if (!ret) { if (!ret) {
/* ignore errors on applying disable config */ /* ignore errors on applying disable config */
ufs_qcom_phy_cfg_vreg(phy, vreg, false); ufs_qcom_phy_cfg_vreg(dev, vreg, false);
vreg->enabled = false; vreg->enabled = false;
} else { } else {
dev_err(dev, "%s: %s disable failed, err=%d\n", dev_err(dev, "%s: %s disable failed, err=%d\n",
...@@ -673,7 +655,7 @@ int ufs_qcom_phy_power_on(struct phy *generic_phy) ...@@ -673,7 +655,7 @@ int ufs_qcom_phy_power_on(struct phy *generic_phy)
struct device *dev = phy_common->dev; struct device *dev = phy_common->dev;
int err; int err;
err = ufs_qcom_phy_enable_vreg(generic_phy, &phy_common->vdda_phy); err = ufs_qcom_phy_enable_vreg(dev, &phy_common->vdda_phy);
if (err) { if (err) {
dev_err(dev, "%s enable vdda_phy failed, err=%d\n", dev_err(dev, "%s enable vdda_phy failed, err=%d\n",
__func__, err); __func__, err);
...@@ -683,7 +665,7 @@ int ufs_qcom_phy_power_on(struct phy *generic_phy) ...@@ -683,7 +665,7 @@ int ufs_qcom_phy_power_on(struct phy *generic_phy)
phy_common->phy_spec_ops->power_control(phy_common, true); phy_common->phy_spec_ops->power_control(phy_common, true);
/* vdda_pll also enables ref clock LDOs so enable it first */ /* vdda_pll also enables ref clock LDOs so enable it first */
err = ufs_qcom_phy_enable_vreg(generic_phy, &phy_common->vdda_pll); err = ufs_qcom_phy_enable_vreg(dev, &phy_common->vdda_pll);
if (err) { if (err) {
dev_err(dev, "%s enable vdda_pll failed, err=%d\n", dev_err(dev, "%s enable vdda_pll failed, err=%d\n",
__func__, err); __func__, err);
...@@ -699,7 +681,7 @@ int ufs_qcom_phy_power_on(struct phy *generic_phy) ...@@ -699,7 +681,7 @@ int ufs_qcom_phy_power_on(struct phy *generic_phy)
/* enable device PHY ref_clk pad rail */ /* enable device PHY ref_clk pad rail */
if (phy_common->vddp_ref_clk.reg) { if (phy_common->vddp_ref_clk.reg) {
err = ufs_qcom_phy_enable_vreg(generic_phy, err = ufs_qcom_phy_enable_vreg(dev,
&phy_common->vddp_ref_clk); &phy_common->vddp_ref_clk);
if (err) { if (err) {
dev_err(dev, "%s enable vddp_ref_clk failed, err=%d\n", dev_err(dev, "%s enable vddp_ref_clk failed, err=%d\n",
...@@ -714,9 +696,9 @@ int ufs_qcom_phy_power_on(struct phy *generic_phy) ...@@ -714,9 +696,9 @@ int ufs_qcom_phy_power_on(struct phy *generic_phy)
out_disable_ref_clk: out_disable_ref_clk:
ufs_qcom_phy_disable_ref_clk(generic_phy); ufs_qcom_phy_disable_ref_clk(generic_phy);
out_disable_pll: out_disable_pll:
ufs_qcom_phy_disable_vreg(generic_phy, &phy_common->vdda_pll); ufs_qcom_phy_disable_vreg(dev, &phy_common->vdda_pll);
out_disable_phy: out_disable_phy:
ufs_qcom_phy_disable_vreg(generic_phy, &phy_common->vdda_phy); ufs_qcom_phy_disable_vreg(dev, &phy_common->vdda_phy);
out: out:
return err; return err;
} }
...@@ -729,12 +711,12 @@ int ufs_qcom_phy_power_off(struct phy *generic_phy) ...@@ -729,12 +711,12 @@ int ufs_qcom_phy_power_off(struct phy *generic_phy)
phy_common->phy_spec_ops->power_control(phy_common, false); phy_common->phy_spec_ops->power_control(phy_common, false);
if (phy_common->vddp_ref_clk.reg) if (phy_common->vddp_ref_clk.reg)
ufs_qcom_phy_disable_vreg(generic_phy, ufs_qcom_phy_disable_vreg(phy_common->dev,
&phy_common->vddp_ref_clk); &phy_common->vddp_ref_clk);
ufs_qcom_phy_disable_ref_clk(generic_phy); ufs_qcom_phy_disable_ref_clk(generic_phy);
ufs_qcom_phy_disable_vreg(generic_phy, &phy_common->vdda_pll); ufs_qcom_phy_disable_vreg(phy_common->dev, &phy_common->vdda_pll);
ufs_qcom_phy_disable_vreg(generic_phy, &phy_common->vdda_phy); ufs_qcom_phy_disable_vreg(phy_common->dev, &phy_common->vdda_phy);
phy_common->is_powered_on = false; phy_common->is_powered_on = false;
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