frank-w
(Frank W.)
January 14, 2025, 4:35pm
4
I meant that issue is still there if no 100mbit device is directly connected to r4 only “through” dumb switch.
So basicly if one port on r4 switch is recognize a 100mbit link (ethtool) the full switch may operate in 100mbit mode (rx),would be interesting if it happens too when no software bridge is added.
No “software” bridge == no issue. However, as it’s DSA, no way to check with really software bridge
frank-w
(Frank W.)
January 14, 2025, 5:41pm
6
With software bridge i mean the lanbr created by openwrt which bridges the dsa ports…if you remove this and use the ports alone (different subnets on the dsa ports) the issue is not there,right?
That sounds for me more like an issue with software bridge limiting the underlying hardware/dsa ports
@ericwoud have you noticed something like this on your bridge vlan tests?
ericwoud
(Eric W.)
January 14, 2025, 6:36pm
8
I did the tests on R3 on 6.12. Nothing noticed there, even with one 100mb/s rj45.
Edit:
Wasn’t this an issue about a year ago, sounds similar. That was solved right?
One could check the settings on lan0…4 ports as well as eth0, which could also be affected. Look at pause settings and check other settings too. What changes at the affected port, when a 100mbit linkpartner is attached on another port…
vpupkin
January 14, 2025, 10:16pm
9
Tested both eth0 and lan* ports - same behavior, nothing changed
frank-w
(Frank W.)
January 15, 2025, 11:11am
10
Afaik these are 2 different issues…imho you have the first one (first link from eric) where i see no solution. Second is a hw offloading issue and disabling it would fix it.
romanovj
(Romanovj)
January 15, 2025, 12:20pm
11
try
echo 2 > /sys/kernel/debug/mtk_ppe/qos_toggle
vpupkin
January 15, 2025, 1:14pm
12
Well, this one I don’t have
> cat /sys/kernel/debug/mtk_ppe/qos_toggle
cat: can't open '/sys/kernel/debug/mtk_ppe/qos_toggle': No such file or directory
romanovj
(Romanovj)
January 15, 2025, 1:25pm
13
vpupkin
January 15, 2025, 1:46pm
14
Yes, I thought it’s wifi related, which I don’t have and don’t plan to have
ericwoud
(Eric W.)
January 15, 2025, 3:22pm
15
So some output may help. Let’s say lan0 is the affected port that slows down, lan1 is the port with the 100mb device. lan0 and lan1 are bridged.
So what is the output of:
ethtool eth0
ethtool lan0
In both cases,
without 100mb device attached to lan1,
with 100mb device attached to lan1.
Anything changes in the output?
vpupkin
January 15, 2025, 3:30pm
16
cat /tmp/with.txt
# brctl addif br-lan lan2
# brctl show br-lan
bridge name bridge id STP enabled interfaces
br-lan 7fff.eeb4e28d068c no eth1
lan1
lan2
Settings for eth0:
Supported ports: [ MII ]
Supported link modes: 10000baseCR/Full
Supported pause frame use: Symmetric Receive-only
Supports auto-negotiation: Yes
Supported FEC modes: Not reported
Advertised link modes: 10000baseCR/Full
Advertised pause frame use: Symmetric Receive-only
Advertised auto-negotiation: Yes
Advertised FEC modes: Not reported
Link partner advertised link modes: 10000baseCR/Full
Link partner advertised pause frame use: Symmetric
Link partner advertised auto-negotiation: No
Link partner advertised FEC modes: Not reported
Speed: 10000Mb/s
Duplex: Full
Auto-negotiation: on
Port: MII
PHYAD: 0
Transceiver: internal
Current message level: 0x000000ff (255)
drv probe link timer ifdown ifup rx_err tx_err
Link detected: yes
Settings for lan1:
Supported ports: [ TP MII ]
Supported link modes: 10baseT/Half 10baseT/Full
100baseT/Half 100baseT/Full
1000baseT/Full
Supported pause frame use: Symmetric Receive-only
Supports auto-negotiation: Yes
Supported FEC modes: Not reported
Advertised link modes: 10baseT/Half 10baseT/Full
100baseT/Half 100baseT/Full
1000baseT/Full
Advertised pause frame use: Symmetric Receive-only
Advertised auto-negotiation: Yes
Advertised FEC modes: Not reported
Link partner advertised link modes: 10baseT/Half 10baseT/Full
100baseT/Half 100baseT/Full
1000baseT/Full
Link partner advertised pause frame use: Symmetric
Link partner advertised auto-negotiation: Yes
Link partner advertised FEC modes: Not reported
Speed: 1000Mb/s
Duplex: Full
Auto-negotiation: on
master-slave cfg: preferred slave
master-slave status: slave
Port: Twisted Pair
PHYAD: 1
Transceiver: external
MDI-X: Unknown
Supports Wake-on: d
Wake-on: d
Link detected: yes
Settings for lan2:
Supported ports: [ TP MII ]
Supported link modes: 10baseT/Half 10baseT/Full
100baseT/Half 100baseT/Full
1000baseT/Full
Supported pause frame use: Symmetric Receive-only
Supports auto-negotiation: Yes
Supported FEC modes: Not reported
Advertised link modes: 10baseT/Half 10baseT/Full
100baseT/Half 100baseT/Full
1000baseT/Full
Advertised pause frame use: Symmetric Receive-only
Advertised auto-negotiation: Yes
Advertised FEC modes: Not reported
Link partner advertised link modes: 10baseT/Half 10baseT/Full
100baseT/Half 100baseT/Full
Link partner advertised pause frame use: Symmetric
Link partner advertised auto-negotiation: Yes
Link partner advertised FEC modes: Not reported
Speed: 100Mb/s
Duplex: Full
Auto-negotiation: on
master-slave cfg: preferred slave
master-slave status: master
Port: Twisted Pair
PHYAD: 2
Transceiver: external
MDI-X: Unknown
Supports Wake-on: d
Wake-on: d
Link detected: yes
cat /tmp/without.txt
# brctl show br-lan
bridge name bridge id STP enabled interfaces
br-lan 7fff.eeb4e28d068c no eth1
lan1
Settings for eth0:
Supported ports: [ MII ]
Supported link modes: 10000baseCR/Full
Supported pause frame use: Symmetric Receive-only
Supports auto-negotiation: Yes
Supported FEC modes: Not reported
Advertised link modes: 10000baseCR/Full
Advertised pause frame use: Symmetric Receive-only
Advertised auto-negotiation: Yes
Advertised FEC modes: Not reported
Link partner advertised link modes: 10000baseCR/Full
Link partner advertised pause frame use: Symmetric
Link partner advertised auto-negotiation: No
Link partner advertised FEC modes: Not reported
Speed: 10000Mb/s
Duplex: Full
Auto-negotiation: on
Port: MII
PHYAD: 0
Transceiver: internal
Current message level: 0x000000ff (255)
drv probe link timer ifdown ifup rx_err tx_err
Link detected: yes
Settings for lan1:
Supported ports: [ TP MII ]
Supported link modes: 10baseT/Half 10baseT/Full
100baseT/Half 100baseT/Full
1000baseT/Full
Supported pause frame use: Symmetric Receive-only
Supports auto-negotiation: Yes
Supported FEC modes: Not reported
Advertised link modes: 10baseT/Half 10baseT/Full
100baseT/Half 100baseT/Full
1000baseT/Full
Advertised pause frame use: Symmetric Receive-only
Advertised auto-negotiation: Yes
Advertised FEC modes: Not reported
Link partner advertised link modes: 10baseT/Half 10baseT/Full
100baseT/Half 100baseT/Full
1000baseT/Full
Link partner advertised pause frame use: Symmetric
Link partner advertised auto-negotiation: Yes
Link partner advertised FEC modes: Not reported
Speed: 1000Mb/s
Duplex: Full
Auto-negotiation: on
master-slave cfg: preferred slave
master-slave status: slave
Port: Twisted Pair
PHYAD: 1
Transceiver: external
MDI-X: Unknown
Supports Wake-on: d
Wake-on: d
Link detected: yes
Settings for lan2:
Supported ports: [ TP MII ]
Supported link modes: 10baseT/Half 10baseT/Full
100baseT/Half 100baseT/Full
1000baseT/Full
Supported pause frame use: Symmetric Receive-only
Supports auto-negotiation: Yes
Supported FEC modes: Not reported
Advertised link modes: 10baseT/Half 10baseT/Full
100baseT/Half 100baseT/Full
1000baseT/Full
Advertised pause frame use: Symmetric Receive-only
Advertised auto-negotiation: Yes
Advertised FEC modes: Not reported
Link partner advertised link modes: 10baseT/Half 10baseT/Full
100baseT/Half 100baseT/Full
Link partner advertised pause frame use: Symmetric
Link partner advertised auto-negotiation: Yes
Link partner advertised FEC modes: Not reported
Speed: 100Mb/s
Duplex: Full
Auto-negotiation: on
master-slave cfg: preferred slave
master-slave status: master
Port: Twisted Pair
PHYAD: 2
Transceiver: external
MDI-X: Unknown
Supports Wake-on: d
Wake-on: d
Link detected: yes
diff /tmp/with.txt /tmp/without.txt
1d0
< # brctl addif br-lan lan2
6,7d4
< lan2
<
95a93
>
cat /tmp/iperf3-with.txt
> iperf3 -c 192.168.1.1 --bidir
Connecting to host 192.168.1.1, port 5201
[ 5] local 192.168.1.159 port 60824 connected to 192.168.1.1 port 5201
[ 7] local 192.168.1.159 port 60840 connected to 192.168.1.1 port 5201
[ ID][Role] Interval Transfer Bitrate Retr Cwnd
[ 5][TX-C] 0.00-1.00 sec 13.2 MBytes 111 Mbits/sec 0 494 KBytes
[ 7][RX-C] 0.00-1.00 sec 13.0 MBytes 109 Mbits/sec
[ 5][TX-C] 1.00-2.00 sec 11.8 MBytes 98.6 Mbits/sec 0 518 KBytes
[ 7][RX-C] 1.00-2.00 sec 55.5 MBytes 466 Mbits/sec
[ 5][TX-C] 2.00-3.00 sec 10.6 MBytes 89.1 Mbits/sec 0 518 KBytes
[ 7][RX-C] 2.00-3.00 sec 97.1 MBytes 815 Mbits/sec
[ 5][TX-C] 3.00-4.00 sec 11.5 MBytes 96.5 Mbits/sec 0 571 KBytes
[ 7][RX-C] 3.00-4.00 sec 97.6 MBytes 819 Mbits/sec
[ 5][TX-C] 4.00-5.00 sec 11.0 MBytes 92.3 Mbits/sec 0 600 KBytes
[ 7][RX-C] 4.00-5.00 sec 103 MBytes 867 Mbits/sec
[ 5][TX-C] 5.00-6.00 sec 10.9 MBytes 91.2 Mbits/sec 0 626 KBytes
[ 7][RX-C] 5.00-6.00 sec 100 MBytes 841 Mbits/sec
[ 5][TX-C] 6.00-7.00 sec 10.9 MBytes 91.2 Mbits/sec 0 720 KBytes
[ 7][RX-C] 6.00-7.00 sec 92.4 MBytes 775 Mbits/sec
[ 5][TX-C] 7.00-8.00 sec 11.1 MBytes 93.3 Mbits/sec 0 720 KBytes
[ 7][RX-C] 7.00-8.00 sec 100 MBytes 843 Mbits/sec
[ 5][TX-C] 8.00-9.00 sec 11.1 MBytes 93.3 Mbits/sec 0 720 KBytes
[ 7][RX-C] 8.00-9.00 sec 104 MBytes 874 Mbits/sec
[ 5][TX-C] 9.00-10.00 sec 11.0 MBytes 92.2 Mbits/sec 0 720 KBytes
[ 7][RX-C] 9.00-10.00 sec 92.5 MBytes 775 Mbits/sec
- - - - - - - - - - - - - - - - - - - - - - - - -
[ ID][Role] Interval Transfer Bitrate Retr
[ 5][TX-C] 0.00-10.00 sec 113 MBytes 94.9 Mbits/sec 0 sender
[ 5][TX-C] 0.00-10.02 sec 110 MBytes 91.9 Mbits/sec receiver
[ 7][RX-C] 0.00-10.00 sec 859 MBytes 721 Mbits/sec 0 sender
[ 7][RX-C] 0.00-10.02 sec 856 MBytes 717 Mbits/sec receiver
iperf Done.
cat /tmp/iperf3-without.txt
> iperf3 -c 192.168.1.1 --bidir
Connecting to host 192.168.1.1, port 5201
[ 5] local 192.168.1.159 port 43510 connected to 192.168.1.1 port 5201
[ 7] local 192.168.1.159 port 43518 connected to 192.168.1.1 port 5201
[ ID][Role] Interval Transfer Bitrate Retr Cwnd
[ 5][TX-C] 0.00-1.00 sec 113 MBytes 949 Mbits/sec 0 773 KBytes
[ 7][RX-C] 0.00-1.00 sec 111 MBytes 929 Mbits/sec
[ 5][TX-C] 1.00-2.00 sec 112 MBytes 935 Mbits/sec 0 773 KBytes
[ 7][RX-C] 1.00-2.00 sec 112 MBytes 937 Mbits/sec
[ 5][TX-C] 2.00-3.00 sec 110 MBytes 924 Mbits/sec 0 773 KBytes
[ 7][RX-C] 2.00-3.00 sec 112 MBytes 938 Mbits/sec
[ 5][TX-C] 3.00-4.00 sec 111 MBytes 934 Mbits/sec 0 773 KBytes
[ 7][RX-C] 3.00-4.00 sec 112 MBytes 937 Mbits/sec
[ 5][TX-C] 4.00-5.00 sec 111 MBytes 933 Mbits/sec 0 851 KBytes
[ 7][RX-C] 4.00-5.00 sec 112 MBytes 939 Mbits/sec
[ 5][TX-C] 5.00-6.00 sec 111 MBytes 930 Mbits/sec 0 851 KBytes
[ 7][RX-C] 5.00-6.00 sec 112 MBytes 937 Mbits/sec
[ 5][TX-C] 6.00-7.00 sec 110 MBytes 927 Mbits/sec 0 851 KBytes
[ 7][RX-C] 6.00-7.00 sec 112 MBytes 939 Mbits/sec
[ 5][TX-C] 7.00-8.00 sec 112 MBytes 937 Mbits/sec 0 851 KBytes
[ 7][RX-C] 7.00-8.00 sec 112 MBytes 938 Mbits/sec
[ 5][TX-C] 8.00-9.00 sec 111 MBytes 932 Mbits/sec 0 897 KBytes
[ 7][RX-C] 8.00-9.00 sec 112 MBytes 938 Mbits/sec
[ 5][TX-C] 9.00-10.00 sec 110 MBytes 921 Mbits/sec 0 897 KBytes
[ 7][RX-C] 9.00-10.00 sec 112 MBytes 938 Mbits/sec
- - - - - - - - - - - - - - - - - - - - - - - - -
[ ID][Role] Interval Transfer Bitrate Retr
[ 5][TX-C] 0.00-10.00 sec 1.09 GBytes 933 Mbits/sec 0 sender
[ 5][TX-C] 0.00-10.00 sec 1.08 GBytes 931 Mbits/sec receiver
[ 7][RX-C] 0.00-10.00 sec 1.09 GBytes 940 Mbits/sec 0 sender
[ 7][RX-C] 0.00-10.00 sec 1.09 GBytes 937 Mbits/sec receiver
iperf Done.
romanovj
(Romanovj)
January 15, 2025, 7:12pm
17
you are missing HQoS and some fixes
vpupkin
January 16, 2025, 8:05am
18
Recompiled kernel with almost all patches from MTK feed (excluding wifi hw related) - behavior has not changed.
Tried qos_toggle – same.
romanovj
(Romanovj)
January 16, 2025, 9:44am
19
Did you try?
echo 1 > /sys/kernel/debug/mtk_ppe/qos_toggle
vpupkin
January 16, 2025, 10:02am
20
I tried 0 1 2. But the issue initially doesn’t looks like QoS issue, or anything like that …
romanovj
(Romanovj)
January 20, 2025, 9:53am
21
the new patch from mtk feeds
[][kernel-6.6][common][switch][Add fine-tuning for internal PHY in mt7531 dsa]
[Description]
Add fine-tuning for internal PHY in the mt7531 dsa,
referencing the drivers/net/dsa/mt7531_phy.c file in kernel 5.4
https://git01.mediatek.com/plugins/gitiles/openwrt/feeds/mtk-openwrt-feeds/+/cc89eda3a6223fc2dd285fb4ab163ef2ad4df4c0/24.10/files/target/linux/mediatek/patches-6.6/999-2746-mt7531-dsa-iphy-fine-tuning.patch
ericwoud
(Eric W.)
January 20, 2025, 3:36pm
22
Does this have anything to do with it?
net: dsa: mt7530: fix 10M/100M speed on MT7988 switch · torvalds/linux@dfa988b
May need it, or may need to revert it?
1 Like
frank-w
(Frank W.)
January 20, 2025, 6:17pm
23
As far as i read it you need this,but this patch is from Daniel,so it should be already included in openwrt.