summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorClaudio Jeker <claudio@cvs.openbsd.org>2009-06-18 18:49:35 +0000
committerClaudio Jeker <claudio@cvs.openbsd.org>2009-06-18 18:49:35 +0000
commita8a360403bc3d2677eb2f9caac61df98b9c71222 (patch)
treef01f44634051c3b1a0b77ccbe6ae917a5f3e8148
parent196175d87c8f783c1f872a0e112169b85441bdf4 (diff)
First sync the descriptor then check if the owner of the descriptor.
While there switch some m_freem() to m_free() where only a single mbuf is involved.
-rw-r--r--sys/dev/pci/if_sis.c10
1 files changed, 5 insertions, 5 deletions
diff --git a/sys/dev/pci/if_sis.c b/sys/dev/pci/if_sis.c
index ec783da4182..da22d1d9c9a 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.91 2009/06/12 21:55:50 claudio Exp $ */
+/* $OpenBSD: if_sis.c,v 1.92 2009/06/18 18:49:34 claudio Exp $ */
/*
* Copyright (c) 1997, 1998, 1999
* Bill Paul <wpaul@ctr.columbia.edu>. All rights reserved.
@@ -1237,7 +1237,7 @@ sis_newbuf(struct sis_softc *sc, struct sis_desc *c)
MCLGETI(m_new, M_DONTWAIT, &sc->arpcom.ac_if, MCLBYTES);
if (!(m_new->m_flags & M_EXT)) {
- m_freem(m_new);
+ m_free(m_new);
return (ENOBUFS);
}
@@ -1245,7 +1245,7 @@ sis_newbuf(struct sis_softc *sc, struct sis_desc *c)
if (bus_dmamap_load_mbuf(sc->sc_dmat, c->map, m_new,
BUS_DMA_NOWAIT)) {
- m_freem(m_new);
+ m_free(m_new);
return (ENOBUFS);
}
@@ -1280,12 +1280,12 @@ sis_rxeof(struct sis_softc *sc)
while(sc->sis_cdata.sis_rx_cnt > 0) {
cur_rx = &sc->sis_ldata->sis_rx_list[sc->sis_cdata.sis_rx_cons];
- if (!SIS_OWNDESC(cur_rx))
- break;
bus_dmamap_sync(sc->sc_dmat, sc->sc_listmap,
((caddr_t)cur_rx - sc->sc_listkva),
sizeof(struct sis_desc),
BUS_DMASYNC_POSTREAD | BUS_DMASYNC_POSTWRITE);
+ if (!SIS_OWNDESC(cur_rx))
+ break;
rxstat = cur_rx->sis_rxstat;
m = cur_rx->sis_mbuf;