Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp4354869pxa; Mon, 10 Aug 2020 07:16:49 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyI+5wgiJUX7pxXypqKrmxYdeyCiYBdXoZb0HQ2hfzloV5deRoyN0q888wDnHK7TAFptK0V X-Received: by 2002:a17:906:5a93:: with SMTP id l19mr6023849ejq.418.1597069009245; Mon, 10 Aug 2020 07:16:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1597069009; cv=none; d=google.com; s=arc-20160816; b=Y4BPKNXWL+4AB6ZqoIrYMpPwq+nQvnjUnksTr7shiZ96gN1i0ftpKfLNfwB5hHc+dW rAhzpjlQ970ZCDh5QGTrxsOd1YxVc7pSfh8mK9GmkiZ64bDs1FveyFvCpyepl0xWyIm7 FUEumHBKhvtLcpgj7Ig1jkebEvKzaIu0T1Vyb/ODhkpZqTLk+GCFE85UDpWXZDYJptkn oSM11/TIGSpxBm3Kw/NkBBCsp70de8GD+xkjHrLX4ZvfnVsXHK+QbRmFOd7ptnzEbld9 7nSt1WG7qPy7wLiIee+VoYr74H/1lLVO/49uIx3z+AzVBARdDqV4Sw+Sii26y34BDOPK We3A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=4A8WRhD2o29RIXt4E7qkw/3tmfPZ8CsAUxYJ5tF/rsM=; b=TDVU+gTJLW2ur1bxZScc1HYktK52+frI5q1CYUioSvVmxfSzUEI4O+kNczX9/TJaaa oJYnmU2RPvpXvhFTyFpMZhcvDZzTYnqvwIzk5FO9qfueS5V+bDAn234rY+IFyO4fpJkO Y9IvU5pCRRg4LXCS3wbhVXhvyNPG/WqLQEuOqz3LFdx2p6HaKm0u5xUHQDSo833foA0n 4eGn23zq/ZbTQAcgxUzGb1WzFYWe/UxiTUcjowEmUrWsj9JA1bWYQhVa06xXwHpF3w4G Rj/G4lUhpxgIbuRp4zpBuPkdkGSKEwuU+qC/rPVNZgCGQQO/QH7eJhjsErP3Ie0W03zL SFtw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id e12si10485394edy.213.2020.08.10.07.16.26; Mon, 10 Aug 2020 07:16:49 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726897AbgHJONp (ORCPT + 99 others); Mon, 10 Aug 2020 10:13:45 -0400 Received: from netrider.rowland.org ([192.131.102.5]:59613 "HELO netrider.rowland.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with SMTP id S1726814AbgHJONp (ORCPT ); Mon, 10 Aug 2020 10:13:45 -0400 Received: (qmail 300172 invoked by uid 1000); 10 Aug 2020 10:13:43 -0400 Date: Mon, 10 Aug 2020 10:13:43 -0400 From: Alan Stern To: Martin Kepplinger Cc: James Bottomley , Bart Van Assche , Can Guo , martin.petersen@oracle.com, linux-scsi@vger.kernel.org, linux-kernel@vger.kernel.org, kernel@puri.sm Subject: Re: [PATCH] scsi: sd: add runtime pm to open / release Message-ID: <20200810141343.GA299045@rowland.harvard.edu> References: <20200730151030.GB6332@rowland.harvard.edu> <9b80ca7c-39f8-e52d-2535-8b0baf93c7d1@puri.sm> <425990b3-4b0b-4dcf-24dc-4e7e60d5869d@puri.sm> <20200807143002.GE226516@rowland.harvard.edu> <20200808150542.GB256751@rowland.harvard.edu> <20200809152643.GA277165@rowland.harvard.edu> <60150284-be13-d373-5448-651b72a7c4c9@puri.sm> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <60150284-be13-d373-5448-651b72a7c4c9@puri.sm> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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