From decd89c57ff3b0d17d87d198c2cd48e20131d2fc Mon Sep 17 00:00:00 2001 From: blogic Date: Mon, 2 May 2016 18:50:52 +0000 Subject: ramips: Fix multicast ICMPv6 for the rt3050 ethernet switch. The FCT2 esw register should be set to 0x2500C to have "unknown IPv6 multicast" packets broadcasted to every port, instead of dropped. The previous value only let those packets go through ports 1 and 3. "Unknown IPv6 multicast" packets include packets needed by ICMPv6 echo requests addressed to well-known addresses, such as ff02::1 (MAC address is 33:33:00:00:00:01 in this case). Please note that by default ICMPv6 echo requests to ff02::1 are not replied to by the router because of ip6tables considering those packets to be invalid. But this is another bug/patch. ;) Signed-off-by: Vittorio Gambaletta SVN-Revision: 49287 --- ...k-fix-multicast-icmpv6-for-the-rt3050-eth.patch | 26 ++++++++++++++++++++++ 1 file changed, 26 insertions(+) create mode 100644 target/linux/ramips/patches-4.4/0515-net-mediatek-fix-multicast-icmpv6-for-the-rt3050-eth.patch (limited to 'target/linux') diff --git a/target/linux/ramips/patches-4.4/0515-net-mediatek-fix-multicast-icmpv6-for-the-rt3050-eth.patch b/target/linux/ramips/patches-4.4/0515-net-mediatek-fix-multicast-icmpv6-for-the-rt3050-eth.patch new file mode 100644 index 0000000000..66b65d8e19 --- /dev/null +++ b/target/linux/ramips/patches-4.4/0515-net-mediatek-fix-multicast-icmpv6-for-the-rt3050-eth.patch @@ -0,0 +1,26 @@ +From: Vittorio Gambaletta +Date: Mon, 02 May 2016 04:55:48 +0200 +Subject: [PATCH] net: mediatek: Fix multicast ICMPv6 for the rt3050 ethernet switch. + +The FCT2 esw register should be set to 0x2500C to have "unknown IPv6 +multicast" packets broadcasted to every port, instead of dropped. +The previous value only let those packets go through ports 1 and 3. + +"Unknown IPv6 multicast" packets include packets needed by ICMPv6 echo +requests addressed to well-known addresses, such as ff02::1 (MAC address +is 33:33:00:00:00:01 in this case). + +Signed-off-by: Vittorio Gambaletta +--- + +--- a/drivers/net/ethernet/mediatek/esw_rt3050.c ++++ b/drivers/net/ethernet/mediatek/esw_rt3050.c +@@ -450,7 +450,7 @@ static void esw_hw_init(struct rt305x_es + (RT305X_ESW_PORTS_NOCPU << RT305X_ESW_POC2_UNTAG_EN_S)), + RT305X_ESW_REG_POC2); + +- esw_w32(esw, 0x00d6500c, RT305X_ESW_REG_FCT2); ++ esw_w32(esw, 0x0002500c, RT305X_ESW_REG_FCT2); + + /* 300s aging timer, max packet len 1536, broadcast storm prevention + * disabled, disable collision abort, mac xor48 hash, 10 packet back -- cgit v1.2.3