ramips: mt7530 swconfig: fix race condition in register access
authorDENG Qingfang <dqfext@gmail.com>
Sat, 3 Apr 2021 14:59:15 +0000 (22:59 +0800)
committerHauke Mehrtens <hauke@hauke-m.de>
Sun, 18 Apr 2021 10:05:04 +0000 (12:05 +0200)
commit6552f31acdb14bca5e6b51c82ef63fd08d3b7a9f
treef6c758107d56ddd283499d38c8cb83829cec6055
parentcc6ad94fb920a5577239d60d42d8f1ec8d9b668c
ramips: mt7530 swconfig: fix race condition in register access

The mt7530_{r,w}32 operation over MDIO uses 3 mdiobus operations and
does not hold a lock, which causes a race condition when multiple
threads try to access a register, they may get unexpected results.

To avoid this, handle the MDIO lock manually, and use the unlocked
__mdiobus_{read,write} in the critical section.

This fixes the "Ghost VLAN" artifact[1] in MT7530/7621 when the VLAN
operation and the swconfig LED link status poll race between each other.

[1] https://forum.openwrt.org/t/mysterious-vlan-ids-on-mt7621-device/64495

Signed-off-by: DENG Qingfang <dqfext@gmail.com>
(cherry picked from commit f99c9cd9c4d4c49a676d678327546fd41690fe2a)
target/linux/ramips/files/drivers/net/ethernet/ralink/mt7530.c