aboutsummaryrefslogtreecommitdiff
path: root/sys/dev/gem
diff options
context:
space:
mode:
authorThomas Moestl <tmm@FreeBSD.org>2002-05-24 12:47:41 +0000
committerThomas Moestl <tmm@FreeBSD.org>2002-05-24 12:47:41 +0000
commit9bb711b95d9f01795ce5b03fb90378774d9bcbe7 (patch)
tree871a42065657e5d182b6c918a9085347f24b4e12 /sys/dev/gem
parent08198a0e3e43a94b2ec1668f792c3e612de28122 (diff)
Notes
Diffstat (limited to 'sys/dev/gem')
-rw-r--r--sys/dev/gem/if_gem.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/sys/dev/gem/if_gem.c b/sys/dev/gem/if_gem.c
index fe91327cb553..ecff86ffb2d4 100644
--- a/sys/dev/gem/if_gem.c
+++ b/sys/dev/gem/if_gem.c
@@ -1610,11 +1610,15 @@ gem_intr(v)
int txstat = bus_space_read_4(t, seb, GEM_MAC_TX_STATUS);
if (txstat & ~GEM_MAC_TX_XMIT_DONE)
printf("MAC tx fault, status %x\n", txstat);
+ if (txstat & (GEM_MAC_TX_UNDERRUN | GEM_MAC_TX_PKT_TOO_LONG))
+ gem_init(sc);
}
if (status & GEM_INTR_RX_MAC) {
int rxstat = bus_space_read_4(t, seb, GEM_MAC_RX_STATUS);
if (rxstat & ~(GEM_MAC_RX_DONE | GEM_MAC_RX_FRAME_CNT))
printf("MAC rx fault, status %x\n", rxstat);
+ if ((rxstat & GEM_MAC_RX_OVERFLOW) != 0)
+ gem_init(sc);
}
}