diff options
Diffstat (limited to 'drivers/net/bonding/bond_main.c')
-rw-r--r-- | drivers/net/bonding/bond_main.c | 39 |
1 files changed, 31 insertions, 8 deletions
diff --git a/drivers/net/bonding/bond_main.c b/drivers/net/bonding/bond_main.c index dc733d75a5e9..8ae7ff313218 100644 --- a/drivers/net/bonding/bond_main.c +++ b/drivers/net/bonding/bond_main.c | |||
@@ -772,39 +772,49 @@ static struct dev_mc_list *bond_mc_list_find_dmi(struct dev_mc_list *dmi, struct | |||
772 | /* | 772 | /* |
773 | * Push the promiscuity flag down to appropriate slaves | 773 | * Push the promiscuity flag down to appropriate slaves |
774 | */ | 774 | */ |
775 | static void bond_set_promiscuity(struct bonding *bond, int inc) | 775 | static int bond_set_promiscuity(struct bonding *bond, int inc) |
776 | { | 776 | { |
777 | int err = 0; | ||
777 | if (USES_PRIMARY(bond->params.mode)) { | 778 | if (USES_PRIMARY(bond->params.mode)) { |
778 | /* write lock already acquired */ | 779 | /* write lock already acquired */ |
779 | if (bond->curr_active_slave) { | 780 | if (bond->curr_active_slave) { |
780 | dev_set_promiscuity(bond->curr_active_slave->dev, inc); | 781 | err = dev_set_promiscuity(bond->curr_active_slave->dev, |
782 | inc); | ||
781 | } | 783 | } |
782 | } else { | 784 | } else { |
783 | struct slave *slave; | 785 | struct slave *slave; |
784 | int i; | 786 | int i; |
785 | bond_for_each_slave(bond, slave, i) { | 787 | bond_for_each_slave(bond, slave, i) { |
786 | dev_set_promiscuity(slave->dev, inc); | 788 | err = dev_set_promiscuity(slave->dev, inc); |
789 | if (err) | ||
790 | return err; | ||
787 | } | 791 | } |
788 | } | 792 | } |
793 | return err; | ||
789 | } | 794 | } |
790 | 795 | ||
791 | /* | 796 | /* |
792 | * Push the allmulti flag down to all slaves | 797 | * Push the allmulti flag down to all slaves |
793 | */ | 798 | */ |
794 | static void bond_set_allmulti(struct bonding *bond, int inc) | 799 | static int bond_set_allmulti(struct bonding *bond, int inc) |
795 | { | 800 | { |
801 | int err = 0; | ||
796 | if (USES_PRIMARY(bond->params.mode)) { | 802 | if (USES_PRIMARY(bond->params.mode)) { |
797 | /* write lock already acquired */ | 803 | /* write lock already acquired */ |
798 | if (bond->curr_active_slave) { | 804 | if (bond->curr_active_slave) { |
799 | dev_set_allmulti(bond->curr_active_slave->dev, inc); | 805 | err = dev_set_allmulti(bond->curr_active_slave->dev, |
806 | inc); | ||
800 | } | 807 | } |
801 | } else { | 808 | } else { |
802 | struct slave *slave; | 809 | struct slave *slave; |
803 | int i; | 810 | int i; |
804 | bond_for_each_slave(bond, slave, i) { | 811 | bond_for_each_slave(bond, slave, i) { |
805 | dev_set_allmulti(slave->dev, inc); | 812 | err = dev_set_allmulti(slave->dev, inc); |
813 | if (err) | ||
814 | return err; | ||
806 | } | 815 | } |
807 | } | 816 | } |
817 | return err; | ||
808 | } | 818 | } |
809 | 819 | ||
810 | /* | 820 | /* |
@@ -965,6 +975,7 @@ static void bond_mc_swap(struct bonding *bond, struct slave *new_active, struct | |||
965 | } | 975 | } |
966 | 976 | ||
967 | if (new_active) { | 977 | if (new_active) { |
978 | /* FIXME: Signal errors upstream. */ | ||
968 | if (bond->dev->flags & IFF_PROMISC) { | 979 | if (bond->dev->flags & IFF_PROMISC) { |
969 | dev_set_promiscuity(new_active->dev, 1); | 980 | dev_set_promiscuity(new_active->dev, 1); |
970 | } | 981 | } |
@@ -1544,12 +1555,16 @@ int bond_enslave(struct net_device *bond_dev, struct net_device *slave_dev) | |||
1544 | if (!USES_PRIMARY(bond->params.mode)) { | 1555 | if (!USES_PRIMARY(bond->params.mode)) { |
1545 | /* set promiscuity level to new slave */ | 1556 | /* set promiscuity level to new slave */ |
1546 | if (bond_dev->flags & IFF_PROMISC) { | 1557 | if (bond_dev->flags & IFF_PROMISC) { |
1547 | dev_set_promiscuity(slave_dev, 1); | 1558 | res = dev_set_promiscuity(slave_dev, 1); |
1559 | if (res) | ||
1560 | goto err_close; | ||
1548 | } | 1561 | } |
1549 | 1562 | ||
1550 | /* set allmulti level to new slave */ | 1563 | /* set allmulti level to new slave */ |
1551 | if (bond_dev->flags & IFF_ALLMULTI) { | 1564 | if (bond_dev->flags & IFF_ALLMULTI) { |
1552 | dev_set_allmulti(slave_dev, 1); | 1565 | res = dev_set_allmulti(slave_dev, 1); |
1566 | if (res) | ||
1567 | goto err_close; | ||
1553 | } | 1568 | } |
1554 | 1569 | ||
1555 | netif_tx_lock_bh(bond_dev); | 1570 | netif_tx_lock_bh(bond_dev); |
@@ -4065,6 +4080,10 @@ static void bond_set_multicast_list(struct net_device *bond_dev) | |||
4065 | * Do promisc before checking multicast_mode | 4080 | * Do promisc before checking multicast_mode |
4066 | */ | 4081 | */ |
4067 | if ((bond_dev->flags & IFF_PROMISC) && !(bond->flags & IFF_PROMISC)) { | 4082 | if ((bond_dev->flags & IFF_PROMISC) && !(bond->flags & IFF_PROMISC)) { |
4083 | /* | ||
4084 | * FIXME: Need to handle the error when one of the multi-slaves | ||
4085 | * encounters error. | ||
4086 | */ | ||
4068 | bond_set_promiscuity(bond, 1); | 4087 | bond_set_promiscuity(bond, 1); |
4069 | } | 4088 | } |
4070 | 4089 | ||
@@ -4074,6 +4093,10 @@ static void bond_set_multicast_list(struct net_device *bond_dev) | |||
4074 | 4093 | ||
4075 | /* set allmulti flag to slaves */ | 4094 | /* set allmulti flag to slaves */ |
4076 | if ((bond_dev->flags & IFF_ALLMULTI) && !(bond->flags & IFF_ALLMULTI)) { | 4095 | if ((bond_dev->flags & IFF_ALLMULTI) && !(bond->flags & IFF_ALLMULTI)) { |
4096 | /* | ||
4097 | * FIXME: Need to handle the error when one of the multi-slaves | ||
4098 | * encounters error. | ||
4099 | */ | ||
4077 | bond_set_allmulti(bond, 1); | 4100 | bond_set_allmulti(bond, 1); |
4078 | } | 4101 | } |
4079 | 4102 | ||