mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-12 07:53:07 +00:00
be381a7ac7
Deleted (upstreamed): generic/backport-5.15/350-v5.18-MIPS-pgalloc-fix-memory-leak-caused-by-pgd_free.patch [1] generic/backport-5.15/730-v5.16-hv-utils-add-PTP_1588_CLOCK-to-Kconfig-to-fix-build.patch [2] generic/pending-5.15/850-0014-PCI-aardvark-Fix-reading-PCI_EXP_RTSTA_PME-bit-on-em.patch [3] generic/pending-5.15/850-0002-PCI-aardvark-Fix-reading-MSI-interrupt-number.patch [4] Manually rebased: generic/pending-5.15/850-0002-PCI-aardvark-Fix-reading-MSI-interrupt-number.patch ramips/patches-5.15/710-at803x.patch [1] https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v5.15.33&id=d29cda15cab086d82d692de016f7249545d4b6b4 [2] https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v5.15.33&id=d5aad7d63b1b5c1f3c4b69e12c05e7c7d196fae8 [3] https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v5.15.33&id=ed750e22e44366e264bcdf7b1cf0713f08f7980a [4] https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v5.15.33&id=0fe94b84c43cfea867e1721606185e8686d7d32f Signed-off-by: Rui Salvaterra <rsalvaterra@gmail.com> [Refresh patches again] [Remove generic/pending-5.15/850-0002-PCI-aardvark-Fix-reading-MSI-interrupt-number.patch] Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
92 lines
3.2 KiB
Diff
92 lines
3.2 KiB
Diff
From 1ca8311949aec5c9447645731ef1c6bc5bd71350 Mon Sep 17 00:00:00 2001
|
|
From: Ansuel Smith <ansuelsmth@gmail.com>
|
|
Date: Sun, 10 Oct 2021 00:46:16 +0200
|
|
Subject: net: phy: at803x: add DAC amplitude fix for 8327 phy
|
|
|
|
QCA8327 internal phy require DAC amplitude adjustement set to +6% with
|
|
100m speed. Also add additional define to report a change of the same
|
|
reg in QCA8337. (different scope it does set 1000m voltage)
|
|
Add link_change_notify function to set the proper amplitude adjustement
|
|
on PHY_RUNNING state and disable on any other state.
|
|
|
|
Fixes: b4df02b562f4 ("net: phy: at803x: add support for qca 8327 A variant internal phy")
|
|
Signed-off-by: Ansuel Smith <ansuelsmth@gmail.com>
|
|
Signed-off-by: David S. Miller <davem@davemloft.net>
|
|
---
|
|
drivers/net/phy/at803x.c | 33 +++++++++++++++++++++++++++++++++
|
|
1 file changed, 33 insertions(+)
|
|
|
|
--- a/drivers/net/phy/at803x.c
|
|
+++ b/drivers/net/phy/at803x.c
|
|
@@ -87,6 +87,8 @@
|
|
#define AT803X_PSSR_MR_AN_COMPLETE 0x0200
|
|
|
|
#define AT803X_DEBUG_REG_0 0x00
|
|
+#define QCA8327_DEBUG_MANU_CTRL_EN BIT(2)
|
|
+#define QCA8337_DEBUG_MANU_CTRL_EN GENMASK(3, 2)
|
|
#define AT803X_DEBUG_RX_CLK_DLY_EN BIT(15)
|
|
|
|
#define AT803X_DEBUG_REG_5 0x05
|
|
@@ -1306,9 +1308,37 @@ static int qca83xx_config_init(struct ph
|
|
break;
|
|
}
|
|
|
|
+ /* QCA8327 require DAC amplitude adjustment for 100m set to +6%.
|
|
+ * Disable on init and enable only with 100m speed following
|
|
+ * qca original source code.
|
|
+ */
|
|
+ if (phydev->drv->phy_id == QCA8327_A_PHY_ID ||
|
|
+ phydev->drv->phy_id == QCA8327_B_PHY_ID)
|
|
+ at803x_debug_reg_mask(phydev, AT803X_DEBUG_REG_0,
|
|
+ QCA8327_DEBUG_MANU_CTRL_EN, 0);
|
|
+
|
|
return 0;
|
|
}
|
|
|
|
+static void qca83xx_link_change_notify(struct phy_device *phydev)
|
|
+{
|
|
+ /* QCA8337 doesn't require DAC Amplitude adjustement */
|
|
+ if (phydev->drv->phy_id == QCA8337_PHY_ID)
|
|
+ return;
|
|
+
|
|
+ /* Set DAC Amplitude adjustment to +6% for 100m on link running */
|
|
+ if (phydev->state == PHY_RUNNING) {
|
|
+ if (phydev->speed == SPEED_100)
|
|
+ at803x_debug_reg_mask(phydev, AT803X_DEBUG_REG_0,
|
|
+ QCA8327_DEBUG_MANU_CTRL_EN,
|
|
+ QCA8327_DEBUG_MANU_CTRL_EN);
|
|
+ } else {
|
|
+ /* Reset DAC Amplitude adjustment */
|
|
+ at803x_debug_reg_mask(phydev, AT803X_DEBUG_REG_0,
|
|
+ QCA8327_DEBUG_MANU_CTRL_EN, 0);
|
|
+ }
|
|
+}
|
|
+
|
|
static int qca83xx_resume(struct phy_device *phydev)
|
|
{
|
|
int ret, val;
|
|
@@ -1463,6 +1493,7 @@ static struct phy_driver at803x_driver[]
|
|
.phy_id_mask = QCA8K_PHY_ID_MASK,
|
|
.name = "Qualcomm Atheros 8337 internal PHY",
|
|
/* PHY_GBIT_FEATURES */
|
|
+ .link_change_notify = qca83xx_link_change_notify,
|
|
.probe = at803x_probe,
|
|
.flags = PHY_IS_INTERNAL,
|
|
.config_init = qca83xx_config_init,
|
|
@@ -1478,6 +1509,7 @@ static struct phy_driver at803x_driver[]
|
|
.phy_id_mask = QCA8K_PHY_ID_MASK,
|
|
.name = "Qualcomm Atheros 8327-A internal PHY",
|
|
/* PHY_GBIT_FEATURES */
|
|
+ .link_change_notify = qca83xx_link_change_notify,
|
|
.probe = at803x_probe,
|
|
.flags = PHY_IS_INTERNAL,
|
|
.config_init = qca83xx_config_init,
|
|
@@ -1493,6 +1525,7 @@ static struct phy_driver at803x_driver[]
|
|
.phy_id_mask = QCA8K_PHY_ID_MASK,
|
|
.name = "Qualcomm Atheros 8327-B internal PHY",
|
|
/* PHY_GBIT_FEATURES */
|
|
+ .link_change_notify = qca83xx_link_change_notify,
|
|
.probe = at803x_probe,
|
|
.flags = PHY_IS_INTERNAL,
|
|
.config_init = qca83xx_config_init,
|