提交 2f76216f 编写于 作者: B Brice Goglin 提交者: Jeff Garzik

myri10ge: fix restoring of multicast list after reset

Don't count on whatever implementation artifact preserves the
multicast list across a reset cmd, and setup multicast filtering
as part of our reset routine.

The setting of allmulti when adopting firmware with the rx-filter
broadcast bug is also moved into the multicast setup routine where
it belongs.
Signed-off-by: NBrice Goglin <brice@myri.com>
Signed-off-by: NJeff Garzik <jeff@garzik.org>
上级 772a8158
...@@ -290,6 +290,8 @@ MODULE_PARM_DESC(myri10ge_wcfifo, "Enable WC Fifo when WC is enabled\n"); ...@@ -290,6 +290,8 @@ MODULE_PARM_DESC(myri10ge_wcfifo, "Enable WC Fifo when WC is enabled\n");
#define myri10ge_pio_copy(to,from,size) __iowrite64_copy(to,from,size/8) #define myri10ge_pio_copy(to,from,size) __iowrite64_copy(to,from,size/8)
static void myri10ge_set_multicast_list(struct net_device *dev);
static inline void put_be32(__be32 val, __be32 __iomem * p) static inline void put_be32(__be32 val, __be32 __iomem * p)
{ {
__raw_writel((__force __u32) val, (__force void __iomem *)p); __raw_writel((__force __u32) val, (__force void __iomem *)p);
...@@ -820,10 +822,8 @@ static int myri10ge_reset(struct myri10ge_priv *mgp) ...@@ -820,10 +822,8 @@ static int myri10ge_reset(struct myri10ge_priv *mgp)
mgp->rx_done.cnt = 0; mgp->rx_done.cnt = 0;
mgp->link_changes = 0; mgp->link_changes = 0;
status = myri10ge_update_mac_address(mgp, mgp->dev->dev_addr); status = myri10ge_update_mac_address(mgp, mgp->dev->dev_addr);
myri10ge_change_promisc(mgp, 0, 0);
myri10ge_change_pause(mgp, mgp->pause); myri10ge_change_pause(mgp, mgp->pause);
if (mgp->adopted_rx_filter_bug) myri10ge_set_multicast_list(mgp->dev);
(void)myri10ge_send_cmd(mgp, MXGEFW_ENABLE_ALLMULTI, &cmd, 1);
return status; return status;
} }
...@@ -2283,7 +2283,7 @@ static void myri10ge_set_multicast_list(struct net_device *dev) ...@@ -2283,7 +2283,7 @@ static void myri10ge_set_multicast_list(struct net_device *dev)
myri10ge_change_promisc(mgp, dev->flags & IFF_PROMISC, 1); myri10ge_change_promisc(mgp, dev->flags & IFF_PROMISC, 1);
/* This firmware is known to not support multicast */ /* This firmware is known to not support multicast */
if (!mgp->fw_multicast_support || mgp->adopted_rx_filter_bug) if (!mgp->fw_multicast_support)
return; return;
/* Disable multicast filtering */ /* Disable multicast filtering */
...@@ -2295,7 +2295,7 @@ static void myri10ge_set_multicast_list(struct net_device *dev) ...@@ -2295,7 +2295,7 @@ static void myri10ge_set_multicast_list(struct net_device *dev)
goto abort; goto abort;
} }
if (dev->flags & IFF_ALLMULTI) { if ((dev->flags & IFF_ALLMULTI) || mgp->adopted_rx_filter_bug) {
/* request to disable multicast filtering, so quit here */ /* request to disable multicast filtering, so quit here */
return; return;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册