From 6aaa3c88f9e8083e8e80eb26115f4ab1b62f9821 Mon Sep 17 00:00:00 2001 From: Michael Chan Date: Sat, 29 Apr 2006 18:58:01 -0700 Subject: [PATCH] --- yaml --- r: 26380 b: refs/heads/master c: 58712ef9f2cbaaeac5b32ac11810a4bbd0eeacc5 h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/drivers/net/tg3.c | 20 +++++++++++++++++--- 2 files changed, 18 insertions(+), 4 deletions(-) diff --git a/[refs] b/[refs] index ef6f73ddec69..9d0e02670b99 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: c424cb249dae10fb7f118f89091f1329b62b92f4 +refs/heads/master: 58712ef9f2cbaaeac5b32ac11810a4bbd0eeacc5 diff --git a/trunk/drivers/net/tg3.c b/trunk/drivers/net/tg3.c index a30734061700..0ccfb63d3ac1 100644 --- a/trunk/drivers/net/tg3.c +++ b/trunk/drivers/net/tg3.c @@ -5732,9 +5732,23 @@ static int tg3_set_mac_addr(struct net_device *dev, void *p) if (!netif_running(dev)) return 0; - spin_lock_bh(&tp->lock); - __tg3_set_mac_addr(tp); - spin_unlock_bh(&tp->lock); + if (tp->tg3_flags & TG3_FLAG_ENABLE_ASF) { + /* Reset chip so that ASF can re-init any MAC addresses it + * needs. + */ + tg3_netif_stop(tp); + tg3_full_lock(tp, 1); + + tg3_halt(tp, RESET_KIND_SHUTDOWN, 1); + tg3_init_hw(tp); + + tg3_netif_start(tp); + tg3_full_unlock(tp); + } else { + spin_lock_bh(&tp->lock); + __tg3_set_mac_addr(tp); + spin_unlock_bh(&tp->lock); + } return 0; }