1
0
mirror of https://git.FreeBSD.org/src.git synced 2025-01-18 15:30:21 +00:00

Get wlread() closer to working. Use m->m_len as the initial value for

bytes_in_mbuf rather than MCLBYTES. Add the ethertnet header to the
front of the mbuf. Adjust bytes_in_mbuf inside the loop that reads
the packet out of the card.
This commit is contained in:
John Hay 2003-04-17 17:51:24 +00:00
parent a368c85b62
commit e37f27be24
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=113606

View File

@ -1119,7 +1119,14 @@ wlread(struct wl_softc *sc, u_short fd_p)
*/
mlen = 0;
mb_p = mtod(m, u_char *);
bytes_in_mbuf = MCLBYTES;
bytes_in_mbuf = m->m_len;
/* Put the ethernet header inside the mbuf. */
bcopy(&fd.destination[0], mb_p, 14);
mb_p += 14;
mlen += 14;
bytes_in_mbuf -= 14;
bytes = min(bytes_in_mbuf, bytes_in_msg);
for (;;) {
if (bytes & 1) {
@ -1144,6 +1151,7 @@ wlread(struct wl_softc *sc, u_short fd_p)
return 0;
}
mb_p += bytes;
bytes_in_mbuf -= bytes;
bytes_in_msg -= bytes;
if (bytes_in_msg == 0) {
if (rbd.status & RBD_SW_EOF || rbd.next_rbd_offset == I82586NULL) {