diff options
Diffstat (limited to 'include/linux/netdevice.h')
| -rw-r--r-- | include/linux/netdevice.h | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h index 50a4719512ed..9264139bd8df 100644 --- a/include/linux/netdevice.h +++ b/include/linux/netdevice.h | |||
| @@ -187,7 +187,7 @@ struct hh_cache | |||
| 187 | { | 187 | { |
| 188 | struct hh_cache *hh_next; /* Next entry */ | 188 | struct hh_cache *hh_next; /* Next entry */ |
| 189 | atomic_t hh_refcnt; /* number of users */ | 189 | atomic_t hh_refcnt; /* number of users */ |
| 190 | unsigned short hh_type; /* protocol identifier, f.e ETH_P_IP | 190 | __be16 hh_type; /* protocol identifier, f.e ETH_P_IP |
| 191 | * NOTE: For VLANs, this will be the | 191 | * NOTE: For VLANs, this will be the |
| 192 | * encapuslated type. --BLG | 192 | * encapuslated type. --BLG |
| 193 | */ | 193 | */ |
| @@ -334,7 +334,6 @@ struct net_device | |||
| 334 | 334 | ||
| 335 | 335 | ||
| 336 | struct net_device_stats* (*get_stats)(struct net_device *dev); | 336 | struct net_device_stats* (*get_stats)(struct net_device *dev); |
| 337 | struct iw_statistics* (*get_wireless_stats)(struct net_device *dev); | ||
| 338 | 337 | ||
| 339 | /* List of functions to handle Wireless Extensions (instead of ioctl). | 338 | /* List of functions to handle Wireless Extensions (instead of ioctl). |
| 340 | * See <net/iw_handler.h> for details. Jean II */ | 339 | * See <net/iw_handler.h> for details. Jean II */ |
| @@ -342,7 +341,7 @@ struct net_device | |||
| 342 | /* Instance data managed by the core of Wireless Extensions. */ | 341 | /* Instance data managed by the core of Wireless Extensions. */ |
| 343 | struct iw_public_data * wireless_data; | 342 | struct iw_public_data * wireless_data; |
| 344 | 343 | ||
| 345 | struct ethtool_ops *ethtool_ops; | 344 | const struct ethtool_ops *ethtool_ops; |
| 346 | 345 | ||
| 347 | /* | 346 | /* |
| 348 | * This marks the end of the "visible" part of the structure. All | 347 | * This marks the end of the "visible" part of the structure. All |
| @@ -976,7 +975,7 @@ extern void dev_mcast_init(void); | |||
| 976 | extern int netdev_max_backlog; | 975 | extern int netdev_max_backlog; |
| 977 | extern int weight_p; | 976 | extern int weight_p; |
| 978 | extern int netdev_set_master(struct net_device *dev, struct net_device *master); | 977 | extern int netdev_set_master(struct net_device *dev, struct net_device *master); |
| 979 | extern int skb_checksum_help(struct sk_buff *skb, int inward); | 978 | extern int skb_checksum_help(struct sk_buff *skb); |
| 980 | extern struct sk_buff *skb_gso_segment(struct sk_buff *skb, int features); | 979 | extern struct sk_buff *skb_gso_segment(struct sk_buff *skb, int features); |
| 981 | #ifdef CONFIG_BUG | 980 | #ifdef CONFIG_BUG |
| 982 | extern void netdev_rx_csum_fault(struct net_device *dev); | 981 | extern void netdev_rx_csum_fault(struct net_device *dev); |
| @@ -1012,11 +1011,12 @@ static inline int netif_needs_gso(struct net_device *dev, struct sk_buff *skb) | |||
| 1012 | { | 1011 | { |
| 1013 | return skb_is_gso(skb) && | 1012 | return skb_is_gso(skb) && |
| 1014 | (!skb_gso_ok(skb, dev->features) || | 1013 | (!skb_gso_ok(skb, dev->features) || |
| 1015 | unlikely(skb->ip_summed != CHECKSUM_HW)); | 1014 | unlikely(skb->ip_summed != CHECKSUM_PARTIAL)); |
| 1016 | } | 1015 | } |
| 1017 | 1016 | ||
| 1018 | /* On bonding slaves other than the currently active slave, suppress | 1017 | /* On bonding slaves other than the currently active slave, suppress |
| 1019 | * duplicates except for 802.3ad ETH_P_SLOW and alb non-mcast/bcast. | 1018 | * duplicates except for 802.3ad ETH_P_SLOW, alb non-mcast/bcast, and |
| 1019 | * ARP on active-backup slaves with arp_validate enabled. | ||
| 1020 | */ | 1020 | */ |
| 1021 | static inline int skb_bond_should_drop(struct sk_buff *skb) | 1021 | static inline int skb_bond_should_drop(struct sk_buff *skb) |
| 1022 | { | 1022 | { |
| @@ -1025,6 +1025,10 @@ static inline int skb_bond_should_drop(struct sk_buff *skb) | |||
| 1025 | 1025 | ||
| 1026 | if (master && | 1026 | if (master && |
| 1027 | (dev->priv_flags & IFF_SLAVE_INACTIVE)) { | 1027 | (dev->priv_flags & IFF_SLAVE_INACTIVE)) { |
| 1028 | if ((dev->priv_flags & IFF_SLAVE_NEEDARP) && | ||
| 1029 | skb->protocol == __constant_htons(ETH_P_ARP)) | ||
| 1030 | return 0; | ||
| 1031 | |||
| 1028 | if (master->priv_flags & IFF_MASTER_ALB) { | 1032 | if (master->priv_flags & IFF_MASTER_ALB) { |
| 1029 | if (skb->pkt_type != PACKET_BROADCAST && | 1033 | if (skb->pkt_type != PACKET_BROADCAST && |
| 1030 | skb->pkt_type != PACKET_MULTICAST) | 1034 | skb->pkt_type != PACKET_MULTICAST) |
