diff options
| author | Marc Zyngier <maz@kernel.org> | 2025-06-03 15:18:01 +0100 | 
|---|---|---|
| committer | Thomas Gleixner <tglx@linutronix.de> | 2025-06-04 11:19:25 +0200 | 
| commit | 9cc82d99b13c1ad04e3dff9182b7953a8dba10b6 (patch) | |
| tree | d8f93912b5718e42377e323363cbe1794a7a0f8c /rust/kernel/firmware.rs | |
| parent | 5abc7438f1e9d62e91ad775cc83c9594c48d2282 (diff) | |
PCI/MSI: Size device MSI domain with the maximum number of vectors
Zenghui reports that since 1396e89e09f0 ("genirq/msi: Move prepare() call
to per-device allocation"), his Multi-MSI capable device isn't working
anymore.
This is a consequence of 15c72f824b32 ("PCI/MSI: Add support for per device
MSI[X] domains"), which always creates a MSI domain of size 1, even in the
presence of Multi-MSI.
While this was somehow working until then, moving the .prepare() call ends
up sizing the ITS table with a tiny value for this device, and making the
endpoint driver unhappy.
Instead, always create the domain and call the .prepare() helper with the
maximum expected size.
Fixes: 1396e89e09f0 ("genirq/msi: Move prepare() call to per-device allocation")
Fixes: 15c72f824b32 ("PCI/MSI: Add support for per device MSI[X] domains")
Reported-by: Zenghui Yu <yuzenghui@huawei.com>
Signed-off-by: Marc Zyngier <maz@kernel.org>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Tested-by: Zenghui Yu <yuzenghui@huawei.com>
Reviewed-by: Lorenzo Pieralisi <lpieralisi@kernel.org>
Link: https://lore.kernel.org/all/20250603141801.915305-1-maz@kernel.org
Closes: https://lore.kernel.org/r/0b1d7aec-1eac-a9cd-502a-339e216e08a1@huawei.com
Diffstat (limited to 'rust/kernel/firmware.rs')
0 files changed, 0 insertions, 0 deletions
