On Mon, 4 Aug 2003 01:50:37 -0400
Ben Collins <[EMAIL PROTECTED]> wrote:

> A thing to note is that there is one known bug remaining. There's a PCI
> error reported when the broadcom (tg3) ethernet devs are brought up, but
> other than that things seem to be running smoothly.
> 
> With my luck, Dave will have that PCI error fixed just after I send out
> this email :)

Yeah, this patch should do it :-)  I'll test it out tomorrow.

# This is a BitKeeper generated patch for the following project:
# Project Name: Linux kernel tree
# This patch format is intended for GNU patch command version 2.5 or higher.
# This patch includes the following deltas:
#                  ChangeSet    1.1033  -> 1.1034 
#          drivers/net/tg3.c    1.67    -> 1.68   
#
# The following is the BitKeeper ChangeSet Log
# --------------------------------------------
# 03/08/03      [EMAIL PROTECTED]       1.1034
# [TG3]: Only call tg3_init_rings() after hardware has been reset.
# 
# In tg3_init_rings() we might write out to the NIC SRAM area,
# thus we should only run it when the chip is in a known state.
# Also, fix comments above tg3_init_rings() wrt. locking state.
# --------------------------------------------
#
diff -Nru a/drivers/net/tg3.c b/drivers/net/tg3.c
--- a/drivers/net/tg3.c Mon Aug  4 00:38:19 2003
+++ b/drivers/net/tg3.c Mon Aug  4 00:38:19 2003
@@ -52,8 +52,8 @@
 
 #define DRV_MODULE_NAME                "tg3"
 #define PFX DRV_MODULE_NAME    ": "
-#define DRV_MODULE_VERSION     "1.8"
-#define DRV_MODULE_RELDATE     "August 1, 2003"
+#define DRV_MODULE_VERSION     "1.9"
+#define DRV_MODULE_RELDATE     "August 3, 2003"
 
 #define TG3_DEF_MAC_MODE       0
 #define TG3_DEF_RX_MODE                0
@@ -2186,7 +2186,6 @@
        spin_unlock_irqrestore(&tp->lock, flags);
 }
 
-static void tg3_init_rings(struct tg3 *);
 static int tg3_init_hw(struct tg3 *);
 static int tg3_halt(struct tg3 *);
 
@@ -2204,7 +2203,6 @@
        tp->tg3_flags2 &= ~TG3_FLG2_RESTART_TIMER;
 
        tg3_halt(tp);
-       tg3_init_rings(tp);
        tg3_init_hw(tp);
 
        spin_unlock(&tp->tx_lock);
@@ -2680,7 +2678,6 @@
 
        tg3_set_mtu(dev, tp, new_mtu);
 
-       tg3_init_rings(tp);
        tg3_init_hw(tp);
 
        spin_unlock(&tp->tx_lock);
@@ -2766,8 +2763,8 @@
  *
  * The chip has been shut down and the driver detached from
  * the networking, so no interrupts or new tx packets will
- * end up in the driver.  tp->{tx,}lock is not held and we are not
- * in an interrupt context and thus may sleep.
+ * end up in the driver.  tp->{tx,}lock are held and thus
+ * we may not sleep.
  */
 static void tg3_init_rings(struct tg3 *tp)
 {
@@ -3946,6 +3943,13 @@
                tw32(TG3PCI_PCISTATE, val);
        }
 
+       /* Descriptor ring init may make accesses to the
+        * NIC SRAM area to setup the TX descriptors, so we
+        * can only do this after the hardware has been
+        * successfully reset.
+        */
+       tg3_init_rings(tp);
+
        /* Clear statistics/status block in chip, and status block in ram. */
        for (i = NIC_SRAM_STATS_BLK;
             i < NIC_SRAM_STATUS_BLK + TG3_HW_STATUS_SIZE;
@@ -4505,8 +4509,6 @@
        spin_lock_irq(&tp->lock);
        spin_lock(&tp->tx_lock);
 
-       tg3_init_rings(tp);
-
        err = tg3_init_hw(tp);
        if (err) {
                tg3_halt(tp);
@@ -5318,7 +5320,6 @@
                tp->tx_pending = ering.tx_pending;
 
                tg3_halt(tp);
-               tg3_init_rings(tp);
                tg3_init_hw(tp);
                netif_wake_queue(tp->dev);
                spin_unlock(&tp->tx_lock);
@@ -5362,7 +5363,6 @@
                else
                        tp->tg3_flags &= ~TG3_FLAG_PAUSE_TX;
                tg3_halt(tp);
-               tg3_init_rings(tp);
                tg3_init_hw(tp);
                spin_unlock(&tp->tx_lock);
                spin_unlock_irq(&tp->lock);
@@ -6963,7 +6963,6 @@
                spin_lock_irq(&tp->lock);
                spin_lock(&tp->tx_lock);
 
-               tg3_init_rings(tp);
                tg3_init_hw(tp);
 
                spin_unlock(&tp->tx_lock);
@@ -6994,7 +6993,6 @@
        spin_lock_irq(&tp->lock);
        spin_lock(&tp->tx_lock);
 
-       tg3_init_rings(tp);
        tg3_init_hw(tp);
        tg3_enable_ints(tp);
 

Reply via email to