mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-04 13:04:22 +00:00
401a6ccfaf
Backport lots upstream changes, many of them fixes, for the mt7530 DSA driver. Some of them may or may not find they way into Linux 6.1 stable, some certainly won't because they are fixes for backported commits which aren't even present in Linux 6.1 upstream. Apart from adding new patches, also remove mutated patch 723-net-mt7531-ensure-all-MACs-are-powered-down-before-r.patch which should never have been added for Linux 6.1 -- it was applied already upstream but coincidentally would fuzzy-apply in the wrong place as well (for MT7530 instead of MT7531). While that didn't really hurt anyone it is just unneeded. The other deleted patch 795-mt7530-register-OF-node-for-internal-MDIO-bus.patch has been replaced by an equivalent commit with a more complete patch description by upstream maintainer Arınç Ünal. The remaining differences compared to the upstream driver are: * C22/C45 MDIO ops aren't split Upstream did that, backporting it would require making changes to *all* DSA drivers * 'slave' -> 'user', 'master' -> 'conduit' language change in DSA * support for selecting preferred CPU port on MT7531 Also this would require too many DSA framework changes potentially affecting other devices. If we ever really use Linux 6.1 in a release (I hope not) we can still reconsider to make the effort to backport that. In addition to some minor bug fixes and style improvements the switch should now behave more conformant when it comes to link-local frames, and we will again be able to cleanly pick patches from upstream. MAINTAIERS NOTE: Three patches are already part of Linux stable and should be removed with the next minor kernel version bump: 789-STABLE-01-net-dsa-mt7530-prevent-possible-incorrect-XTAL-frequ.patch 789-STABLE-02-net-dsa-mt7530-fix-link-local-frames-that-ingress-vl.patch 789-STABLE-03-net-dsa-mt7530-fix-handling-of-all-link-local-frames.patch Signed-off-by: Daniel Golle <daniel@makrotopia.org>
119 lines
3.9 KiB
Diff
119 lines
3.9 KiB
Diff
From ed01748319b25456c5226ed0cb5e49e970da0e4f Mon Sep 17 00:00:00 2001
|
||
From: Daniel Golle <daniel@makrotopia.org>
|
||
Date: Sun, 16 Apr 2023 13:08:14 +0100
|
||
Subject: [PATCH 15/48] net: dsa: mt7530: fix support for MT7531BE
|
||
MIME-Version: 1.0
|
||
Content-Type: text/plain; charset=UTF-8
|
||
Content-Transfer-Encoding: 8bit
|
||
|
||
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 | 16 ++++++++--------
|
||
drivers/net/dsa/mt7530.c | 6 ++++++
|
||
drivers/net/dsa/mt7530.h | 4 ++--
|
||
3 files changed, 16 insertions(+), 10 deletions(-)
|
||
|
||
--- a/drivers/net/dsa/mt7530-mdio.c
|
||
+++ b/drivers/net/dsa/mt7530-mdio.c
|
||
@@ -81,14 +81,17 @@ static const struct regmap_bus mt7530_re
|
||
};
|
||
|
||
static int
|
||
-mt7531_create_sgmii(struct mt7530_priv *priv)
|
||
+mt7531_create_sgmii(struct mt7530_priv *priv, bool dual_sgmii)
|
||
{
|
||
- struct regmap_config *mt7531_pcs_config[2];
|
||
+ struct regmap_config *mt7531_pcs_config[2] = {};
|
||
struct phylink_pcs *pcs;
|
||
struct regmap *regmap;
|
||
int i, ret = 0;
|
||
|
||
- for (i = 0; i < 2; i++) {
|
||
+ /* MT7531AE has two SGMII units for port 5 and port 6
|
||
+ * MT7531BE has only one SGMII unit for port 6
|
||
+ */
|
||
+ for (i = dual_sgmii ? 0 : 1; i < 2; i++) {
|
||
mt7531_pcs_config[i] = devm_kzalloc(priv->dev,
|
||
sizeof(struct regmap_config),
|
||
GFP_KERNEL);
|
||
@@ -208,11 +211,8 @@ mt7530_probe(struct mdio_device *mdiodev
|
||
if (IS_ERR(priv->regmap))
|
||
return PTR_ERR(priv->regmap);
|
||
|
||
- if (priv->id == ID_MT7531) {
|
||
- ret = mt7531_create_sgmii(priv);
|
||
- if (ret)
|
||
- return ret;
|
||
- }
|
||
+ if (priv->id == ID_MT7531)
|
||
+ priv->create_sgmii = mt7531_create_sgmii;
|
||
|
||
return dsa_register_switch(priv->ds);
|
||
}
|
||
--- a/drivers/net/dsa/mt7530.c
|
||
+++ b/drivers/net/dsa/mt7530.c
|
||
@@ -3081,6 +3081,12 @@ mt753x_setup(struct dsa_switch *ds)
|
||
if (ret && priv->irq)
|
||
mt7530_free_irq_common(priv);
|
||
|
||
+ if (priv->create_sgmii) {
|
||
+ ret = priv->create_sgmii(priv, mt7531_dual_sgmii_supported(priv));
|
||
+ if (ret && priv->irq)
|
||
+ mt7530_free_irq(priv);
|
||
+ }
|
||
+
|
||
return ret;
|
||
}
|
||
|
||
--- a/drivers/net/dsa/mt7530.h
|
||
+++ b/drivers/net/dsa/mt7530.h
|
||
@@ -768,10 +768,10 @@ struct mt753x_info {
|
||
* registers
|
||
* @p6_interface Holding the current port 6 interface
|
||
* @p5_intf_sel: Holding the current port 5 interface select
|
||
- *
|
||
* @irq: IRQ number of the switch
|
||
* @irq_domain: IRQ domain of the switch irq_chip
|
||
* @irq_enable: IRQ enable bits, synced to SYS_INT_EN
|
||
+ * @create_sgmii: Pointer to function creating SGMII PCS instance(s)
|
||
*/
|
||
struct mt7530_priv {
|
||
struct device *dev;
|
||
@@ -790,7 +790,6 @@ struct mt7530_priv {
|
||
unsigned int p5_intf_sel;
|
||
u8 mirror_rx;
|
||
u8 mirror_tx;
|
||
-
|
||
struct mt7530_port ports[MT7530_NUM_PORTS];
|
||
struct mt753x_pcs pcs[MT7530_NUM_PORTS];
|
||
/* protect among processes for registers access*/
|
||
@@ -798,6 +797,7 @@ struct mt7530_priv {
|
||
int irq;
|
||
struct irq_domain *irq_domain;
|
||
u32 irq_enable;
|
||
+ int (*create_sgmii)(struct mt7530_priv *priv, bool dual_sgmii);
|
||
};
|
||
|
||
struct mt7530_hw_vlan_entry {
|