Page MenuHomeFreeBSD

if_awg: mark the first tx descriptor as ready only after all the other tx descriptors are set up
ClosedPublic

Authored by guyyur_gmail.com on Nov 10 2017, 4:55 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Nov 1, 12:57 PM
Unknown Object (File)
Fri, Oct 31, 2:28 AM
Unknown Object (File)
Tue, Oct 21, 11:36 PM
Unknown Object (File)
Tue, Oct 14, 2:27 AM
Unknown Object (File)
Tue, Oct 14, 2:27 AM
Unknown Object (File)
Tue, Oct 14, 2:27 AM
Unknown Object (File)
Tue, Oct 14, 2:27 AM
Unknown Object (File)
Mon, Oct 13, 1:03 PM
Subscribers

Details

Summary

In a multi segment frame, if the first tx descriptor is marked with TX_DESC_CTL
but not all tx descriptors for the other segments in the frame are set up,
the TX DMA may transmit an incomplete frame.
To prevent this, set TX_DESC_CTL for the first tx descriptor only when done
with all the other segments.

Also, don't bother cleaning transmitted tx descriptors since TX_DESC_CTL
is cleared for them by the hardware and they will be reprogrammed before
TX_DESC_CTL is reenabled for them.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable