On 06/12/2013 08:34 AM, Bart Van Assche wrote: > On 06/11/13 20:57, James Bottomley wrote: >> Actually, I think we can dump the workqueue altogether. The only >> reason >> we need it is because the current abort handlers wait for the command >> and return the completion state. However, all LLDs are capable of >> emitting TMFs at interrupt level, so if we separated the emit from >> the >> wait, we could simply do this sequence: >> >> on timeout, fire the abort from interrupt and mark the command as >> having >> an abort issued (possibly by adding a pointer to the abort task), >> return >> BLK_EH_RESET_TIMER. >> >> Now if the timeout fires again, assume the abort was unsuccessful and >> escalate to LUN reset. >> >> This is fully asynchronous, fully tracked and doesn't rely on work >> queues. >> >> The necessary additions for something like this are the from >> interrupt >> issue abort and LUN reset, which could just be additional >> callbacks in >> the host template. > > Do we really need a new callback in the host template for a command > abort that does not wait ? Several LLDs already have their own > internal data structures for keeping track of the request state and > can use these data structures to set a flag "command has been > aborted". If aborting a command fails and the command completes that > flag can then be used to avoid a second invocation of scsi_done(). > At least, that's what the SRP initiator already does today in > srp_abort(). > Currently I'm playing around with this: diff --git a/include/scsi/scsi_host.h b/include/scsi/scsi_host.h index 4908480..498164a 100644 --- a/include/scsi/scsi_host.h +++ b/include/scsi/scsi_host.h @@ -174,6 +174,9 @@ struct scsi_host_template { int (* eh_bus_reset_handler)(struct scsi_cmnd *); int (* eh_host_reset_handler)(struct scsi_cmnd *); + int (* eh_send_abort)(struct scsi_cmnd *); + void (* eh_cancel_abort)(struct scsi_cmnd *); + /* 'eh_send_abort' sends the TMF asynchronously; it is the drivers responsibility to return the command to be aborted to the SCSI midlayer after calling this function. The return value is 'SUCCESS' if the TMF was sent or 'FAILED' if sending the TMF failed. It does _not_ indicate the status of the TMF itself, as this is done implicitly by returning the command with an appropriate status. 'eh_cancel_abort' is optional, and can be called at any time after 'eh_send_abort' to cancel the TMF. After calling 'eh_cancel_abort' neither the TMF nor the command must be considered valid from the LLDD. 'eh_cancel_abort' is for LLDDs requiring cleanups when aborting TMFs. LLDDs not requiring any cleanup simply can not implement this callback. Cheers, Hannes -- Dr. Hannes Reinecke zSeries & Storage hare@xxxxxxx +49 911 74053 688 SUSE LINUX Products GmbH, Maxfeldstr. 5, 90409 Nürnberg GF: J. Hawn, J. Guild, F. Imendörffer, HRB 16746 (AG Nürnberg) -- To unsubscribe from this list: send the line "unsubscribe linux-scsi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html