All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH 1/1] scsi: storvsc: Spread interrupts when picking a channel for I/O requests
@ 2018-01-24 22:14 ` Michael Kelley (EOSG)
  0 siblings, 0 replies; 12+ messages in thread
From: Michael Kelley (EOSG) @ 2018-01-24 22:14 UTC (permalink / raw)
  To: KY Srinivasan, Stephen Hemminger, martin.petersen@oracle.com,
	longi@microsoft.com, JBottomley@odin.com,
	devel@linuxdriverproject.org, linux-kernel@vger.kernel.org,
	linux-scsi@vger.kernel.org
  Cc: Michael Kelley (EOSG)

Update the algorithm in storvsc_do_io to look for a channel
starting with the current CPU + 1 and wrap around (within the
current NUMA node). This spreads VMbus interrupts more evenly
across CPUs. Previous code always started with first CPU in
the current NUMA node, skewing the interrupt load to that CPU.

Signed-off-by: Michael Kelley <mikelley@microsoft.com>
---
 drivers/scsi/storvsc_drv.c | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

diff --git a/drivers/scsi/storvsc_drv.c b/drivers/scsi/storvsc_drv.c
index e07907d..f3264c4 100644
--- a/drivers/scsi/storvsc_drv.c
+++ b/drivers/scsi/storvsc_drv.c
@@ -1310,7 +1310,8 @@ static int storvsc_do_io(struct hv_device *device,
 			 */
 			cpumask_and(&alloced_mask, &stor_device->alloced_cpus,
 				    cpumask_of_node(cpu_to_node(q_num)));
-			for_each_cpu(tgt_cpu, &alloced_mask) {
+			for_each_cpu_wrap(tgt_cpu, &alloced_mask,
+					outgoing_channel->target_cpu + 1) {
 				if (tgt_cpu != outgoing_channel->target_cpu) {
 					outgoing_channel =
 					stor_device->stor_chns[tgt_cpu];
-- 
1.8.3.1

^ permalink raw reply related	[flat|nested] 12+ messages in thread

end of thread, other threads:[~2018-02-07  0:39 UTC | newest]

Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2018-01-24 22:14 [PATCH 1/1] scsi: storvsc: Spread interrupts when picking a channel for I/O requests Michael Kelley (EOSG)
2018-01-24 22:14 ` Michael Kelley (EOSG)
2018-01-24 22:37 ` Michael Kelley (EOSG)
2018-01-24 22:37   ` Michael Kelley (EOSG)
2018-01-31 20:22   ` Long Li
2018-01-31 20:22     ` Long Li
2018-01-31 21:14     ` Michael Kelley (EOSG)
2018-01-31 21:14       ` Michael Kelley (EOSG)
2018-01-31 21:22       ` Long Li
2018-01-31 21:22         ` Long Li
2018-02-07  0:39 ` Martin K. Petersen
2018-02-07  0:39   ` Martin K. Petersen

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.