mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-03 12:34:19 +00:00
d59d69f9e1
Manually rebased: backport-5.15/704-15-v5.19-net-mtk_eth_soc-move-MAC_MCR-setting-to-mac_finish.patch Removed upstreamed: backport-5.15/060-v6.0-01-tools-build-Add-feature-test-for-init_disassemble_in.patch[1] backport-5.15/060-v6.0-02-tools-include-add-dis-asm-compat.h-to-handle-version.patch[2] backport-5.15/060-v6.0-03-tools-perf-Fix-compilation-error-with-new-binutils.patch[3] backport-5.15/060-v6.0-04-tools-bpf_jit_disasm-Fix-compilation-error-with-new-.patch[4] backport-5.15/060-v6.0-05-tools-bpftool-Fix-compilation-error-with-new-binutil.patch[5] pending-5.15/733-02-net-ethernet-mtk_eth_soc-fix-RX-data-corruption-issu.patch[6] bcm47xx/patches-5.15/170-bgmac-fix-initial-chip-reset-to-support-BCM5358.patch[7] All other patches automatically rebased. 1. https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v5.15.103&id=51b99dc38c1a053e2e732d7f9e2740e343ae7eae 2. https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v5.15.103&id=451c9d7b16169645ed291ebb2ca9844caa088f2d 3. https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v5.15.103&id=97f005c0bdbaf656a7808586d234965385a06c58 4. https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v5.15.103&id=1c27fab243333821375e4d63128d60093fdbe149 5. https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v5.15.103&id=4441a90091931fd81607567961dc122f24f735bb 6. https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v5.15.103&id=2adc29350a5b4669544566f71f208d2abaec60ab 7. https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v5.15.103&id=04bfc5bcdfc0fdb73587487c71b04d63807ae15a Build system: x86_64 Build-tested: bcm2711/RPi4B, ramips/tplink_archer-a6-v3, filogic/xiaomi_redmi-router-ax6000-ubootmod Run-tested: bcm2711/RPi4B, ramips/tplink_archer-a6-v3, filogic/xiaomi_redmi-router-ax6000-ubootmod Signed-off-by: John Audia <therealgraysky@proton.me>
131 lines
4.3 KiB
Diff
131 lines
4.3 KiB
Diff
From e19de30d20809af3221ef8a2648b8a8a52e02d90 Mon Sep 17 00:00:00 2001
|
|
From: Daniel Golle <daniel@makrotopia.org>
|
|
Date: Wed, 21 Sep 2022 01:23:14 +0100
|
|
Subject: [PATCH 1/1] net: dsa: mt7530: add support for in-band link status
|
|
|
|
Read link status from SGMII PCS for in-band managed 2500Base-X and
|
|
1000Base-X connection on a MAC port of the MT7531. This is needed to
|
|
get the SFP cage working which is connected to SGMII interface of
|
|
port 5 of the MT7531 switch IC on the Bananapi BPi-R3 board.
|
|
While at it also handle an_complete for both the autoneg and the
|
|
non-autoneg codepath.
|
|
|
|
Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|
Signed-off-by: David S. Miller <davem@davemloft.net>
|
|
---
|
|
drivers/net/dsa/mt7530.c | 50 +++++++++++++++++++++++++++++-----------
|
|
drivers/net/dsa/mt7530.h | 1 +
|
|
2 files changed, 38 insertions(+), 13 deletions(-)
|
|
|
|
--- a/drivers/net/dsa/mt7530.c
|
|
+++ b/drivers/net/dsa/mt7530.c
|
|
@@ -2716,9 +2716,6 @@ mt7531_mac_config(struct dsa_switch *ds,
|
|
case PHY_INTERFACE_MODE_NA:
|
|
case PHY_INTERFACE_MODE_1000BASEX:
|
|
case PHY_INTERFACE_MODE_2500BASEX:
|
|
- if (phylink_autoneg_inband(mode))
|
|
- return -EINVAL;
|
|
-
|
|
return mt7531_sgmii_setup_mode_force(priv, port, interface);
|
|
default:
|
|
return -EINVAL;
|
|
@@ -2794,13 +2791,6 @@ unsupported:
|
|
return;
|
|
}
|
|
|
|
- if (phylink_autoneg_inband(mode) &&
|
|
- state->interface != PHY_INTERFACE_MODE_SGMII) {
|
|
- dev_err(ds->dev, "%s: in-band negotiation unsupported\n",
|
|
- __func__);
|
|
- return;
|
|
- }
|
|
-
|
|
mcr_cur = mt7530_read(priv, MT7530_PMCR_P(port));
|
|
mcr_new = mcr_cur;
|
|
mcr_new &= ~PMCR_LINK_SETTINGS_MASK;
|
|
@@ -2937,6 +2927,9 @@ static void mt753x_phylink_get_caps(stru
|
|
config->mac_capabilities = MAC_ASYM_PAUSE | MAC_SYM_PAUSE |
|
|
MAC_10 | MAC_100 | MAC_1000FD;
|
|
|
|
+ if ((priv->id == ID_MT7531) && mt753x_is_mac_port(port))
|
|
+ config->mac_capabilities |= MAC_2500FD;
|
|
+
|
|
/* This driver does not make use of the speed, duplex, pause or the
|
|
* advertisement in its mac_config, so it is safe to mark this driver
|
|
* as non-legacy.
|
|
@@ -3002,6 +2995,7 @@ mt7531_sgmii_pcs_get_state_an(struct mt7
|
|
|
|
status = mt7530_read(priv, MT7531_PCS_CONTROL_1(port));
|
|
state->link = !!(status & MT7531_SGMII_LINK_STATUS);
|
|
+ state->an_complete = !!(status & MT7531_SGMII_AN_COMPLETE);
|
|
if (state->interface == PHY_INTERFACE_MODE_SGMII &&
|
|
(status & MT7531_SGMII_AN_ENABLE)) {
|
|
val = mt7530_read(priv, MT7531_PCS_SPEED_ABILITY(port));
|
|
@@ -3032,16 +3026,44 @@ mt7531_sgmii_pcs_get_state_an(struct mt7
|
|
return 0;
|
|
}
|
|
|
|
+static void
|
|
+mt7531_sgmii_pcs_get_state_inband(struct mt7530_priv *priv, int port,
|
|
+ struct phylink_link_state *state)
|
|
+{
|
|
+ unsigned int val;
|
|
+
|
|
+ val = mt7530_read(priv, MT7531_PCS_CONTROL_1(port));
|
|
+ state->link = !!(val & MT7531_SGMII_LINK_STATUS);
|
|
+ if (!state->link)
|
|
+ return;
|
|
+
|
|
+ state->an_complete = state->link;
|
|
+
|
|
+ if (state->interface == PHY_INTERFACE_MODE_2500BASEX)
|
|
+ state->speed = SPEED_2500;
|
|
+ else
|
|
+ state->speed = SPEED_1000;
|
|
+
|
|
+ state->duplex = DUPLEX_FULL;
|
|
+ state->pause = MLO_PAUSE_NONE;
|
|
+}
|
|
+
|
|
static void mt7531_pcs_get_state(struct phylink_pcs *pcs,
|
|
struct phylink_link_state *state)
|
|
{
|
|
struct mt7530_priv *priv = pcs_to_mt753x_pcs(pcs)->priv;
|
|
int port = pcs_to_mt753x_pcs(pcs)->port;
|
|
|
|
- if (state->interface == PHY_INTERFACE_MODE_SGMII)
|
|
+ if (state->interface == PHY_INTERFACE_MODE_SGMII) {
|
|
mt7531_sgmii_pcs_get_state_an(priv, port, state);
|
|
- else
|
|
- state->link = false;
|
|
+ return;
|
|
+ } else if ((state->interface == PHY_INTERFACE_MODE_1000BASEX) ||
|
|
+ (state->interface == PHY_INTERFACE_MODE_2500BASEX)) {
|
|
+ mt7531_sgmii_pcs_get_state_inband(priv, port, state);
|
|
+ return;
|
|
+ }
|
|
+
|
|
+ state->link = false;
|
|
}
|
|
|
|
static int mt753x_pcs_config(struct phylink_pcs *pcs, unsigned int mode,
|
|
@@ -3082,6 +3104,8 @@ mt753x_setup(struct dsa_switch *ds)
|
|
priv->pcs[i].pcs.ops = priv->info->pcs_ops;
|
|
priv->pcs[i].priv = priv;
|
|
priv->pcs[i].port = i;
|
|
+ if (mt753x_is_mac_port(i))
|
|
+ priv->pcs[i].pcs.poll = 1;
|
|
}
|
|
|
|
ret = priv->info->sw_setup(ds);
|
|
--- a/drivers/net/dsa/mt7530.h
|
|
+++ b/drivers/net/dsa/mt7530.h
|
|
@@ -373,6 +373,7 @@ enum mt7530_vlan_port_acc_frm {
|
|
#define MT7531_SGMII_LINK_STATUS BIT(18)
|
|
#define MT7531_SGMII_AN_ENABLE BIT(12)
|
|
#define MT7531_SGMII_AN_RESTART BIT(9)
|
|
+#define MT7531_SGMII_AN_COMPLETE BIT(21)
|
|
|
|
/* Register for SGMII PCS_SPPED_ABILITY */
|
|
#define MT7531_PCS_SPEED_ABILITY(p) MT7531_SGMII_REG(p, 0x08)
|