Page MenuHomeFreeBSD

SPI MSI mapping for gic v3 acpi in arm64
ClosedPublic

Authored by schakrabarti_microsoft.com on Dec 20 2022, 8:55 PM.
Tags
None
Referenced Files
F94669486: D37763.id114494.diff
Wed, Sep 18, 1:12 AM
Unknown Object (File)
Wed, Sep 11, 2:53 PM
Unknown Object (File)
Mon, Sep 9, 4:01 AM
Unknown Object (File)
Thu, Sep 5, 5:02 AM
Unknown Object (File)
Sun, Sep 1, 1:03 PM
Unknown Object (File)
Sun, Sep 1, 1:03 PM
Unknown Object (File)
Sun, Sep 1, 1:03 PM
Unknown Object (File)
Sat, Aug 31, 10:20 AM

Details

Summary

Microsoft Azure Hyper-V uses SPI to map MSI in ARM64, instead of using LPI IDS.
To enable that we need to have gic registered with ACPI_MSI_XREF and gic acpi to map SPI for MSI.

Diff Detail

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

Event Timeline

sys/arm64/arm64/gic_v3.c
393

style(9) is four spaces for 2nd level indentation (i.e., arg line wrapping) so please leave this unchanged

Are there times other than when running as a hyperv guest that these might be needed?

In D37763#862942, @imp wrote:

Are there times other than when running as a hyperv guest that these might be needed?

If any other ACPI platform uses SPI for MSI, instead of using LPI and ITS for MSI, then it would be required.

This revision is now accepted and ready to land.Jan 30 2023, 2:21 PM
sys/arm64/arm64/gic_v3.c
385

Is this needed? We set the end in gic_v3_acpi.c

sys/arm64/arm64/gic_v3_acpi.c
339

range

sys/arm64/arm64/gic_v3.c
385

Yes, but the value of the end is 0 for Hyper-V, so if the end value is zero, we are using the full range.

jrtc27 added inline comments.
sys/arm64/arm64/gic_v3_acpi.c
339

This was not addressed prior to committing

sys/arm64/arm64/gic_v3_acpi.c
339

Will fix this typo in next commit.