Commit 4efee05f authored by David S. Miller's avatar David S. Miller

Merge branch 'mvpp2-child-port-removal'

Javier Carrasco says:

====================
net: mvpp2: rework child node/port removal handling

These two patches used to be part of another series [1] that did not
apply to the networking tree without conflicts. This is therefore just a
partial resend with no code modifications, just rebased onto net/main.

Link: https://lore.kernel.org/all/20240806181026.5fe7f777@kernel.org/ [1]
====================
Signed-off-by: default avatarJavier Carrasco <javier.carrasco.cruz@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parents 80d021bc a7b32744
...@@ -7417,8 +7417,6 @@ static int mvpp2_get_sram(struct platform_device *pdev, ...@@ -7417,8 +7417,6 @@ static int mvpp2_get_sram(struct platform_device *pdev,
static int mvpp2_probe(struct platform_device *pdev) static int mvpp2_probe(struct platform_device *pdev)
{ {
struct fwnode_handle *fwnode = pdev->dev.fwnode;
struct fwnode_handle *port_fwnode;
struct mvpp2 *priv; struct mvpp2 *priv;
struct resource *res; struct resource *res;
void __iomem *base; void __iomem *base;
...@@ -7591,7 +7589,7 @@ static int mvpp2_probe(struct platform_device *pdev) ...@@ -7591,7 +7589,7 @@ static int mvpp2_probe(struct platform_device *pdev)
} }
/* Map DTS-active ports. Should be done before FIFO mvpp2_init */ /* Map DTS-active ports. Should be done before FIFO mvpp2_init */
fwnode_for_each_available_child_node(fwnode, port_fwnode) { device_for_each_child_node_scoped(&pdev->dev, port_fwnode) {
if (!fwnode_property_read_u32(port_fwnode, "port-id", &i)) if (!fwnode_property_read_u32(port_fwnode, "port-id", &i))
priv->port_map |= BIT(i); priv->port_map |= BIT(i);
} }
...@@ -7614,7 +7612,7 @@ static int mvpp2_probe(struct platform_device *pdev) ...@@ -7614,7 +7612,7 @@ static int mvpp2_probe(struct platform_device *pdev)
goto err_axi_clk; goto err_axi_clk;
/* Initialize ports */ /* Initialize ports */
fwnode_for_each_available_child_node(fwnode, port_fwnode) { device_for_each_child_node_scoped(&pdev->dev, port_fwnode) {
err = mvpp2_port_probe(pdev, port_fwnode, priv); err = mvpp2_port_probe(pdev, port_fwnode, priv);
if (err < 0) if (err < 0)
goto err_port_probe; goto err_port_probe;
...@@ -7653,14 +7651,8 @@ static int mvpp2_probe(struct platform_device *pdev) ...@@ -7653,14 +7651,8 @@ static int mvpp2_probe(struct platform_device *pdev)
return 0; return 0;
err_port_probe: err_port_probe:
fwnode_handle_put(port_fwnode); for (i = 0; i < priv->port_count; i++)
mvpp2_port_remove(priv->port_list[i]);
i = 0;
fwnode_for_each_available_child_node(fwnode, port_fwnode) {
if (priv->port_list[i])
mvpp2_port_remove(priv->port_list[i]);
i++;
}
err_axi_clk: err_axi_clk:
clk_disable_unprepare(priv->axi_clk); clk_disable_unprepare(priv->axi_clk);
err_mg_core_clk: err_mg_core_clk:
...@@ -7677,18 +7669,13 @@ static int mvpp2_probe(struct platform_device *pdev) ...@@ -7677,18 +7669,13 @@ static int mvpp2_probe(struct platform_device *pdev)
static void mvpp2_remove(struct platform_device *pdev) static void mvpp2_remove(struct platform_device *pdev)
{ {
struct mvpp2 *priv = platform_get_drvdata(pdev); struct mvpp2 *priv = platform_get_drvdata(pdev);
struct fwnode_handle *fwnode = pdev->dev.fwnode; int i, poolnum = MVPP2_BM_POOLS_NUM;
int i = 0, poolnum = MVPP2_BM_POOLS_NUM;
struct fwnode_handle *port_fwnode;
mvpp2_dbgfs_cleanup(priv); mvpp2_dbgfs_cleanup(priv);
fwnode_for_each_available_child_node(fwnode, port_fwnode) { for (i = 0; i < priv->port_count; i++) {
if (priv->port_list[i]) { mutex_destroy(&priv->port_list[i]->gather_stats_lock);
mutex_destroy(&priv->port_list[i]->gather_stats_lock); mvpp2_port_remove(priv->port_list[i]);
mvpp2_port_remove(priv->port_list[i]);
}
i++;
} }
destroy_workqueue(priv->stats_queue); destroy_workqueue(priv->stats_queue);
...@@ -7711,7 +7698,7 @@ static void mvpp2_remove(struct platform_device *pdev) ...@@ -7711,7 +7698,7 @@ static void mvpp2_remove(struct platform_device *pdev)
aggr_txq->descs_dma); aggr_txq->descs_dma);
} }
if (is_acpi_node(port_fwnode)) if (!dev_of_node(&pdev->dev))
return; return;
clk_disable_unprepare(priv->axi_clk); clk_disable_unprepare(priv->axi_clk);
......
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