public inbox for linux-scsi@vger.kernel.org
 help / color / mirror / Atom feed
From: Douglas Gilbert <dougg@torque.net>
To: Tom Coughlan <coughlan@redhat.com>
Cc: James Bottomley <James.Bottomley@SteelEye.com>,
	Christoph Hellwig <hch@lst.de>,
	"Scott M. Ferris" <sferris@acm.org>,
	Mike Christie <mikenc@us.ibm.com>,
	linux-iscsi-devel <linux-iscsi-devel@lists.sourceforge.net>,
	SCSI Mailing List <linux-scsi@vger.kernel.org>
Subject: Re: [linux-iscsi-devel] [question] deferred sense
Date: Fri, 07 Jan 2005 10:06:13 +1000	[thread overview]
Message-ID: <41DDD275.50500@torque.net> (raw)
In-Reply-To: <1105029477.20393.187.camel@bianchi.boston.redhat.com>

Tom Coughlan wrote:
> On Wed, 2005-01-05 at 11:44, James Bottomley wrote:
> 
>>On Wed, 2005-01-05 at 16:23 +0100, Christoph Hellwig wrote:
>>
>>>On Wed, Jan 05, 2005 at 09:21:12AM -0600, Scott M. Ferris wrote:
>>>
>>>>To be more specific, there were some devices that would fail a command
>>>>and return deferred sense.  The command didn't complete at the target,
>>>>and the kernel wasn't retrying it because the sense was deferred
>>>>rather than current.  For those devices, the translation produced the
>>>>desired retry.
>>>
>>>Do you remember these devices?  Might be worth adding a midlayer
>>>blacklist entry for them.
>>
>>That's certainly possible ... although we'd need a lot more details.
>>Any device that returns deferred sense for a current error is pretty
>>badly broken according to the spec.
> 
> 
> If a current command returns deferred sense, the SCSI spec. requires
> that the current command shall not have been executed [1]. So, if at
> some point in the past the kernel did not retry a current command that
> returned deferred sense, the iscsi folks would have forced the retry by
> converting deferred sense to current sense. The scenario does not
> require a device that is working incorrectly.
> 
> The big flaw in what iscsi did is the case where the deferred sense
> indicates a non-fatal error. In that case, iscsi converts it to current,
> the mitlayer examines it and determines that it does not require a
> retry. This causes the current command to complete to the application
> even though it was not executed by the device. 
> 
> It looks to me as though the 2.4 iscsi driver is susceptible to this. It
> is probably not seen in practice because disk devices that return
> non-fatal deferred sense are rare (it probably requires the PER bit set
> in the error recovery mode page?). Anyone know for sure?

Tom,
 From my reading of SBC-2 (rev 16, 13 Nov 2004) deferred errors
cannot be turned off by a mode page. The VERIFY and
WRITE AND VERIFY commands can be used to make sure blocks get
to the media (or not) without deferred errors. There are also
the "Force Unit Access" (FUA and FUA_NV) bits in the READ and
WRITE commands (but not the 6 byte variants).

The t10 folks have added the idea of non-volatile cache in
a disk (more likely a RAID) which further complicates things.
Now a deferred error could theoretically span a power cycle!

The PER bit in the Read-Write Error Recovery mode page (SBC-2
rev 16 section 6.3.4) controls whether RECOVERED ERRORs are
reported or not. Also if the ARRE bit (for reads) and/or the
AWRE bit (for writes) are set in the same mode
page, the offending block will be remapped (whether a recovered
error is reported on not). If PER is 0 then RECOVERED ERRORs
are not reported. [In any case the Error Counter log pages
should reflect the problems (and perhaps the "grown" defect
list) so smartmontools may be of use.]

> [1] If the task terminates with CHECK CONDITION status and the sense
> data describes a deferred error the command for the terminated task
> shall not have been processed. (SPC-3) 

I fear my tinkering with sense descriptor data in
the mid level may have tripped up on this case (if
it wasn't already broken), that is: a deferred error
report must cause the current command to be retried,
even if the deferred error was reporting a
recovered error. This case can only arise when PER=1.

Doug Gilbert


  reply	other threads:[~2005-01-07  0:04 UTC|newest]

Thread overview: 13+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <41DB21D7.5080904@us.ibm.com>
     [not found] ` <20050104234700.GA18343@visi.com>
     [not found]   ` <20050105092144.GB26793@lst.de>
     [not found]     ` <20050105152112.GA8472@visi.com>
2005-01-05 15:23       ` [linux-iscsi-devel] [question] deferred sense Christoph Hellwig
2005-01-05 16:44         ` James Bottomley
2005-01-06 16:37           ` Tom Coughlan
2005-01-07  0:06             ` Douglas Gilbert [this message]
2005-01-11 11:44               ` Douglas Gilbert
2005-01-05 17:47 Salyzyn, Mark
2005-01-05 21:51 ` James Bottomley
2005-01-05 22:58   ` Matthew Wilcox
2005-01-06 23:09   ` Bryan Henderson
  -- strict thread matches above, loose matches on Subject: below --
2005-01-06 14:23 Salyzyn, Mark
2005-01-06 14:38 ` James Bottomley
2005-01-06 14:57 Salyzyn, Mark
2005-01-06 15:50 ` James Bottomley

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=41DDD275.50500@torque.net \
    --to=dougg@torque.net \
    --cc=James.Bottomley@SteelEye.com \
    --cc=coughlan@redhat.com \
    --cc=hch@lst.de \
    --cc=linux-iscsi-devel@lists.sourceforge.net \
    --cc=linux-scsi@vger.kernel.org \
    --cc=mikenc@us.ibm.com \
    --cc=sferris@acm.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox