Skip to content

Commit

Permalink
isci: fix isci_task_execute_tmf completion
Browse files Browse the repository at this point in the history
1/ fix the timeout for wait_for_completion_timeout
2/ In the tmf timeout case we need to wait for our termination callback
3/ Once the request is successfully started it will be freed according to the
   normal lifetime for requests.

Signed-off-by: Dan Williams <dan.j.williams@intel.com>
  • Loading branch information
Dan Williams committed Jul 3, 2011
1 parent e9bf709 commit 086a0da
Showing 1 changed file with 8 additions and 12 deletions.
20 changes: 8 additions & 12 deletions drivers/scsi/isci/task.c
Original file line number Diff line number Diff line change
Expand Up @@ -339,7 +339,8 @@ int isci_task_execute_tmf(struct isci_host *ihost,
status,
ireq);
spin_unlock_irqrestore(&ihost->scic_lock, flags);
goto cleanup_request;
isci_request_free(ihost, ireq);
return ret;
}

if (tmf->cb_state_func != NULL)
Expand All @@ -354,19 +355,21 @@ int isci_task_execute_tmf(struct isci_host *ihost,

/* Wait for the TMF to complete, or a timeout. */
timeleft = wait_for_completion_timeout(&completion,
jiffies + msecs_to_jiffies(timeout_ms));
msecs_to_jiffies(timeout_ms));

if (timeleft == 0) {
spin_lock_irqsave(&ihost->scic_lock, flags);

if (tmf->cb_state_func != NULL)
tmf->cb_state_func(isci_tmf_timed_out, tmf, tmf->cb_data);

status = scic_controller_terminate_request(&ihost->sci,
&isci_device->sci,
&ireq->sci);
scic_controller_terminate_request(&ihost->sci,
&isci_device->sci,
&ireq->sci);

spin_unlock_irqrestore(&ihost->scic_lock, flags);

wait_for_completion(tmf->complete);
}

isci_print_tmf(tmf);
Expand All @@ -387,13 +390,6 @@ int isci_task_execute_tmf(struct isci_host *ihost,
__func__,
ireq);

if (ireq->io_request_completion != NULL) {
/* A thread is waiting for this TMF to finish. */
complete(ireq->io_request_completion);
}

cleanup_request:
isci_request_free(ihost, ireq);
return ret;
}

Expand Down

0 comments on commit 086a0da

Please sign in to comment.