ath6kl: use eth_hw_addr_set()
authorJakub Kicinski <kuba@kernel.org>
Mon, 18 Oct 2021 23:50:10 +0000 (16:50 -0700)
committerKalle Valo <kvalo@codeaurora.org>
Wed, 20 Oct 2021 09:39:43 +0000 (12:39 +0300)
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.

Do the special encoding on the stack, then copy the address.

Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
Link: https://lore.kernel.org/r/20211018235021.1279697-5-kuba@kernel.org
drivers/net/wireless/ath/ath6kl/cfg80211.c

index 51cc5f898a79bac8845d3639a99ff78f667e225c..bd1183830e9112e84f3fbe60cafa8b3cd4097879 100644 (file)
@@ -3781,6 +3781,7 @@ struct wireless_dev *ath6kl_interface_add(struct ath6kl *ar, const char *name,
 {
        struct net_device *ndev;
        struct ath6kl_vif *vif;
+       u8 addr[ETH_ALEN];
 
        ndev = alloc_netdev(sizeof(*vif), name, name_assign_type, ether_setup);
        if (!ndev)
@@ -3803,14 +3804,14 @@ struct wireless_dev *ath6kl_interface_add(struct ath6kl *ar, const char *name,
        vif->htcap[NL80211_BAND_2GHZ].ht_enable = true;
        vif->htcap[NL80211_BAND_5GHZ].ht_enable = true;
 
-       eth_hw_addr_set(ndev, ar->mac_addr);
+       ether_addr_copy(addr, ar->mac_addr);
        if (fw_vif_idx != 0) {
-               ndev->dev_addr[0] = (ndev->dev_addr[0] ^ (1 << fw_vif_idx)) |
-                                    0x2;
+               addr[0] = (addr[0] ^ (1 << fw_vif_idx)) | 0x2;
                if (test_bit(ATH6KL_FW_CAPABILITY_CUSTOM_MAC_ADDR,
                             ar->fw_capabilities))
-                       ndev->dev_addr[4] ^= 0x80;
+                       addr[4] ^= 0x80;
        }
+       eth_hw_addr_set(ndev, addr);
 
        init_netdev(ndev);