Skip to content

Commit 6bf69a1

Browse files
yanmarkmandavem330
authored andcommitted
net: mvpp2: fix port list indexing
The private port_list array has a list of pointers to mvpp2_port instances. This list is allocated given the number of ports enabled in the device tree, but the pointers are set using the port-id property. If on a single port is enabled, the port_list array will be of size 1, but when registering the port, if its id is not 0 the driver will crash. Other crashes were encountered in various situations. This fixes the issue by using an index not equal to the value of the port-id property. Fixes: 3f51850 ("ethernet: Add new driver for Marvell Armada 375 network unit") Signed-off-by: Antoine Tenart <antoine.tenart@free-electrons.com> Signed-off-by: Yan Markman <ymarkman@marvell.com> Signed-off-by: David S. Miller <davem@davemloft.net>
1 parent aff3da3 commit 6bf69a1

File tree

1 file changed

+5
-3
lines changed
  • drivers/net/ethernet/marvell

1 file changed

+5
-3
lines changed

drivers/net/ethernet/marvell/mvpp2.c

Lines changed: 5 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -7504,7 +7504,7 @@ static void mvpp2_port_copy_mac_addr(struct net_device *dev, struct mvpp2 *priv,
75047504
/* Ports initialization */
75057505
static int mvpp2_port_probe(struct platform_device *pdev,
75067506
struct device_node *port_node,
7507-
struct mvpp2 *priv)
7507+
struct mvpp2 *priv, int index)
75087508
{
75097509
struct device_node *phy_node;
75107510
struct phy *comphy;
@@ -7678,7 +7678,7 @@ static int mvpp2_port_probe(struct platform_device *pdev,
76787678
}
76797679
netdev_info(dev, "Using %s mac address %pM\n", mac_from, dev->dev_addr);
76807680

7681-
priv->port_list[id] = port;
7681+
priv->port_list[index] = port;
76827682
return 0;
76837683

76847684
err_free_port_pcpu:
@@ -8013,10 +8013,12 @@ static int mvpp2_probe(struct platform_device *pdev)
80138013
}
80148014

80158015
/* Initialize ports */
8016+
i = 0;
80168017
for_each_available_child_of_node(dn, port_node) {
8017-
err = mvpp2_port_probe(pdev, port_node, priv);
8018+
err = mvpp2_port_probe(pdev, port_node, priv, i);
80188019
if (err < 0)
80198020
goto err_mg_clk;
8021+
i++;
80208022
}
80218023

80228024
platform_set_drvdata(pdev, priv);

0 commit comments

Comments
 (0)