diff options
Diffstat (limited to 'include/linux')
-rw-r--r-- | include/linux/netdevice.h | 17 | ||||
-rw-r--r-- | include/linux/skbuff.h | 5 |
2 files changed, 16 insertions, 6 deletions
diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h index 03cd7551a7a1..84b0f0d16fcb 100644 --- a/include/linux/netdevice.h +++ b/include/linux/netdevice.h | |||
@@ -315,6 +315,7 @@ struct net_device | |||
315 | #define NETIF_F_GSO_SHIFT 16 | 315 | #define NETIF_F_GSO_SHIFT 16 |
316 | #define NETIF_F_TSO (SKB_GSO_TCPV4 << NETIF_F_GSO_SHIFT) | 316 | #define NETIF_F_TSO (SKB_GSO_TCPV4 << NETIF_F_GSO_SHIFT) |
317 | #define NETIF_F_UFO (SKB_GSO_UDPV4 << NETIF_F_GSO_SHIFT) | 317 | #define NETIF_F_UFO (SKB_GSO_UDPV4 << NETIF_F_GSO_SHIFT) |
318 | #define NETIF_F_GSO_ROBUST (SKB_GSO_DODGY << NETIF_F_GSO_SHIFT) | ||
318 | 319 | ||
319 | #define NETIF_F_GEN_CSUM (NETIF_F_NO_CSUM | NETIF_F_HW_CSUM) | 320 | #define NETIF_F_GEN_CSUM (NETIF_F_NO_CSUM | NETIF_F_HW_CSUM) |
320 | #define NETIF_F_ALL_CSUM (NETIF_F_IP_CSUM | NETIF_F_GEN_CSUM) | 321 | #define NETIF_F_ALL_CSUM (NETIF_F_IP_CSUM | NETIF_F_GEN_CSUM) |
@@ -543,7 +544,8 @@ struct packet_type { | |||
543 | struct net_device *, | 544 | struct net_device *, |
544 | struct packet_type *, | 545 | struct packet_type *, |
545 | struct net_device *); | 546 | struct net_device *); |
546 | struct sk_buff *(*gso_segment)(struct sk_buff *skb, int sg); | 547 | struct sk_buff *(*gso_segment)(struct sk_buff *skb, |
548 | int features); | ||
547 | void *af_packet_priv; | 549 | void *af_packet_priv; |
548 | struct list_head list; | 550 | struct list_head list; |
549 | }; | 551 | }; |
@@ -968,7 +970,7 @@ extern int netdev_max_backlog; | |||
968 | extern int weight_p; | 970 | extern int weight_p; |
969 | extern int netdev_set_master(struct net_device *dev, struct net_device *master); | 971 | extern int netdev_set_master(struct net_device *dev, struct net_device *master); |
970 | extern int skb_checksum_help(struct sk_buff *skb, int inward); | 972 | extern int skb_checksum_help(struct sk_buff *skb, int inward); |
971 | extern struct sk_buff *skb_gso_segment(struct sk_buff *skb, int sg); | 973 | extern struct sk_buff *skb_gso_segment(struct sk_buff *skb, int features); |
972 | #ifdef CONFIG_BUG | 974 | #ifdef CONFIG_BUG |
973 | extern void netdev_rx_csum_fault(struct net_device *dev); | 975 | extern void netdev_rx_csum_fault(struct net_device *dev); |
974 | #else | 976 | #else |
@@ -988,11 +990,16 @@ extern void dev_seq_stop(struct seq_file *seq, void *v); | |||
988 | 990 | ||
989 | extern void linkwatch_run_queue(void); | 991 | extern void linkwatch_run_queue(void); |
990 | 992 | ||
993 | static inline int skb_gso_ok(struct sk_buff *skb, int features) | ||
994 | { | ||
995 | int feature = skb_shinfo(skb)->gso_size ? | ||
996 | skb_shinfo(skb)->gso_type << NETIF_F_GSO_SHIFT : 0; | ||
997 | return (features & feature) != feature; | ||
998 | } | ||
999 | |||
991 | static inline int netif_needs_gso(struct net_device *dev, struct sk_buff *skb) | 1000 | static inline int netif_needs_gso(struct net_device *dev, struct sk_buff *skb) |
992 | { | 1001 | { |
993 | int feature = skb_shinfo(skb)->gso_type << NETIF_F_GSO_SHIFT; | 1002 | return skb_gso_ok(skb, dev->features); |
994 | return skb_shinfo(skb)->gso_size && | ||
995 | (dev->features & feature) != feature; | ||
996 | } | 1003 | } |
997 | 1004 | ||
998 | #endif /* __KERNEL__ */ | 1005 | #endif /* __KERNEL__ */ |
diff --git a/include/linux/skbuff.h b/include/linux/skbuff.h index 16eef03ce0eb..5fb72da7da03 100644 --- a/include/linux/skbuff.h +++ b/include/linux/skbuff.h | |||
@@ -172,6 +172,9 @@ enum { | |||
172 | enum { | 172 | enum { |
173 | SKB_GSO_TCPV4 = 1 << 0, | 173 | SKB_GSO_TCPV4 = 1 << 0, |
174 | SKB_GSO_UDPV4 = 1 << 1, | 174 | SKB_GSO_UDPV4 = 1 << 1, |
175 | |||
176 | /* This indicates the skb is from an untrusted source. */ | ||
177 | SKB_GSO_DODGY = 1 << 2, | ||
175 | }; | 178 | }; |
176 | 179 | ||
177 | /** | 180 | /** |
@@ -1299,7 +1302,7 @@ extern void skb_split(struct sk_buff *skb, | |||
1299 | struct sk_buff *skb1, const u32 len); | 1302 | struct sk_buff *skb1, const u32 len); |
1300 | 1303 | ||
1301 | extern void skb_release_data(struct sk_buff *skb); | 1304 | extern void skb_release_data(struct sk_buff *skb); |
1302 | extern struct sk_buff *skb_segment(struct sk_buff *skb, int sg); | 1305 | extern struct sk_buff *skb_segment(struct sk_buff *skb, int features); |
1303 | 1306 | ||
1304 | static inline void *skb_header_pointer(const struct sk_buff *skb, int offset, | 1307 | static inline void *skb_header_pointer(const struct sk_buff *skb, int offset, |
1305 | int len, void *buffer) | 1308 | int len, void *buffer) |