Page MenuHomeFreeBSD

pcib: Allocate the memory BAR with the MSI-X table.
ClosedPublic

Authored by jhb on Jun 16 2023, 8:47 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 18, 10:42 AM
Unknown Object (File)
Tue, Jan 14, 1:17 AM
Unknown Object (File)
Tue, Jan 14, 1:17 AM
Unknown Object (File)
Tue, Jan 14, 1:16 AM
Unknown Object (File)
Tue, Jan 14, 1:09 AM
Unknown Object (File)
Sun, Jan 5, 10:04 AM
Unknown Object (File)
Dec 15 2024, 3:06 PM
Unknown Object (File)
Nov 27 2024, 10:35 PM
Subscribers
None

Details

Summary

This is required for pci_alloc_msix() to work and to thus use
MSI-X interrupts for PCI-e hotplug.

Reported by: cperciva

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 52110
Build 49001: arc lint + arc unit

Event Timeline

jhb requested review of this revision.Jun 16 2023, 8:47 PM
jhb created this revision.

FWIW, this makes it possible for an ena device attached to a PCIe hotplug port to attach, but it's getting watchdog timeouts so there's something else going on which might or might not be related to PCIe/MSIX.

I'm pretty sure that Colin's unique device is the first PCI-e HP bridge that supports MSI-X but not MSI. We have probably just always been falling back to MSI before without anyone noticing.

FWIW, this makes it possible for an ena device attached to a PCIe hotplug port to attach, but it's getting watchdog timeouts so there's something else going on which might or might not be related to PCIe/MSIX.

It sounds like the "something else going on" is a hypervisor bug which is being fixed separately. So as far as FreeBSD is concerned the patch we have here should be the only thing we need.

Is this MFCable? It breaks ABI but it's an ABI in pcib_private.h which maybe we don't care about that?

This revision is now accepted and ready to land.Jun 17 2023, 4:25 AM

It is definitely MFCable, the pcib softc is not a public KBI.