summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorBrad Smith <brad@cvs.openbsd.org>2005-10-18 00:44:24 +0000
committerBrad Smith <brad@cvs.openbsd.org>2005-10-18 00:44:24 +0000
commit89aabae5d37d72f978d1c81cd182a3d4995b66a9 (patch)
treef5c73a983225b667e908f366f62806d55bfbaea2 /sys
parentce6302f31ccc74d4a37d88e5751704a0fd03610b (diff)
revert last commit for now.
Diffstat (limited to 'sys')
-rw-r--r--sys/dev/pci/if_sis.c30
1 files changed, 20 insertions, 10 deletions
diff --git a/sys/dev/pci/if_sis.c b/sys/dev/pci/if_sis.c
index 021862bb9d6..32e61f5e9fb 100644
--- a/sys/dev/pci/if_sis.c
+++ b/sys/dev/pci/if_sis.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_sis.c,v 1.56 2005/10/18 00:12:09 brad Exp $ */
+/* $OpenBSD: if_sis.c,v 1.57 2005/10/18 00:44:23 brad Exp $ */
/*
* Copyright (c) 1997, 1998, 1999
* Bill Paul <wpaul@ctr.columbia.edu>. All rights reserved.
@@ -1425,18 +1425,22 @@ void sis_rxeoc(sc)
void sis_txeof(sc)
struct sis_softc *sc;
{
+ struct sis_desc *cur_tx = NULL;
struct ifnet *ifp;
u_int32_t idx;
ifp = &sc->arpcom.ac_if;
+ /* Clear the timeout timer. */
+ ifp->if_timer = 0;
+
/*
* Go through our tx list and free mbufs for those
* frames that have been transmitted.
*/
- for (idx = sc->sis_cdata.sis_tx_cons; sc->sis_cdata.sis_tx_cnt > 0;
- sc->sis_cdata.sis_tx_cnt--, SIS_INC(idx, SIS_TX_LIST_CNT)) {
- struct sis_desc *cur_tx = &sc->sis_ldata->sis_tx_list[idx];
+ idx = sc->sis_cdata.sis_tx_cons;
+ while (idx != sc->sis_cdata.sis_tx_prod) {
+ cur_tx = &sc->sis_ldata->sis_tx_list[idx];
bus_dmamap_sync(sc->sc_dmat, sc->sc_listmap,
((caddr_t)cur_tx - sc->sc_listkva),
@@ -1446,8 +1450,11 @@ void sis_txeof(sc)
if (SIS_OWNDESC(cur_tx))
break;
- if (cur_tx->sis_ctl & SIS_CMDSTS_MORE)
+ if (cur_tx->sis_ctl & SIS_CMDSTS_MORE) {
+ sc->sis_cdata.sis_tx_cnt--;
+ SIS_INC(idx, SIS_TX_LIST_CNT);
continue;
+ }
if (!(cur_tx->sis_ctl & SIS_CMDSTS_PKT_OK)) {
ifp->if_oerrors++;
@@ -1472,15 +1479,18 @@ void sis_txeof(sc)
m_freem(cur_tx->sis_mbuf);
cur_tx->sis_mbuf = NULL;
}
+
+ sc->sis_cdata.sis_tx_cnt--;
+ SIS_INC(idx, SIS_TX_LIST_CNT);
+ ifp->if_timer = 0;
}
- if (idx != sc->sis_cdata.sis_tx_cons) {
- /* we freed up some buffers */
- sc->sis_cdata.sis_tx_cons = idx;
+ sc->sis_cdata.sis_tx_cons = idx;
+
+ if (cur_tx != NULL)
ifp->if_flags &= ~IFF_OACTIVE;
- }
- ifp->if_timer = (sc->sis_cdata.sis_tx_cnt == 0) ? 0 : 5;
+ return;
}
void sis_tick(xsc)