Page MenuHomeFreeBSD

Assorted fixes to MSI-X/MSI/INTx setup iflib(9)
ClosedPublic

Authored by marius on Jun 10 2018, 3:14 AM.
Tags
None
Referenced Files
Unknown Object (File)
Sun, Oct 12, 5:51 PM
Unknown Object (File)
Sep 18 2025, 7:11 PM
Unknown Object (File)
Sep 18 2025, 2:17 AM
Unknown Object (File)
Sep 17 2025, 7:57 PM
Unknown Object (File)
Sep 15 2025, 12:18 PM
Unknown Object (File)
Sep 13 2025, 8:12 AM
Unknown Object (File)
Aug 19 2025, 8:47 AM
Unknown Object (File)
Aug 16 2025, 10:56 PM
Subscribers

Details

Summary
  • In iflib_msix_init(), VMMs with broken MSI-X activation are trying to be worked around by manually enabling PCIM_MSIXCTRL_MSIX_ENABLE before calling pci_alloc_msix(9). Apart from constituting a layering violation, this has the problem of leaving PCIM_MSIXCTRL_MSIX_ENABLE enabled when falling back to MSI or INTx when e. g. MSI-X is black- listed and initially also when disabled via hw.pci.enable_msix. The later in turn was incorrectly worked around in r325166. Since r310806, pci(4) itself has code to deal with broken MSI-X handling of VMMs, so all of these workarounds in iflib(9) can go, fixing non-working interrupts when falling back to MSI/INTx. In any case, possibly further adjustments to broken MSI-X activation of VMMs like enabling r310806 by default in VM environments need to be placed into pci(4), not iflib(9). [1]
  • Also remove the pci_enable_busmaster(9) call from iflib_msix_init(), which is already more properly invoked from iflib_device_attach().
  • When falling back to MSI/INTx, release the MSI-X BAR resource again.
  • When falling back to INTx, ensure scctx->isc_vectors is set to 1 and not to something higher from a device with more than one MSI message supported.
  • Make the nearby ring_state(s) stuff (static) const.

Discussed with: jhb@ at BSDCan 2018 [1]

Test Plan

Successfully verified that one now ends up with a working MSI for em(4) on systems where MSI-X is black-listed.

Diff Detail

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

Event Timeline

This looks good to my eye as far as I can tell...

This revision is now accepted and ready to land.Jun 10 2018, 5:18 AM

Thanks. You probably want Matt to review this as well though.

Can you provide a diff with context so I can see where you're adding the resource release without having to go directly to the sources?

This revision now requires review to proceed.Jun 13 2018, 9:54 AM
This revision was not accepted when it landed; it landed in state Needs Review.Jun 17 2018, 8:33 PM
This revision was automatically updated to reflect the committed changes.