Page MenuHomeFreeBSD

iflib: fix vlan offload processing across multiple drivers.
ClosedPublic

Authored by vmaffione on Nov 28 2021, 10:16 PM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Dec 31, 7:29 AM
Unknown Object (File)
Sun, Dec 15, 11:31 AM
Unknown Object (File)
Fri, Dec 13, 9:36 AM
Unknown Object (File)
Dec 6 2024, 1:18 AM
Unknown Object (File)
Dec 4 2024, 6:02 PM
Unknown Object (File)
Nov 24 2024, 10:19 AM
Unknown Object (File)
Nov 22 2024, 7:07 AM
Unknown Object (File)
Nov 21 2024, 7:10 PM

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

vmaffione created this revision.

Use iri_ifp rather than iflib_get_ifp().

erj requested changes to this revision.Dec 2 2021, 10:35 PM
erj added a subscriber: erj.
erj added inline comments.
sys/dev/e1000/igb_txrx.c
501 ↗(On Diff #99376)

This is a subtle bug that I caught in another of our drivers, but you shouldn't just check if the vtag is non-zero; that improperly strips the packet of a possible priority 0 & VLAN 0-tagged header. You should still check the descriptor see if a tag exists.

This revision now requires changes to proceed.Dec 2 2021, 10:35 PM
sys/dev/e1000/igb_txrx.c
501 ↗(On Diff #99376)

Do you mean checking for (staterr & E1000_RXD_STAT_VP)? That is done in the loop above, to avoid possible issues with multi-descriptor packets. Or what should I do?

sys/dev/e1000/igb_txrx.c
501 ↗(On Diff #99376)

Sorry, maybe it wasn't completely clear in my last comment, but you need to change the check from if there is a non-zero VLAN tag to if a VLAN tag was detected because it's possible that there is a VLAN tag that is just all 0's and we need to still inform the upper layers that it's there with M_VLANTAG -- one way to do that would be to copy that (staterr & E1000_RXD_STAT_VP) check down, and replace the if (vtag) highlighted here with it.

That's right, thanks. The same issue is there for at least em and ixgbe.
I can fix those if you like.

vmaffione added inline comments.
sys/dev/e1000/igb_txrx.c
501 ↗(On Diff #99376)

I see, thanks. Btw, I was also worried about multi-descriptor packets: I expect the "vtag" to be present in the descriptor that contains the E1000_RXD_STAT_VP bit (staterr), but not in the other packet fragments. This means that it may be wrong to check for the VP bit outside of the loop.

vmaffione marked an inline comment as done.
vmaffione retitled this revision from igb: align rx offload processing to the other Intel drivers to iflib: fix vlan offload processing across multiple drivers..
vmaffione edited the summary of this revision. (Show Details)

Fix the iri_vtag setting logic for all the iflib drivers.

Also fix scctx->isc_capenable and isc_capabilities usage in igc.

vmaffione added inline comments.
sys/dev/e1000/igb_txrx.c
501 ↗(On Diff #99376)

Never mind. The VLAN info (RXD_STAT_VP bit and vtag) is set in all the descriptors of a multi-descriptor packet. So it is safe to access those info outside of the loop.
I tried to fix the issue for all the iflib drivers.

I'm less optimistic about the ifp seeing the change required in all drivers, @gallatin odes anyone have any idea on the impact of the ifp pointer chase and fetch versus grabbing it from the already fetched scctx in these hot paths? How would we sync scctx_capenable with ifnet, that seems to be a critical missing implementation from the outset.

Note that this patch contains a number of changes that fix separate issues:

  1. fix VLAN offload processing handling the case of vtag == 0.
  2. use if_getcapenable() rather the isc_capenable because the latter is not synchronized.
  3. use iri_ifp rather than iflib_get_ifp() to avoid an additional indirection.

Those changes could/should be committed separately.
Regarding point (2), I agree with you that we should avoid the additional indirection by accessing isc_capenable. But the current status is that we have some drivers that use isc_capenable (and are therefore broken) and some drivers that use iflib_get_ifp() and are therefore correct although suboptimal. I would then propose to make the change in two steps. The first step is to restore correctness (this patch), as soon as possible, since there is no point in having "fast broken" code. Then we can have a second step where we properly synchronize isc_capenable and then change back all the drivers to access that.

use iri_ifp rather than iflib_get_ifp() in ice and ixgbe.

...or we can also switch to isc_capenable in the same changeset.
The last diff tweaks iflib's ioctl handler to synchronize isc_capenable to if_capenable.

This revision was not accepted when it landed; it landed in state Needs Review.Dec 28 2021, 10:56 AM
This revision was automatically updated to reflect the committed changes.