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)
Fri, Dec 6, 5:58 AM
Unknown Object (File)
Mon, Dec 2, 2:27 PM
Unknown Object (File)
Nov 26 2024, 6:23 AM
Unknown Object (File)
Oct 29 2024, 7:58 AM
Unknown Object (File)
Oct 9 2024, 11:24 PM
Unknown Object (File)
Sep 28 2024, 2:05 PM
Unknown Object (File)
Sep 20 2024, 9:43 AM
Unknown Object (File)
Sep 16 2024, 8:09 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