Wed, Sep 19, 2012 at 10:22:48PM CEST, shemmin...@vyatta.com wrote:
>Rather than saving and restoring values, why not just redo the
>full setup? This would also determine if the change was a result
>of something outside the driver.

You cannot call sky2_set_multicast() directly here. It is called from
__dev_set_rx_mode(). You would have to take at lease netif_addr_lock()
here. I think that clearer is to remember computed value....

>
>
>--- a/drivers/net/ethernet/marvell/sky2.c      2012-09-18 21:12:01.156438131 
>-0700
>+++ b/drivers/net/ethernet/marvell/sky2.c      2012-09-19 13:20:40.373620276 
>-0700
>@@ -2201,6 +2201,8 @@ static void sky2_link_up(struct sky2_por
> 
>       sky2_enable_rx_tx(sky2);
> 
>+      sky2_set_multicast(sky2->netdev);
>+
>       gm_phy_write(hw, port, PHY_MARV_INT_MASK, PHY_M_DEF_MSK);
> 
>       netif_carrier_on(sky2->netdev);
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to