aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/ethernet/ibm
diff options
context:
space:
mode:
authorThadeu Lima de Souza Cascardo <cascardo@linux.vnet.ibm.com>2012-04-25 03:32:12 -0400
committerDavid S. Miller <davem@davemloft.net>2012-04-26 05:07:45 -0400
commit47d59d01322f60d1c46fdf2650e0613daa8ce637 (patch)
tree912782dfc8d6c6492cc0756f8613ad1b1d1a68e3 /drivers/net/ethernet/ibm
parent5d384574e8bceb9bada323da8044ca43e621886b (diff)
ehea: fix promiscuous mode
commit a4910b744486254cfa61995954c118fb2283c4fd has broken promiscuous mode, which is never set. port->promisc just reflects the last setting of PROMISCUOUS mode to avoid doing an extra hypercall when it's already set. However, since it may fail because of hypervisor permissions, we should still respect the multicast settings and not simply exit after setting promiscuous mode. Signed-off-by: Thadeu Lima de Souza Cascardo <cascardo@linux.vnet.ibm.com> Cc: Breno Leitao <leitao@linux.vnet.ibm.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet/ibm')
-rw-r--r--drivers/net/ethernet/ibm/ehea/ehea_main.c6
1 files changed, 1 insertions, 5 deletions
diff --git a/drivers/net/ethernet/ibm/ehea/ehea_main.c b/drivers/net/ethernet/ibm/ehea/ehea_main.c
index 9dcb5fd37371..c9069a28832b 100644
--- a/drivers/net/ethernet/ibm/ehea/ehea_main.c
+++ b/drivers/net/ethernet/ibm/ehea/ehea_main.c
@@ -1946,11 +1946,7 @@ static void ehea_set_multicast_list(struct net_device *dev)
1946 struct netdev_hw_addr *ha; 1946 struct netdev_hw_addr *ha;
1947 int ret; 1947 int ret;
1948 1948
1949 if (port->promisc) { 1949 ehea_promiscuous(dev, !!(dev->flags & IFF_PROMISC));
1950 ehea_promiscuous(dev, 1);
1951 return;
1952 }
1953 ehea_promiscuous(dev, 0);
1954 1950
1955 if (dev->flags & IFF_ALLMULTI) { 1951 if (dev->flags & IFF_ALLMULTI) {
1956 ehea_allmulti(dev, 1); 1952 ehea_allmulti(dev, 1);