Commit bc74d636 authored by Shmulik Hen's avatar Shmulik Hen Committed by Jeff Garzik

[PATCH] bonding cleanup 2.6 - empty lines cleanup

Remove duplicate empty lines. add empty lines where
needed to improve readability.
parent ec5efa9d
...@@ -146,6 +146,7 @@ static inline void tlb_init_table_entry(struct tlb_client_info *entry, int save_ ...@@ -146,6 +146,7 @@ static inline void tlb_init_table_entry(struct tlb_client_info *entry, int save_
BOND_TLB_REBALANCE_INTERVAL; BOND_TLB_REBALANCE_INTERVAL;
entry->tx_bytes = 0; entry->tx_bytes = 0;
} }
entry->tx_slave = NULL; entry->tx_slave = NULL;
entry->next = TLB_NULL_INDEX; entry->next = TLB_NULL_INDEX;
entry->prev = TLB_NULL_INDEX; entry->prev = TLB_NULL_INDEX;
...@@ -164,6 +165,7 @@ static void tlb_clear_slave(struct bonding *bond, struct slave *slave, int save_ ...@@ -164,6 +165,7 @@ static void tlb_clear_slave(struct bonding *bond, struct slave *slave, int save_
u32 index; u32 index;
_lock_tx_hashtbl(bond); _lock_tx_hashtbl(bond);
/* clear slave from tx_hashtbl */ /* clear slave from tx_hashtbl */
tx_hash_table = BOND_ALB_INFO(bond).tx_hashtbl; tx_hash_table = BOND_ALB_INFO(bond).tx_hashtbl;
...@@ -173,6 +175,7 @@ static void tlb_clear_slave(struct bonding *bond, struct slave *slave, int save_ ...@@ -173,6 +175,7 @@ static void tlb_clear_slave(struct bonding *bond, struct slave *slave, int save_
tlb_init_table_entry(&tx_hash_table[index], save_load); tlb_init_table_entry(&tx_hash_table[index], save_load);
index = next_index; index = next_index;
} }
_unlock_tx_hashtbl(bond); _unlock_tx_hashtbl(bond);
tlb_init_slave(slave); tlb_init_slave(slave);
...@@ -199,9 +202,11 @@ static int tlb_initialize(struct bonding *bond) ...@@ -199,9 +202,11 @@ static int tlb_initialize(struct bonding *bond)
} }
memset(bond_info->tx_hashtbl, 0, size); memset(bond_info->tx_hashtbl, 0, size);
for (i = 0; i < TLB_HASH_TABLE_SIZE; i++) { for (i = 0; i < TLB_HASH_TABLE_SIZE; i++) {
tlb_init_table_entry(&bond_info->tx_hashtbl[i], 1); tlb_init_table_entry(&bond_info->tx_hashtbl[i], 1);
} }
_unlock_tx_hashtbl(bond); _unlock_tx_hashtbl(bond);
return 0; return 0;
...@@ -213,8 +218,10 @@ static void tlb_deinitialize(struct bonding *bond) ...@@ -213,8 +218,10 @@ static void tlb_deinitialize(struct bonding *bond)
struct alb_bond_info *bond_info = &(BOND_ALB_INFO(bond)); struct alb_bond_info *bond_info = &(BOND_ALB_INFO(bond));
_lock_tx_hashtbl(bond); _lock_tx_hashtbl(bond);
kfree(bond_info->tx_hashtbl); kfree(bond_info->tx_hashtbl);
bond_info->tx_hashtbl = NULL; bond_info->tx_hashtbl = NULL;
_unlock_tx_hashtbl(bond); _unlock_tx_hashtbl(bond);
} }
...@@ -326,7 +333,6 @@ static void rlb_update_entry_from_arp(struct bonding *bond, struct arp_pkt *arp) ...@@ -326,7 +333,6 @@ static void rlb_update_entry_from_arp(struct bonding *bond, struct arp_pkt *arp)
if ((client_info->assigned) && if ((client_info->assigned) &&
(client_info->ip_src == arp->ip_dst) && (client_info->ip_src == arp->ip_dst) &&
(client_info->ip_dst == arp->ip_src)) { (client_info->ip_dst == arp->ip_src)) {
/* update the clients MAC address */ /* update the clients MAC address */
memcpy(client_info->mac_dst, arp->mac_src, ETH_ALEN); memcpy(client_info->mac_dst, arp->mac_src, ETH_ALEN);
client_info->ntt = 1; client_info->ntt = 1;
...@@ -409,10 +415,12 @@ static void rlb_teach_disabled_mac_on_primary(struct bonding *bond, u8 addr[]) ...@@ -409,10 +415,12 @@ static void rlb_teach_disabled_mac_on_primary(struct bonding *bond, u8 addr[])
if (!bond->curr_active_slave) { if (!bond->curr_active_slave) {
return; return;
} }
if (!bond->alb_info.primary_is_promisc) { if (!bond->alb_info.primary_is_promisc) {
bond->alb_info.primary_is_promisc = 1; bond->alb_info.primary_is_promisc = 1;
dev_set_promiscuity(bond->curr_active_slave->dev, 1); dev_set_promiscuity(bond->curr_active_slave->dev, 1);
} }
bond->alb_info.rlb_promisc_timeout_counter = 0; bond->alb_info.rlb_promisc_timeout_counter = 0;
alb_send_learning_packets(bond->curr_active_slave, addr); alb_send_learning_packets(bond->curr_active_slave, addr);
...@@ -435,7 +443,6 @@ static void rlb_clear_slave(struct bonding *bond, struct slave *slave) ...@@ -435,7 +443,6 @@ static void rlb_clear_slave(struct bonding *bond, struct slave *slave)
index = bond_info->rx_hashtbl_head; index = bond_info->rx_hashtbl_head;
for (; index != RLB_NULL_INDEX; index = next_index) { for (; index != RLB_NULL_INDEX; index = next_index) {
next_index = rx_hash_table[index].next; next_index = rx_hash_table[index].next;
if (rx_hash_table[index].slave == slave) { if (rx_hash_table[index].slave == slave) {
struct slave *assigned_slave = rlb_next_rx_slave(bond); struct slave *assigned_slave = rlb_next_rx_slave(bond);
...@@ -464,9 +471,11 @@ static void rlb_clear_slave(struct bonding *bond, struct slave *slave) ...@@ -464,9 +471,11 @@ static void rlb_clear_slave(struct bonding *bond, struct slave *slave)
_unlock_rx_hashtbl(bond); _unlock_rx_hashtbl(bond);
write_lock(&bond->curr_slave_lock); write_lock(&bond->curr_slave_lock);
if (slave != bond->curr_active_slave) { if (slave != bond->curr_active_slave) {
rlb_teach_disabled_mac_on_primary(bond, slave->dev->dev_addr); rlb_teach_disabled_mac_on_primary(bond, slave->dev->dev_addr);
} }
write_unlock(&bond->curr_slave_lock); write_unlock(&bond->curr_slave_lock);
} }
...@@ -600,7 +609,6 @@ struct slave *rlb_choose_channel(struct bonding *bond, struct arp_pkt *arp) ...@@ -600,7 +609,6 @@ struct slave *rlb_choose_channel(struct bonding *bond, struct arp_pkt *arp)
if ((client_info->ip_src == arp->ip_src) && if ((client_info->ip_src == arp->ip_src) &&
(client_info->ip_dst == arp->ip_dst)) { (client_info->ip_dst == arp->ip_dst)) {
/* the entry is already assigned to this client */ /* the entry is already assigned to this client */
if (memcmp(arp->mac_dst, mac_bcast, ETH_ALEN)) { if (memcmp(arp->mac_dst, mac_bcast, ETH_ALEN)) {
/* update mac address from arp */ /* update mac address from arp */
memcpy(client_info->mac_dst, arp->mac_dst, ETH_ALEN); memcpy(client_info->mac_dst, arp->mac_dst, ETH_ALEN);
...@@ -679,7 +687,6 @@ static struct slave *rlb_arp_xmit(struct sk_buff *skb, struct bonding *bond) ...@@ -679,7 +687,6 @@ static struct slave *rlb_arp_xmit(struct sk_buff *skb, struct bonding *bond)
} }
dprintk("Server sent ARP Reply packet\n"); dprintk("Server sent ARP Reply packet\n");
} else if (arp->op_code == __constant_htons(ARPOP_REQUEST)) { } else if (arp->op_code == __constant_htons(ARPOP_REQUEST)) {
/* Create an entry in the rx_hashtbl for this client as a /* Create an entry in the rx_hashtbl for this client as a
* place holder. * place holder.
* When the arp reply is received the entry will be updated * When the arp reply is received the entry will be updated
...@@ -767,6 +774,7 @@ static int rlb_initialize(struct bonding *bond) ...@@ -767,6 +774,7 @@ static int rlb_initialize(struct bonding *bond)
for (i = 0; i < RLB_HASH_TABLE_SIZE; i++) { for (i = 0; i < RLB_HASH_TABLE_SIZE; i++) {
rlb_init_table_entry(bond_info->rx_hashtbl + i); rlb_init_table_entry(bond_info->rx_hashtbl + i);
} }
_unlock_rx_hashtbl(bond); _unlock_rx_hashtbl(bond);
/*initialize packet type*/ /*initialize packet type*/
...@@ -787,8 +795,10 @@ static void rlb_deinitialize(struct bonding *bond) ...@@ -787,8 +795,10 @@ static void rlb_deinitialize(struct bonding *bond)
dev_remove_pack(&(bond_info->rlb_pkt_type)); dev_remove_pack(&(bond_info->rlb_pkt_type));
_lock_rx_hashtbl(bond); _lock_rx_hashtbl(bond);
kfree(bond_info->rx_hashtbl); kfree(bond_info->rx_hashtbl);
bond_info->rx_hashtbl = NULL; bond_info->rx_hashtbl = NULL;
_unlock_rx_hashtbl(bond); _unlock_rx_hashtbl(bond);
} }
...@@ -816,14 +826,15 @@ static void alb_send_learning_packets(struct slave *slave, u8 mac_addr[]) ...@@ -816,14 +826,15 @@ static void alb_send_learning_packets(struct slave *slave, u8 mac_addr[])
data = skb_put(skb, size); data = skb_put(skb, size);
memcpy(data, &pkt, size); memcpy(data, &pkt, size);
skb->mac.raw = data; skb->mac.raw = data;
skb->nh.raw = data + ETH_HLEN; skb->nh.raw = data + ETH_HLEN;
skb->protocol = pkt.type; skb->protocol = pkt.type;
skb->priority = TC_PRIO_CONTROL; skb->priority = TC_PRIO_CONTROL;
skb->dev = slave->dev; skb->dev = slave->dev;
dev_queue_xmit(skb); dev_queue_xmit(skb);
} }
} }
/* hw is a boolean parameter that determines whether we should try and /* hw is a boolean parameter that determines whether we should try and
...@@ -991,6 +1002,7 @@ static int alb_handle_addr_collision_on_attach(struct bonding *bond, struct slav ...@@ -991,6 +1002,7 @@ static int alb_handle_addr_collision_on_attach(struct bonding *bond, struct slav
break; break;
} }
} }
if (found) { if (found) {
/* a slave was found that is using the mac address /* a slave was found that is using the mac address
* of the new slave * of the new slave
...@@ -1001,6 +1013,7 @@ static int alb_handle_addr_collision_on_attach(struct bonding *bond, struct slav ...@@ -1001,6 +1013,7 @@ static int alb_handle_addr_collision_on_attach(struct bonding *bond, struct slav
slave->dev->name); slave->dev->name);
return -EINVAL; return -EINVAL;
} }
return 0; return 0;
} }
...@@ -1178,7 +1191,6 @@ int bond_alb_xmit(struct sk_buff *skb, struct net_device *bond_dev) ...@@ -1178,7 +1191,6 @@ int bond_alb_xmit(struct sk_buff *skb, struct net_device *bond_dev)
hash_start = (char*)&(skb->nh.iph->daddr); hash_start = (char*)&(skb->nh.iph->daddr);
hash_size = sizeof(skb->nh.iph->daddr); hash_size = sizeof(skb->nh.iph->daddr);
break; break;
case ETH_P_IPV6: case ETH_P_IPV6:
if (memcmp(eth_data->h_dest, mac_bcast, ETH_ALEN) == 0) { if (memcmp(eth_data->h_dest, mac_bcast, ETH_ALEN) == 0) {
do_tx_balance = 0; do_tx_balance = 0;
...@@ -1188,7 +1200,6 @@ int bond_alb_xmit(struct sk_buff *skb, struct net_device *bond_dev) ...@@ -1188,7 +1200,6 @@ int bond_alb_xmit(struct sk_buff *skb, struct net_device *bond_dev)
hash_start = (char*)&(skb->nh.ipv6h->daddr); hash_start = (char*)&(skb->nh.ipv6h->daddr);
hash_size = sizeof(skb->nh.ipv6h->daddr); hash_size = sizeof(skb->nh.ipv6h->daddr);
break; break;
case ETH_P_IPX: case ETH_P_IPX:
if (ipx_hdr(skb)->ipx_checksum != if (ipx_hdr(skb)->ipx_checksum !=
__constant_htons(IPX_NO_CHECKSUM)) { __constant_htons(IPX_NO_CHECKSUM)) {
...@@ -1210,14 +1221,12 @@ int bond_alb_xmit(struct sk_buff *skb, struct net_device *bond_dev) ...@@ -1210,14 +1221,12 @@ int bond_alb_xmit(struct sk_buff *skb, struct net_device *bond_dev)
hash_start = (char*)eth_data->h_dest; hash_start = (char*)eth_data->h_dest;
hash_size = ETH_ALEN; hash_size = ETH_ALEN;
break; break;
case ETH_P_ARP: case ETH_P_ARP:
do_tx_balance = 0; do_tx_balance = 0;
if (bond_info->rlb_enabled) { if (bond_info->rlb_enabled) {
tx_slave = rlb_arp_xmit(skb, bond); tx_slave = rlb_arp_xmit(skb, bond);
} }
break; break;
default: default:
do_tx_balance = 0; do_tx_balance = 0;
break; break;
...@@ -1290,9 +1299,11 @@ void bond_alb_monitor(struct bonding *bond) ...@@ -1290,9 +1299,11 @@ void bond_alb_monitor(struct bonding *bond)
* read. * read.
*/ */
read_lock(&bond->curr_slave_lock); read_lock(&bond->curr_slave_lock);
bond_for_each_slave(bond, slave, i) { bond_for_each_slave(bond, slave, i) {
alb_send_learning_packets(slave,slave->dev->dev_addr); alb_send_learning_packets(slave,slave->dev->dev_addr);
} }
read_unlock(&bond->curr_slave_lock); read_unlock(&bond->curr_slave_lock);
bond_info->lp_counter = 0; bond_info->lp_counter = 0;
...@@ -1300,7 +1311,9 @@ void bond_alb_monitor(struct bonding *bond) ...@@ -1300,7 +1311,9 @@ void bond_alb_monitor(struct bonding *bond)
/* rebalance tx traffic */ /* rebalance tx traffic */
if (bond_info->tx_rebalance_counter >= BOND_TLB_REBALANCE_TICKS) { if (bond_info->tx_rebalance_counter >= BOND_TLB_REBALANCE_TICKS) {
read_lock(&bond->curr_slave_lock); read_lock(&bond->curr_slave_lock);
bond_for_each_slave(bond, slave, i) { bond_for_each_slave(bond, slave, i) {
tlb_clear_slave(bond, slave, 1); tlb_clear_slave(bond, slave, 1);
if (slave == bond->curr_active_slave) { if (slave == bond->curr_active_slave) {
...@@ -1310,7 +1323,9 @@ void bond_alb_monitor(struct bonding *bond) ...@@ -1310,7 +1323,9 @@ void bond_alb_monitor(struct bonding *bond)
bond_info->unbalanced_load = 0; bond_info->unbalanced_load = 0;
} }
} }
read_unlock(&bond->curr_slave_lock); read_unlock(&bond->curr_slave_lock);
bond_info->tx_rebalance_counter = 0; bond_info->tx_rebalance_counter = 0;
} }
...@@ -1322,6 +1337,7 @@ void bond_alb_monitor(struct bonding *bond) ...@@ -1322,6 +1337,7 @@ void bond_alb_monitor(struct bonding *bond)
* sets the promiscuity. * sets the promiscuity.
*/ */
write_lock(&bond->curr_slave_lock); write_lock(&bond->curr_slave_lock);
if (bond_info->primary_is_promisc && if (bond_info->primary_is_promisc &&
(++bond_info->rlb_promisc_timeout_counter >= RLB_PROMISC_TIMEOUT)) { (++bond_info->rlb_promisc_timeout_counter >= RLB_PROMISC_TIMEOUT)) {
...@@ -1334,6 +1350,7 @@ void bond_alb_monitor(struct bonding *bond) ...@@ -1334,6 +1350,7 @@ void bond_alb_monitor(struct bonding *bond)
dev_set_promiscuity(bond->curr_active_slave->dev, -1); dev_set_promiscuity(bond->curr_active_slave->dev, -1);
bond_info->primary_is_promisc = 0; bond_info->primary_is_promisc = 0;
} }
write_unlock(&bond->curr_slave_lock); write_unlock(&bond->curr_slave_lock);
if (bond_info->rlb_rebalance) { if (bond_info->rlb_rebalance) {
......
...@@ -596,7 +596,6 @@ static void bond_change_active_slave(struct bonding *bond, struct slave *new_act ...@@ -596,7 +596,6 @@ static void bond_change_active_slave(struct bonding *bond, struct slave *new_act
static void bond_select_active_slave(struct bonding *bond); static void bond_select_active_slave(struct bonding *bond);
static struct slave *bond_find_best_slave(struct bonding *bond); static struct slave *bond_find_best_slave(struct bonding *bond);
static void bond_arp_send_all(struct slave *slave) static void bond_arp_send_all(struct slave *slave)
{ {
int i; int i;
...@@ -608,7 +607,6 @@ static void bond_arp_send_all(struct slave *slave) ...@@ -608,7 +607,6 @@ static void bond_arp_send_all(struct slave *slave)
} }
} }
static const char *bond_mode_name(void) static const char *bond_mode_name(void)
{ {
switch (bond_mode) { switch (bond_mode) {
...@@ -697,7 +695,6 @@ static void bond_attach_slave(struct bonding *bond, struct slave *new_slave) ...@@ -697,7 +695,6 @@ static void bond_attach_slave(struct bonding *bond, struct slave *new_slave)
bond->slave_cnt++; bond->slave_cnt++;
} }
/* /*
* Less bad way to call ioctl from within the kernel; this needs to be * Less bad way to call ioctl from within the kernel; this needs to be
* done some other way to get the call out of interrupt context. * done some other way to get the call out of interrupt context.
...@@ -827,7 +824,6 @@ static int bond_check_dev_link(struct net_device *slave_dev, int reporting) ...@@ -827,7 +824,6 @@ static int bond_check_dev_link(struct net_device *slave_dev, int reporting)
return 0; return 0;
} }
} }
} }
/* /*
...@@ -1067,12 +1063,12 @@ static int bond_mc_list_copy(struct dev_mc_list *mc_list, struct bonding *bond, ...@@ -1067,12 +1063,12 @@ static int bond_mc_list_copy(struct dev_mc_list *mc_list, struct bonding *bond,
new_dmi->next = bond->mc_list; new_dmi->next = bond->mc_list;
bond->mc_list = new_dmi; bond->mc_list = new_dmi;
new_dmi->dmi_addrlen = dmi->dmi_addrlen; new_dmi->dmi_addrlen = dmi->dmi_addrlen;
memcpy(new_dmi->dmi_addr, dmi->dmi_addr, dmi->dmi_addrlen); memcpy(new_dmi->dmi_addr, dmi->dmi_addr, dmi->dmi_addrlen);
new_dmi->dmi_users = dmi->dmi_users; new_dmi->dmi_users = dmi->dmi_users;
new_dmi->dmi_gusers = dmi->dmi_gusers; new_dmi->dmi_gusers = dmi->dmi_gusers;
} }
return 0; return 0;
} }
...@@ -1095,7 +1091,6 @@ static void bond_set_promiscuity(struct bonding *bond, int inc) ...@@ -1095,7 +1091,6 @@ static void bond_set_promiscuity(struct bonding *bond, int inc)
if (bond->curr_active_slave) { if (bond->curr_active_slave) {
dev_set_promiscuity(bond->curr_active_slave->dev, inc); dev_set_promiscuity(bond->curr_active_slave->dev, inc);
} }
} else { } else {
struct slave *slave; struct slave *slave;
int i; int i;
...@@ -1136,6 +1131,7 @@ static struct dev_mc_list *bond_mc_list_find_dmi(struct dev_mc_list *dmi, struct ...@@ -1136,6 +1131,7 @@ static struct dev_mc_list *bond_mc_list_find_dmi(struct dev_mc_list *dmi, struct
return idmi; return idmi;
} }
} }
return NULL; return NULL;
} }
...@@ -1182,7 +1178,6 @@ static void bond_set_multicast_list(struct net_device *bond_dev) ...@@ -1182,7 +1178,6 @@ static void bond_set_multicast_list(struct net_device *bond_dev)
} }
} }
/* save master's multicast list */ /* save master's multicast list */
bond_mc_list_destroy(bond); bond_mc_list_destroy(bond);
bond_mc_list_copy(bond_dev->mc_list, bond, GFP_ATOMIC); bond_mc_list_copy(bond_dev->mc_list, bond, GFP_ATOMIC);
...@@ -1210,9 +1205,11 @@ static void bond_mc_swap(struct bonding *bond, struct slave *new_active, struct ...@@ -1210,9 +1205,11 @@ static void bond_mc_swap(struct bonding *bond, struct slave *new_active, struct
if (bond->dev->flags & IFF_PROMISC) { if (bond->dev->flags & IFF_PROMISC) {
dev_set_promiscuity(old_active->dev, -1); dev_set_promiscuity(old_active->dev, -1);
} }
if (bond->dev->flags & IFF_ALLMULTI) { if (bond->dev->flags & IFF_ALLMULTI) {
dev_set_allmulti(old_active->dev, -1); dev_set_allmulti(old_active->dev, -1);
} }
for (dmi = bond->dev->mc_list; dmi; dmi = dmi->next) { for (dmi = bond->dev->mc_list; dmi; dmi = dmi->next) {
dev_mc_delete(old_active->dev, dmi->dmi_addr, dmi->dmi_addrlen, 0); dev_mc_delete(old_active->dev, dmi->dmi_addr, dmi->dmi_addrlen, 0);
} }
...@@ -1222,9 +1219,11 @@ static void bond_mc_swap(struct bonding *bond, struct slave *new_active, struct ...@@ -1222,9 +1219,11 @@ static void bond_mc_swap(struct bonding *bond, struct slave *new_active, struct
if (bond->dev->flags & IFF_PROMISC) { if (bond->dev->flags & IFF_PROMISC) {
dev_set_promiscuity(new_active->dev, 1); dev_set_promiscuity(new_active->dev, 1);
} }
if (bond->dev->flags & IFF_ALLMULTI) { if (bond->dev->flags & IFF_ALLMULTI) {
dev_set_allmulti(new_active->dev, 1); dev_set_allmulti(new_active->dev, 1);
} }
for (dmi = bond->dev->mc_list; dmi; dmi = dmi->next) { for (dmi = bond->dev->mc_list; dmi; dmi = dmi->next) {
dev_mc_add(new_active->dev, dmi->dmi_addr, dmi->dmi_addrlen, 0); dev_mc_add(new_active->dev, dmi->dmi_addr, dmi->dmi_addrlen, 0);
} }
...@@ -1247,7 +1246,6 @@ static int bond_enslave(struct net_device *bond_dev, struct net_device *slave_de ...@@ -1247,7 +1246,6 @@ static int bond_enslave(struct net_device *bond_dev, struct net_device *slave_de
slave_dev->name); slave_dev->name);
} }
/* bond must be initialized by bond_open() before enslaving */ /* bond must be initialized by bond_open() before enslaving */
if (!(bond_dev->flags & IFF_UP)) { if (!(bond_dev->flags & IFF_UP)) {
dprintk("Error, master_dev is not up\n"); dprintk("Error, master_dev is not up\n");
...@@ -1307,6 +1305,7 @@ static int bond_enslave(struct net_device *bond_dev, struct net_device *slave_de ...@@ -1307,6 +1305,7 @@ static int bond_enslave(struct net_device *bond_dev, struct net_device *slave_de
if (!new_slave) { if (!new_slave) {
return -ENOMEM; return -ENOMEM;
} }
memset(new_slave, 0, sizeof(struct slave)); memset(new_slave, 0, sizeof(struct slave));
/* save slave's original flags before calling /* save slave's original flags before calling
...@@ -1374,6 +1373,7 @@ static int bond_enslave(struct net_device *bond_dev, struct net_device *slave_de ...@@ -1374,6 +1373,7 @@ static int bond_enslave(struct net_device *bond_dev, struct net_device *slave_de
if (bond_dev->flags & IFF_PROMISC) { if (bond_dev->flags & IFF_PROMISC) {
dev_set_promiscuity(slave_dev, 1); dev_set_promiscuity(slave_dev, 1);
} }
/* set allmulti level to new slave */ /* set allmulti level to new slave */
if (bond_dev->flags & IFF_ALLMULTI) { if (bond_dev->flags & IFF_ALLMULTI) {
dev_set_allmulti(slave_dev, 1); dev_set_allmulti(slave_dev, 1);
...@@ -1395,6 +1395,7 @@ static int bond_enslave(struct net_device *bond_dev, struct net_device *slave_de ...@@ -1395,6 +1395,7 @@ static int bond_enslave(struct net_device *bond_dev, struct net_device *slave_de
write_lock_bh(&bond->lock); write_lock_bh(&bond->lock);
bond_attach_slave(bond, new_slave); bond_attach_slave(bond, new_slave);
new_slave->delay = 0; new_slave->delay = 0;
new_slave->link_failure_count = 0; new_slave->link_failure_count = 0;
...@@ -1452,11 +1453,11 @@ static int bond_enslave(struct net_device *bond_dev, struct net_device *slave_de ...@@ -1452,11 +1453,11 @@ static int bond_enslave(struct net_device *bond_dev, struct net_device *slave_de
if (bond_update_speed_duplex(new_slave) && if (bond_update_speed_duplex(new_slave) &&
(new_slave->link != BOND_LINK_DOWN)) { (new_slave->link != BOND_LINK_DOWN)) {
printk(KERN_WARNING DRV_NAME printk(KERN_WARNING DRV_NAME
": Warning: failed to get speed/duplex from %s, speed " ": Warning: failed to get speed/duplex from %s, speed "
"forced to 100Mbps, duplex forced to Full.\n", "forced to 100Mbps, duplex forced to Full.\n",
new_slave->dev->name); new_slave->dev->name);
if (bond_mode == BOND_MODE_8023AD) { if (bond_mode == BOND_MODE_8023AD) {
printk(KERN_WARNING printk(KERN_WARNING
"Operation of 802.3ad mode requires ETHTOOL " "Operation of 802.3ad mode requires ETHTOOL "
...@@ -1527,6 +1528,7 @@ static int bond_enslave(struct net_device *bond_dev, struct net_device *slave_de ...@@ -1527,6 +1528,7 @@ static int bond_enslave(struct net_device *bond_dev, struct net_device *slave_de
break; break;
default: default:
dprintk("This slave is always active in trunk mode\n"); dprintk("This slave is always active in trunk mode\n");
/* always active in trunk mode */ /* always active in trunk mode */
new_slave->state = BOND_STATE_ACTIVE; new_slave->state = BOND_STATE_ACTIVE;
...@@ -1561,6 +1563,7 @@ static int bond_enslave(struct net_device *bond_dev, struct net_device *slave_de ...@@ -1561,6 +1563,7 @@ static int bond_enslave(struct net_device *bond_dev, struct net_device *slave_de
break; break;
} }
} }
if (ndx == bond_dev->addr_len) { if (ndx == bond_dev->addr_len) {
/* /*
* We got all the way through the address and it was * We got all the way through the address and it was
...@@ -1646,7 +1649,9 @@ static int bond_ioctl_change_active(struct net_device *bond_dev, struct net_devi ...@@ -1646,7 +1649,9 @@ static int bond_ioctl_change_active(struct net_device *bond_dev, struct net_devi
} else { } else {
res = -EINVAL; res = -EINVAL;
} }
write_unlock_bh(&bond->lock); write_unlock_bh(&bond->lock);
return res; return res;
} }
...@@ -1799,7 +1804,6 @@ static void bond_select_active_slave(struct bonding *bond) ...@@ -1799,7 +1804,6 @@ static void bond_select_active_slave(struct bonding *bond)
struct slave *best_slave; struct slave *best_slave;
best_slave = bond_find_best_slave(bond); best_slave = bond_find_best_slave(bond);
if (best_slave != bond->curr_active_slave) { if (best_slave != bond->curr_active_slave) {
bond_change_active_slave(bond, best_slave); bond_change_active_slave(bond, best_slave);
} }
...@@ -1920,10 +1924,12 @@ static int bond_release(struct net_device *bond_dev, struct net_device *slave_de ...@@ -1920,10 +1924,12 @@ static int bond_release(struct net_device *bond_dev, struct net_device *slave_de
if (bond_dev->flags & IFF_PROMISC) { if (bond_dev->flags & IFF_PROMISC) {
dev_set_promiscuity(slave_dev, -1); dev_set_promiscuity(slave_dev, -1);
} }
/* unset allmulti level from slave */ /* unset allmulti level from slave */
if (bond_dev->flags & IFF_ALLMULTI) { if (bond_dev->flags & IFF_ALLMULTI) {
dev_set_allmulti(slave_dev, -1); dev_set_allmulti(slave_dev, -1);
} }
/* flush master's mc_list from slave */ /* flush master's mc_list from slave */
bond_mc_list_flush (slave_dev, bond_dev); bond_mc_list_flush (slave_dev, bond_dev);
} }
...@@ -2015,10 +2021,12 @@ static int bond_release_all(struct net_device *bond_dev) ...@@ -2015,10 +2021,12 @@ static int bond_release_all(struct net_device *bond_dev)
if (bond_dev->flags & IFF_PROMISC) { if (bond_dev->flags & IFF_PROMISC) {
dev_set_promiscuity(slave_dev, -1); dev_set_promiscuity(slave_dev, -1);
} }
/* unset allmulti level from slave */ /* unset allmulti level from slave */
if (bond_dev->flags & IFF_ALLMULTI) { if (bond_dev->flags & IFF_ALLMULTI) {
dev_set_allmulti(slave_dev, -1); dev_set_allmulti(slave_dev, -1);
} }
/* flush master's mc_list from slave */ /* flush master's mc_list from slave */
bond_mc_list_flush(slave_dev, bond_dev); bond_mc_list_flush(slave_dev, bond_dev);
} }
...@@ -2110,9 +2118,11 @@ static void bond_mii_monitor(struct net_device *bond_dev) ...@@ -2110,9 +2118,11 @@ static void bond_mii_monitor(struct net_device *bond_dev)
} else { /* link going down */ } else { /* link going down */
slave->link = BOND_LINK_FAIL; slave->link = BOND_LINK_FAIL;
slave->delay = downdelay; slave->delay = downdelay;
if (slave->link_failure_count < UINT_MAX) { if (slave->link_failure_count < UINT_MAX) {
slave->link_failure_count++; slave->link_failure_count++;
} }
if (downdelay) { if (downdelay) {
printk(KERN_INFO DRV_NAME printk(KERN_INFO DRV_NAME
": %s: link status down for %s " ": %s: link status down for %s "
...@@ -2138,6 +2148,7 @@ static void bond_mii_monitor(struct net_device *bond_dev) ...@@ -2138,6 +2148,7 @@ static void bond_mii_monitor(struct net_device *bond_dev)
if (slave->delay <= 0) { if (slave->delay <= 0) {
/* link down for too long time */ /* link down for too long time */
slave->link = BOND_LINK_DOWN; slave->link = BOND_LINK_DOWN;
/* in active/backup mode, we must /* in active/backup mode, we must
* completely disable this interface * completely disable this interface
*/ */
...@@ -2210,6 +2221,7 @@ static void bond_mii_monitor(struct net_device *bond_dev) ...@@ -2210,6 +2221,7 @@ static void bond_mii_monitor(struct net_device *bond_dev)
if (link_state != BMSR_LSTATUS) { if (link_state != BMSR_LSTATUS) {
/* link down again */ /* link down again */
slave->link = BOND_LINK_DOWN; slave->link = BOND_LINK_DOWN;
printk(KERN_INFO DRV_NAME printk(KERN_INFO DRV_NAME
": %s: link status down again after %d " ": %s: link status down again after %d "
"ms for interface %s.\n", "ms for interface %s.\n",
...@@ -2272,6 +2284,7 @@ static void bond_mii_monitor(struct net_device *bond_dev) ...@@ -2272,6 +2284,7 @@ static void bond_mii_monitor(struct net_device *bond_dev)
if (old_speed != slave->speed) { if (old_speed != slave->speed) {
bond_3ad_adapter_speed_changed(slave); bond_3ad_adapter_speed_changed(slave);
} }
if (old_duplex != slave->duplex) { if (old_duplex != slave->duplex) {
bond_3ad_adapter_duplex_changed(slave); bond_3ad_adapter_duplex_changed(slave);
} }
...@@ -2337,9 +2350,7 @@ static void bond_loadbalance_arp_mon(struct net_device *bond_dev) ...@@ -2337,9 +2350,7 @@ static void bond_loadbalance_arp_mon(struct net_device *bond_dev)
* so it can wait * so it can wait
*/ */
bond_for_each_slave(bond, slave, i) { bond_for_each_slave(bond, slave, i) {
if (slave->link != BOND_LINK_UP) { if (slave->link != BOND_LINK_UP) {
if (((jiffies - slave->dev->trans_start) <= delta_in_ticks) && if (((jiffies - slave->dev->trans_start) <= delta_in_ticks) &&
((jiffies - slave->dev->last_rx) <= delta_in_ticks)) { ((jiffies - slave->dev->last_rx) <= delta_in_ticks)) {
...@@ -2375,11 +2386,14 @@ static void bond_loadbalance_arp_mon(struct net_device *bond_dev) ...@@ -2375,11 +2386,14 @@ static void bond_loadbalance_arp_mon(struct net_device *bond_dev)
if (((jiffies - slave->dev->trans_start) >= (2*delta_in_ticks)) || if (((jiffies - slave->dev->trans_start) >= (2*delta_in_ticks)) ||
(((jiffies - slave->dev->last_rx) >= (2*delta_in_ticks)) && (((jiffies - slave->dev->last_rx) >= (2*delta_in_ticks)) &&
my_ip)) { my_ip)) {
slave->link = BOND_LINK_DOWN; slave->link = BOND_LINK_DOWN;
slave->state = BOND_STATE_BACKUP; slave->state = BOND_STATE_BACKUP;
if (slave->link_failure_count < UINT_MAX) { if (slave->link_failure_count < UINT_MAX) {
slave->link_failure_count++; slave->link_failure_count++;
} }
printk(KERN_INFO DRV_NAME printk(KERN_INFO DRV_NAME
": %s: interface %s is now down.\n", ": %s: interface %s is now down.\n",
bond_dev->name, bond_dev->name,
...@@ -2407,6 +2421,7 @@ static void bond_loadbalance_arp_mon(struct net_device *bond_dev) ...@@ -2407,6 +2421,7 @@ static void bond_loadbalance_arp_mon(struct net_device *bond_dev)
write_lock(&bond->curr_slave_lock); write_lock(&bond->curr_slave_lock);
bond_select_active_slave(bond); bond_select_active_slave(bond);
if (oldcurrent && !bond->curr_active_slave) { if (oldcurrent && !bond->curr_active_slave) {
printk(KERN_INFO DRV_NAME printk(KERN_INFO DRV_NAME
": %s: now running without any active " ": %s: now running without any active "
...@@ -2461,12 +2476,13 @@ static void bond_activebackup_arp_mon(struct net_device *bond_dev) ...@@ -2461,12 +2476,13 @@ static void bond_activebackup_arp_mon(struct net_device *bond_dev)
* so it can wait * so it can wait
*/ */
bond_for_each_slave(bond, slave, i) { bond_for_each_slave(bond, slave, i) {
if (slave->link != BOND_LINK_UP) { if (slave->link != BOND_LINK_UP) {
if ((jiffies - slave->dev->last_rx) <= delta_in_ticks) { if ((jiffies - slave->dev->last_rx) <= delta_in_ticks) {
slave->link = BOND_LINK_UP; slave->link = BOND_LINK_UP;
write_lock(&bond->curr_slave_lock); write_lock(&bond->curr_slave_lock);
if ((!bond->curr_active_slave) && if ((!bond->curr_active_slave) &&
((jiffies - slave->dev->trans_start) <= delta_in_ticks)) { ((jiffies - slave->dev->trans_start) <= delta_in_ticks)) {
bond_change_active_slave(bond, slave); bond_change_active_slave(bond, slave);
...@@ -2500,6 +2516,7 @@ static void bond_activebackup_arp_mon(struct net_device *bond_dev) ...@@ -2500,6 +2516,7 @@ static void bond_activebackup_arp_mon(struct net_device *bond_dev)
} }
} else { } else {
read_lock(&bond->curr_slave_lock); read_lock(&bond->curr_slave_lock);
if ((slave != bond->curr_active_slave) && if ((slave != bond->curr_active_slave) &&
(!bond->current_arp_slave) && (!bond->current_arp_slave) &&
(((jiffies - slave->dev->last_rx) >= 3*delta_in_ticks) && (((jiffies - slave->dev->last_rx) >= 3*delta_in_ticks) &&
...@@ -2514,12 +2531,17 @@ static void bond_activebackup_arp_mon(struct net_device *bond_dev) ...@@ -2514,12 +2531,17 @@ static void bond_activebackup_arp_mon(struct net_device *bond_dev)
* down - this gives each slave a chance to * down - this gives each slave a chance to
* tx/rx traffic before being taken out * tx/rx traffic before being taken out
*/ */
read_unlock(&bond->curr_slave_lock); read_unlock(&bond->curr_slave_lock);
slave->link = BOND_LINK_DOWN; slave->link = BOND_LINK_DOWN;
if (slave->link_failure_count < UINT_MAX) { if (slave->link_failure_count < UINT_MAX) {
slave->link_failure_count++; slave->link_failure_count++;
} }
bond_set_slave_inactive_flags(slave); bond_set_slave_inactive_flags(slave);
printk(KERN_INFO DRV_NAME printk(KERN_INFO DRV_NAME
": %s: backup interface %s is now down\n", ": %s: backup interface %s is now down\n",
bond_dev->name, bond_dev->name,
...@@ -2535,7 +2557,6 @@ static void bond_activebackup_arp_mon(struct net_device *bond_dev) ...@@ -2535,7 +2557,6 @@ static void bond_activebackup_arp_mon(struct net_device *bond_dev)
read_unlock(&bond->curr_slave_lock); read_unlock(&bond->curr_slave_lock);
if (slave) { if (slave) {
/* if we have sent traffic in the past 2*arp_intervals but /* if we have sent traffic in the past 2*arp_intervals but
* haven't xmit and rx traffic in that time interval, select * haven't xmit and rx traffic in that time interval, select
* a different slave. slave->jiffies is only updated when * a different slave. slave->jiffies is only updated when
...@@ -2550,23 +2571,29 @@ static void bond_activebackup_arp_mon(struct net_device *bond_dev) ...@@ -2550,23 +2571,29 @@ static void bond_activebackup_arp_mon(struct net_device *bond_dev)
((jiffies - slave->jiffies) >= 2*delta_in_ticks)) { ((jiffies - slave->jiffies) >= 2*delta_in_ticks)) {
slave->link = BOND_LINK_DOWN; slave->link = BOND_LINK_DOWN;
if (slave->link_failure_count < UINT_MAX) { if (slave->link_failure_count < UINT_MAX) {
slave->link_failure_count++; slave->link_failure_count++;
} }
printk(KERN_INFO DRV_NAME printk(KERN_INFO DRV_NAME
": %s: link status down for active interface " ": %s: link status down for active interface "
"%s, disabling it", "%s, disabling it",
bond_dev->name, bond_dev->name,
slave->dev->name); slave->dev->name);
write_lock(&bond->curr_slave_lock); write_lock(&bond->curr_slave_lock);
bond_select_active_slave(bond); bond_select_active_slave(bond);
slave = bond->curr_active_slave; slave = bond->curr_active_slave;
write_unlock(&bond->curr_slave_lock); write_unlock(&bond->curr_slave_lock);
bond->current_arp_slave = slave; bond->current_arp_slave = slave;
if (slave) { if (slave) {
slave->jiffies = jiffies; slave->jiffies = jiffies;
} }
} else if ((bond->primary_slave) && } else if ((bond->primary_slave) &&
(bond->primary_slave != slave) && (bond->primary_slave != slave) &&
(bond->primary_slave->link == BOND_LINK_UP)) { (bond->primary_slave->link == BOND_LINK_UP)) {
...@@ -2582,6 +2609,7 @@ static void bond_activebackup_arp_mon(struct net_device *bond_dev) ...@@ -2582,6 +2609,7 @@ static void bond_activebackup_arp_mon(struct net_device *bond_dev)
write_lock(&bond->curr_slave_lock); write_lock(&bond->curr_slave_lock);
bond_change_active_slave(bond, bond->primary_slave); bond_change_active_slave(bond, bond->primary_slave);
write_unlock(&bond->curr_slave_lock); write_unlock(&bond->curr_slave_lock);
slave = bond->primary_slave; slave = bond->primary_slave;
slave->jiffies = jiffies; slave->jiffies = jiffies;
} else { } else {
...@@ -2634,6 +2662,7 @@ static void bond_activebackup_arp_mon(struct net_device *bond_dev) ...@@ -2634,6 +2662,7 @@ static void bond_activebackup_arp_mon(struct net_device *bond_dev)
} }
bond_set_slave_inactive_flags(slave); bond_set_slave_inactive_flags(slave);
printk(KERN_INFO DRV_NAME printk(KERN_INFO DRV_NAME
": %s: backup interface %s is " ": %s: backup interface %s is "
"now down.\n", "now down.\n",
...@@ -2684,12 +2713,14 @@ static int bond_slave_info_query(struct net_device *bond_dev, struct ifslave *in ...@@ -2684,12 +2713,14 @@ static int bond_slave_info_query(struct net_device *bond_dev, struct ifslave *in
} }
read_lock_bh(&bond->lock); read_lock_bh(&bond->lock);
bond_for_each_slave(bond, slave, i) { bond_for_each_slave(bond, slave, i) {
if (i == (int)info->slave_id) { if (i == (int)info->slave_id) {
found = 1; found = 1;
break; break;
} }
} }
read_unlock_bh(&bond->lock); read_unlock_bh(&bond->lock);
if (found) { if (found) {
...@@ -2716,7 +2747,6 @@ static int bond_ethtool_ioctl(struct net_device *bond_dev, struct ifreq *ifr) ...@@ -2716,7 +2747,6 @@ static int bond_ethtool_ioctl(struct net_device *bond_dev, struct ifreq *ifr)
} }
switch (cmd) { switch (cmd) {
case ETHTOOL_GDRVINFO: case ETHTOOL_GDRVINFO:
if (copy_from_user(&info, addr, sizeof(info))) { if (copy_from_user(&info, addr, sizeof(info))) {
return -EFAULT; return -EFAULT;
...@@ -2771,7 +2801,6 @@ static int bond_do_ioctl(struct net_device *bond_dev, struct ifreq *ifr, int cmd ...@@ -2771,7 +2801,6 @@ static int bond_do_ioctl(struct net_device *bond_dev, struct ifreq *ifr, int cmd
switch (cmd) { switch (cmd) {
case SIOCETHTOOL: case SIOCETHTOOL:
return bond_ethtool_ioctl(bond_dev, ifr); return bond_ethtool_ioctl(bond_dev, ifr);
case SIOCGMIIPHY: case SIOCGMIIPHY:
mii = (struct mii_ioctl_data *)&ifr->ifr_data; mii = (struct mii_ioctl_data *)&ifr->ifr_data;
if (!mii) { if (!mii) {
...@@ -2788,6 +2817,7 @@ static int bond_do_ioctl(struct net_device *bond_dev, struct ifreq *ifr, int cmd ...@@ -2788,6 +2817,7 @@ static int bond_do_ioctl(struct net_device *bond_dev, struct ifreq *ifr, int cmd
if (!mii) { if (!mii) {
return -EINVAL; return -EINVAL;
} }
if (mii->reg_num == 1) { if (mii->reg_num == 1) {
struct bonding *bond = (struct bonding *)bond_dev->priv; struct bonding *bond = (struct bonding *)bond_dev->priv;
mii->val_out = 0; mii->val_out = 0;
...@@ -2799,32 +2829,39 @@ static int bond_do_ioctl(struct net_device *bond_dev, struct ifreq *ifr, int cmd ...@@ -2799,32 +2829,39 @@ static int bond_do_ioctl(struct net_device *bond_dev, struct ifreq *ifr, int cmd
read_unlock(&bond->curr_slave_lock); read_unlock(&bond->curr_slave_lock);
read_unlock_bh(&bond->lock); read_unlock_bh(&bond->lock);
} }
return 0; return 0;
case BOND_INFO_QUERY_OLD: case BOND_INFO_QUERY_OLD:
case SIOCBONDINFOQUERY: case SIOCBONDINFOQUERY:
u_binfo = (struct ifbond *)ifr->ifr_data; u_binfo = (struct ifbond *)ifr->ifr_data;
if (copy_from_user(&k_binfo, u_binfo, sizeof(ifbond))) { if (copy_from_user(&k_binfo, u_binfo, sizeof(ifbond))) {
return -EFAULT; return -EFAULT;
} }
res = bond_info_query(bond_dev, &k_binfo); res = bond_info_query(bond_dev, &k_binfo);
if (res == 0) { if (res == 0) {
if (copy_to_user(u_binfo, &k_binfo, sizeof(ifbond))) { if (copy_to_user(u_binfo, &k_binfo, sizeof(ifbond))) {
return -EFAULT; return -EFAULT;
} }
} }
return res; return res;
case BOND_SLAVE_INFO_QUERY_OLD: case BOND_SLAVE_INFO_QUERY_OLD:
case SIOCBONDSLAVEINFOQUERY: case SIOCBONDSLAVEINFOQUERY:
u_sinfo = (struct ifslave *)ifr->ifr_data; u_sinfo = (struct ifslave *)ifr->ifr_data;
if (copy_from_user(&k_sinfo, u_sinfo, sizeof(ifslave))) { if (copy_from_user(&k_sinfo, u_sinfo, sizeof(ifslave))) {
return -EFAULT; return -EFAULT;
} }
res = bond_slave_info_query(bond_dev, &k_sinfo); res = bond_slave_info_query(bond_dev, &k_sinfo);
if (res == 0) { if (res == 0) {
if (copy_to_user(u_sinfo, &k_sinfo, sizeof(ifslave))) { if (copy_to_user(u_sinfo, &k_sinfo, sizeof(ifslave))) {
return -EFAULT; return -EFAULT;
} }
} }
return res; return res;
default: default:
/* Go on */ /* Go on */
...@@ -2882,6 +2919,7 @@ static int bond_do_ioctl(struct net_device *bond_dev, struct ifreq *ifr, int cmd ...@@ -2882,6 +2919,7 @@ static int bond_do_ioctl(struct net_device *bond_dev, struct ifreq *ifr, int cmd
default: default:
res = -EOPNOTSUPP; res = -EOPNOTSUPP;
} }
dev_put(slave_dev); dev_put(slave_dev);
} }
...@@ -2991,7 +3029,6 @@ static int bond_xmit_roundrobin(struct sk_buff *skb, struct net_device *bond_dev ...@@ -2991,7 +3029,6 @@ static int bond_xmit_roundrobin(struct sk_buff *skb, struct net_device *bond_dev
if (IS_UP(slave->dev) && if (IS_UP(slave->dev) &&
(slave->link == BOND_LINK_UP) && (slave->link == BOND_LINK_UP) &&
(slave->state == BOND_STATE_ACTIVE)) { (slave->state == BOND_STATE_ACTIVE)) {
skb->dev = slave->dev; skb->dev = slave->dev;
skb->priority = 1; skb->priority = 1;
dev_queue_xmit(skb); dev_queue_xmit(skb);
...@@ -3048,7 +3085,6 @@ static int bond_xmit_xor(struct sk_buff *skb, struct net_device *bond_dev) ...@@ -3048,7 +3085,6 @@ static int bond_xmit_xor(struct sk_buff *skb, struct net_device *bond_dev)
if (IS_UP(slave->dev) && if (IS_UP(slave->dev) &&
(slave->link == BOND_LINK_UP) && (slave->link == BOND_LINK_UP) &&
(slave->state == BOND_STATE_ACTIVE)) { (slave->state == BOND_STATE_ACTIVE)) {
skb->dev = slave->dev; skb->dev = slave->dev;
skb->priority = 1; skb->priority = 1;
dev_queue_xmit(skb); dev_queue_xmit(skb);
...@@ -3151,10 +3187,10 @@ static struct net_device_stats *bond_get_stats(struct net_device *bond_dev) ...@@ -3151,10 +3187,10 @@ static struct net_device_stats *bond_get_stats(struct net_device *bond_dev)
stats->tx_fifo_errors += sstats->tx_fifo_errors; stats->tx_fifo_errors += sstats->tx_fifo_errors;
stats->tx_heartbeat_errors += sstats->tx_heartbeat_errors; stats->tx_heartbeat_errors += sstats->tx_heartbeat_errors;
stats->tx_window_errors += sstats->tx_window_errors; stats->tx_window_errors += sstats->tx_window_errors;
} }
read_unlock_bh(&bond->lock); read_unlock_bh(&bond->lock);
return stats; return stats;
} }
...@@ -3326,6 +3362,7 @@ static int bond_info_open(struct inode *inode, struct file *file) ...@@ -3326,6 +3362,7 @@ static int bond_info_open(struct inode *inode, struct file *file)
proc = PDE(inode); proc = PDE(inode);
seq->private = proc->data; seq->private = proc->data;
} }
return res; return res;
} }
...@@ -3464,6 +3501,7 @@ static int bond_set_mac_address(struct net_device *bond_dev, void *addr) ...@@ -3464,6 +3501,7 @@ static int bond_set_mac_address(struct net_device *bond_dev, void *addr)
bond_for_each_slave(bond, slave, i) { bond_for_each_slave(bond, slave, i) {
dprintk("slave %p %s\n", slave, slave->dev->name); dprintk("slave %p %s\n", slave, slave->dev->name);
if (slave->dev->set_mac_address == NULL) { if (slave->dev->set_mac_address == NULL) {
res = -EOPNOTSUPP; res = -EOPNOTSUPP;
dprintk("EOPNOTSUPP %s\n", slave->dev->name); dprintk("EOPNOTSUPP %s\n", slave->dev->name);
...@@ -3559,8 +3597,8 @@ static int bond_change_mtu(struct net_device *bond_dev, int new_mtu) ...@@ -3559,8 +3597,8 @@ static int bond_change_mtu(struct net_device *bond_dev, int new_mtu)
} }
bond_dev->mtu = new_mtu; bond_dev->mtu = new_mtu;
return 0;
return 0;
unwind: unwind:
/* unwind from the first slave that failed to head */ /* unwind from the first slave that failed to head */
...@@ -3845,7 +3883,6 @@ static inline int bond_parse_parm(char *mode_arg, struct bond_parm_tbl *tbl) ...@@ -3845,7 +3883,6 @@ static inline int bond_parse_parm(char *mode_arg, struct bond_parm_tbl *tbl)
return -1; return -1;
} }
static int bond_check_params(void) static int bond_check_params(void)
{ {
/* /*
...@@ -3872,7 +3909,6 @@ static int bond_check_params(void) ...@@ -3872,7 +3909,6 @@ static int bond_check_params(void)
printk(KERN_ERR DRV_NAME printk(KERN_ERR DRV_NAME
": Error: Invalid lacp rate \"%s\"\n", ": Error: Invalid lacp rate \"%s\"\n",
lacp_rate == NULL ? "NULL" : lacp_rate); lacp_rate == NULL ? "NULL" : lacp_rate);
return -EINVAL; return -EINVAL;
} }
} }
...@@ -4025,7 +4061,6 @@ static int bond_check_params(void) ...@@ -4025,7 +4061,6 @@ static int bond_check_params(void)
} }
} }
if (arp_interval && !arp_ip_count) { if (arp_interval && !arp_ip_count) {
/* don't allow arping if no arp_ip_target given... */ /* don't allow arping if no arp_ip_target given... */
printk(KERN_WARNING DRV_NAME printk(KERN_WARNING DRV_NAME
...@@ -4149,3 +4184,4 @@ MODULE_DESCRIPTION(DRV_DESCRIPTION ", v" DRV_VERSION); ...@@ -4149,3 +4184,4 @@ MODULE_DESCRIPTION(DRV_DESCRIPTION ", v" DRV_VERSION);
* tab-width: 8 * tab-width: 8
* End: * End:
*/ */
...@@ -111,3 +111,4 @@ struct ad_info { ...@@ -111,3 +111,4 @@ struct ad_info {
* tab-width: 8 * tab-width: 8
* End: * End:
*/ */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment