mirror of https://gitee.com/openkylin/linux.git
x86/PCI: VMD: Allocate IRQ lists with correct MSI-X count
To reduce the amount of memory required for IRQ lists, only allocate their space after calling pci_msix_enable_range() which may reduce the number of MSI-X vectors allocated. Signed-off-by: Jon Derrick <jonathan.derrick@intel.com> Signed-off-by: Bjorn Helgaas <bhelgaas@google.com> Reviewed-by: Keith Busch <keith.busch@intel.com>
This commit is contained in:
parent
4fe0d15488
commit
c68db51589
|
@ -671,11 +671,6 @@ static int vmd_probe(struct pci_dev *dev, const struct pci_device_id *id)
|
||||||
if (vmd->msix_count < 0)
|
if (vmd->msix_count < 0)
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
vmd->irqs = devm_kcalloc(&dev->dev, vmd->msix_count, sizeof(*vmd->irqs),
|
|
||||||
GFP_KERNEL);
|
|
||||||
if (!vmd->irqs)
|
|
||||||
return -ENOMEM;
|
|
||||||
|
|
||||||
vmd->msix_entries = devm_kcalloc(&dev->dev, vmd->msix_count,
|
vmd->msix_entries = devm_kcalloc(&dev->dev, vmd->msix_count,
|
||||||
sizeof(*vmd->msix_entries),
|
sizeof(*vmd->msix_entries),
|
||||||
GFP_KERNEL);
|
GFP_KERNEL);
|
||||||
|
@ -689,6 +684,11 @@ static int vmd_probe(struct pci_dev *dev, const struct pci_device_id *id)
|
||||||
if (vmd->msix_count < 0)
|
if (vmd->msix_count < 0)
|
||||||
return vmd->msix_count;
|
return vmd->msix_count;
|
||||||
|
|
||||||
|
vmd->irqs = devm_kcalloc(&dev->dev, vmd->msix_count, sizeof(*vmd->irqs),
|
||||||
|
GFP_KERNEL);
|
||||||
|
if (!vmd->irqs)
|
||||||
|
return -ENOMEM;
|
||||||
|
|
||||||
for (i = 0; i < vmd->msix_count; i++) {
|
for (i = 0; i < vmd->msix_count; i++) {
|
||||||
INIT_LIST_HEAD(&vmd->irqs[i].irq_list);
|
INIT_LIST_HEAD(&vmd->irqs[i].irq_list);
|
||||||
vmd->irqs[i].vmd_vector = vmd->msix_entries[i].vector;
|
vmd->irqs[i].vmd_vector = vmd->msix_entries[i].vector;
|
||||||
|
|
Loading…
Reference in New Issue