|
|
@@ -2478,6 +2478,10 @@ int ata_dev_configure(struct ata_device *dev)
|
|
|
dev->max_sectors = min_t(unsigned int, ATA_MAX_SECTORS_128,
|
|
|
dev->max_sectors);
|
|
|
|
|
|
+ if (dev->horkage & ATA_HORKAGE_MAX_SEC_1024)
|
|
|
+ dev->max_sectors = min_t(unsigned int, ATA_MAX_SECTORS_1024,
|
|
|
+ dev->max_sectors);
|
|
|
+
|
|
|
if (dev->horkage & ATA_HORKAGE_MAX_SEC_LBA48)
|
|
|
dev->max_sectors = ATA_MAX_SECTORS_LBA48;
|
|
|
|
|
|
@@ -4146,6 +4150,12 @@ static const struct ata_blacklist_entry ata_device_blacklist [] = {
|
|
|
{ "Slimtype DVD A DS8A8SH", NULL, ATA_HORKAGE_MAX_SEC_LBA48 },
|
|
|
{ "Slimtype DVD A DS8A9SH", NULL, ATA_HORKAGE_MAX_SEC_LBA48 },
|
|
|
|
|
|
+ /*
|
|
|
+ * Causes silent data corruption with higher max sects.
|
|
|
+ * http://lkml.kernel.org/g/x49wpy40ysk.fsf@segfault.boston.devel.redhat.com
|
|
|
+ */
|
|
|
+ { "ST380013AS", "3.20", ATA_HORKAGE_MAX_SEC_1024 },
|
|
|
+
|
|
|
/* Devices we expect to fail diagnostics */
|
|
|
|
|
|
/* Devices where NCQ should be avoided */
|
|
|
@@ -4174,9 +4184,10 @@ static const struct ata_blacklist_entry ata_device_blacklist [] = {
|
|
|
{ "ST3320[68]13AS", "SD1[5-9]", ATA_HORKAGE_NONCQ |
|
|
|
ATA_HORKAGE_FIRMWARE_WARN },
|
|
|
|
|
|
- /* Seagate Momentus SpinPoint M8 seem to have FPMDA_AA issues */
|
|
|
+ /* drives which fail FPDMA_AA activation (some may freeze afterwards) */
|
|
|
{ "ST1000LM024 HN-M101MBB", "2AR10001", ATA_HORKAGE_BROKEN_FPDMA_AA },
|
|
|
{ "ST1000LM024 HN-M101MBB", "2BA30001", ATA_HORKAGE_BROKEN_FPDMA_AA },
|
|
|
+ { "VB0250EAVER", "HPG7", ATA_HORKAGE_BROKEN_FPDMA_AA },
|
|
|
|
|
|
/* Blacklist entries taken from Silicon Image 3124/3132
|
|
|
Windows driver .inf file - also several Linux problem reports */
|
|
|
@@ -4229,7 +4240,7 @@ static const struct ata_blacklist_entry ata_device_blacklist [] = {
|
|
|
ATA_HORKAGE_ZERO_AFTER_TRIM, },
|
|
|
{ "Crucial_CT*M500*", NULL, ATA_HORKAGE_NO_NCQ_TRIM |
|
|
|
ATA_HORKAGE_ZERO_AFTER_TRIM, },
|
|
|
- { "Micron_M5[15]0*", "MU01", ATA_HORKAGE_NO_NCQ_TRIM |
|
|
|
+ { "Micron_M5[15]0_*", "MU01", ATA_HORKAGE_NO_NCQ_TRIM |
|
|
|
ATA_HORKAGE_ZERO_AFTER_TRIM, },
|
|
|
{ "Crucial_CT*M550*", "MU01", ATA_HORKAGE_NO_NCQ_TRIM |
|
|
|
ATA_HORKAGE_ZERO_AFTER_TRIM, },
|
|
|
@@ -4238,6 +4249,9 @@ static const struct ata_blacklist_entry ata_device_blacklist [] = {
|
|
|
{ "Samsung SSD 8*", NULL, ATA_HORKAGE_NO_NCQ_TRIM |
|
|
|
ATA_HORKAGE_ZERO_AFTER_TRIM, },
|
|
|
|
|
|
+ /* devices that don't properly handle TRIM commands */
|
|
|
+ { "SuperSSpeed S238*", NULL, ATA_HORKAGE_NOTRIM, },
|
|
|
+
|
|
|
/*
|
|
|
* As defined, the DRAT (Deterministic Read After Trim) and RZAT
|
|
|
* (Return Zero After Trim) flags in the ATA Command Set are
|
|
|
@@ -4501,7 +4515,8 @@ static unsigned int ata_dev_set_xfermode(struct ata_device *dev)
|
|
|
else /* In the ancient relic department - skip all of this */
|
|
|
return 0;
|
|
|
|
|
|
- err_mask = ata_exec_internal(dev, &tf, NULL, DMA_NONE, NULL, 0, 0);
|
|
|
+ /* On some disks, this command causes spin-up, so we need longer timeout */
|
|
|
+ err_mask = ata_exec_internal(dev, &tf, NULL, DMA_NONE, NULL, 0, 15000);
|
|
|
|
|
|
DPRINTK("EXIT, err_mask=%x\n", err_mask);
|
|
|
return err_mask;
|