From 6edc9aa9c8eae8bb44e17d70870d37445471be80 Mon Sep 17 00:00:00 2001 From: David Gwynne Date: Tue, 23 Dec 2008 00:12:23 +0000 Subject: if we cant put enough packets on the rx ring then schedule a timeout to try again later. tested by many --- sys/dev/pci/if_bge.c | 23 ++++++++++++++++++++++- sys/dev/pci/if_bgereg.h | 3 ++- 2 files changed, 24 insertions(+), 2 deletions(-) diff --git a/sys/dev/pci/if_bge.c b/sys/dev/pci/if_bge.c index 1875ff5a5f8..3930d7ea87f 100644 --- a/sys/dev/pci/if_bge.c +++ b/sys/dev/pci/if_bge.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_bge.c,v 1.258 2008/12/03 23:51:52 dlg Exp $ */ +/* $OpenBSD: if_bge.c,v 1.259 2008/12/23 00:12:22 dlg Exp $ */ /* * Copyright (c) 2001 Wind River Systems @@ -171,6 +171,7 @@ void bge_free_rx_ring_jumbo(struct bge_softc *); int bge_newbuf(struct bge_softc *, int); int bge_init_rx_ring_std(struct bge_softc *); +void bge_rxtick(void *); void bge_fill_rx_ring_std(struct bge_softc *); void bge_free_rx_ring_std(struct bge_softc *); @@ -1013,6 +1014,17 @@ uncreate: return (1); } +void +bge_rxtick(void *arg) +{ + struct bge_softc *sc = arg; + int s; + + s = splnet(); + bge_fill_rx_ring_std(sc); + splx(s); +} + void bge_fill_rx_ring_std(struct bge_softc *sc) { @@ -1032,6 +1044,13 @@ bge_fill_rx_ring_std(struct bge_softc *sc) if (post) bge_writembx(sc, BGE_MBX_RX_STD_PROD_LO, sc->bge_std); + + /* + * bge always needs more than 8 packets on the ring. if we cant do + * that now, then try again later. + */ + if (sc->bge_std_cnt <= 8) + timeout_add(&sc->bge_rxtimeout, 1); } void @@ -2230,6 +2249,7 @@ bge_attach(struct device *parent, struct device *self, void *aux) sc->sc_powerhook = powerhook_establish(bge_power, sc); timeout_set(&sc->bge_timeout, bge_tick, sc); + timeout_set(&sc->bge_rxtimeout, bge_rxtick, sc); return; fail_5: @@ -3430,6 +3450,7 @@ bge_stop(struct bge_softc *sc) int mtmp, itmp; timeout_del(&sc->bge_timeout); + timeout_del(&sc->bge_rxtimeout); ifp->if_flags &= ~(IFF_RUNNING | IFF_OACTIVE); diff --git a/sys/dev/pci/if_bgereg.h b/sys/dev/pci/if_bgereg.h index 823673f27ee..321ccb35bf9 100644 --- a/sys/dev/pci/if_bgereg.h +++ b/sys/dev/pci/if_bgereg.h @@ -1,4 +1,4 @@ -/* $OpenBSD: if_bgereg.h,v 1.89 2008/12/03 23:51:52 dlg Exp $ */ +/* $OpenBSD: if_bgereg.h,v 1.90 2008/12/23 00:12:22 dlg Exp $ */ /* * Copyright (c) 2001 Wind River Systems @@ -2477,6 +2477,7 @@ struct bge_softc { int bge_if_flags; int bge_txcnt; struct timeout bge_timeout; + struct timeout bge_rxtimeout; void *sc_powerhook; void *sc_shutdownhook; u_int32_t bge_rx_discards; -- cgit v1.2.3