Re: meson-gxbb-p200 4.12.0 network TCP transfer stalls

2017-07-10 Thread Marc Duponcheel
 I use NBD for fast building and savif SD card and, sadly, the TV box crashes 
after few min of building

On 2017 Jul 11, Marc Duponcheel wrote:
>  FYI
> 
> I changed 4.12.0 drivers/net/phy/realtek.c RTL8211F code to equal the
> 3.14.29 amlogic/ethernet/phy/am_realtek.c code and now the networking
> works without TCP stalls.
> 
> I don't say below patch should be considered mainstream (as maybe some
> 4.12.0 rtl8211f_config_init code should not be removed) but sure
> someone could figure out what best patch is...

--
 Marc Duponcheel
 Velodroomstraat 74 - 2600 Berchem - Belgium
 +32 (0)478 68 10 91 - m...@offline.be


Re: meson-gxbb-p200 4.12.0 network TCP transfer stalls

2017-07-10 Thread Marc Duponcheel
 FYI

I changed 4.12.0 drivers/net/phy/realtek.c RTL8211F code to equal the
3.14.29 amlogic/ethernet/phy/am_realtek.c code and now the networking
works without TCP stalls.

I don't say below patch should be considered mainstream (as maybe some
4.12.0 rtl8211f_config_init code should not be removed) but sure
someone could figure out what best patch is...

 --
# diff -U2 realtek.c.orig realtek.c
--- realtek.c.orig  2017-07-03 01:07:02.0 +0200
+++ realtek.c   2017-07-11 01:32:20.273445023 +0200
@@ -94,28 +94,27 @@
 }
 
+#define RTL8211F_MMD_CTRL   0x0D
+#define RTL8211F_MMD_DATA   0x0E
+#define RTL8211E_INER_LINK_STAT 0x10
+
 static int rtl8211f_config_init(struct phy_device *phydev)
 {
-   int ret;
-   u16 reg;
-
-   ret = genphy_config_init(phydev);
-   if (ret < 0)
-   return ret;
-
-   phy_write(phydev, RTL8211F_PAGE_SELECT, 0xd08);
-   reg = phy_read(phydev, 0x11);
-
-   /* enable TX-delay for rgmii-id and rgmii-txid, otherwise disable it */
-   if (phydev->interface == PHY_INTERFACE_MODE_RGMII_ID ||
-   phydev->interface == PHY_INTERFACE_MODE_RGMII_TXID)
-   reg |= RTL8211F_TX_DELAY;
-   else
-   reg &= ~RTL8211F_TX_DELAY;
-
-   phy_write(phydev, 0x11, reg);
-   /* restore to default page 0 */
-   phy_write(phydev, RTL8211F_PAGE_SELECT, 0x0);
-
+   int val;
+/* we want to disable eee */
+   phy_write(phydev, RTL8211F_MMD_CTRL, 0x7);
+   phy_write(phydev, RTL8211F_MMD_DATA, 0x3c);
+   phy_write(phydev, RTL8211F_MMD_CTRL, 0x4007);
+   phy_write(phydev, RTL8211F_MMD_DATA, 0x0);
+/* disable 1000m adv*/
+   val = phy_read(phydev, 0x9);
+   phy_write(phydev, 0x9, val&(~(1<<9)));
+/* rx reg 21 bit 3 tx reg 17 bit 8 */
+/*
+   phy_write(phydev, 0x1f, 0xd08);
+   val =  phy_read(phydev, 0x15);
+   phy_write(phydev, 0x15,val| 1<<21);
+ */
return 0;
+/* Enable Auto Power Saving mode */
 }
 
@@ -167,6 +166,6 @@
.name   = "RTL8211F Gigabit Ethernet",
.phy_id_mask= 0x001f,
-   .features   = PHY_GBIT_FEATURES,
-   .flags  = PHY_HAS_INTERRUPT,
+   .features   = PHY_GBIT_FEATURES | SUPPORTED_Pause | 
SUPPORTED_Asym_Pause,
+   .flags  = PHY_HAS_INTERRUPT | PHY_HAS_MAGICANEG,
.config_aneg    = _config_aneg,
 --


On 2017 Jul 08, Marc Duponcheel wrote:
> Hi all
> 
> Similar to 'crow'
> 
> ARM GLX Khadas VIM Pro - Ethernet detected as only 10Mbps and stalled after 
> some traffic
> 
> I also have the situation where copying large file over LAN stalls.
> 
> 3.14.29 performance is good 4.12.0 performance not
> 
> 
>  Perhaps one must compare 3.14.29 am_realtek.c and realtek.c with 4.12.0 
> realtek.c
> 
> 
>  thanks

have a nice day


meson-gxbb-p200 4.12.0 network TCP transfer stalls

2017-07-07 Thread Marc Duponcheel
Hi all

Similar to 'crow'

ARM GLX Khadas VIM Pro - Ethernet detected as only 10Mbps and stalled after 
some traffic

I also have the situation where copying large file over LAN stalls.

3.14.29 performance is good 4.12.0 performance not

output of 'mii-tool -vvv eth0' differs (e.g. flow-control)

 --
$ echo *
3.14.29 4.12.0

$ diff */mii-tool-vvv.eth0
4,5c4,5
< 1040 79ad 001c c916 0de1 c5e1 006d 2801
< 4806 0200 3800   4007  2000
---
> 1040 79ad 001c c916 01e1 c5e1 006f 2001
> 5806 0200 3800   4007 0002 2000
7c7
< 211a 0862 30ee 0002 6295   
---
> 211a 0863 302c 0002  0020  
12c12
<   advertising:  1000baseT-FD 100baseTx-FD 100baseTx-HD 10baseT-FD 10baseT-HD 
flow-control
---
>   advertising:  1000baseT-FD 100baseTx-FD 100baseTx-HD 10baseT-FD 10baseT-HD
 --

When capturing with tcpdump stalled transfer shows various
retransmits, duplicate acks and fast retransmit issues.

# nstat | grep ^Tcp

also shows much more exceptions in 4.12.0 versus 3.14.29

$ cat 3.14.29/nstat^Tcp
TcpInSegs   18 0.0
TcpOutSegs  11 0.0
TcpExtTCPHPAcks 11 0.0

$ cat 4.12.0/nstat^Tcp
TcpPassiveOpens 2  0.0
TcpInSegs   6870.0
TcpOutSegs  3790.0
TcpExtDelayedACKs   4  0.0
TcpExtTCPHPHits 2070.0
TcpExtTCPPureAcks   10 0.0
TcpExtTCPHPAcks 3500.0
TcpExtTCPAutoCorking6  0.0
TcpExtTCPOrigDataSent   3650.0


 Perhaps one must compare 3.14.29 am_realtek.c and realtek.c with 
4.12.0realtek.c


 thanks

--
 Marc Duponcheel
 Velodroomstraat 74 - 2600 Berchem - Belgium
 +32 (0)478 68 10 91 - m...@offline.be