summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--target/linux/generic/patches-3.18/680-net-skip-gro-for-otherhost-packets.patch14
-rw-r--r--target/linux/generic/patches-3.19/680-net-skip-gro-for-otherhost-packets.patch14
-rw-r--r--target/linux/generic/patches-4.0/680-net-skip-gro-for-otherhost-packets.patch14
3 files changed, 42 insertions, 0 deletions
diff --git a/target/linux/generic/patches-3.18/680-net-skip-gro-for-otherhost-packets.patch b/target/linux/generic/patches-3.18/680-net-skip-gro-for-otherhost-packets.patch
index 3adc4e3..2a65c0b 100644
--- a/target/linux/generic/patches-3.18/680-net-skip-gro-for-otherhost-packets.patch
+++ b/target/linux/generic/patches-3.18/680-net-skip-gro-for-otherhost-packets.patch
@@ -1,3 +1,17 @@
+Subject: NET: skip GRO for otherhost packets
+
+For network drivers using napi_gro_receive, packets are run through GRO,
+even when the destination MAC address does not match, and they're supposed
+to be delivered to another host behind a different bridge port.
+
+This can be very expensive, because for drivers without TSO or scatter-
+gather, this can only be undone by copying the skb and checksumming it
+again.
+
+Fix this by leaving skbs with PACKET_OTHERHOST untouched.
+
+Signed-off-by: Felix Fietkau <nbd@openwrt.org>
+
--- a/net/core/dev.c
+++ b/net/core/dev.c
@@ -4003,6 +4003,9 @@ static enum gro_result dev_gro_receive(s
diff --git a/target/linux/generic/patches-3.19/680-net-skip-gro-for-otherhost-packets.patch b/target/linux/generic/patches-3.19/680-net-skip-gro-for-otherhost-packets.patch
index e3fa917..292d021 100644
--- a/target/linux/generic/patches-3.19/680-net-skip-gro-for-otherhost-packets.patch
+++ b/target/linux/generic/patches-3.19/680-net-skip-gro-for-otherhost-packets.patch
@@ -1,3 +1,17 @@
+Subject: NET: skip GRO for otherhost packets
+
+For network drivers using napi_gro_receive, packets are run through GRO,
+even when the destination MAC address does not match, and they're supposed
+to be delivered to another host behind a different bridge port.
+
+This can be very expensive, because for drivers without TSO or scatter-
+gather, this can only be undone by copying the skb and checksumming it
+again.
+
+Fix this by leaving skbs with PACKET_OTHERHOST untouched.
+
+Signed-off-by: Felix Fietkau <nbd@openwrt.org>
+
--- a/net/core/dev.c
+++ b/net/core/dev.c
@@ -3967,6 +3967,9 @@ static enum gro_result dev_gro_receive(s
diff --git a/target/linux/generic/patches-4.0/680-net-skip-gro-for-otherhost-packets.patch b/target/linux/generic/patches-4.0/680-net-skip-gro-for-otherhost-packets.patch
index fc36258..62e0bde 100644
--- a/target/linux/generic/patches-4.0/680-net-skip-gro-for-otherhost-packets.patch
+++ b/target/linux/generic/patches-4.0/680-net-skip-gro-for-otherhost-packets.patch
@@ -1,3 +1,17 @@
+Subject: NET: skip GRO for otherhost packets
+
+For network drivers using napi_gro_receive, packets are run through GRO,
+even when the destination MAC address does not match, and they're supposed
+to be delivered to another host behind a different bridge port.
+
+This can be very expensive, because for drivers without TSO or scatter-
+gather, this can only be undone by copying the skb and checksumming it
+again.
+
+Fix this by leaving skbs with PACKET_OTHERHOST untouched.
+
+Signed-off-by: Felix Fietkau <nbd@openwrt.org>
+
--- a/net/core/dev.c
+++ b/net/core/dev.c
@@ -4005,6 +4005,9 @@ static enum gro_result dev_gro_receive(s