[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <45D1D72D.9020509@gmail.com>
Date: Tue, 13 Feb 2007 07:20:13 -0800
From: Tejun Heo <htejun@...il.com>
To: Robert Hancock <hancockr@...w.ca>
CC: linux-kernel <linux-kernel@...r.kernel.org>,
linux-ide@...r.kernel.org, edmudama@...il.com,
Nicolas.Mailhot@...oste.net
Subject: Re: libata FUA revisited
Hello, Robert.
Robert Hancock wrote:
[--snip--]
> On the NCQ side, I think it's pretty safe to assume that all controllers
> will handle it. Obviously I've verified it with sata_nv (at least that
> it doesn't blow up obviously), and the other two NCQ drivers we have,
> ahci and sata_sil24 just feed raw FIS data into the controller so there
> should be no issue with not supporting it.
FWIW, ICH6/7/8 ahci's clear PMP field when transmitting FIS. The reason
why I'm hesitant is because there is no way to tell whether the FUA bit
got honored or ignored. With extra opcode, it's okay because barrier
explicitly fails but if NCQ FUA is not supported, it will succeed
silently as normal write. Everything will be okay generally but the
barrier is done incorrectly and on a really bad day it will lead to
journal corruption.
So, actually, I was thinking about *always* using the non-NCQ FUA
opcode. As currently implemented, FUA request is always issued by
itself, so NCQ doesn't make any difference there. So, I think it would
be better to turn on FUA on driver-by-driver basis whether the
controller supports NCQ or not.
Well, I might be being too paranoid but silent FUA failure would be
really hard to diagnose if that ever happens (and I'm fairly certain
that it will on some firmwares).
--
tejun
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists