[openwrt/openwrt] mediatek: yet again, replace patch with updated pending patch

LEDE Commits lede-commits at lists.infradead.org
Mon Dec 27 12:20:54 PST 2021


dangole pushed a commit to openwrt/openwrt.git, branch master:
https://git.openwrt.org/92820cc5b995251e7eefe59dc586283a565f7c18

commit 92820cc5b995251e7eefe59dc586283a565f7c18
Author: Daniel Golle <daniel at makrotopia.org>
AuthorDate: Mon Dec 27 20:08:04 2021 +0000

    mediatek: yet again, replace patch with updated pending patch
    
    Upon comment of Russell King ('Oh no, not this "-1 disease" again.')
    clean up mdio read and write return type and value in mtk_eth_soc
    driver and also use appropriate return values for bus-busy-timeout-
    errors in newly added Clause 45 access code.
    
    Signed-off-by: Daniel Golle <daniel at makrotopia.org>
---
 ...-mtk_eth_soc-fix-return-value-of-MDIO-ops.patch | 97 ++++++++++++++++++++++
 ..._eth_soc-implement-Clause-45-MDIO-access.patch} | 65 +++++++--------
 2 files changed, 125 insertions(+), 37 deletions(-)

diff --git a/target/linux/mediatek/patches-5.10/701-net-ethernet-mtk_eth_soc-fix-return-value-of-MDIO-ops.patch b/target/linux/mediatek/patches-5.10/701-net-ethernet-mtk_eth_soc-fix-return-value-of-MDIO-ops.patch
new file mode 100644
index 0000000000..696b68df47
--- /dev/null
+++ b/target/linux/mediatek/patches-5.10/701-net-ethernet-mtk_eth_soc-fix-return-value-of-MDIO-ops.patch
@@ -0,0 +1,97 @@
+From patchwork Mon Dec 27 18:31:09 2021
+Content-Type: text/plain; charset="utf-8"
+MIME-Version: 1.0
+Content-Transfer-Encoding: 7bit
+X-Patchwork-Submitter: Daniel Golle <daniel at makrotopia.org>
+X-Patchwork-Id: 12699993
+X-Patchwork-Delegate: kuba at kernel.org
+Return-Path: <netdev-owner at kernel.org>
+Date: Mon, 27 Dec 2021 18:31:09 +0000
+From: Daniel Golle <daniel at makrotopia.org>
+To: linux-mediatek at lists.infradead.org, netdev at vger.kernel.org,
+        linux-arm-kernel at lists.infradead.org, linux-kernel at vger.kernel.org
+Cc: Felix Fietkau <nbd at nbd.name>, John Crispin <john at phrozen.org>,
+        Sean Wang <sean.wang at mediatek.com>,
+        Mark Lee <Mark-MC.Lee at mediatek.com>,
+        "David S. Miller" <davem at davemloft.net>,
+        Jakub Kicinski <kuba at kernel.org>,
+        Matthias Brugger <matthias.bgg at gmail.com>,
+        Russell King <linux at armlinux.org.uk>,
+        Andrew Lunn <andrew at lunn.ch>
+Subject: [PATCH v5 1/2] net: ethernet: mtk_eth_soc: fix return value of MDIO
+ ops
+Message-ID: <YcoGbf/klFzaJhGE at makrotopia.org>
+References: <YcnoAscVe+2YILT8 at shell.armlinux.org.uk>
+ <YcnlMtninjjjPhjI at makrotopia.org>
+MIME-Version: 1.0
+Content-Disposition: inline
+In-Reply-To: <YcnoAscVe+2YILT8 at shell.armlinux.org.uk>
+ <YcnlMtninjjjPhjI at makrotopia.org>
+Precedence: bulk
+List-ID: <netdev.vger.kernel.org>
+X-Mailing-List: netdev at vger.kernel.org
+X-Patchwork-Delegate: kuba at kernel.org
+
+Instead of returning -1 (-EPERM) when MDIO bus is stuck busy
+while writing or 0xffff if it happens while reading, return the
+appropriate -EBUSY. Also fix return type to int instead of u32.
+
+Fixes: 656e705243fd0 ("net-next: mediatek: add support for MT7623 ethernet")
+Signed-off-by: Daniel Golle <daniel at makrotopia.org>
+---
+v5: fix incomplete unification of variable names phy_reg vs. phy_register
+v4: clean-up return values and types, split into two commits
+
+ drivers/net/ethernet/mediatek/mtk_eth_soc.c | 16 ++++++++--------
+ 1 file changed, 8 insertions(+), 8 deletions(-)
+
+--- a/drivers/net/ethernet/mediatek/mtk_eth_soc.c
++++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
+@@ -95,31 +95,31 @@ static int mtk_mdio_busy_wait(struct mtk
+ 	return -1;
+ }
+ 
+-static u32 _mtk_mdio_write(struct mtk_eth *eth, u32 phy_addr,
+-			   u32 phy_register, u32 write_data)
++static int _mtk_mdio_write(struct mtk_eth *eth, u32 phy_addr, u32 phy_reg,
++			   u32 write_data)
+ {
+ 	if (mtk_mdio_busy_wait(eth))
+-		return -1;
++		return -EBUSY;
+ 
+ 	write_data &= 0xffff;
+ 
+ 	mtk_w32(eth, PHY_IAC_ACCESS | PHY_IAC_START | PHY_IAC_WRITE |
+-		(phy_register << PHY_IAC_REG_SHIFT) |
++		(phy_reg << PHY_IAC_REG_SHIFT) |
+ 		(phy_addr << PHY_IAC_ADDR_SHIFT) | write_data,
+ 		MTK_PHY_IAC);
+ 
+ 	if (mtk_mdio_busy_wait(eth))
+-		return -1;
++		return -EBUSY;
+ 
+ 	return 0;
+ }
+ 
+-static u32 _mtk_mdio_read(struct mtk_eth *eth, int phy_addr, int phy_reg)
++static int _mtk_mdio_read(struct mtk_eth *eth, int phy_addr, int phy_reg)
+ {
+ 	u32 d;
+ 
+ 	if (mtk_mdio_busy_wait(eth))
+-		return 0xffff;
++		return -EBUSY;
+ 
+ 	mtk_w32(eth, PHY_IAC_ACCESS | PHY_IAC_START | PHY_IAC_READ |
+ 		(phy_reg << PHY_IAC_REG_SHIFT) |
+@@ -127,7 +127,7 @@ static u32 _mtk_mdio_read(struct mtk_eth
+ 		MTK_PHY_IAC);
+ 
+ 	if (mtk_mdio_busy_wait(eth))
+-		return 0xffff;
++		return -EBUSY;
+ 
+ 	d = mtk_r32(eth, MTK_PHY_IAC) & 0xffff;
+ 
diff --git a/target/linux/mediatek/patches-5.10/701-net-ethernet-mtk_eth_soc-implement-Clause-45-MDIO-access.patch b/target/linux/mediatek/patches-5.10/702-net-ethernet-mtk_eth_soc-implement-Clause-45-MDIO-access.patch
similarity index 76%
rename from target/linux/mediatek/patches-5.10/701-net-ethernet-mtk_eth_soc-implement-Clause-45-MDIO-access.patch
rename to target/linux/mediatek/patches-5.10/702-net-ethernet-mtk_eth_soc-implement-Clause-45-MDIO-access.patch
index 78e1a626d5..f7732cae9b 100644
--- a/target/linux/mediatek/patches-5.10/701-net-ethernet-mtk_eth_soc-implement-Clause-45-MDIO-access.patch
+++ b/target/linux/mediatek/patches-5.10/702-net-ethernet-mtk_eth_soc-implement-Clause-45-MDIO-access.patch
@@ -1,11 +1,12 @@
-From patchwork Mon Dec 27 16:09:22 2021
+From patchwork Mon Dec 27 18:31:43 2021
 Content-Type: text/plain; charset="utf-8"
 MIME-Version: 1.0
 Content-Transfer-Encoding: 7bit
 X-Patchwork-Submitter: Daniel Golle <daniel at makrotopia.org>
-X-Patchwork-Id: 12699860
+X-Patchwork-Id: 12699994
 X-Patchwork-Delegate: kuba at kernel.org
-Date: Mon, 27 Dec 2021 16:09:22 +0000
+Return-Path: <netdev-owner at kernel.org>
+Date: Mon, 27 Dec 2021 18:31:43 +0000
 From: Daniel Golle <daniel at makrotopia.org>
 To: linux-mediatek at lists.infradead.org, netdev at vger.kernel.org,
         linux-arm-kernel at lists.infradead.org, linux-kernel at vger.kernel.org
@@ -17,19 +18,15 @@ Cc: Felix Fietkau <nbd at nbd.name>, John Crispin <john at phrozen.org>,
         Matthias Brugger <matthias.bgg at gmail.com>,
         Russell King <linux at armlinux.org.uk>,
         Andrew Lunn <andrew at lunn.ch>
-Subject: [PATCH v3] net: ethernet: mtk_eth_soc: implement Clause 45 MDIO
+Subject: [PATCH v5 2/2] net: ethernet: mtk_eth_soc: implement Clause 45 MDIO
  access
-Message-ID: <YcnlMtninjjjPhjI at makrotopia.org>
-References: <YcjsFnbg87o45ltd at lunn.ch>
- <YcjjzNJ159Bo1xk7 at lunn.ch>
- <YcjlMCacTTJ4RsSA at shell.armlinux.org.uk>
- <YcjepQ2fmkPZ2+pE at makrotopia.org>
+Message-ID: <YcoGj4Rj5mJlXz4D at makrotopia.org>
+References: <YcnoAscVe+2YILT8 at shell.armlinux.org.uk>
+ <YcnlMtninjjjPhjI at makrotopia.org>
 MIME-Version: 1.0
 Content-Disposition: inline
-In-Reply-To: <YcjsFnbg87o45ltd at lunn.ch>
- <YcjjzNJ159Bo1xk7 at lunn.ch>
- <YcjlMCacTTJ4RsSA at shell.armlinux.org.uk>
- <YcjepQ2fmkPZ2+pE at makrotopia.org>
+In-Reply-To: <YcnoAscVe+2YILT8 at shell.armlinux.org.uk>
+ <YcnlMtninjjjPhjI at makrotopia.org>
 Precedence: bulk
 List-ID: <netdev.vger.kernel.org>
 X-Mailing-List: netdev at vger.kernel.org
@@ -42,34 +39,27 @@ MediaTek MT7622BV WiSoC with Aquantia AQR112C.
 
 Signed-off-by: Daniel Golle <daniel at makrotopia.org>
 ---
+v5: unchanged
+v4: clean-up return values and types, split into two commits
 v3: return -1 instead of 0xffff on error in _mtk_mdio_write
 v2: use MII_DEVADDR_C45_SHIFT and MII_REGADDR_C45_MASK to extract
     device id and register address. Unify read and write functions to
     have identical types and parameter names where possible as we are
     anyway already replacing both function bodies.
 
- drivers/net/ethernet/mediatek/mtk_eth_soc.c | 62 +++++++++++++++++----
- drivers/net/ethernet/mediatek/mtk_eth_soc.h |  3 +
- 2 files changed, 54 insertions(+), 11 deletions(-)
+
+ drivers/net/ethernet/mediatek/mtk_eth_soc.c | 60 +++++++++++++++++----
+ drivers/net/ethernet/mediatek/mtk_eth_soc.h |  3 ++
+ 2 files changed, 53 insertions(+), 10 deletions(-)
 
 --- a/drivers/net/ethernet/mediatek/mtk_eth_soc.c
 +++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
-@@ -95,18 +95,38 @@ static int mtk_mdio_busy_wait(struct mtk
- 	return -1;
- }
- 
--static u32 _mtk_mdio_write(struct mtk_eth *eth, u32 phy_addr,
--			   u32 phy_register, u32 write_data)
-+static u32 _mtk_mdio_write(struct mtk_eth *eth, u32 phy_addr, u32 phy_reg,
-+			   u32 write_data)
- {
- 	if (mtk_mdio_busy_wait(eth))
- 		return -1;
+@@ -103,10 +103,30 @@ static int _mtk_mdio_write(struct mtk_et
  
  	write_data &= 0xffff;
  
 -	mtk_w32(eth, PHY_IAC_ACCESS | PHY_IAC_START | PHY_IAC_WRITE |
--		(phy_register << PHY_IAC_REG_SHIFT) |
+-		(phy_reg << PHY_IAC_REG_SHIFT) |
 -		(phy_addr << PHY_IAC_ADDR_SHIFT) | write_data,
 -		MTK_PHY_IAC);
 +	if (phy_reg & MII_ADDR_C45) {
@@ -83,7 +73,7 @@ v2: use MII_DEVADDR_C45_SHIFT and MII_REGADDR_C45_MASK to extract
 +			MTK_PHY_IAC);
 +
 +		if (mtk_mdio_busy_wait(eth))
-+			return -1;
++			return -EBUSY;
 +
 +		mtk_w32(eth, PHY_IAC_ACCESS | PHY_IAC_START_C45 | PHY_IAC_WRITE |
 +			(phy_addr << PHY_IAC_ADDR_SHIFT) |
@@ -98,18 +88,19 @@ v2: use MII_DEVADDR_C45_SHIFT and MII_REGADDR_C45_MASK to extract
 +	}
  
  	if (mtk_mdio_busy_wait(eth))
- 		return -1;
-@@ -114,17 +134,36 @@ static u32 _mtk_mdio_write(struct mtk_et
+ 		return -EBUSY;
+@@ -114,17 +134,36 @@ static int _mtk_mdio_write(struct mtk_et
  	return 0;
  }
  
--static u32 _mtk_mdio_read(struct mtk_eth *eth, int phy_addr, int phy_reg)
-+static u32 _mtk_mdio_read(struct mtk_eth *eth, u32 phy_addr, u32 phy_reg)
+-static int _mtk_mdio_read(struct mtk_eth *eth, int phy_addr, int phy_reg)
++static int _mtk_mdio_read(struct mtk_eth *eth, u32 phy_addr, u32 phy_reg)
  {
- 	u32 d;
+-	u32 d;
++	int d;
  
  	if (mtk_mdio_busy_wait(eth))
- 		return 0xffff;
+ 		return -EBUSY;
  
 -	mtk_w32(eth, PHY_IAC_ACCESS | PHY_IAC_START | PHY_IAC_READ |
 -		(phy_reg << PHY_IAC_REG_SHIFT) |
@@ -126,7 +117,7 @@ v2: use MII_DEVADDR_C45_SHIFT and MII_REGADDR_C45_MASK to extract
 +			MTK_PHY_IAC);
 +
 +		if (mtk_mdio_busy_wait(eth))
-+			return 0xffff;
++			return -EBUSY;
 +
 +		mtk_w32(eth, PHY_IAC_ACCESS | PHY_IAC_START_C45 | PHY_IAC_READ_C45 |
 +			(phy_addr << PHY_IAC_ADDR_SHIFT) |
@@ -140,7 +131,7 @@ v2: use MII_DEVADDR_C45_SHIFT and MII_REGADDR_C45_MASK to extract
 +	}
  
  	if (mtk_mdio_busy_wait(eth))
- 		return 0xffff;
+ 		return -EBUSY;
 @@ -584,6 +623,7 @@ static int mtk_mdio_init(struct mtk_eth
  	eth->mii_bus->name = "mdio";
  	eth->mii_bus->read = mtk_mdio_read;



More information about the lede-commits mailing list