public inbox for linux-scsi@vger.kernel.org
 help / color / mirror / Atom feed
From: Don Brace <don.brace@pmcs.com>
To: scott.teel@pmcs.com, Kevin.Barnett@pmcs.com,
	james.bottomley@parallels.com, hch@infradead.org,
	Justin.Lindley@pmcs.com, brace@pmcs.com
Cc: linux-scsi@vger.kernel.org
Subject: [PATCH v2 30/41] hpsa: performance tweak for hpsa_scatter_gather()
Date: Fri, 06 Mar 2015 17:48:25 -0600	[thread overview]
Message-ID: <20150306234825.29973.3340.stgit@brunhilda> (raw)
In-Reply-To: <20150306233504.29973.41322.stgit@brunhilda>

From: Webb Scales <webbnh@hp.com>

Divide the loop in hpsa_scatter_gather() into two, one for the initial SG list
and a second one for the chained list, if any.  This allows the conditional
check which resets the indicies for the chained list to be performed outside
the loop instead of being done on every iteration inside the loop.

Reviewed-by: Scott Teel <scott.teel@pmcs.com>
Reviewed-by: Kevin Barnett <kevin.barnett@pmcs.com>
Signed-off-by: Webb Scales <webbnh@hp.com>
Signed-off-by: Don Brace <don.brace@pmcs.com>
---
 drivers/scsi/hpsa.c |   39 ++++++++++++++++++++++++++++-----------
 1 file changed, 28 insertions(+), 11 deletions(-)

diff --git a/drivers/scsi/hpsa.c b/drivers/scsi/hpsa.c
index b91fe35..c2b2c42 100644
--- a/drivers/scsi/hpsa.c
+++ b/drivers/scsi/hpsa.c
@@ -3712,7 +3712,7 @@ static int hpsa_scatter_gather(struct ctlr_info *h,
 		struct scsi_cmnd *cmd)
 {
 	struct scatterlist *sg;
-	int use_sg, i, sg_index, chained;
+	int use_sg, i, sg_limit, chained, last_sg;
 	struct SGDescriptor *curr_sg;
 
 	BUG_ON(scsi_sg_count(cmd) > h->maxsgentries);
@@ -3724,22 +3724,39 @@ static int hpsa_scatter_gather(struct ctlr_info *h,
 	if (!use_sg)
 		goto sglist_finished;
 
+	/*
+	 * If the number of entries is greater than the max for a single list,
+	 * then we have a chained list; we will set up all but one entry in the
+	 * first list (the last entry is saved for link information);
+	 * otherwise, we don't have a chained list and we'll set up at each of
+	 * the entries in the one list.
+	 */
 	curr_sg = cp->SG;
-	chained = 0;
-	sg_index = 0;
-	scsi_for_each_sg(cmd, sg, use_sg, i) {
-		if (i == h->max_cmd_sg_entries - 1 &&
-			use_sg > h->max_cmd_sg_entries) {
-			chained = 1;
-			curr_sg = h->cmd_sg_list[cp->cmdindex];
-			sg_index = 0;
-		}
+	chained = use_sg > h->max_cmd_sg_entries;
+	sg_limit = chained ? h->max_cmd_sg_entries - 1 : use_sg;
+	last_sg = scsi_sg_count(cmd) - 1;
+	scsi_for_each_sg(cmd, sg, sg_limit, i) {
 		hpsa_set_sg_descriptor(curr_sg, sg);
 		curr_sg++;
 	}
 
+	if (chained) {
+		/*
+		 * Continue with the chained list.  Set curr_sg to the chained
+		 * list.  Modify the limit to the total count less the entries
+		 * we've already set up.  Resume the scan at the list entry
+		 * where the previous loop left off.
+		 */
+		curr_sg = h->cmd_sg_list[cp->cmdindex];
+		sg_limit = use_sg - sg_limit;
+		for_each_sg(sg, sg, sg_limit, i) {
+			hpsa_set_sg_descriptor(curr_sg, sg);
+			curr_sg++;
+		}
+	}
+
 	/* Back the pointer up to the last entry and mark it as "last". */
-	(--curr_sg)->Ext = cpu_to_le32(HPSA_SG_LAST);
+	(curr_sg - 1)->Ext = cpu_to_le32(HPSA_SG_LAST);
 
 	if (use_sg + chained > h->maxSG)
 		h->maxSG = use_sg + chained;


  parent reply	other threads:[~2015-03-06 23:49 UTC|newest]

Thread overview: 46+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-03-06 23:45 [PATCH v2 00/41] hpsa updates Don Brace
2015-03-06 23:45 ` [PATCH v2 01/41] hpsa: add masked physical devices into h->dev[] array Don Brace
2015-03-08 15:37   ` Christoph Hellwig
2015-03-06 23:45 ` [PATCH v2 02/41] hpsa: clean up host, channel, target, lun prints Don Brace
2015-03-08 15:38   ` Christoph Hellwig
2015-03-06 23:46 ` [PATCH v2 03/41] hpsa: rework controller command submission Don Brace
2015-03-06 23:46 ` [PATCH v2 04/41] hpsa: clean up aborts Don Brace
2015-03-06 23:46 ` [PATCH v2 05/41] hpsa: decrement h->commands_outstanding in fail_all_outstanding_cmds Don Brace
2015-03-06 23:46 ` [PATCH v2 06/41] hpsa: hpsa decode sense data for io and tmf Don Brace
2015-03-08 15:40   ` Christoph Hellwig
2015-03-06 23:46 ` [PATCH v2 07/41] hpsa: allow lockup detected to be viewed via sysfs Don Brace
2015-03-06 23:46 ` [PATCH v2 08/41] hpsa: make function names consistent Don Brace
2015-03-06 23:46 ` [PATCH v2 09/41] hpsa: factor out hpsa_init_cmd function Don Brace
2015-03-06 23:46 ` [PATCH v2 10/41] hpsa: do not ignore return value of hpsa_register_scsi Don Brace
2015-03-06 23:46 ` [PATCH v2 11/41] hpsa: try resubmitting down raid path on task set full Don Brace
2015-03-06 23:46 ` [PATCH v2 12/41] hpsa: factor out hpsa_ioaccel_submit function Don Brace
2015-03-06 23:46 ` [PATCH v2 13/41] hpsa: print accurate SSD Smart Path Enabled status Don Brace
2015-03-06 23:47 ` [PATCH v2 14/41] hpsa: use ioaccel2 path to submit IOs to physical drives in HBA mode Don Brace
2015-03-06 23:47 ` [PATCH v2 15/41] hpsa: Get queue depth from identify physical bmic for physical disks Don Brace
2015-03-06 23:47 ` [PATCH v2 16/41] hpsa: break hpsa_free_irqs_and_disable_msix into two functions Don Brace
2015-03-08 15:42   ` Christoph Hellwig
2015-03-06 23:47 ` [PATCH v2 17/41] hpsa: clean up error handling Don Brace
2015-03-06 23:47 ` [PATCH v2 18/41] hpsa: refactor freeing of resources into more logical functions Don Brace
2015-03-06 23:47 ` [PATCH v2 19/41] hpsa: add ioaccel sg chaining for the ioaccel2 path Don Brace
2015-03-06 23:47 ` [PATCH v2 20/41] hpsa: add more ioaccel2 error handling, including underrun statuses Don Brace
2015-03-06 23:47 ` [PATCH v2 21/41] hpsa: do not check cmd_alloc return value - it cannnot return NULL Don Brace
2015-03-06 23:47 ` [PATCH v2 22/41] hpsa: correct return values from driver functions Don Brace
2015-03-06 23:47 ` [PATCH v2 23/41] hpsa: clean up driver init Don Brace
2015-03-06 23:47 ` [PATCH v2 24/41] hpsa: clean up some error reporting output in abort handler Don Brace
2015-03-06 23:47 ` [PATCH v2 25/41] hpsa: do not print ioaccel2 warning messages about unusual completions Don Brace
2015-03-06 23:48 ` [PATCH v2 26/41] hpsa: add support sending aborts to physical devices via the ioaccel2 path Don Brace
2015-03-06 23:48 ` [PATCH v2 27/41] hpsa: use helper routines for finishing commands Don Brace
2015-03-06 23:48 ` [PATCH v2 28/41] hpsa: don't return abort request until target is complete Don Brace
2015-03-06 23:48 ` [PATCH v2 29/41] hpsa: refactor and rework support for sending TEST_UNIT_READY Don Brace
2015-03-06 23:48 ` Don Brace [this message]
2015-03-06 23:48 ` [PATCH v2 31/41] hpsa: call pci_release_regions after pci_disable_device Don Brace
2015-03-06 23:48 ` [PATCH v2 32/41] hpsa: skip free_irq calls if irqs are not allocated Don Brace
2015-03-06 23:48 ` [PATCH v2 33/41] hpsa: cleanup for init_one step 2 in kdump Don Brace
2015-03-06 23:48 ` [PATCH v2 34/41] hpsa: fix try_soft_reset error handling Don Brace
2015-03-06 23:48 ` [PATCH v2 35/41] hpsa: create workqueue after the driver is ready for use Don Brace
2015-03-06 23:48 ` [PATCH v2 36/41] hpsa: add interrupt number to /proc/interrupts interrupt name Don Brace
2015-03-06 23:49 ` [PATCH v2 37/41] hpsa: use block layer tag for command allocation Don Brace
2015-03-06 23:49 ` [PATCH v2 38/41] hpsa: use scsi host_no as hpsa controller number Don Brace
2015-03-06 23:49 ` [PATCH v2 39/41] hpsa: propagate the error code in hpsa_kdump_soft_reset Don Brace
2015-03-06 23:49 ` [PATCH v2 40/41] hpsa: cleanup reset Don Brace
2015-03-06 23:49 ` [PATCH v2 41/41] hpsa: change driver version Don Brace

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20150306234825.29973.3340.stgit@brunhilda \
    --to=don.brace@pmcs.com \
    --cc=Justin.Lindley@pmcs.com \
    --cc=Kevin.Barnett@pmcs.com \
    --cc=brace@pmcs.com \
    --cc=hch@infradead.org \
    --cc=james.bottomley@parallels.com \
    --cc=linux-scsi@vger.kernel.org \
    --cc=scott.teel@pmcs.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox