Luben - On Fri, Aug 19, 2005 at 04:43:41PM -0400, Luben Tuikov wrote: > On 08/19/05 16:11, Patrick Mansfield wrote: > > I was changing it to wakeup the eh even while other IO is outstanding, so > > the eh can wakeup and cancel individual commands while other IO is still > > using the HBA. > > Hmm, if you want to do this, then SCSI Core needs to know about: > - Domain, > - Domain device and > - LU. Not really, scsi core is just asking the LLDD to cancel or release the scmd. That is really all we do in the eh today, and then if the LLDD can't cancel the scmd, we take other sometimes less than useful steps. The LLDD could start any error handling scheme it wants, independent of scsi core action. We don't initiate error handling in scsi core for other error cases, why should a timeout be any different? > The reason, is that you do not know why a task timed out. > Is it the LU, is it the device, is it the domain? Right, so in scsi core allow a simple method that can cancel commands while the HBA is still in use. > (Those are concepts talked about in SAM.) > > Since currently, SCSI Core has no clue about those concepts, > the current infrastructure, stalling IO to the host on eh, > satisfies. > > > So, for EH_NOT_HANDLED, do you add the scmd to a LLDD list in your > > eh_timed_out, then wait for the eh to run? > > No, no Patrick, I don't. The SCSI Core does this for me, and then > calls my eh_strategy routine and all the commands are on the list. Oh right ... I was not thinking straight. But I don't see how that gains much, if you sometimes still wait for scsi core to quiesce IO and wakeup the eh. -- Patrick Mansfield - : 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