ethernet: via-rhine: use eth_hw_addr_set()
authorJakub Kicinski <kuba@kernel.org>
Tue, 19 Oct 2021 15:00:10 +0000 (08:00 -0700)
committerDavid S. Miller <davem@davemloft.net>
Wed, 20 Oct 2021 10:41:01 +0000 (11:41 +0100)
Commit 406f42fa0d3c ("net-next: When a bond have a massive amount
of VLANs...") introduced a rbtree for faster Ethernet address look
up. To maintain netdev->dev_addr in this tree we need to make all
the writes to it got through appropriate helpers.

Read the address into an array on the stack, then call
eth_hw_addr_set().

Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/via/via-rhine.c

index 3b73a9c55a5a7653c124f0a2069b812b1ad049af..509c5e9b29dfa4174b8c3b8597ffe1bafede9294 100644 (file)
@@ -899,6 +899,7 @@ static int rhine_init_one_common(struct device *hwdev, u32 quirks,
        struct net_device *dev;
        struct rhine_private *rp;
        int i, rc, phy_id;
+       u8 addr[ETH_ALEN];
        const char *name;
 
        /* this should always be supported */
@@ -933,7 +934,8 @@ static int rhine_init_one_common(struct device *hwdev, u32 quirks,
        rhine_hw_init(dev, pioaddr);
 
        for (i = 0; i < 6; i++)
-               dev->dev_addr[i] = ioread8(ioaddr + StationAddr + i);
+               addr[i] = ioread8(ioaddr + StationAddr + i);
+       eth_hw_addr_set(dev, addr);
 
        if (!is_valid_ether_addr(dev->dev_addr)) {
                /* Report it and use a random ethernet address instead */