- Added check to return from the traffic handling function, if the card status 
  is DOWN.

Signed-off-by: Sivakumar Subramani <[EMAIL PROTECTED]>
Signed-off-by: Santosh Rastapur <[EMAIL PROTECTED]>
Signed-off-by: Ramkrishna Vepa <[EMAIL PROTECTED]>
---
diff -Nurp patch3/drivers/net/s2io.c patch4/drivers/net/s2io.c
--- patch3/drivers/net/s2io.c   2007-08-15 08:57:32.000000000 -0700
+++ patch4/drivers/net/s2io.c   2007-08-15 08:42:14.000000000 -0700
@@ -2927,6 +2927,11 @@ static int s2io_poll(struct net_device *
        int i;
 
        atomic_inc(&nic->isr_cnt);
+       if (unlikely(atomic_read(&nic->card_state) == CARD_DOWN)) {
+               atomic_dec(&nic->isr_cnt);
+               return IRQ_NONE;
+       }
+
        mac_control = &nic->mac_control;
        config = &nic->config;
 
@@ -3062,12 +3067,6 @@ static void rx_intr_handler(struct ring_
        struct RxD3* rxdp3;
 
        spin_lock(&nic->rx_lock);
-       if (atomic_read(&nic->card_state) == CARD_DOWN) {
-               DBG_PRINT(INTR_DBG, "%s: %s going down for reset\n",
-                         __FUNCTION__, dev->name);
-               spin_unlock(&nic->rx_lock);
-               return;
-       }
 
        get_info = ring_data->rx_curr_get_info;
        get_block = get_info.block_index;
@@ -4404,6 +4403,10 @@ static irqreturn_t s2io_msix_ring_handle
        struct s2io_nic *sp = ring->nic;
 
        atomic_inc(&sp->isr_cnt);
+       if (unlikely(atomic_read(&sp->card_state) == CARD_DOWN)){
+               atomic_dec(&sp->isr_cnt);
+               return IRQ_HANDLED;
+       }
 
        rx_intr_handler(ring);
        s2io_chk_rx_buffers(sp, ring->ring_no);
@@ -4418,6 +4421,10 @@ static irqreturn_t s2io_msix_fifo_handle
        struct s2io_nic *sp = fifo->nic;
 
        atomic_inc(&sp->isr_cnt);
+       if (unlikely(atomic_read(&sp->card_state) == CARD_DOWN)){
+               atomic_dec(&sp->isr_cnt);
+               return IRQ_HANDLED;
+       }
        tx_intr_handler(fifo);
        atomic_dec(&sp->isr_cnt);
        return IRQ_HANDLED;
@@ -4896,6 +4903,11 @@ static irqreturn_t s2io_isr(int irq, voi
                return IRQ_NONE;
 
        atomic_inc(&sp->isr_cnt);
+       if (unlikely(atomic_read(&sp->card_state) == CARD_DOWN)) {
+               atomic_dec(&sp->isr_cnt);
+               return IRQ_NONE;
+       }
+
        mac_control = &sp->mac_control;
        config = &sp->config;
 



-
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to