Page MenuHomeFreeBSD

Program the MSI-X vector control field for MSI-X table entries without loading the previous content of the vector control word.
ClosedPublic

Authored by khng on Jul 7 2019, 12:04 PM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Oct 15, 4:02 AM
Unknown Object (File)
Mon, Oct 13, 5:20 AM
Unknown Object (File)
Sun, Oct 12, 2:38 AM
Unknown Object (File)
Sun, Oct 12, 2:38 AM
Unknown Object (File)
Sun, Oct 12, 2:37 AM
Unknown Object (File)
Sun, Oct 12, 2:37 AM
Unknown Object (File)
Sun, Oct 12, 2:37 AM
Unknown Object (File)
Sun, Oct 12, 2:37 AM
Subscribers

Details

Summary

This fixes the interrupt behavior of controllers which has flakey MMIO
behavior. For instance, SM961/PM961 SSDs are observed that the offsets
starting from 0x3084 within the memory region specified by BAR0 are
all read as 0. The changes are made in accord to the MSI-X
implementation of Illumos kernel.

Two non-exported functions are modified: pci_mask_msix() and
pci_unmask_msix().

A reference to a related bug: https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=211713

Diff Detail

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 25240
Build 23909: arc lint + arc unit

Event Timeline

Reading through the standard just now, this change looks good, provided we never use the ST Table Location value of 10b (device specific mode, table 6-12 in the 3.0 standard). If we do, then the upper 16 bits are the ST values and need to be preserved.

It's unclear to me if we use them, though (seems no, but that's a quick grep, not a careful study of the code). There's a bit in the TPH Requester Capability Register (section 7.26) that indicates if ST (steering types) is supported. We don't seem to look at that register at all, via its symbolic name anyway. The core PCI code seems safe to make this change. Grep says it's unused in the rest of the tree.

Subject to the one comment above, I like it and think it should go in

sys/dev/pci/pci.c
1673–1677

/*

  • Some devices (eg Samsung PM961) cannot handle RMW on this register for all its vectors.
  • write the values we need directly. */
This revision is now accepted and ready to land.Jul 7 2019, 4:41 PM

Add comments in regards to SM961/PM961

This revision now requires review to proceed.Jul 7 2019, 5:23 PM

Add comments in regards to SM961/PM961.

khng marked an inline comment as done.Jul 8 2019, 4:21 PM

The newest spec I have (3.0) say this about the upper 31 bits of VCTRL:

After reset, the state of these bits must be 0. However, for potential future use, software must
preserve the value of these reserved bits when modifying the value of other Vector Control bits. If software modifies the value of these reserved bits, the result is undefined.
`

Thus, a RMW seems to be required. The description of the mask bit is also:

When this bit is set, the function is prohibited from sending a message using this MSI-X Table entry.
However, any other MSI-X Table entries programmed with the same vector will still be capable of sending an equivalent message unless they are also masked.
This bit’s state after reset is 1 (entry is masked). This bit is read/write.

As such, it would seem that these devices are just not compliant. However, we could make the W portion unconditional which would satisfy the RMW and still work for these devices I think.

(My 3.0 is older than Warners which is somewhat unfortunate, but I think the requirement for RMW still stands)

Update according to @jhb 's suggestions.

Ah, the PCI vs PCIe specs.

One thing to consider is moving the new comment up above 'pci_mask_msix' function and just listing it once.

sys/dev/pci/pci.c
1678

This needs to write 'val', not the constant.

style(9) wants a blank line before comments.

I would perhaps reword the comment to say something like:

"Some devices (e.g. Samsung PM961) do not support reads of this register, so always write the new value."

1694

Similarly here with using 'val' instead of 0 and comment suggestions.

Opps careless mistakes.

This revision is now accepted and ready to land.Jul 8 2019, 6:32 PM