]> err.no Git - linux-2.6/commit
libata: automatically use DMADIR if drive/bridge requires it
authorTejun Heo <htejun@gmail.com>
Thu, 21 Feb 2008 04:25:50 +0000 (13:25 +0900)
committerJeff Garzik <jeff@garzik.org>
Sun, 24 Feb 2008 05:27:33 +0000 (00:27 -0500)
commit9116300634c5c76cfcd0d2af689846e04d172256
treedfc527d28af35f19dcb9c4092757d6eabb8afb1d
parent559bbe6cbd0d8c68d40076a5f7dc98e3bf5864b2
libata: automatically use DMADIR if drive/bridge requires it

Back in 2.6.17-rc2, a libata module parameter was added for atapi_dmadir.

That's nice, but most SATA devices which need it will tell us about it
in their IDENTIFY PACKET response, as bit-15 of word-62 of the
returned data (as per ATA7, ATA8 specifications).

So for those which specify it, we should automatically use the DMADIR bit.
Otherwise, disc writing will fail by default on many SATA-ATAPI drives.

This patch adds ATA_DFLAG_DMADIR and make ata_dev_configure() set it
if atapi_dmadir is set or identify data indicates DMADIR is necessary.
atapi_xlat() is converted to check ATA_DFLAG_DMADIR before setting
DMADIR.

Original patch is from Mark Lord.

Signed-off-by: Tejun Heo <htejun@gmail.com>
Cc: Mark Lord <mlord@pobox.com>
Signed-off-by: Jeff Garzik <jeff@garzik.org>
drivers/ata/libata-core.c
drivers/ata/libata-scsi.c
include/linux/ata.h
include/linux/libata.h