Browse Source

kernel: fix an af_packet regression that was breaking PPPoE on 4.1+ (#20707)

Signed-off-by: Felix Fietkau <[email protected]>

SVN-Revision: 47459
Felix Fietkau 10 years ago
parent
commit
8a2a1c1d71

+ 17 - 0
target/linux/generic/patches-4.1/103-packet_allow_empty_payload.patch

@@ -0,0 +1,17 @@
+Fix a regression in the af_packet code that was breaking PPPoE
+
+pppd sends packets with only a header and no payload.
+
+Signed-off-by: Felix Fietkau <[email protected]>
+
+--- a/net/packet/af_packet.c
++++ b/net/packet/af_packet.c
+@@ -2106,7 +2106,7 @@ static void tpacket_destruct_skb(struct
+ static bool ll_header_truncated(const struct net_device *dev, int len)
+ {
+ 	/* net device doesn't like empty head */
+-	if (unlikely(len <= dev->hard_header_len)) {
++	if (unlikely(len < dev->hard_header_len)) {
+ 		net_warn_ratelimited("%s: packet size is too short (%d <= %d)\n",
+ 				     current->comm, len, dev->hard_header_len);
+ 		return true;

+ 17 - 0
target/linux/generic/patches-4.3/103-packet_allow_empty_payload.patch

@@ -0,0 +1,17 @@
+Fix a regression in the af_packet code that was breaking PPPoE
+
+pppd sends packets with only a header and no payload.
+
+Signed-off-by: Felix Fietkau <[email protected]>
+
+--- a/net/packet/af_packet.c
++++ b/net/packet/af_packet.c
+@@ -2323,7 +2323,7 @@ static void tpacket_destruct_skb(struct
+ static bool ll_header_truncated(const struct net_device *dev, int len)
+ {
+ 	/* net device doesn't like empty head */
+-	if (unlikely(len <= dev->hard_header_len)) {
++	if (unlikely(len < dev->hard_header_len)) {
+ 		net_warn_ratelimited("%s: packet size is too short (%d <= %d)\n",
+ 				     current->comm, len, dev->hard_header_len);
+ 		return true;