diff options
| -rw-r--r-- | net/bridge/br_forward.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/net/bridge/br_forward.c b/net/bridge/br_forward.c index 2d24fb400e0c..56f3aa47e758 100644 --- a/net/bridge/br_forward.c +++ b/net/bridge/br_forward.c | |||
| @@ -16,6 +16,7 @@ | |||
| 16 | #include <linux/kernel.h> | 16 | #include <linux/kernel.h> |
| 17 | #include <linux/netdevice.h> | 17 | #include <linux/netdevice.h> |
| 18 | #include <linux/skbuff.h> | 18 | #include <linux/skbuff.h> |
| 19 | #include <linux/if_vlan.h> | ||
| 19 | #include <linux/netfilter_bridge.h> | 20 | #include <linux/netfilter_bridge.h> |
| 20 | #include "br_private.h" | 21 | #include "br_private.h" |
| 21 | 22 | ||
| @@ -29,10 +30,15 @@ static inline int should_deliver(const struct net_bridge_port *p, | |||
| 29 | return 1; | 30 | return 1; |
| 30 | } | 31 | } |
| 31 | 32 | ||
| 33 | static inline unsigned packet_length(const struct sk_buff *skb) | ||
| 34 | { | ||
| 35 | return skb->len - (skb->protocol == htons(ETH_P_8021Q) ? VLAN_HLEN : 0); | ||
| 36 | } | ||
| 37 | |||
| 32 | int br_dev_queue_push_xmit(struct sk_buff *skb) | 38 | int br_dev_queue_push_xmit(struct sk_buff *skb) |
| 33 | { | 39 | { |
| 34 | /* drop mtu oversized packets except tso */ | 40 | /* drop mtu oversized packets except tso */ |
| 35 | if (skb->len > skb->dev->mtu && !skb_shinfo(skb)->tso_size) | 41 | if (packet_length(skb) > skb->dev->mtu && !skb_shinfo(skb)->tso_size) |
| 36 | kfree_skb(skb); | 42 | kfree_skb(skb); |
| 37 | else { | 43 | else { |
| 38 | #ifdef CONFIG_BRIDGE_NETFILTER | 44 | #ifdef CONFIG_BRIDGE_NETFILTER |
