===== drivers/scsi/libata-core.c 1.57 vs edited ===== --- 1.57/drivers/scsi/libata-core.c Thu May 13 22:45:55 2004 +++ edited/drivers/scsi/libata-core.c Fri May 14 20:35:23 2004 @@ -1168,6 +1168,9 @@ if (ata_id_is_ata(dev)) /* sanity check */ goto err_out_nosup; + if (ata_id_use_dmadir(dev)) + dev->flags |= ATA_DFLAG_DMADIR; + /* see if 16-byte commands supported */ tmp = dev->id[0] & 0x3; if (tmp == 1) ===== drivers/scsi/libata-scsi.c 1.29 vs edited ===== --- 1.29/drivers/scsi/libata-scsi.c Thu May 13 22:39:12 2004 +++ edited/drivers/scsi/libata-scsi.c Fri May 14 20:36:28 2004 @@ -920,6 +920,9 @@ qc->flags |= ATA_QCFLAG_SG; /* data is present; dma-map it */ qc->tf.protocol = ATA_PROT_ATAPI_DMA; qc->tf.feature |= ATAPI_PKT_DMA; + if ((qc->dev->flags & ATA_DFLAG_DMADIR) && + (cmd->sc_data_direction != SCSI_DATA_WRITE)) + qc->tf.feature |= ATAPI_DMADIR; } return 0; ===== include/linux/ata.h 1.5 vs edited ===== --- 1.5/include/linux/ata.h Mon May 10 21:49:59 2004 +++ edited/include/linux/ata.h Fri May 14 20:34:17 2004 @@ -84,6 +84,8 @@ ATA_ERR = (1 << 0), /* have an error */ ATA_SRST = (1 << 2), /* software reset */ ATA_ABORTED = (1 << 2), /* command aborted */ + ATAPI_DMADIR = (1 << 2), /* ATAPI data dir: + 0=to device, 1=to host */ /* ATA command block registers */ ATA_REG_DATA = 0x00, @@ -203,6 +205,7 @@ #define ata_id_has_wcache(dev) ((dev)->id[82] & (1 << 5)) #define ata_id_has_lba(dev) ((dev)->id[49] & (1 << 8)) #define ata_id_has_dma(dev) ((dev)->id[49] & (1 << 9)) +#define ata_id_use_dmadir(dev) ((dev)->id[62] & (1 << 15)) #define ata_id_u32(dev,n) \ (((u32) (dev)->id[(n) + 1] << 16) | ((u32) (dev)->id[(n)])) #define ata_id_u64(dev,n) \ ===== include/linux/libata.h 1.29 vs edited ===== --- 1.29/include/linux/libata.h Thu May 13 22:45:55 2004 +++ edited/include/linux/libata.h Fri May 14 20:28:37 2004 @@ -90,6 +90,7 @@ ATA_DFLAG_MASTER = (1 << 2), /* is device 0? */ ATA_DFLAG_WCACHE = (1 << 3), /* has write cache we can * (hopefully) flush? */ + ATA_DFLAG_DMADIR = (1 << 4), /* use DMADIR bit in ATAPI */ ATA_DEV_UNKNOWN = 0, /* unknown device */ ATA_DEV_ATA = 1, /* ATA device */