Commit fce52ad3 authored by Dmitry Baryshkov's avatar Dmitry Baryshkov Committed by Georgi Djakov

interconnect: qcom: use icc_sync state for sm8[12]50

In addition to the rest of Qcom interconnect drivers use icc_sync_state
for SM8150/SM8250 interconnect drivers to notify the interconnect
framework when all consumers are probed and there is no need to keep the
bandwidth set to maximum anymore.

Also move the BCM initialization before creating the nodes to set the
max bandwidth in hardware for the initialization/probing stage.
Signed-off-by: default avatarDmitry Baryshkov <dmitry.baryshkov@linaro.org>
Fixes: 7d3b0b0d ("interconnect: qcom: Use icc_sync_state")
Link: https://lore.kernel.org/r/20201027133418.976687-1-dmitry.baryshkov@linaro.orgSigned-off-by: default avatarGeorgi Djakov <georgi.djakov@linaro.org>
parent 266cd33b
...@@ -551,6 +551,9 @@ static int qnoc_probe(struct platform_device *pdev) ...@@ -551,6 +551,9 @@ static int qnoc_probe(struct platform_device *pdev)
return ret; return ret;
} }
for (i = 0; i < qp->num_bcms; i++)
qcom_icc_bcm_init(qp->bcms[i], &pdev->dev);
for (i = 0; i < num_nodes; i++) { for (i = 0; i < num_nodes; i++) {
size_t j; size_t j;
...@@ -574,9 +577,6 @@ static int qnoc_probe(struct platform_device *pdev) ...@@ -574,9 +577,6 @@ static int qnoc_probe(struct platform_device *pdev)
} }
data->num_nodes = num_nodes; data->num_nodes = num_nodes;
for (i = 0; i < qp->num_bcms; i++)
qcom_icc_bcm_init(qp->bcms[i], &pdev->dev);
platform_set_drvdata(pdev, qp); platform_set_drvdata(pdev, qp);
return 0; return 0;
...@@ -627,6 +627,7 @@ static struct platform_driver qnoc_driver = { ...@@ -627,6 +627,7 @@ static struct platform_driver qnoc_driver = {
.driver = { .driver = {
.name = "qnoc-sm8150", .name = "qnoc-sm8150",
.of_match_table = qnoc_of_match, .of_match_table = qnoc_of_match,
.sync_state = icc_sync_state,
}, },
}; };
module_platform_driver(qnoc_driver); module_platform_driver(qnoc_driver);
......
...@@ -567,6 +567,9 @@ static int qnoc_probe(struct platform_device *pdev) ...@@ -567,6 +567,9 @@ static int qnoc_probe(struct platform_device *pdev)
return ret; return ret;
} }
for (i = 0; i < qp->num_bcms; i++)
qcom_icc_bcm_init(qp->bcms[i], &pdev->dev);
for (i = 0; i < num_nodes; i++) { for (i = 0; i < num_nodes; i++) {
size_t j; size_t j;
...@@ -590,9 +593,6 @@ static int qnoc_probe(struct platform_device *pdev) ...@@ -590,9 +593,6 @@ static int qnoc_probe(struct platform_device *pdev)
} }
data->num_nodes = num_nodes; data->num_nodes = num_nodes;
for (i = 0; i < qp->num_bcms; i++)
qcom_icc_bcm_init(qp->bcms[i], &pdev->dev);
platform_set_drvdata(pdev, qp); platform_set_drvdata(pdev, qp);
return 0; return 0;
...@@ -643,6 +643,7 @@ static struct platform_driver qnoc_driver = { ...@@ -643,6 +643,7 @@ static struct platform_driver qnoc_driver = {
.driver = { .driver = {
.name = "qnoc-sm8250", .name = "qnoc-sm8250",
.of_match_table = qnoc_of_match, .of_match_table = qnoc_of_match,
.sync_state = icc_sync_state,
}, },
}; };
module_platform_driver(qnoc_driver); module_platform_driver(qnoc_driver);
......
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