Tejun Heo wrote:
-Add a new port flag ATA_FLAG_NO_FUA to indicate that a controller
can't handle FUA commands, and add that flag to sata_sil. Force FUA
off on any drive connected to a controller with this bit set.
There was some talk that sata_mv might have this problem, but I
believe the conclusion was that it didn't. The only controllers that
would are ones that actually try to interpret the ATA command codes
and don't know about WRITE DMA FUA.
I think it would be better to add ATA_FLAG_FUA instead of ATA_FLAG_NO_FUA.
I'm not sure about that, it appears that the number of controllers that
have problems is much lower than the number that don't, so this would
just need to be added to almost every driver. Especially since the
non-NCQ FUA which was problematic on SiI in the past isn't being
switched on by default.
-Change the fua module option to control FUA enable/disable to have a
third value, "enable for NCQ-supporting drives only", which would
become the new default. That case seems less likely to cause problems
since FUA on NCQ is just another bit in the command whereas FUA on
non-NCQ is an entirely different, potentially unsupported command.
Not enabling FUA doesn't result in huge performance hit. I'm not sure
whether we should go such far. Just supporting FUA on known good
controllers sounds good enough to me.
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.
Assuming that we leave FUA off by default for non-NCQ for the
foreseeable future, is there really much concern here?
Any comments?
As an aside, I came across a comment that the Silicon Image Windows
drivers for NCQ-supporting controllers have some blacklist entries for
drives with broken NCQ in their .inf files. We only seem to have one
in the libata NCQ blacklist, we may want to add some more of these.
The ones in the current SiI3124 and 3132 drivers' .inf files for
"DisableSataQueueing" appear to be:
Model Firmware
Maxtor 7B250S0 BANC1B70
HTS541060G9SA00 MB3OC60D
HTS541080G9SA00 MB4OC60D
HTS541010G9SA00 MBZOC60D
(the latter 3 being Hitachi Travelstar drives)
Yeah, I don't think we need to be too careful about blacklisting NCQ
considering the sorry state of many early NCQ firmwares. Please submit
a patch. It would be nice if you add a comment why the drives are added
for documentation.
Will do shortly. Eric, do you have any info on the blacklisting of that
Maxtor 7B250S0 drive? I would hope that Silicon Image would have a good
reason for blacklisting that one..
--
Robert Hancock Saskatoon, SK, Canada
To email, remove "nospam" from [email protected]
Home Page: http://www.roberthancock.com/
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
[Index of Archives]
[Kernel Newbies]
[Netfilter]
[Bugtraq]
[Photo]
[Stuff]
[Gimp]
[Yosemite News]
[MIPS Linux]
[ARM Linux]
[Linux Security]
[Linux RAID]
[Video 4 Linux]
[Linux for the blind]
[Linux Resources]