提交 fc16c25f 编写于 作者: J Jeff Garzik

[libata] ACPI: remove needless ->qc_issue hook existence test

All drivers must implement this hook, otherwise ATA commands would go
nowhere (and a lot of other oopsen would appear as well).
Signed-off-by: NJeff Garzik <jeff@garzik.org>
上级 ea34e45a
...@@ -455,6 +455,9 @@ static void taskfile_load_raw(struct ata_port *ap, ...@@ -455,6 +455,9 @@ static void taskfile_load_raw(struct ata_port *ap,
struct ata_device *atadev, struct ata_device *atadev,
const struct taskfile_array *gtf) const struct taskfile_array *gtf)
{ {
struct ata_taskfile tf;
unsigned int err;
if (ata_msg_probe(ap)) if (ata_msg_probe(ap))
ata_dev_printk(atadev, KERN_DEBUG, "%s: (0x1f1-1f7): hex: " ata_dev_printk(atadev, KERN_DEBUG, "%s: (0x1f1-1f7): hex: "
"%02x %02x %02x %02x %02x %02x %02x\n", "%02x %02x %02x %02x %02x %02x %02x\n",
...@@ -467,35 +470,25 @@ static void taskfile_load_raw(struct ata_port *ap, ...@@ -467,35 +470,25 @@ static void taskfile_load_raw(struct ata_port *ap,
&& (gtf->tfa[6] == 0)) && (gtf->tfa[6] == 0))
return; return;
if (ap->ops->qc_issue) { ata_tf_init(atadev, &tf);
struct ata_taskfile tf;
unsigned int err; /* convert gtf to tf */
tf.flags |= ATA_TFLAG_ISADDR | ATA_TFLAG_DEVICE; /* TBD */
ata_tf_init(atadev, &tf); tf.protocol = atadev->class == ATA_DEV_ATAPI ?
ATA_PROT_ATAPI_NODATA : ATA_PROT_NODATA;
/* convert gtf to tf */ tf.feature = gtf->tfa[0]; /* 0x1f1 */
tf.flags |= ATA_TFLAG_ISADDR | ATA_TFLAG_DEVICE; /* TBD */ tf.nsect = gtf->tfa[1]; /* 0x1f2 */
tf.protocol = atadev->class == ATA_DEV_ATAPI ? tf.lbal = gtf->tfa[2]; /* 0x1f3 */
ATA_PROT_ATAPI_NODATA : ATA_PROT_NODATA; tf.lbam = gtf->tfa[3]; /* 0x1f4 */
tf.feature = gtf->tfa[0]; /* 0x1f1 */ tf.lbah = gtf->tfa[4]; /* 0x1f5 */
tf.nsect = gtf->tfa[1]; /* 0x1f2 */ tf.device = gtf->tfa[5]; /* 0x1f6 */
tf.lbal = gtf->tfa[2]; /* 0x1f3 */ tf.command = gtf->tfa[6]; /* 0x1f7 */
tf.lbam = gtf->tfa[3]; /* 0x1f4 */
tf.lbah = gtf->tfa[4]; /* 0x1f5 */ err = ata_exec_internal(atadev, &tf, NULL, DMA_NONE, NULL, 0);
tf.device = gtf->tfa[5]; /* 0x1f6 */ if (err && ata_msg_probe(ap))
tf.command = gtf->tfa[6]; /* 0x1f7 */ ata_dev_printk(atadev, KERN_ERR,
"%s: ata_exec_internal failed: %u\n",
err = ata_exec_internal(atadev, &tf, NULL, DMA_NONE, NULL, 0); __FUNCTION__, err);
if (err && ata_msg_probe(ap))
ata_dev_printk(atadev, KERN_ERR,
"%s: ata_exec_internal failed: %u\n",
__FUNCTION__, err);
} else
if (ata_msg_warn(ap))
ata_dev_printk(atadev, KERN_WARNING,
"%s: SATA driver is missing qc_issue function"
" entry points\n",
__FUNCTION__);
} }
/** /**
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册