Skip to content

Commit

Permalink
[PATCH] sky2: status interrupt handling improvement
Browse files Browse the repository at this point in the history
More changes to prevent losing status and causing hangs.
The hardware is smarter than I gave it credit for.
Clearing the status IRQ causes the status state machine to
toggle an IRQ if needed and post any more transmits.

Signed-off-by: Stephen Hemminger <shemminger@osdl.org>
Signed-off-by: Jeff Garzik <jeff@garzik.org>
  • Loading branch information
Stephen Hemminger authored and Jeff Garzik committed Aug 3, 2006
1 parent 834695e commit fe2a24d
Showing 1 changed file with 12 additions and 18 deletions.
30 changes: 12 additions & 18 deletions drivers/net/sky2.c
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@
#include "sky2.h"

#define DRV_NAME "sky2"
#define DRV_VERSION "1.5"
#define DRV_VERSION "1.6"
#define PFX DRV_NAME " "

/*
Expand Down Expand Up @@ -1932,12 +1932,6 @@ static inline void sky2_tx_done(struct net_device *dev, u16 last)
}
}

/* Is status ring empty or is there more to do? */
static inline int sky2_more_work(const struct sky2_hw *hw)
{
return (hw->st_idx != sky2_read16(hw, STAT_PUT_IDX));
}

/* Process status response ring */
static int sky2_status_intr(struct sky2_hw *hw, int to_do)
{
Expand Down Expand Up @@ -2028,6 +2022,9 @@ static int sky2_status_intr(struct sky2_hw *hw, int to_do)
}
}

/* Fully processed status ring so clear irq */
sky2_write32(hw, STAT_CTRL, SC_STAT_CLR_IRQ);

exit_loop:
if (buf_write[0]) {
sky2 = netdev_priv(hw->dev[0]);
Expand Down Expand Up @@ -2237,19 +2234,16 @@ static int sky2_poll(struct net_device *dev0, int *budget)
sky2_descriptor_error(hw, 1, "transmit", Y2_IS_CHK_TXA2);

work_done = sky2_status_intr(hw, work_limit);
*budget -= work_done;
dev0->quota -= work_done;

if (status & Y2_IS_STAT_BMU)
sky2_write32(hw, STAT_CTRL, SC_STAT_CLR_IRQ);
if (work_done < work_limit) {
netif_rx_complete(dev0);

if (sky2_more_work(hw))
sky2_read32(hw, B0_Y2_SP_LISR);
return 0;
} else {
*budget -= work_done;
dev0->quota -= work_done;
return 1;

netif_rx_complete(dev0);

sky2_read32(hw, B0_Y2_SP_LISR);
return 0;
}
}

static irqreturn_t sky2_intr(int irq, void *dev_id, struct pt_regs *regs)
Expand Down

0 comments on commit fe2a24d

Please sign in to comment.