[PATCH] PCI: vmd: White list for fast interrupt handlers

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Please apply the follow patch from kernel 4.18 to kernel 4.14

Commit: a7f58b9ecfd3c0f63703ec10f4a592cc38dbd1b8

This patch fixes a performance issue with some devices being accessed using
the Volume Management Device (vmd). I have included an updated copy of the
patch because the parent directory of the file has changed between the 4.14
and 4.18 releases

4.14: drivers/pci/host/vmd.c
4.18: drivers/pci/controller/vmd.c

Thank you,
Kenneth Heitke <Kenneth.heitke@xxxxxxxxx>
---


From: Keith Busch <keith.busch@xxxxxxxxx>
Date: Tue, 8 May 2018 10:00:22 -0600
Subject: [PATCH] PCI: vmd: White list for fast interrupt handlers

Devices with slow interrupt handlers are significantly harming
performance when their interrupt vector is shared with a fast device.

Create a class code white list for devices with known fast interrupt
handlers and let all other devices share a single vector so that they
don't interfere with performance.

At the moment, only the NVM Express class code is on the list, but more
may be added if VMD users desire to use other low-latency devices in
these domains.

Signed-off-by: Keith Busch <keith.busch@xxxxxxxxx>
[lorenzo.pieralisi@xxxxxxx: changelog]
Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@xxxxxxx>
Acked-by: Jon Derrick: <jonathan.derrick@xxxxxxxxx>
---
 drivers/pci/host/vmd.c | 13 ++++++++++++-
 1 file changed, 12 insertions(+), 1 deletion(-)

diff --git a/drivers/pci/host/vmd.c b/drivers/pci/host/vmd.c
index 509893b..2537b02 100644
--- a/drivers/pci/host/vmd.c
+++ b/drivers/pci/host/vmd.c
@@ -183,9 +183,20 @@ static struct vmd_irq_list *vmd_next_irq(struct vmd_dev *vmd, struct msi_desc *d
        int i, best = 1;
        unsigned long flags;

-       if (pci_is_bridge(msi_desc_to_pci_dev(desc)) || vmd->msix_count == 1)
+       if (vmd->msix_count == 1)
                return &vmd->irqs[0];

+       /*
+        * White list for fast-interrupt handlers. All others will share the
+        * "slow" interrupt vector.
+        */
+       switch (msi_desc_to_pci_dev(desc)->class) {
+       case PCI_CLASS_STORAGE_EXPRESS:
+               break;
+       default:
+               return &vmd->irqs[0];
+       }
+
        raw_spin_lock_irqsave(&list_lock, flags);
        for (i = 1; i < vmd->msix_count; i++)
                if (vmd->irqs[i].count < vmd->irqs[best].count)
--
2.7.4



[Index of Archives]     [Linux Kernel]     [Kernel Development Newbies]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite Hiking]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux