diff options
author | wpaul <wpaul@FreeBSD.org> | 1998-10-19 22:08:56 +0000 |
---|---|---|
committer | wpaul <wpaul@FreeBSD.org> | 1998-10-19 22:08:56 +0000 |
commit | 3c0d8db9217e8fdac7bc7134d0c52f220ecd767e (patch) | |
tree | b0f47630608ebecba1c5b8fe07f74e7a3497f0a1 /sys/pci/if_xl.c | |
parent | 142da85ef5052de403921320b197883828b42117 (diff) | |
download | FreeBSD-src-3c0d8db9217e8fdac7bc7134d0c52f220ecd767e.zip FreeBSD-src-3c0d8db9217e8fdac7bc7134d0c52f220ecd767e.tar.gz |
Modify the transmit packet queuing strategy a bit to be a little less
agressive. With the old code, if a descriptor chain was already on its
way to the chip, xl_start() would try to splice new chains onto the end
of the current chain by stopping the transmitter, modifying the tail
pointer of the current chain to point to the head of the new chain, then
restart the transmitter. The manual says you're allowed to do this and
it works, but I'm not too keen on it anymore.
The new code waits until the eixsting chain has been sent and then
queues the next waiting chain in the 'transmit ok' handler.
Performance still looks good one way or the other.
Diffstat (limited to 'sys/pci/if_xl.c')
-rw-r--r-- | sys/pci/if_xl.c | 40 |
1 files changed, 21 insertions, 19 deletions
diff --git a/sys/pci/if_xl.c b/sys/pci/if_xl.c index aede51e..d064899 100644 --- a/sys/pci/if_xl.c +++ b/sys/pci/if_xl.c @@ -29,7 +29,7 @@ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF * THE POSSIBILITY OF SUCH DAMAGE. * - * $Id: if_xl.c,v 1.54 1998/09/25 17:43:57 wpaul Exp wpaul $ + * $Id: if_xl.c,v 1.13 1998/10/09 03:59:23 wpaul Exp $ */ /* @@ -147,7 +147,7 @@ #ifndef lint static char rcsid[] = - "$Id: if_xl.c,v 1.54 1998/09/25 17:43:57 wpaul Exp wpaul $"; + "$Id: if_xl.c,v 1.13 1998/10/09 03:59:23 wpaul Exp $"; #endif /* @@ -1704,6 +1704,7 @@ static int xl_list_tx_init(sc) cd->xl_tx_free = &cd->xl_tx_chain[0]; cd->xl_tx_tail = cd->xl_tx_head = NULL; + sc->xl_txeoc = 1; return(0); } @@ -1939,15 +1940,16 @@ static void xl_txeof(sc) if (sc->xl_cdata.xl_tx_head == NULL) { ifp->if_flags &= ~IFF_OACTIVE; sc->xl_cdata.xl_tx_tail = NULL; + sc->xl_txeoc = 1; if (sc->xl_want_auto) xl_autoneg_mii(sc, XL_FLAG_SCHEDDELAY, 1); } else { - if (CSR_READ_4(sc, XL_DMACTL) & XL_DMACTL_DOWN_STALLED || - !CSR_READ_4(sc, XL_DOWNLIST_PTR)) { - CSR_WRITE_4(sc, XL_DOWNLIST_PTR, + sc->xl_txeoc = 0; + CSR_WRITE_4(sc, XL_COMMAND, XL_CMD_DOWN_STALL); + xl_wait(sc); + CSR_WRITE_4(sc, XL_DOWNLIST_PTR, vtophys(sc->xl_cdata.xl_tx_head->xl_ptr)); - CSR_WRITE_2(sc, XL_COMMAND, XL_CMD_DOWN_UNSTALL); - } + CSR_WRITE_2(sc, XL_COMMAND, XL_CMD_DOWN_UNSTALL); } return; @@ -2269,21 +2271,21 @@ static void xl_start(ifp) * Queue the packets. If the TX channel is clear, update * the downlist pointer register. */ - CSR_WRITE_2(sc, XL_COMMAND, XL_CMD_DOWN_STALL); - xl_wait(sc); - - if (CSR_READ_4(sc, XL_DOWNLIST_PTR)) { - sc->xl_cdata.xl_tx_tail->xl_next = start_tx; - sc->xl_cdata.xl_tx_tail->xl_ptr->xl_next = - vtophys(start_tx->xl_ptr); - sc->xl_cdata.xl_tx_tail->xl_ptr->xl_status &= - ~XL_TXSTAT_DL_INTR; - } else { + if (sc->xl_cdata.xl_tx_head == NULL) { sc->xl_cdata.xl_tx_head = start_tx; sc->xl_cdata.xl_tx_tail = cur_tx; - CSR_WRITE_4(sc, XL_DOWNLIST_PTR, vtophys(start_tx->xl_ptr)); + if (sc->xl_txeoc) { + sc->xl_txeoc = 0; + CSR_WRITE_2(sc, XL_COMMAND, XL_CMD_DOWN_STALL); + xl_wait(sc); + CSR_WRITE_4(sc, XL_DOWNLIST_PTR, + vtophys(start_tx->xl_ptr)); + CSR_WRITE_2(sc, XL_COMMAND, XL_CMD_DOWN_UNSTALL); + } + } else { + sc->xl_cdata.xl_tx_tail->xl_next = start_tx; + sc->xl_cdata.xl_tx_tail = start_tx; } - CSR_WRITE_2(sc, XL_COMMAND, XL_CMD_DOWN_UNSTALL); XL_SEL_WIN(7); |