Drop the use of the EEPROM address entirely, rely on interface address only Signed-off-by: Felix Fietkau <nbd@xxxxxxxx> --- drivers/net/wireless/mediatek/mt76/mt76x2_init.c | 11 ++++------- drivers/net/wireless/mediatek/mt76/mt76x2_mac.c | 14 ++++++++++++++ 2 files changed, 18 insertions(+), 7 deletions(-) diff --git a/drivers/net/wireless/mediatek/mt76/mt76x2_init.c b/drivers/net/wireless/mediatek/mt76/mt76x2_init.c index ac4eeaf2c993..f54dc67a13d0 100644 --- a/drivers/net/wireless/mediatek/mt76/mt76x2_init.c +++ b/drivers/net/wireless/mediatek/mt76/mt76x2_init.c @@ -231,7 +231,6 @@ mt76x2_init_beacon_offsets(struct mt76x2_dev *dev) int mt76x2_mac_reset(struct mt76x2_dev *dev, bool hard) { static const u8 null_addr[ETH_ALEN] = {}; - const u8 *macaddr = dev->mt76.macaddr; u32 val; int i, k; @@ -271,13 +270,11 @@ int mt76x2_mac_reset(struct mt76x2_dev *dev, bool hard) mt76_wr(dev, MT_MCU_CLOCK_CTL, 0x1401); mt76_clear(dev, MT_FCE_L2_STUFF, MT_FCE_L2_STUFF_WR_MPDU_LEN_EN); - mt76_wr(dev, MT_MAC_ADDR_DW0, get_unaligned_le32(macaddr)); - mt76_wr(dev, MT_MAC_ADDR_DW1, get_unaligned_le16(macaddr + 4)); + mt76_wr(dev, MT_MAC_ADDR_DW0, 0); + mt76_wr(dev, MT_MAC_ADDR_DW1, 0); - mt76_wr(dev, MT_MAC_BSSID_DW0, get_unaligned_le32(macaddr)); - mt76_wr(dev, MT_MAC_BSSID_DW1, get_unaligned_le16(macaddr + 4) | - FIELD_PREP(MT_MAC_BSSID_DW1_MBSS_MODE, 3) | /* 8 beacons */ - MT_MAC_BSSID_DW1_MBSS_LOCAL_BIT); + mt76_wr(dev, MT_MAC_BSSID_DW0, 0); + mt76_wr(dev, MT_MAC_BSSID_DW1, 0); mt76_set(dev, MT_MAC_ADDR_EXT_CTL, MT_MAC_ADDR_EXT_CTL_EN); diff --git a/drivers/net/wireless/mediatek/mt76/mt76x2_mac.c b/drivers/net/wireless/mediatek/mt76/mt76x2_mac.c index 60cee4abed7c..d2ae093b7092 100644 --- a/drivers/net/wireless/mediatek/mt76/mt76x2_mac.c +++ b/drivers/net/wireless/mediatek/mt76/mt76x2_mac.c @@ -27,6 +27,15 @@ void mt76x2_mac_set_bssid(struct mt76x2_dev *dev, u8 idx, const u8 *addr) if (addr) { lo = get_unaligned_le32(addr); hi = get_unaligned_le16(addr + 4); + + if (!idx) { + mt76_wr(dev, MT_MAC_BSSID_DW0, lo); + + mt76_rmw_field(dev, MT_MAC_BSSID_DW1, + MT_MAC_BSSID_DW1_ADDR, + hi); + } + hi |= MT_MAC_APC_BSSID0_H_EN; } @@ -41,6 +50,11 @@ void mt76x2_mac_set_ext_mac(struct mt76x2_dev *dev, u8 idx, const u8 *addr) if (addr) { lo = get_unaligned_le32(addr); hi = get_unaligned_le16(addr + 4); + + if (!idx) { + mt76_wr(dev, MT_MAC_ADDR_DW0, lo); + mt76_wr(dev, MT_MAC_ADDR_DW1, hi); + } } mt76_wr(dev, MT_MAC_ADDR_EXT_L(idx), lo); -- 2.14.2