On Mon, Aug 10, 2020 at 02:03:17PM +0200, Martin Kepplinger wrote: > On 09.08.20 17:26, Alan Stern wrote: > > This is a somewhat fragile approach. You don't know for certain that > > scsi_noretry_cmd will be called. Also, scsi_noretry_cmd can be called > > from other places. > > > > It would be better to clear the expecting_media_change flag just before > > returning from scsi_decide_disposition. That way its use is localized > > to one routine, not spread out between two. > > > > Alan Stern > > > > Hi Alan, > > maybe you're right. I initially just thought that I'd allow for specific > error codes in scsi_noretry_cmd() to return non-NULL (BUS_BUSY, PARITY, > ERROR) despite having the flag set. > > The below version works equally fine for me but I'm not sure if it's > actually more safe. > > James, when exposing a new writable sysfs option like > "suspend_no_media_change"(?) that drivers can check before setting the > new "expecting_media_change" flag (during resume), would this addition > make sense to you? > > thanks, > > martin > > > > --- a/drivers/scsi/scsi_error.c > +++ b/drivers/scsi/scsi_error.c > @@ -565,6 +565,18 @@ int scsi_check_sense(struct scsi_cmnd *scmd) > return NEEDS_RETRY; > } > } > + if (scmd->device->expecting_media_change) { > + if (sshdr.asc == 0x28 && sshdr.ascq == 0x00) { > + /* > + * clear the expecting_media_change in > + * scsi_decide_disposition() because we > + * need to catch possible "fail fast" overrides > + * that block readahead can cause. > + */ > + return NEEDS_RETRY; > + } > + } > + > /* > * we might also expect a cc/ua if another LUN on the target > * reported a UA with an ASC/ASCQ of 3F 0E - > @@ -1944,9 +1956,19 @@ int scsi_decide_disposition(struct scsi_cmnd *scmd) > * the request was not marked fast fail. Note that above, > * even if the request is marked fast fail, we still requeue > * for queue congestion conditions (QUEUE_FULL or BUSY) */ > - if ((++scmd->retries) <= scmd->allowed > - && !scsi_noretry_cmd(scmd)) { > - return NEEDS_RETRY; > + if ((++scmd->retries) <= scmd->allowed) { > + /* > + * but scsi_noretry_cmd() cannot override the > + * expecting_media_change flag. > + */ > + if (!scsi_noretry_cmd(scmd) || > + scmd->device->expecting_media_change) { > + scmd->device->expecting_media_change = 0; > + return NEEDS_RETRY; > + } else { > + /* marked fast fail and not expected. */ > + return SUCCESS; > + } > } else { This may not matter... but it's worth pointing out that expecting_media_change doesn't get cleared if ++scmd->retries > scmd->allowed. It also doesn't get cleared in cases where the device _doesn't_ report a Unit Attention. Alan Stern