On Tue, 2015-05-05 at 17:27 +0200, Bart Van Assche wrote: > On 05/05/15 17:10, Doug Ledford wrote: > > On Tue, 2015-05-05 at 16:26 +0200, Bart Van Assche wrote: > >> On 05/05/15 16:10, Doug Ledford wrote: > >>> However, while looking through the driver to research this, I noticed > >>> something else that seems more important if you ask me. With this patch > >>> we now implement individual channel connection tracking. However, in > >>> srp_queuecommand() you pick the channel based on the tag, and the blk > >>> layer has no idea of these disconnects, so the blk layer is free to > >>> assign a tag/channel to a channel that's disconnected, and then as best > >>> I can tell, you will simply try to post a work request to a channel > >>> that's already disconnected, which I would expect to fail if we have > >>> already disconnected this particular qp and not brought up a new one > >>> yet. So it seems to me there is a race condition between new incoming > >>> SCSI commands and this disconnect/reconnect window, and that maybe we > >>> should be sending these commands back to the mid layer for requeueing > >>> when the channel the blk_mq tag points to is disconnected. Or am I > >>> missing something in there? > >> > >> Hello Doug, > >> > >> Around the time a cable disconnect or other link layer failure is > >> detected by the SRP initiator or any other SCSI LLD it is unavoidable > >> that one or more SCSI requests fail. It is up to a higher layer (e.g. > >> dm-multipath + multipathd) to decide what to do with such requests, e.g. > >> queue these requests and resend these over another path. > > > > Sure, but that wasn't my point. My point was that if you know the > > channel is disconnected, then why don't you go immediately to the > > correct action in queuecommand (where correct action could be requeue > > waiting on reconnect or return with error, whatever is appropriate)? > > Instead you attempt to post a command to a known disconnected queue > > pair. > > > >> The SRP initiator driver has been tested thoroughly with the multipath > >> queue_if_no_path policy, with a fio job with I/O verification enabled > >> running on top of a dm device while concurrently repeatedly simulating > >> link layer failures (via ibportstate). > > > > Part of my questions here are because I don't know how the blk_mq > > handles certain conditions. However, your testing above only handles > > one case: all channels get dropped. As unlikely it may be, what if > > resource constraints caused just one channel to be dropped out of the > > bunch and the others stayed alive? Then the blk_mq would see requests > > on just one queue come back errored, while the others finished > > successfully. Does it drop that one queue out of rotation, or does it > > fail over the entire connection? > > Hello Doug, > > Sorry but I don't think that a SCSI LLD is the appropriate layer to > choose between requeuing or failing a request. Be that as it may, that doesn't change what I said about posting a command to a known disconnected QP. You could just fail immediately. Something like: if (!ch->connected) { scmnd->result = DID_NO_CONNECT; goto err; } right after getting the channel in queuecommand would work. That would save a couple spinlocks, several DMA mappings, a call into the low level driver, and a few other things. (And I only left requeue on the table because I wasn't sure how the blk_mq dealt with just a single channel being down versus all of them being down) > If multiple paths are > available between an initiator system and a SAN and if one path fails Who says the path failed? The path may be just fine. > only the multipath layer knows whether there are other working paths > available. If a working path is still available then the request should > be resent as soon as possible over another path. The multipath layer can > only take such a decision after a SCSI LLD has failed a request. Sure. I totally get failing fast and unilaterally for multipath managed devices. That's all assuming multipath though. There are uses without that. But my point in all of this is that if you have a single qp between yourself and the target, then any error including a qp resource error == path error since you only have one path. When you have a multi queue device, that's no longer true. A transient resource problem on one qp does not mean a path event (at least not necessarily, although your statement below converts a QP event into a path event by virtue disconnecting and reconnecting all of the QPs). My curiosity is now moot given what you wrote about tearing everything down and reconnecting (unless the error handling is modified to be more subtle in its workings), but the original question in my mind was what happens at the blk_mq level if you did have a single queue drop but not all of them and you weren't using multipath. > If only one channel fails all other channels are disconnected and the > transport layer error handling mechanism is started. I missed that. I assume it's done in srp_start_tl_fail_timers()? -- Doug Ledford <dledford@xxxxxxxxxx> GPG KeyID: 0E572FDD
Attachment:
signature.asc
Description: This is a digitally signed message part