scsi: csiostor: create per port irq affinity mask set
authorVarun Prakash <varun@chelsio.com>
Sun, 21 Apr 2019 13:30:43 +0000 (19:00 +0530)
committerMartin K. Petersen <martin.petersen@oracle.com>
Mon, 29 Apr 2019 12:34:08 +0000 (08:34 -0400)
csiostor driver allocates per port num_online_cpus() irq vectors, so create
per-port irq affinity mask set to spread irq vectors evenly.

Signed-off-by: Varun Prakash <varun@chelsio.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/csiostor/csio_isr.c

index 7c881471571162adc99d70f0b9daaa641ba2909a..b2540402fafcf555e05a7be12f8516f9505eaf29 100644 (file)
@@ -474,13 +474,39 @@ csio_reduce_sqsets(struct csio_hw *hw, int cnt)
        csio_dbg(hw, "Reduced sqsets to %d\n", hw->num_sqsets);
 }
 
+static void csio_calc_sets(struct irq_affinity *affd, unsigned int nvecs)
+{
+       struct csio_hw *hw = affd->priv;
+       u8 i;
+
+       if (!nvecs)
+               return;
+
+       if (nvecs < hw->num_pports) {
+               affd->nr_sets = 1;
+               affd->set_size[0] = nvecs;
+               return;
+       }
+
+       affd->nr_sets = hw->num_pports;
+       for (i = 0; i < hw->num_pports; i++)
+               affd->set_size[i] = nvecs / hw->num_pports;
+}
+
 static int
 csio_enable_msix(struct csio_hw *hw)
 {
        int i, j, k, n, min, cnt;
        int extra = CSIO_EXTRA_VECS;
        struct csio_scsi_cpu_info *info;
-       struct irq_affinity desc = { .pre_vectors = 2 };
+       struct irq_affinity desc = {
+               .pre_vectors = CSIO_EXTRA_VECS,
+               .calc_sets = csio_calc_sets,
+               .priv = hw,
+       };
+
+       if (hw->num_pports > IRQ_AFFINITY_MAX_SETS)
+               return -ENOSPC;
 
        min = hw->num_pports + extra;
        cnt = hw->num_sqsets + extra;