diff options
author | David Woodhouse <[email protected]> | 2021-01-05 01:36:13 +0000 |
---|---|---|
committer | Will Deacon <[email protected]> | 2021-01-05 19:24:12 +0000 |
commit | b34f10c2dc5961021850c3c15f46a84b56a0c0e8 (patch) | |
tree | c4e48bfe7876269071983825fd99f56f0589b29d /tools/perf/scripts/python/export-to-sqlite.py | |
parent | 12bc4570c14e24e6244d66466aeda994f805634b (diff) |
iommu/amd: Stop irq_remapping_select() matching when remapping is disabled
The AMD IOMMU initialisation registers the IRQ remapping domain for
each IOMMU before doing the final sanity check that every I/OAPIC is
covered.
This means that the AMD irq_remapping_select() function gets invoked
even when IRQ remapping has been disabled, eventually leading to a NULL
pointer dereference in alloc_irq_table().
Unfortunately, the IVRS isn't fully parsed early enough that the sanity
check can be done in time to registering the IRQ domain altogether.
Doing that would be nice, but is a larger and more error-prone task. The
simple fix is just for irq_remapping_select() to refuse to report a
match when IRQ remapping has disabled.
Link: https://lore.kernel.org/lkml/[email protected]
Fixes: a1a785b57242 ("iommu/amd: Implement select() method on remapping irqdomain")
Reported-by: Johnathan Smithinovic <[email protected]>
Signed-off-by: David Woodhouse <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Will Deacon <[email protected]>
Diffstat (limited to 'tools/perf/scripts/python/export-to-sqlite.py')
0 files changed, 0 insertions, 0 deletions