Commit 725c7b8d authored by Faiz Abbas's avatar Faiz Abbas Committed by Vinod Koul

phy: ti: j721e-wiz: Do not configure wiz if its already configured

Serdes lanes might be shared between multiple cores in some usecases
and its not possible to lock PLLs for both the lanes independently
by the two cores. This requires a bootloader to configure both the
lanes at early boot time.

To handle this case, skip all configuration if any of the lanes has
already been enabled.
Signed-off-by: default avatarFaiz Abbas <faiz_abbas@ti.com>
Signed-off-by: default avatarKishon Vijay Abraham I <kishon@ti.com>
Link: https://lore.kernel.org/r/20210330110138.24356-2-kishon@ti.comSigned-off-by: default avatarVinod Koul <vkoul@kernel.org>
parent 1436ec30
...@@ -1134,13 +1134,14 @@ static int wiz_probe(struct platform_device *pdev) ...@@ -1134,13 +1134,14 @@ static int wiz_probe(struct platform_device *pdev)
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
struct device_node *node = dev->of_node; struct device_node *node = dev->of_node;
struct platform_device *serdes_pdev; struct platform_device *serdes_pdev;
bool already_configured = false;
struct device_node *child_node; struct device_node *child_node;
struct regmap *regmap; struct regmap *regmap;
struct resource res; struct resource res;
void __iomem *base; void __iomem *base;
struct wiz *wiz; struct wiz *wiz;
int ret, val, i;
u32 num_lanes; u32 num_lanes;
int ret;
wiz = devm_kzalloc(dev, sizeof(*wiz), GFP_KERNEL); wiz = devm_kzalloc(dev, sizeof(*wiz), GFP_KERNEL);
if (!wiz) if (!wiz)
...@@ -1268,11 +1269,21 @@ static int wiz_probe(struct platform_device *pdev) ...@@ -1268,11 +1269,21 @@ static int wiz_probe(struct platform_device *pdev)
goto err_get_sync; goto err_get_sync;
} }
for (i = 0; i < wiz->num_lanes; i++) {
regmap_field_read(wiz->p_enable[i], &val);
if (val & (P_ENABLE | P_ENABLE_FORCE)) {
already_configured = true;
break;
}
}
if (!already_configured) {
ret = wiz_init(wiz); ret = wiz_init(wiz);
if (ret) { if (ret) {
dev_err(dev, "WIZ initialization failed\n"); dev_err(dev, "WIZ initialization failed\n");
goto err_wiz_init; goto err_wiz_init;
} }
}
serdes_pdev = of_platform_device_create(child_node, NULL, dev); serdes_pdev = of_platform_device_create(child_node, NULL, dev);
if (!serdes_pdev) { if (!serdes_pdev) {
......
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