diff options
author | Mike Belopuhov <mikeb@cvs.openbsd.org> | 2012-08-10 10:56:23 +0000 |
---|---|---|
committer | Mike Belopuhov <mikeb@cvs.openbsd.org> | 2012-08-10 10:56:23 +0000 |
commit | ec626d50c66db72f66d0d2a30df3cee3e459bbf1 (patch) | |
tree | 77c875528da3cb0ff872933278ebcfbf125f890b /sys/dev/pci | |
parent | 101d8015b80b16aad18a1b1e0fef0b793bf319ed (diff) |
cleanup ixgbe_start routine; from brad, ok jsg
Diffstat (limited to 'sys/dev/pci')
-rw-r--r-- | sys/dev/pci/if_ix.c | 56 |
1 files changed, 21 insertions, 35 deletions
diff --git a/sys/dev/pci/if_ix.c b/sys/dev/pci/if_ix.c index b0be27aa504..8f178043e47 100644 --- a/sys/dev/pci/if_ix.c +++ b/sys/dev/pci/if_ix.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_ix.c,v 1.68 2012/08/08 14:44:13 mikeb Exp $ */ +/* $OpenBSD: if_ix.c,v 1.69 2012/08/10 10:56:22 mikeb Exp $ */ /****************************************************************************** @@ -86,7 +86,6 @@ int ixgbe_probe(struct device *, void *, void *); void ixgbe_attach(struct device *, struct device *, void *); int ixgbe_detach(struct device *, int); void ixgbe_start(struct ifnet *); -void ixgbe_start_locked(struct tx_ring *, struct ifnet *); int ixgbe_ioctl(struct ifnet *, u_long, caddr_t); void ixgbe_watchdog(struct ifnet *); void ixgbe_init(void *); @@ -391,18 +390,33 @@ ixgbe_detach(struct device *self, int flags) **********************************************************************/ void -ixgbe_start_locked(struct tx_ring *txr, struct ifnet * ifp) +ixgbe_start(struct ifnet * ifp) { + struct ix_softc *sc = ifp->if_softc; + struct tx_ring *txr = sc->tx_rings; struct mbuf *m_head; - struct ix_softc *sc = txr->sc; + uint32_t queue = 0; int post = 0; if ((ifp->if_flags & (IFF_RUNNING|IFF_OACTIVE)) != IFF_RUNNING) return; - if (!sc->link_active) return; +#if 0 + /* + * This is really just here for testing + * TX multiqueue, ultimately what is + * needed is the flow support in the stack + * and appropriate logic here to deal with + * it. -jfv + */ + if (sc->num_queues > 1) + queue = (curcpu % sc->num_queues); +#endif + + txr = &sc->tx_rings[queue]; + bus_dmamap_sync(txr->txdma.dma_tag, txr->txdma.dma_map, 0, txr->txdma.dma_map->dm_mapsize, BUS_DMASYNC_POSTREAD | BUS_DMASYNC_POSTWRITE); @@ -444,34 +458,6 @@ ixgbe_start_locked(struct tx_ring *txr, struct ifnet * ifp) txr->next_avail_desc); } - -void -ixgbe_start(struct ifnet *ifp) -{ - struct ix_softc *sc = ifp->if_softc; - struct tx_ring *txr = sc->tx_rings; - uint32_t queue = 0; - -#if 0 - /* - * This is really just here for testing - * TX multiqueue, ultimately what is - * needed is the flow support in the stack - * and appropriate logic here to deal with - * it. -jfv - */ - if (sc->num_queues > 1) - queue = (curcpu % sc->num_queues); -#endif - - txr = &sc->tx_rings[queue]; - - if (ifp->if_flags & IFF_RUNNING) - ixgbe_start_locked(txr, ifp); - - return; -} - /********************************************************************* * Ioctl entry point * @@ -921,7 +907,7 @@ ixgbe_handle_que(void *context, int pending) } if (!IFQ_IS_EMPTY(&ifp->if_snd)) - ixgbe_start_locked(txr, ifp); + ixgbe_start(ifp); } /* Reenable this interrupt */ @@ -991,7 +977,7 @@ ixgbe_legacy_irq(void *arg) } if (ifp->if_flags & IFF_RUNNING && !IFQ_IS_EMPTY(&ifp->if_snd)) - ixgbe_start_locked(txr, ifp); + ixgbe_start(ifp); for (i = 0; i < sc->num_queues; i++, que++) ixgbe_enable_queue(sc, que->msix); |