Commit 15de15c6 authored by Chunfeng Yun's avatar Chunfeng Yun Committed by Kishon Vijay Abraham I

phy: phy-mt65xx-usb3: move clock from phy node into port nodes

each port has its own reference clock, the HighSpeed port is 48M,
and the SuperSpeed port is usually 26M, put them into port node for
flexibility, this can close clock if the port is not used.
Signed-off-by: default avatarChunfeng Yun <chunfeng.yun@mediatek.com>
Signed-off-by: default avatarKishon Vijay Abraham I <kishon@ti.com>
parent 04466efc
...@@ -153,6 +153,7 @@ struct mt65xx_phy_pdata { ...@@ -153,6 +153,7 @@ struct mt65xx_phy_pdata {
struct mt65xx_phy_instance { struct mt65xx_phy_instance {
struct phy *phy; struct phy *phy;
void __iomem *port_base; void __iomem *port_base;
struct clk *ref_clk; /* reference clock of anolog phy */
u32 index; u32 index;
u8 type; u8 type;
}; };
...@@ -160,6 +161,7 @@ struct mt65xx_phy_instance { ...@@ -160,6 +161,7 @@ struct mt65xx_phy_instance {
struct mt65xx_u3phy { struct mt65xx_u3phy {
struct device *dev; struct device *dev;
void __iomem *sif_base; /* only shared sif */ void __iomem *sif_base; /* only shared sif */
/* deprecated, use @ref_clk instead in phy instance */
struct clk *u3phya_ref; /* reference clock of usb3 anolog phy */ struct clk *u3phya_ref; /* reference clock of usb3 anolog phy */
const struct mt65xx_phy_pdata *pdata; const struct mt65xx_phy_pdata *pdata;
struct mt65xx_phy_instance **phys; struct mt65xx_phy_instance **phys;
...@@ -455,6 +457,12 @@ static int mt65xx_phy_init(struct phy *phy) ...@@ -455,6 +457,12 @@ static int mt65xx_phy_init(struct phy *phy)
return ret; return ret;
} }
ret = clk_prepare_enable(instance->ref_clk);
if (ret) {
dev_err(u3phy->dev, "failed to enable ref_clk\n");
return ret;
}
if (instance->type == PHY_TYPE_USB2) if (instance->type == PHY_TYPE_USB2)
phy_instance_init(u3phy, instance); phy_instance_init(u3phy, instance);
else else
...@@ -494,6 +502,7 @@ static int mt65xx_phy_exit(struct phy *phy) ...@@ -494,6 +502,7 @@ static int mt65xx_phy_exit(struct phy *phy)
if (instance->type == PHY_TYPE_USB2) if (instance->type == PHY_TYPE_USB2)
phy_instance_exit(u3phy, instance); phy_instance_exit(u3phy, instance);
clk_disable_unprepare(instance->ref_clk);
clk_disable_unprepare(u3phy->u3phya_ref); clk_disable_unprepare(u3phy->u3phya_ref);
return 0; return 0;
} }
...@@ -594,10 +603,13 @@ static int mt65xx_u3phy_probe(struct platform_device *pdev) ...@@ -594,10 +603,13 @@ static int mt65xx_u3phy_probe(struct platform_device *pdev)
return PTR_ERR(u3phy->sif_base); return PTR_ERR(u3phy->sif_base);
} }
/* it's deprecated, make it optional for backward compatibility */
u3phy->u3phya_ref = devm_clk_get(dev, "u3phya_ref"); u3phy->u3phya_ref = devm_clk_get(dev, "u3phya_ref");
if (IS_ERR(u3phy->u3phya_ref)) { if (IS_ERR(u3phy->u3phya_ref)) {
dev_err(dev, "error to get u3phya_ref\n"); if (PTR_ERR(u3phy->u3phya_ref) == -EPROBE_DEFER)
return PTR_ERR(u3phy->u3phya_ref); return -EPROBE_DEFER;
u3phy->u3phya_ref = NULL;
} }
port = 0; port = 0;
...@@ -638,6 +650,17 @@ static int mt65xx_u3phy_probe(struct platform_device *pdev) ...@@ -638,6 +650,17 @@ static int mt65xx_u3phy_probe(struct platform_device *pdev)
instance->index = port; instance->index = port;
phy_set_drvdata(phy, instance); phy_set_drvdata(phy, instance);
port++; port++;
/* if deprecated clock is provided, ignore instance's one */
if (u3phy->u3phya_ref)
continue;
instance->ref_clk = devm_clk_get(&phy->dev, "ref");
if (IS_ERR(instance->ref_clk)) {
dev_err(dev, "failed to get ref_clk(id-%d)\n", port);
retval = PTR_ERR(instance->ref_clk);
goto put_child;
}
} }
provider = devm_of_phy_provider_register(dev, mt65xx_phy_xlate); provider = devm_of_phy_provider_register(dev, mt65xx_phy_xlate);
......
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