isci: Requests that do not start must be set to "complete"

Requests that fail at start because of a reset pending condition
must be set to complete in order to allow for later cleanup.

Signed-off-by: Jeff Skirvin <jeffrey.d.skirvin@intel.com>
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
This commit is contained in:
Jeff Skirvin 2011-06-20 14:09:11 -07:00 committed by Dan Williams
parent cde76fbf1f
commit f53a3a32c1
1 changed files with 2 additions and 1 deletions

View File

@ -3678,18 +3678,19 @@ int isci_request_execute(
* Update it's status and add it to the list in the * Update it's status and add it to the list in the
* remote device object. * remote device object.
*/ */
isci_request_change_state(request, started);
list_add(&request->dev_node, &isci_device->reqs_in_process); list_add(&request->dev_node, &isci_device->reqs_in_process);
if (status == SCI_SUCCESS) { if (status == SCI_SUCCESS) {
/* Save the tag for possible task mgmt later. */ /* Save the tag for possible task mgmt later. */
request->io_tag = request->sci.io_tag; request->io_tag = request->sci.io_tag;
isci_request_change_state(request, started);
} else { } else {
/* The request did not really start in the /* The request did not really start in the
* hardware, so clear the request handle * hardware, so clear the request handle
* here so no terminations will be done. * here so no terminations will be done.
*/ */
request->terminated = true; request->terminated = true;
isci_request_change_state(request, completed);
} }
spin_unlock_irqrestore(&isci_host->scic_lock, flags); spin_unlock_irqrestore(&isci_host->scic_lock, flags);