diff options
author | Keith Busch <keith.busch@intel.com> | 2016-08-23 23:36:42 +0200 |
---|---|---|
committer | Bjorn Helgaas <bhelgaas@google.com> | 2016-08-23 23:36:42 +0200 |
commit | 21c80c9fefc3db10b530a96eb0478c29eb28bf77 (patch) | |
tree | f04f76432839643639668f8b9e011fa3dffdf741 /drivers/pci/msi.c | |
parent | PCI: Call pci_intx() when using legacy interrupts in pci_alloc_irq_vectors() (diff) | |
download | linux-21c80c9fefc3db10b530a96eb0478c29eb28bf77.tar.xz linux-21c80c9fefc3db10b530a96eb0478c29eb28bf77.zip |
x86/PCI: VMD: Fix infinite loop executing irq's
We can't initialize the list head on deletion as this causes the node to
point to itself, which causes an infinite loop if vmd_irq() happens to be
servicing that node.
The list initialization was trying to fix a bug from multiple calls to
disable the same IRQ. Fix this instead by having the VMD driver track if
the interrupt is enabled.
[bhelgaas: changelog, add "Fixes"]
Fixes: 97e923063575 ("x86/PCI: VMD: Initialize list item in IRQ disable")
Reported-by: Grzegorz Koczot <grzegorz.koczot@intel.com>
Tested-by: Miroslaw Drost <miroslaw.drost@intel.com>
Signed-off-by: Keith Busch <keith.busch@intel.com>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Acked-by Jon Derrick: <jonathan.derrick@intel.com>
Diffstat (limited to 'drivers/pci/msi.c')
0 files changed, 0 insertions, 0 deletions