From: James Bottomley <James.Bottomley@HansenPartnership.com>
To: Vladislav Bolkhovitin <vst@vlnb.net>
Cc: greg@enjellic.com, scst-devel@lists.sourceforge.net,
linux-driver@qlogic.com, linux-scsi@vger.kernel.org,
linuxraid@amcc.com, neilb@suse.de, linux-raid@vger.kernel.org,
linux-fsdevel@vger.kernel.org
Subject: Re: Who do we point to?
Date: Thu, 21 Aug 2008 09:32:19 -0500 [thread overview]
Message-ID: <1219329139.3265.17.camel@localhost.localdomain> (raw)
In-Reply-To: <48AD5C14.6050508@vlnb.net>
On Thu, 2008-08-21 at 16:14 +0400, Vladislav Bolkhovitin wrote:
> MOANING MODE ON
>
> Testing SCST and target drivers I often have to deal with various
> failures and with how initiators recover from them. And,
> unfortunately,
> my observations on Linux aren't very encouraging. See, for instance,
> http://marc.info/?l=linux-scsi&m=119557128825721&w=2 thread.
> Receiving
> from the target TASK ABORTED status isn't really a failure, it's
> rather
> a corner case behavior, but it leads to immediate file system errors
> on
> initiator and then after remount ext3 journal replay doesn't
> completely
> repair it, only manual e2fsck helps. Even mounting with barrier=1
> doesn't improve anything. Target can't be blamed for the failure,
> because it stayed online, all its cache fully healthy and no commands
> were lost. Hence, apparently, the journaling code in ext3 isn't as
> reliable in face of storage corner cases as it's thought. I haven't
> tried that test since I reported it, but recently I've seen the
> similar
> ext3 failures on 2.6.26 in other tests, so I guess the problem(s)
> still
> there.
>
> A software SCSI target, like SCST, is beautiful to test things like
> that, because it allows easily simulate any possible corner case and
> storage failure. Unfortunately, I don't work on file systems level
> and
> can't participate in all that great testing and fixing effort. I can
> only help with setup and assistance in failures simulations.
>
> MOANING MODE OFF
Well, since I can see your just so anxious to stop moaning and get
coding, let me help you.
Firstly, from a standards point of view, TASK_ABORTED means that the
target is telling us this particular command was killed by another
initiator (seeing this also requires the TAS bit to be set in the
control mode page, so you can easily fix your current problem by
unsetting it). This makes TASK_ABORTED an incredibly rare status
condition (hence the problems below).
The way the kernel currently handles it is to return SUCCESS (around
line 1411 in scsi_error.c). This return actually propagates an I/O
error all the way up the stack. If the filesystem is the consumer, then
how it handles the error depends on what you have the errors= switch set
to. If you've got it set to a safety condition like remount-ro or
panic, then the fs should be recoverable on reboot (or unmount recheck).
If you have it set to something unsafe like continue, then yes, you're
asking for trouble and fs corruption ... but it's hardly the OSs fault,
you told it you didn't want to operate safely.
So, given what TASK_ABORT means, it looks to me like the handling should
go through the maybe_retry path. I'd say that's about a three line
patch ... and since you have the test bed, you can even try it out.
James
next prev parent reply other threads:[~2008-08-21 14:32 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-08-20 19:11 Who do we point to? greg
2008-08-21 1:06 ` [Scst-devel] " Stanislaw Gruszka
2008-08-21 12:17 ` Vladislav Bolkhovitin
2008-08-21 12:14 ` Vladislav Bolkhovitin
2008-08-21 14:32 ` James Bottomley [this message]
2008-08-27 18:17 ` Vladislav Bolkhovitin
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=1219329139.3265.17.camel@localhost.localdomain \
--to=james.bottomley@hansenpartnership.com \
--cc=greg@enjellic.com \
--cc=linux-driver@qlogic.com \
--cc=linux-fsdevel@vger.kernel.org \
--cc=linux-raid@vger.kernel.org \
--cc=linux-scsi@vger.kernel.org \
--cc=linuxraid@amcc.com \
--cc=neilb@suse.de \
--cc=scst-devel@lists.sourceforge.net \
--cc=vst@vlnb.net \
/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;
as well as URLs for NNTP newsgroup(s).