net: dsa: mt7530: fix support for MT7531BE
authorDaniel Golle <daniel@makrotopia.org>
Sun, 16 Apr 2023 12:08:14 +0000 (13:08 +0100)
committerJakub Kicinski <kuba@kernel.org>
Thu, 20 Apr 2023 00:37:45 +0000 (17:37 -0700)
commit91daa4f62ce878b6e1ac5908aceb83550332447f
treed56a4f974a1361a2579d6ee9a563ea40c046e9b6
parent8e4c62c7d980eaf0f64c1c0ef0c80f5685af0fb6
net: dsa: mt7530: fix support for MT7531BE

There are two variants of the MT7531 switch IC which got different
features (and pins) regarding port 5:
 * MT7531AE: SGMII/1000Base-X/2500Base-X SerDes PCS
 * MT7531BE: RGMII

Moving the creation of the SerDes PCS from mt753x_setup to mt7530_probe
with commit 6de285229773 ("net: dsa: mt7530: move SGMII PCS creation
to mt7530_probe function") works fine for MT7531AE which got two
instances of mtk-pcs-lynxi, however, MT7531BE requires mt7531_pll_setup
to setup clocks before the single PCS on port 6 (usually used as CPU
port) starts to work and hence the PCS creation failed on MT7531BE.

Fix this by introducing a pointer to mt7531_create_sgmii function in
struct mt7530_priv and call it again at the end of mt753x_setup like it
was before commit 6de285229773 ("net: dsa: mt7530: move SGMII PCS
creation to mt7530_probe function").

Fixes: 6de285229773 ("net: dsa: mt7530: move SGMII PCS creation to mt7530_probe function")
Signed-off-by: Daniel Golle <daniel@makrotopia.org>
Acked-by: Arınç ÜNAL <arinc.unal@arinc9.com>
Link: https://lore.kernel.org/r/ZDvlLhhqheobUvOK@makrotopia.org
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/dsa/mt7530-mdio.c
drivers/net/dsa/mt7530.c
drivers/net/dsa/mt7530.h