aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/ata
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/ata')
-rw-r--r--drivers/ata/ahci.c74
-rw-r--r--drivers/ata/libata-core.c18
2 files changed, 4 insertions, 88 deletions
diff --git a/drivers/ata/ahci.c b/drivers/ata/ahci.c
index cb7853b7335d..54f38c21dd95 100644
--- a/drivers/ata/ahci.c
+++ b/drivers/ata/ahci.c
@@ -1640,7 +1640,7 @@ static void ahci_port_intr(struct ata_port *ap)
1640 struct ahci_host_priv *hpriv = ap->host->private_data; 1640 struct ahci_host_priv *hpriv = ap->host->private_data;
1641 int resetting = !!(ap->pflags & ATA_PFLAG_RESETTING); 1641 int resetting = !!(ap->pflags & ATA_PFLAG_RESETTING);
1642 u32 status, qc_active; 1642 u32 status, qc_active;
1643 int rc, known_irq = 0; 1643 int rc;
1644 1644
1645 status = readl(port_mmio + PORT_IRQ_STAT); 1645 status = readl(port_mmio + PORT_IRQ_STAT);
1646 writel(status, port_mmio + PORT_IRQ_STAT); 1646 writel(status, port_mmio + PORT_IRQ_STAT);
@@ -1698,80 +1698,12 @@ static void ahci_port_intr(struct ata_port *ap)
1698 1698
1699 rc = ata_qc_complete_multiple(ap, qc_active, NULL); 1699 rc = ata_qc_complete_multiple(ap, qc_active, NULL);
1700 1700
1701 /* If resetting, spurious or invalid completions are expected, 1701 /* while resetting, invalid completions are expected */
1702 * return unconditionally. 1702 if (unlikely(rc < 0 && !resetting)) {
1703 */
1704 if (resetting)
1705 return;
1706
1707 if (rc > 0)
1708 return;
1709 if (rc < 0) {
1710 ehi->err_mask |= AC_ERR_HSM; 1703 ehi->err_mask |= AC_ERR_HSM;
1711 ehi->action |= ATA_EH_SOFTRESET; 1704 ehi->action |= ATA_EH_SOFTRESET;
1712 ata_port_freeze(ap); 1705 ata_port_freeze(ap);
1713 return;
1714 }
1715
1716 /* hmmm... a spurious interrupt */
1717
1718 /* if !NCQ, ignore. No modern ATA device has broken HSM
1719 * implementation for non-NCQ commands.
1720 */
1721 if (!ap->link.sactive)
1722 return;
1723
1724 if (status & PORT_IRQ_D2H_REG_FIS) {
1725 if (!pp->ncq_saw_d2h)
1726 ata_port_printk(ap, KERN_INFO,
1727 "D2H reg with I during NCQ, "
1728 "this message won't be printed again\n");
1729 pp->ncq_saw_d2h = 1;
1730 known_irq = 1;
1731 }
1732
1733 if (status & PORT_IRQ_DMAS_FIS) {
1734 if (!pp->ncq_saw_dmas)
1735 ata_port_printk(ap, KERN_INFO,
1736 "DMAS FIS during NCQ, "
1737 "this message won't be printed again\n");
1738 pp->ncq_saw_dmas = 1;
1739 known_irq = 1;
1740 } 1706 }
1741
1742 if (status & PORT_IRQ_SDB_FIS) {
1743 const __le32 *f = pp->rx_fis + RX_FIS_SDB;
1744
1745 if (le32_to_cpu(f[1])) {
1746 /* SDB FIS containing spurious completions
1747 * might be dangerous, whine and fail commands
1748 * with HSM violation. EH will turn off NCQ
1749 * after several such failures.
1750 */
1751 ata_ehi_push_desc(ehi,
1752 "spurious completions during NCQ "
1753 "issue=0x%x SAct=0x%x FIS=%08x:%08x",
1754 readl(port_mmio + PORT_CMD_ISSUE),
1755 readl(port_mmio + PORT_SCR_ACT),
1756 le32_to_cpu(f[0]), le32_to_cpu(f[1]));
1757 ehi->err_mask |= AC_ERR_HSM;
1758 ehi->action |= ATA_EH_SOFTRESET;
1759 ata_port_freeze(ap);
1760 } else {
1761 if (!pp->ncq_saw_sdb)
1762 ata_port_printk(ap, KERN_INFO,
1763 "spurious SDB FIS %08x:%08x during NCQ, "
1764 "this message won't be printed again\n",
1765 le32_to_cpu(f[0]), le32_to_cpu(f[1]));
1766 pp->ncq_saw_sdb = 1;
1767 }
1768 known_irq = 1;
1769 }
1770
1771 if (!known_irq)
1772 ata_port_printk(ap, KERN_INFO, "spurious interrupt "
1773 "(irq_stat 0x%x active_tag 0x%x sactive 0x%x)\n",
1774 status, ap->link.active_tag, ap->link.sactive);
1775} 1707}
1776 1708
1777static void ahci_irq_clear(struct ata_port *ap) 1709static void ahci_irq_clear(struct ata_port *ap)
diff --git a/drivers/ata/libata-core.c b/drivers/ata/libata-core.c
index b514a80f1370..e4dea8623a71 100644
--- a/drivers/ata/libata-core.c
+++ b/drivers/ata/libata-core.c
@@ -4140,6 +4140,7 @@ static const struct ata_blacklist_entry ata_device_blacklist [] = {
4140 /* Devices where NCQ should be avoided */ 4140 /* Devices where NCQ should be avoided */
4141 /* NCQ is slow */ 4141 /* NCQ is slow */
4142 { "WDC WD740ADFD-00", NULL, ATA_HORKAGE_NONCQ }, 4142 { "WDC WD740ADFD-00", NULL, ATA_HORKAGE_NONCQ },
4143 { "WDC WD740ADFD-00NLR1", NULL, ATA_HORKAGE_NONCQ, },
4143 /* http://thread.gmane.org/gmane.linux.ide/14907 */ 4144 /* http://thread.gmane.org/gmane.linux.ide/14907 */
4144 { "FUJITSU MHT2060BH", NULL, ATA_HORKAGE_NONCQ }, 4145 { "FUJITSU MHT2060BH", NULL, ATA_HORKAGE_NONCQ },
4145 /* NCQ is broken */ 4146 /* NCQ is broken */
@@ -4154,23 +4155,6 @@ static const struct ata_blacklist_entry ata_device_blacklist [] = {
4154 { "HTS541060G9SA00", "MB3OC60D", ATA_HORKAGE_NONCQ, }, 4155 { "HTS541060G9SA00", "MB3OC60D", ATA_HORKAGE_NONCQ, },
4155 { "HTS541080G9SA00", "MB4OC60D", ATA_HORKAGE_NONCQ, }, 4156 { "HTS541080G9SA00", "MB4OC60D", ATA_HORKAGE_NONCQ, },
4156 { "HTS541010G9SA00", "MBZOC60D", ATA_HORKAGE_NONCQ, }, 4157 { "HTS541010G9SA00", "MBZOC60D", ATA_HORKAGE_NONCQ, },
4157 /* Drives which do spurious command completion */
4158 { "HTS541680J9SA00", "SB2IC7EP", ATA_HORKAGE_NONCQ, },
4159 { "HTS541612J9SA00", "SBDIC7JP", ATA_HORKAGE_NONCQ, },
4160 { "HDT722516DLA380", "V43OA96A", ATA_HORKAGE_NONCQ, },
4161 { "Hitachi HTS541616J9SA00", "SB4OC70P", ATA_HORKAGE_NONCQ, },
4162 { "Hitachi HTS542525K9SA00", "BBFOC31P", ATA_HORKAGE_NONCQ, },
4163 { "WDC WD740ADFD-00NLR1", NULL, ATA_HORKAGE_NONCQ, },
4164 { "WDC WD3200AAJS-00RYA0", "12.01B01", ATA_HORKAGE_NONCQ, },
4165 { "FUJITSU MHV2080BH", "00840028", ATA_HORKAGE_NONCQ, },
4166 { "ST9120822AS", "3.CLF", ATA_HORKAGE_NONCQ, },
4167 { "ST9160821AS", "3.CLF", ATA_HORKAGE_NONCQ, },
4168 { "ST9160821AS", "3.ALD", ATA_HORKAGE_NONCQ, },
4169 { "ST9160821AS", "3.CCD", ATA_HORKAGE_NONCQ, },
4170 { "ST3160812AS", "3.ADJ", ATA_HORKAGE_NONCQ, },
4171 { "ST980813AS", "3.ADB", ATA_HORKAGE_NONCQ, },
4172 { "SAMSUNG HD401LJ", "ZZ100-15", ATA_HORKAGE_NONCQ, },
4173 { "Maxtor 7V300F0", "VA111900", ATA_HORKAGE_NONCQ, },
4174 4158
4175 /* devices which puke on READ_NATIVE_MAX */ 4159 /* devices which puke on READ_NATIVE_MAX */
4176 { "HDS724040KLSA80", "KFAOA20N", ATA_HORKAGE_BROKEN_HPA, }, 4160 { "HDS724040KLSA80", "KFAOA20N", ATA_HORKAGE_BROKEN_HPA, },