aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/scsi/libata-core.c18
-rw-r--r--drivers/scsi/libata-scsi.c11
-rw-r--r--drivers/scsi/sata_sil.c19
3 files changed, 13 insertions, 35 deletions
diff --git a/drivers/scsi/libata-core.c b/drivers/scsi/libata-core.c
index 7e410299d67a..1d65f703348e 100644
--- a/drivers/scsi/libata-core.c
+++ b/drivers/scsi/libata-core.c
@@ -2301,24 +2301,14 @@ static const char * const ata_dma_blacklist [] = {
2301 2301
2302static int ata_dma_blacklisted(const struct ata_device *dev) 2302static int ata_dma_blacklisted(const struct ata_device *dev)
2303{ 2303{
2304 unsigned char model_num[40]; 2304 unsigned char model_num[41];
2305 char *s;
2306 unsigned int len;
2307 int i; 2305 int i;
2308 2306
2309 ata_dev_id_string(dev->id, model_num, ATA_ID_PROD_OFS, 2307 ata_dev_id_c_string(dev->id, model_num, ATA_ID_PROD_OFS,
2310 sizeof(model_num)); 2308 sizeof(model_num));
2311 s = &model_num[0];
2312 len = strnlen(s, sizeof(model_num));
2313
2314 /* ATAPI specifies that empty space is blank-filled; remove blanks */
2315 while ((len > 0) && (s[len - 1] == ' ')) {
2316 len--;
2317 s[len] = 0;
2318 }
2319 2309
2320 for (i = 0; i < ARRAY_SIZE(ata_dma_blacklist); i++) 2310 for (i = 0; i < ARRAY_SIZE(ata_dma_blacklist); i++)
2321 if (!strncmp(ata_dma_blacklist[i], s, len)) 2311 if (!strcmp(ata_dma_blacklist[i], model_num))
2322 return 1; 2312 return 1;
2323 2313
2324 return 0; 2314 return 0;
diff --git a/drivers/scsi/libata-scsi.c b/drivers/scsi/libata-scsi.c
index 26f07a2617f9..ebd7cf42550b 100644
--- a/drivers/scsi/libata-scsi.c
+++ b/drivers/scsi/libata-scsi.c
@@ -1806,15 +1806,12 @@ static int ata_dev_supports_fua(u16 *id)
1806 if (!ata_id_has_fua(id)) 1806 if (!ata_id_has_fua(id))
1807 return 0; 1807 return 0;
1808 1808
1809 model[40] = '\0'; 1809 ata_dev_id_c_string(id, model, ATA_ID_PROD_OFS, sizeof(model));
1810 fw[8] = '\0'; 1810 ata_dev_id_c_string(id, fw, ATA_ID_FW_REV_OFS, sizeof(fw));
1811 1811
1812 ata_dev_id_string(id, model, ATA_ID_PROD_OFS, sizeof(model) - 1); 1812 if (strcmp(model, "Maxtor"))
1813 ata_dev_id_string(id, fw, ATA_ID_FW_REV_OFS, sizeof(fw) - 1);
1814
1815 if (strncmp(model, "Maxtor", 6))
1816 return 1; 1813 return 1;
1817 if (strncmp(fw, "BANC1G10", 8)) 1814 if (strcmp(fw, "BANC1G10"))
1818 return 1; 1815 return 1;
1819 1816
1820 return 0; /* blacklisted */ 1817 return 0; /* blacklisted */
diff --git a/drivers/scsi/sata_sil.c b/drivers/scsi/sata_sil.c
index bd2887741d78..61c4ac7ff9db 100644
--- a/drivers/scsi/sata_sil.c
+++ b/drivers/scsi/sata_sil.c
@@ -337,22 +337,13 @@ static void sil_scr_write (struct ata_port *ap, unsigned int sc_reg, u32 val)
337static void sil_dev_config(struct ata_port *ap, struct ata_device *dev) 337static void sil_dev_config(struct ata_port *ap, struct ata_device *dev)
338{ 338{
339 unsigned int n, quirks = 0; 339 unsigned int n, quirks = 0;
340 unsigned char model_num[40]; 340 unsigned char model_num[41];
341 const char *s;
342 unsigned int len;
343 341
344 ata_dev_id_string(dev->id, model_num, ATA_ID_PROD_OFS, 342 ata_dev_id_c_string(dev->id, model_num, ATA_ID_PROD_OFS,
345 sizeof(model_num)); 343 sizeof(model_num));
346 s = &model_num[0];
347 len = strnlen(s, sizeof(model_num));
348
349 /* ATAPI specifies that empty space is blank-filled; remove blanks */
350 while ((len > 0) && (s[len - 1] == ' '))
351 len--;
352 344
353 for (n = 0; sil_blacklist[n].product; n++) 345 for (n = 0; sil_blacklist[n].product; n++)
354 if (!memcmp(sil_blacklist[n].product, s, 346 if (!strcmp(sil_blacklist[n].product, model_num)) {
355 strlen(sil_blacklist[n].product))) {
356 quirks = sil_blacklist[n].quirk; 347 quirks = sil_blacklist[n].quirk;
357 break; 348 break;
358 } 349 }
@@ -372,7 +363,7 @@ static void sil_dev_config(struct ata_port *ap, struct ata_device *dev)
372 /* limit to udma5 */ 363 /* limit to udma5 */
373 if (quirks & SIL_QUIRK_UDMA5MAX) { 364 if (quirks & SIL_QUIRK_UDMA5MAX) {
374 printk(KERN_INFO "ata%u(%u): applying Maxtor errata fix %s\n", 365 printk(KERN_INFO "ata%u(%u): applying Maxtor errata fix %s\n",
375 ap->id, dev->devno, s); 366 ap->id, dev->devno, model_num);
376 ap->udma_mask &= ATA_UDMA5; 367 ap->udma_mask &= ATA_UDMA5;
377 return; 368 return;
378 } 369 }