diff options
author | Stephen Hemminger <shemminger@linux-foundation.org> | 2007-05-14 15:38:13 -0400 |
---|---|---|
committer | Jeff Garzik <jeff@garzik.org> | 2007-05-17 20:43:14 -0400 |
commit | a3caeada948535f126e407457e15f2633ee7168a (patch) | |
tree | 9a083f3b090d3c59ff4ee40942a0f9636a2b1dbc /drivers | |
parent | 3225b919036a3ec2e96bb36b7a4fd64c43fdbe84 (diff) |
sky2: MIB counter overflow handling
Make sure that if we ever get a MIB counter overflow interrupt (normally
masked off), that the IRQ is cleared.
Signed-off-by: Stephen Hemminger <shemminger@linux-foundation.org>
Signed-off-by: Jeff Garzik <jeff@garzik.org>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/sky2.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/drivers/net/sky2.c b/drivers/net/sky2.c index bde28ad9797d..6e360f816605 100644 --- a/drivers/net/sky2.c +++ b/drivers/net/sky2.c | |||
@@ -2345,6 +2345,12 @@ static void sky2_mac_intr(struct sky2_hw *hw, unsigned port) | |||
2345 | printk(KERN_INFO PFX "%s: mac interrupt status 0x%x\n", | 2345 | printk(KERN_INFO PFX "%s: mac interrupt status 0x%x\n", |
2346 | dev->name, status); | 2346 | dev->name, status); |
2347 | 2347 | ||
2348 | if (status & GM_IS_RX_CO_OV) | ||
2349 | gma_read16(hw, port, GM_RX_IRQ_SRC); | ||
2350 | |||
2351 | if (status & GM_IS_TX_CO_OV) | ||
2352 | gma_read16(hw, port, GM_TX_IRQ_SRC); | ||
2353 | |||
2348 | if (status & GM_IS_RX_FF_OR) { | 2354 | if (status & GM_IS_RX_FF_OR) { |
2349 | ++sky2->net_stats.rx_fifo_errors; | 2355 | ++sky2->net_stats.rx_fifo_errors; |
2350 | sky2_write8(hw, SK_REG(port, RX_GMF_CTRL_T), GMF_CLI_RX_FO); | 2356 | sky2_write8(hw, SK_REG(port, RX_GMF_CTRL_T), GMF_CLI_RX_FO); |