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)
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
Unknown Object (File)
Mon, Oct 6, 11:49 PM
Unknown Object (File)
Fri, Oct 3, 7:33 PM
Unknown Object (File)
Mon, Sep 29, 10:00 AM
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