summaryrefslogtreecommitdiffstats
path: root/sys/dev/re/if_re.c
diff options
context:
space:
mode:
authorwpaul <wpaul@FreeBSD.org>2003-09-18 18:32:15 +0000
committerwpaul <wpaul@FreeBSD.org>2003-09-18 18:32:15 +0000
commita73aca6e630914805d05277c30f775cda99b214f (patch)
treeb948940a4ab770f5b6a7911bcc7b0ff579e2b439 /sys/dev/re/if_re.c
parent8fde9fc2dec6e152f906640ed9daf3e076830dcf (diff)
downloadFreeBSD-src-a73aca6e630914805d05277c30f775cda99b214f.zip
FreeBSD-src-a73aca6e630914805d05277c30f775cda99b214f.tar.gz
In re_diag(), there's no need for us to call re_start() ourselves:
IF_HANDOFF() does it for us behind the scenes. Remove the extra call to re_start() otherwise we try to transmit twice. In re_encap(), fix the code that guards against consuming too many descriptors in the TX ring so that it actually works. With the new 8169S chip, I was able to hit a corner case that drained the free descriptor count all the way to 0. This is not supposed to be possible.
Diffstat (limited to 'sys/dev/re/if_re.c')
-rw-r--r--sys/dev/re/if_re.c12
1 files changed, 8 insertions, 4 deletions
diff --git a/sys/dev/re/if_re.c b/sys/dev/re/if_re.c
index 4cdfe99..c6bff91 100644
--- a/sys/dev/re/if_re.c
+++ b/sys/dev/re/if_re.c
@@ -740,11 +740,13 @@ re_diag(sc)
eh->ether_type = htons(ETHERTYPE_IP);
m0->m_pkthdr.len = m0->m_len = ETHER_MIN_LEN - ETHER_CRC_LEN;
- /* Queue the packet, start transmission */
+ /*
+ * Queue the packet, start transmission.
+ * Note: IF_HANDOFF() ultimately calls re_start() for us.
+ */
- IF_HANDOFF(&ifp->if_snd, m0, ifp);
CSR_WRITE_2(sc, RL_ISR, 0xFFFF);
- re_start(ifp);
+ IF_HANDOFF(&ifp->if_snd, m0, ifp);
m0 = NULL;
/* Wait for it to propagate through the chip */
@@ -1892,7 +1894,7 @@ re_encap(sc, m_head, idx)
int error;
struct m_tag *mtag;
- if (sc->rl_ldata.rl_tx_free < 4)
+ if (sc->rl_ldata.rl_tx_free <= 4)
return(EFBIG);
/*
@@ -1914,6 +1916,8 @@ re_encap(sc, m_head, idx)
arg.sc = sc;
arg.rl_idx = *idx;
arg.rl_maxsegs = sc->rl_ldata.rl_tx_free;
+ if (arg.rl_maxsegs > 4)
+ arg.rl_maxsegs -= 4;
arg.rl_ring = sc->rl_ldata.rl_tx_list;
map = sc->rl_ldata.rl_tx_dmamap[*idx];
OpenPOWER on IntegriCloud