diff options
Diffstat (limited to 'drivers/scsi')
-rw-r--r-- | drivers/scsi/ahci.c | 4 | ||||
-rw-r--r-- | drivers/scsi/ata_piix.c | 4 | ||||
-rw-r--r-- | drivers/scsi/libata-core.c | 148 | ||||
-rw-r--r-- | drivers/scsi/libata-scsi.c | 33 | ||||
-rw-r--r-- | drivers/scsi/pdc_adma.c | 1 | ||||
-rw-r--r-- | drivers/scsi/sata_mv.c | 1 | ||||
-rw-r--r-- | drivers/scsi/sata_nv.c | 1 | ||||
-rw-r--r-- | drivers/scsi/sata_promise.c | 1 | ||||
-rw-r--r-- | drivers/scsi/sata_qstor.c | 1 | ||||
-rw-r--r-- | drivers/scsi/sata_sil.c | 24 | ||||
-rw-r--r-- | drivers/scsi/sata_sil24.c | 5 | ||||
-rw-r--r-- | drivers/scsi/sata_sis.c | 1 | ||||
-rw-r--r-- | drivers/scsi/sata_svw.c | 1 | ||||
-rw-r--r-- | drivers/scsi/sata_sx4.c | 1 | ||||
-rw-r--r-- | drivers/scsi/sata_uli.c | 1 | ||||
-rw-r--r-- | drivers/scsi/sata_via.c | 1 | ||||
-rw-r--r-- | drivers/scsi/sata_vsc.c | 1 |
17 files changed, 115 insertions, 114 deletions
diff --git a/drivers/scsi/ahci.c b/drivers/scsi/ahci.c index 24a54a5a91b8..1c2ab3dede71 100644 --- a/drivers/scsi/ahci.c +++ b/drivers/scsi/ahci.c | |||
@@ -211,7 +211,6 @@ static struct scsi_host_template ahci_sht = { | |||
211 | .can_queue = ATA_DEF_QUEUE, | 211 | .can_queue = ATA_DEF_QUEUE, |
212 | .this_id = ATA_SHT_THIS_ID, | 212 | .this_id = ATA_SHT_THIS_ID, |
213 | .sg_tablesize = AHCI_MAX_SG, | 213 | .sg_tablesize = AHCI_MAX_SG, |
214 | .max_sectors = ATA_MAX_SECTORS, | ||
215 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, | 214 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, |
216 | .emulated = ATA_SHT_EMULATED, | 215 | .emulated = ATA_SHT_EMULATED, |
217 | .use_clustering = AHCI_USE_CLUSTERING, | 216 | .use_clustering = AHCI_USE_CLUSTERING, |
@@ -617,7 +616,8 @@ static void ahci_qc_prep(struct ata_queued_cmd *qc) | |||
617 | ata_tf_to_fis(&qc->tf, pp->cmd_tbl, 0); | 616 | ata_tf_to_fis(&qc->tf, pp->cmd_tbl, 0); |
618 | if (is_atapi) { | 617 | if (is_atapi) { |
619 | memset(pp->cmd_tbl + AHCI_CMD_TBL_CDB, 0, 32); | 618 | memset(pp->cmd_tbl + AHCI_CMD_TBL_CDB, 0, 32); |
620 | memcpy(pp->cmd_tbl + AHCI_CMD_TBL_CDB, qc->cdb, ap->cdb_len); | 619 | memcpy(pp->cmd_tbl + AHCI_CMD_TBL_CDB, qc->cdb, |
620 | qc->dev->cdb_len); | ||
621 | } | 621 | } |
622 | 622 | ||
623 | n_elem = 0; | 623 | n_elem = 0; |
diff --git a/drivers/scsi/ata_piix.c b/drivers/scsi/ata_piix.c index 4933ba284885..4cc1108f721a 100644 --- a/drivers/scsi/ata_piix.c +++ b/drivers/scsi/ata_piix.c | |||
@@ -185,7 +185,6 @@ static struct scsi_host_template piix_sht = { | |||
185 | .can_queue = ATA_DEF_QUEUE, | 185 | .can_queue = ATA_DEF_QUEUE, |
186 | .this_id = ATA_SHT_THIS_ID, | 186 | .this_id = ATA_SHT_THIS_ID, |
187 | .sg_tablesize = LIBATA_MAX_PRD, | 187 | .sg_tablesize = LIBATA_MAX_PRD, |
188 | .max_sectors = ATA_MAX_SECTORS, | ||
189 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, | 188 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, |
190 | .emulated = ATA_SHT_EMULATED, | 189 | .emulated = ATA_SHT_EMULATED, |
191 | .use_clustering = ATA_SHT_USE_CLUSTERING, | 190 | .use_clustering = ATA_SHT_USE_CLUSTERING, |
@@ -415,9 +414,6 @@ static int piix_sata_probe (struct ata_port *ap) | |||
415 | int orig_mask, mask, i; | 414 | int orig_mask, mask, i; |
416 | u8 pcs; | 415 | u8 pcs; |
417 | 416 | ||
418 | mask = (PIIX_PORT_PRESENT << ap->hard_port_no) | | ||
419 | (PIIX_PORT_ENABLED << ap->hard_port_no); | ||
420 | |||
421 | pci_read_config_byte(pdev, ICH5_PCS, &pcs); | 417 | pci_read_config_byte(pdev, ICH5_PCS, &pcs); |
422 | orig_mask = (int) pcs & 0xff; | 418 | orig_mask = (int) pcs & 0xff; |
423 | 419 | ||
diff --git a/drivers/scsi/libata-core.c b/drivers/scsi/libata-core.c index bfe0a00b1135..5ab220e9907c 100644 --- a/drivers/scsi/libata-core.c +++ b/drivers/scsi/libata-core.c | |||
@@ -520,6 +520,49 @@ void ata_dev_id_string(const u16 *id, unsigned char *s, | |||
520 | } | 520 | } |
521 | } | 521 | } |
522 | 522 | ||
523 | /** | ||
524 | * ata_dev_id_c_string - Convert IDENTIFY DEVICE page into C string | ||
525 | * @id: IDENTIFY DEVICE results we will examine | ||
526 | * @s: string into which data is output | ||
527 | * @ofs: offset into identify device page | ||
528 | * @len: length of string to return. must be an odd number. | ||
529 | * | ||
530 | * This function is identical to ata_dev_id_string except that it | ||
531 | * trims trailing spaces and terminates the resulting string with | ||
532 | * null. @len must be actual maximum length (even number) + 1. | ||
533 | * | ||
534 | * LOCKING: | ||
535 | * caller. | ||
536 | */ | ||
537 | void ata_dev_id_c_string(const u16 *id, unsigned char *s, | ||
538 | unsigned int ofs, unsigned int len) | ||
539 | { | ||
540 | unsigned char *p; | ||
541 | |||
542 | WARN_ON(!(len & 1)); | ||
543 | |||
544 | ata_dev_id_string(id, s, ofs, len - 1); | ||
545 | |||
546 | p = s + strnlen(s, len - 1); | ||
547 | while (p > s && p[-1] == ' ') | ||
548 | p--; | ||
549 | *p = '\0'; | ||
550 | } | ||
551 | |||
552 | static u64 ata_id_n_sectors(const u16 *id) | ||
553 | { | ||
554 | if (ata_id_has_lba(id)) { | ||
555 | if (ata_id_has_lba48(id)) | ||
556 | return ata_id_u64(id, 100); | ||
557 | else | ||
558 | return ata_id_u32(id, 60); | ||
559 | } else { | ||
560 | if (ata_id_current_chs_valid(id)) | ||
561 | return ata_id_u32(id, 57); | ||
562 | else | ||
563 | return id[1] * id[3] * id[6]; | ||
564 | } | ||
565 | } | ||
523 | 566 | ||
524 | /** | 567 | /** |
525 | * ata_noop_dev_select - Select device 0/1 on ATA bus | 568 | * ata_noop_dev_select - Select device 0/1 on ATA bus |
@@ -609,41 +652,41 @@ void ata_dev_select(struct ata_port *ap, unsigned int device, | |||
609 | 652 | ||
610 | /** | 653 | /** |
611 | * ata_dump_id - IDENTIFY DEVICE info debugging output | 654 | * ata_dump_id - IDENTIFY DEVICE info debugging output |
612 | * @dev: Device whose IDENTIFY DEVICE page we will dump | 655 | * @id: IDENTIFY DEVICE page to dump |
613 | * | 656 | * |
614 | * Dump selected 16-bit words from a detected device's | 657 | * Dump selected 16-bit words from the given IDENTIFY DEVICE |
615 | * IDENTIFY PAGE page. | 658 | * page. |
616 | * | 659 | * |
617 | * LOCKING: | 660 | * LOCKING: |
618 | * caller. | 661 | * caller. |
619 | */ | 662 | */ |
620 | 663 | ||
621 | static inline void ata_dump_id(const struct ata_device *dev) | 664 | static inline void ata_dump_id(const u16 *id) |
622 | { | 665 | { |
623 | DPRINTK("49==0x%04x " | 666 | DPRINTK("49==0x%04x " |
624 | "53==0x%04x " | 667 | "53==0x%04x " |
625 | "63==0x%04x " | 668 | "63==0x%04x " |
626 | "64==0x%04x " | 669 | "64==0x%04x " |
627 | "75==0x%04x \n", | 670 | "75==0x%04x \n", |
628 | dev->id[49], | 671 | id[49], |
629 | dev->id[53], | 672 | id[53], |
630 | dev->id[63], | 673 | id[63], |
631 | dev->id[64], | 674 | id[64], |
632 | dev->id[75]); | 675 | id[75]); |
633 | DPRINTK("80==0x%04x " | 676 | DPRINTK("80==0x%04x " |
634 | "81==0x%04x " | 677 | "81==0x%04x " |
635 | "82==0x%04x " | 678 | "82==0x%04x " |
636 | "83==0x%04x " | 679 | "83==0x%04x " |
637 | "84==0x%04x \n", | 680 | "84==0x%04x \n", |
638 | dev->id[80], | 681 | id[80], |
639 | dev->id[81], | 682 | id[81], |
640 | dev->id[82], | 683 | id[82], |
641 | dev->id[83], | 684 | id[83], |
642 | dev->id[84]); | 685 | id[84]); |
643 | DPRINTK("88==0x%04x " | 686 | DPRINTK("88==0x%04x " |
644 | "93==0x%04x\n", | 687 | "93==0x%04x\n", |
645 | dev->id[88], | 688 | id[88], |
646 | dev->id[93]); | 689 | id[93]); |
647 | } | 690 | } |
648 | 691 | ||
649 | /* | 692 | /* |
@@ -877,12 +920,11 @@ static void ata_dev_identify(struct ata_port *ap, unsigned int device) | |||
877 | { | 920 | { |
878 | struct ata_device *dev = &ap->device[device]; | 921 | struct ata_device *dev = &ap->device[device]; |
879 | unsigned int major_version; | 922 | unsigned int major_version; |
880 | u16 tmp; | ||
881 | unsigned long xfer_modes; | 923 | unsigned long xfer_modes; |
882 | unsigned int using_edd; | 924 | unsigned int using_edd; |
883 | struct ata_taskfile tf; | 925 | struct ata_taskfile tf; |
884 | unsigned int err_mask; | 926 | unsigned int err_mask; |
885 | int rc; | 927 | int i, rc; |
886 | 928 | ||
887 | if (!ata_dev_present(dev)) { | 929 | if (!ata_dev_present(dev)) { |
888 | DPRINTK("ENTER/EXIT (host %u, dev %u) -- nodev\n", | 930 | DPRINTK("ENTER/EXIT (host %u, dev %u) -- nodev\n", |
@@ -890,7 +932,8 @@ static void ata_dev_identify(struct ata_port *ap, unsigned int device) | |||
890 | return; | 932 | return; |
891 | } | 933 | } |
892 | 934 | ||
893 | if (ap->flags & (ATA_FLAG_SRST | ATA_FLAG_SATA_RESET)) | 935 | if (ap->ops->probe_reset || |
936 | ap->flags & (ATA_FLAG_SRST | ATA_FLAG_SATA_RESET)) | ||
894 | using_edd = 0; | 937 | using_edd = 0; |
895 | else | 938 | else |
896 | using_edd = 1; | 939 | using_edd = 1; |
@@ -970,18 +1013,17 @@ retry: | |||
970 | if (!xfer_modes) | 1013 | if (!xfer_modes) |
971 | xfer_modes = ata_pio_modes(dev); | 1014 | xfer_modes = ata_pio_modes(dev); |
972 | 1015 | ||
973 | ata_dump_id(dev); | 1016 | ata_dump_id(dev->id); |
974 | 1017 | ||
975 | /* ATA-specific feature tests */ | 1018 | /* ATA-specific feature tests */ |
976 | if (dev->class == ATA_DEV_ATA) { | 1019 | if (dev->class == ATA_DEV_ATA) { |
1020 | dev->n_sectors = ata_id_n_sectors(dev->id); | ||
1021 | |||
977 | if (!ata_id_is_ata(dev->id)) /* sanity check */ | 1022 | if (!ata_id_is_ata(dev->id)) /* sanity check */ |
978 | goto err_out_nosup; | 1023 | goto err_out_nosup; |
979 | 1024 | ||
980 | /* get major version */ | 1025 | /* get major version */ |
981 | tmp = dev->id[ATA_ID_MAJOR_VER]; | 1026 | major_version = ata_id_major_version(dev->id); |
982 | for (major_version = 14; major_version >= 1; major_version--) | ||
983 | if (tmp & (1 << major_version)) | ||
984 | break; | ||
985 | 1027 | ||
986 | /* | 1028 | /* |
987 | * The exact sequence expected by certain pre-ATA4 drives is: | 1029 | * The exact sequence expected by certain pre-ATA4 drives is: |
@@ -1003,12 +1045,8 @@ retry: | |||
1003 | if (ata_id_has_lba(dev->id)) { | 1045 | if (ata_id_has_lba(dev->id)) { |
1004 | dev->flags |= ATA_DFLAG_LBA; | 1046 | dev->flags |= ATA_DFLAG_LBA; |
1005 | 1047 | ||
1006 | if (ata_id_has_lba48(dev->id)) { | 1048 | if (ata_id_has_lba48(dev->id)) |
1007 | dev->flags |= ATA_DFLAG_LBA48; | 1049 | dev->flags |= ATA_DFLAG_LBA48; |
1008 | dev->n_sectors = ata_id_u64(dev->id, 100); | ||
1009 | } else { | ||
1010 | dev->n_sectors = ata_id_u32(dev->id, 60); | ||
1011 | } | ||
1012 | 1050 | ||
1013 | /* print device info to dmesg */ | 1051 | /* print device info to dmesg */ |
1014 | printk(KERN_INFO "ata%u: dev %u ATA-%d, max %s, %Lu sectors:%s\n", | 1052 | printk(KERN_INFO "ata%u: dev %u ATA-%d, max %s, %Lu sectors:%s\n", |
@@ -1024,15 +1062,12 @@ retry: | |||
1024 | dev->cylinders = dev->id[1]; | 1062 | dev->cylinders = dev->id[1]; |
1025 | dev->heads = dev->id[3]; | 1063 | dev->heads = dev->id[3]; |
1026 | dev->sectors = dev->id[6]; | 1064 | dev->sectors = dev->id[6]; |
1027 | dev->n_sectors = dev->cylinders * dev->heads * dev->sectors; | ||
1028 | 1065 | ||
1029 | if (ata_id_current_chs_valid(dev->id)) { | 1066 | if (ata_id_current_chs_valid(dev->id)) { |
1030 | /* Current CHS translation is valid. */ | 1067 | /* Current CHS translation is valid. */ |
1031 | dev->cylinders = dev->id[54]; | 1068 | dev->cylinders = dev->id[54]; |
1032 | dev->heads = dev->id[55]; | 1069 | dev->heads = dev->id[55]; |
1033 | dev->sectors = dev->id[56]; | 1070 | dev->sectors = dev->id[56]; |
1034 | |||
1035 | dev->n_sectors = ata_id_u32(dev->id, 57); | ||
1036 | } | 1071 | } |
1037 | 1072 | ||
1038 | /* print device info to dmesg */ | 1073 | /* print device info to dmesg */ |
@@ -1051,7 +1086,6 @@ retry: | |||
1051 | ap->id, device, dev->multi_count); | 1086 | ap->id, device, dev->multi_count); |
1052 | } | 1087 | } |
1053 | 1088 | ||
1054 | ap->host->max_cmd_len = 16; | ||
1055 | } | 1089 | } |
1056 | 1090 | ||
1057 | /* ATAPI-specific feature tests */ | 1091 | /* ATAPI-specific feature tests */ |
@@ -1064,8 +1098,7 @@ retry: | |||
1064 | printk(KERN_WARNING "ata%u: unsupported CDB len\n", ap->id); | 1098 | printk(KERN_WARNING "ata%u: unsupported CDB len\n", ap->id); |
1065 | goto err_out_nosup; | 1099 | goto err_out_nosup; |
1066 | } | 1100 | } |
1067 | ap->cdb_len = (unsigned int) rc; | 1101 | dev->cdb_len = (unsigned int) rc; |
1068 | ap->host->max_cmd_len = (unsigned char) ap->cdb_len; | ||
1069 | 1102 | ||
1070 | if (ata_id_cdb_intr(dev->id)) | 1103 | if (ata_id_cdb_intr(dev->id)) |
1071 | dev->flags |= ATA_DFLAG_CDB_INTR; | 1104 | dev->flags |= ATA_DFLAG_CDB_INTR; |
@@ -1076,6 +1109,12 @@ retry: | |||
1076 | ata_mode_string(xfer_modes)); | 1109 | ata_mode_string(xfer_modes)); |
1077 | } | 1110 | } |
1078 | 1111 | ||
1112 | ap->host->max_cmd_len = 0; | ||
1113 | for (i = 0; i < ATA_MAX_DEVICES; i++) | ||
1114 | ap->host->max_cmd_len = max_t(unsigned int, | ||
1115 | ap->host->max_cmd_len, | ||
1116 | ap->device[i].cdb_len); | ||
1117 | |||
1079 | DPRINTK("EXIT, drv_stat = 0x%x\n", ata_chk_status(ap)); | 1118 | DPRINTK("EXIT, drv_stat = 0x%x\n", ata_chk_status(ap)); |
1080 | return; | 1119 | return; |
1081 | 1120 | ||
@@ -1088,9 +1127,10 @@ err_out: | |||
1088 | } | 1127 | } |
1089 | 1128 | ||
1090 | 1129 | ||
1091 | static inline u8 ata_dev_knobble(const struct ata_port *ap) | 1130 | static inline u8 ata_dev_knobble(const struct ata_port *ap, |
1131 | struct ata_device *dev) | ||
1092 | { | 1132 | { |
1093 | return ((ap->cbl == ATA_CBL_SATA) && (!ata_id_is_sata(ap->device->id))); | 1133 | return ((ap->cbl == ATA_CBL_SATA) && (!ata_id_is_sata(dev->id))); |
1094 | } | 1134 | } |
1095 | 1135 | ||
1096 | /** | 1136 | /** |
@@ -1104,13 +1144,11 @@ static inline u8 ata_dev_knobble(const struct ata_port *ap) | |||
1104 | void ata_dev_config(struct ata_port *ap, unsigned int i) | 1144 | void ata_dev_config(struct ata_port *ap, unsigned int i) |
1105 | { | 1145 | { |
1106 | /* limit bridge transfers to udma5, 200 sectors */ | 1146 | /* limit bridge transfers to udma5, 200 sectors */ |
1107 | if (ata_dev_knobble(ap)) { | 1147 | if (ata_dev_knobble(ap, &ap->device[i])) { |
1108 | printk(KERN_INFO "ata%u(%u): applying bridge limits\n", | 1148 | printk(KERN_INFO "ata%u(%u): applying bridge limits\n", |
1109 | ap->id, ap->device->devno); | 1149 | ap->id, i); |
1110 | ap->udma_mask &= ATA_UDMA5; | 1150 | ap->udma_mask &= ATA_UDMA5; |
1111 | ap->host->max_sectors = ATA_MAX_SECTORS; | 1151 | ap->device[i].max_sectors = ATA_MAX_SECTORS; |
1112 | ap->host->hostt->max_sectors = ATA_MAX_SECTORS; | ||
1113 | ap->device[i].flags |= ATA_DFLAG_LOCK_SECTORS; | ||
1114 | } | 1152 | } |
1115 | 1153 | ||
1116 | if (ap->ops->dev_config) | 1154 | if (ap->ops->dev_config) |
@@ -1144,8 +1182,11 @@ static int ata_bus_probe(struct ata_port *ap) | |||
1144 | 1182 | ||
1145 | rc = ap->ops->probe_reset(ap, classes); | 1183 | rc = ap->ops->probe_reset(ap, classes); |
1146 | if (rc == 0) { | 1184 | if (rc == 0) { |
1147 | for (i = 0; i < ATA_MAX_DEVICES; i++) | 1185 | for (i = 0; i < ATA_MAX_DEVICES; i++) { |
1186 | if (classes[i] == ATA_DEV_UNKNOWN) | ||
1187 | classes[i] = ATA_DEV_NONE; | ||
1148 | ap->device[i].class = classes[i]; | 1188 | ap->device[i].class = classes[i]; |
1189 | } | ||
1149 | } else { | 1190 | } else { |
1150 | printk(KERN_ERR "ata%u: probe reset failed, " | 1191 | printk(KERN_ERR "ata%u: probe reset failed, " |
1151 | "disabling port\n", ap->id); | 1192 | "disabling port\n", ap->id); |
@@ -2272,24 +2313,14 @@ static const char * const ata_dma_blacklist [] = { | |||
2272 | 2313 | ||
2273 | static int ata_dma_blacklisted(const struct ata_device *dev) | 2314 | static int ata_dma_blacklisted(const struct ata_device *dev) |
2274 | { | 2315 | { |
2275 | unsigned char model_num[40]; | 2316 | unsigned char model_num[41]; |
2276 | char *s; | ||
2277 | unsigned int len; | ||
2278 | int i; | 2317 | int i; |
2279 | 2318 | ||
2280 | ata_dev_id_string(dev->id, model_num, ATA_ID_PROD_OFS, | 2319 | ata_dev_id_c_string(dev->id, model_num, ATA_ID_PROD_OFS, |
2281 | sizeof(model_num)); | 2320 | sizeof(model_num)); |
2282 | s = &model_num[0]; | ||
2283 | len = strnlen(s, sizeof(model_num)); | ||
2284 | |||
2285 | /* ATAPI specifies that empty space is blank-filled; remove blanks */ | ||
2286 | while ((len > 0) && (s[len - 1] == ' ')) { | ||
2287 | len--; | ||
2288 | s[len] = 0; | ||
2289 | } | ||
2290 | 2321 | ||
2291 | for (i = 0; i < ARRAY_SIZE(ata_dma_blacklist); i++) | 2322 | for (i = 0; i < ARRAY_SIZE(ata_dma_blacklist); i++) |
2292 | if (!strncmp(ata_dma_blacklist[i], s, len)) | 2323 | if (!strcmp(ata_dma_blacklist[i], model_num)) |
2293 | return 1; | 2324 | return 1; |
2294 | 2325 | ||
2295 | return 0; | 2326 | return 0; |
@@ -2485,7 +2516,7 @@ static void ata_dev_reread_id(struct ata_port *ap, struct ata_device *dev) | |||
2485 | 2516 | ||
2486 | swap_buf_le16(dev->id, ATA_ID_WORDS); | 2517 | swap_buf_le16(dev->id, ATA_ID_WORDS); |
2487 | 2518 | ||
2488 | ata_dump_id(dev); | 2519 | ata_dump_id(dev->id); |
2489 | 2520 | ||
2490 | DPRINTK("EXIT\n"); | 2521 | DPRINTK("EXIT\n"); |
2491 | 2522 | ||
@@ -5179,6 +5210,7 @@ EXPORT_SYMBOL_GPL(ata_scsi_release); | |||
5179 | EXPORT_SYMBOL_GPL(ata_host_intr); | 5210 | EXPORT_SYMBOL_GPL(ata_host_intr); |
5180 | EXPORT_SYMBOL_GPL(ata_dev_classify); | 5211 | EXPORT_SYMBOL_GPL(ata_dev_classify); |
5181 | EXPORT_SYMBOL_GPL(ata_dev_id_string); | 5212 | EXPORT_SYMBOL_GPL(ata_dev_id_string); |
5213 | EXPORT_SYMBOL_GPL(ata_dev_id_c_string); | ||
5182 | EXPORT_SYMBOL_GPL(ata_dev_config); | 5214 | EXPORT_SYMBOL_GPL(ata_dev_config); |
5183 | EXPORT_SYMBOL_GPL(ata_scsi_simulate); | 5215 | EXPORT_SYMBOL_GPL(ata_scsi_simulate); |
5184 | EXPORT_SYMBOL_GPL(ata_eh_qc_complete); | 5216 | EXPORT_SYMBOL_GPL(ata_eh_qc_complete); |
diff --git a/drivers/scsi/libata-scsi.c b/drivers/scsi/libata-scsi.c index 26f07a2617f9..86da46502b3e 100644 --- a/drivers/scsi/libata-scsi.c +++ b/drivers/scsi/libata-scsi.c | |||
@@ -684,23 +684,23 @@ int ata_scsi_slave_config(struct scsi_device *sdev) | |||
684 | if (sdev->id < ATA_MAX_DEVICES) { | 684 | if (sdev->id < ATA_MAX_DEVICES) { |
685 | struct ata_port *ap; | 685 | struct ata_port *ap; |
686 | struct ata_device *dev; | 686 | struct ata_device *dev; |
687 | unsigned int max_sectors; | ||
687 | 688 | ||
688 | ap = (struct ata_port *) &sdev->host->hostdata[0]; | 689 | ap = (struct ata_port *) &sdev->host->hostdata[0]; |
689 | dev = &ap->device[sdev->id]; | 690 | dev = &ap->device[sdev->id]; |
690 | 691 | ||
691 | /* TODO: 1024 is an arbitrary number, not the | 692 | /* TODO: 2048 is an arbitrary number, not the |
692 | * hardware maximum. This should be increased to | 693 | * hardware maximum. This should be increased to |
693 | * 65534 when Jens Axboe's patch for dynamically | 694 | * 65534 when Jens Axboe's patch for dynamically |
694 | * determining max_sectors is merged. | 695 | * determining max_sectors is merged. |
695 | */ | 696 | */ |
696 | if ((dev->flags & ATA_DFLAG_LBA48) && | 697 | max_sectors = ATA_MAX_SECTORS; |
697 | ((dev->flags & ATA_DFLAG_LOCK_SECTORS) == 0)) { | 698 | if (dev->flags & ATA_DFLAG_LBA48) |
698 | /* | 699 | max_sectors = 2048; |
699 | * do not overwrite sdev->host->max_sectors, since | 700 | if (dev->max_sectors) |
700 | * other drives on this host may not support LBA48 | 701 | max_sectors = dev->max_sectors; |
701 | */ | 702 | |
702 | blk_queue_max_sectors(sdev->request_queue, 2048); | 703 | blk_queue_max_sectors(sdev->request_queue, max_sectors); |
703 | } | ||
704 | 704 | ||
705 | /* | 705 | /* |
706 | * SATA DMA transfers must be multiples of 4 byte, so | 706 | * SATA DMA transfers must be multiples of 4 byte, so |
@@ -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 | |||
1812 | ata_dev_id_string(id, model, ATA_ID_PROD_OFS, sizeof(model) - 1); | ||
1813 | ata_dev_id_string(id, fw, ATA_ID_FW_REV_OFS, sizeof(fw) - 1); | ||
1814 | 1811 | ||
1815 | if (strncmp(model, "Maxtor", 6)) | 1812 | if (strcmp(model, "Maxtor")) |
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 */ |
@@ -2149,7 +2146,7 @@ static void atapi_request_sense(struct ata_queued_cmd *qc) | |||
2149 | ata_sg_init_one(qc, cmd->sense_buffer, sizeof(cmd->sense_buffer)); | 2146 | ata_sg_init_one(qc, cmd->sense_buffer, sizeof(cmd->sense_buffer)); |
2150 | qc->dma_dir = DMA_FROM_DEVICE; | 2147 | qc->dma_dir = DMA_FROM_DEVICE; |
2151 | 2148 | ||
2152 | memset(&qc->cdb, 0, ap->cdb_len); | 2149 | memset(&qc->cdb, 0, qc->dev->cdb_len); |
2153 | qc->cdb[0] = REQUEST_SENSE; | 2150 | qc->cdb[0] = REQUEST_SENSE; |
2154 | qc->cdb[4] = SCSI_SENSE_BUFFERSIZE; | 2151 | qc->cdb[4] = SCSI_SENSE_BUFFERSIZE; |
2155 | 2152 | ||
@@ -2251,7 +2248,7 @@ static unsigned int atapi_xlat(struct ata_queued_cmd *qc, const u8 *scsicmd) | |||
2251 | if (ata_check_atapi_dma(qc)) | 2248 | if (ata_check_atapi_dma(qc)) |
2252 | using_pio = 1; | 2249 | using_pio = 1; |
2253 | 2250 | ||
2254 | memcpy(&qc->cdb, scsicmd, qc->ap->cdb_len); | 2251 | memcpy(&qc->cdb, scsicmd, dev->cdb_len); |
2255 | 2252 | ||
2256 | qc->complete_fn = atapi_qc_complete; | 2253 | qc->complete_fn = atapi_qc_complete; |
2257 | 2254 | ||
diff --git a/drivers/scsi/pdc_adma.c b/drivers/scsi/pdc_adma.c index 0f7e45a39fd9..f32af5dc58c4 100644 --- a/drivers/scsi/pdc_adma.c +++ b/drivers/scsi/pdc_adma.c | |||
@@ -148,7 +148,6 @@ static struct scsi_host_template adma_ata_sht = { | |||
148 | .can_queue = ATA_DEF_QUEUE, | 148 | .can_queue = ATA_DEF_QUEUE, |
149 | .this_id = ATA_SHT_THIS_ID, | 149 | .this_id = ATA_SHT_THIS_ID, |
150 | .sg_tablesize = LIBATA_MAX_PRD, | 150 | .sg_tablesize = LIBATA_MAX_PRD, |
151 | .max_sectors = ATA_MAX_SECTORS, | ||
152 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, | 151 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, |
153 | .emulated = ATA_SHT_EMULATED, | 152 | .emulated = ATA_SHT_EMULATED, |
154 | .use_clustering = ENABLE_CLUSTERING, | 153 | .use_clustering = ENABLE_CLUSTERING, |
diff --git a/drivers/scsi/sata_mv.c b/drivers/scsi/sata_mv.c index d35460ff5275..e05751e7aad4 100644 --- a/drivers/scsi/sata_mv.c +++ b/drivers/scsi/sata_mv.c | |||
@@ -383,7 +383,6 @@ static struct scsi_host_template mv_sht = { | |||
383 | .can_queue = MV_USE_Q_DEPTH, | 383 | .can_queue = MV_USE_Q_DEPTH, |
384 | .this_id = ATA_SHT_THIS_ID, | 384 | .this_id = ATA_SHT_THIS_ID, |
385 | .sg_tablesize = MV_MAX_SG_CT / 2, | 385 | .sg_tablesize = MV_MAX_SG_CT / 2, |
386 | .max_sectors = ATA_MAX_SECTORS, | ||
387 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, | 386 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, |
388 | .emulated = ATA_SHT_EMULATED, | 387 | .emulated = ATA_SHT_EMULATED, |
389 | .use_clustering = ATA_SHT_USE_CLUSTERING, | 388 | .use_clustering = ATA_SHT_USE_CLUSTERING, |
diff --git a/drivers/scsi/sata_nv.c b/drivers/scsi/sata_nv.c index 94dc2e1a8f30..5168db981dde 100644 --- a/drivers/scsi/sata_nv.c +++ b/drivers/scsi/sata_nv.c | |||
@@ -234,7 +234,6 @@ static struct scsi_host_template nv_sht = { | |||
234 | .can_queue = ATA_DEF_QUEUE, | 234 | .can_queue = ATA_DEF_QUEUE, |
235 | .this_id = ATA_SHT_THIS_ID, | 235 | .this_id = ATA_SHT_THIS_ID, |
236 | .sg_tablesize = LIBATA_MAX_PRD, | 236 | .sg_tablesize = LIBATA_MAX_PRD, |
237 | .max_sectors = ATA_MAX_SECTORS, | ||
238 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, | 237 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, |
239 | .emulated = ATA_SHT_EMULATED, | 238 | .emulated = ATA_SHT_EMULATED, |
240 | .use_clustering = ATA_SHT_USE_CLUSTERING, | 239 | .use_clustering = ATA_SHT_USE_CLUSTERING, |
diff --git a/drivers/scsi/sata_promise.c b/drivers/scsi/sata_promise.c index a88b563ebcc4..7fa807d7d9e1 100644 --- a/drivers/scsi/sata_promise.c +++ b/drivers/scsi/sata_promise.c | |||
@@ -117,7 +117,6 @@ static struct scsi_host_template pdc_ata_sht = { | |||
117 | .can_queue = ATA_DEF_QUEUE, | 117 | .can_queue = ATA_DEF_QUEUE, |
118 | .this_id = ATA_SHT_THIS_ID, | 118 | .this_id = ATA_SHT_THIS_ID, |
119 | .sg_tablesize = LIBATA_MAX_PRD, | 119 | .sg_tablesize = LIBATA_MAX_PRD, |
120 | .max_sectors = ATA_MAX_SECTORS, | ||
121 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, | 120 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, |
122 | .emulated = ATA_SHT_EMULATED, | 121 | .emulated = ATA_SHT_EMULATED, |
123 | .use_clustering = ATA_SHT_USE_CLUSTERING, | 122 | .use_clustering = ATA_SHT_USE_CLUSTERING, |
diff --git a/drivers/scsi/sata_qstor.c b/drivers/scsi/sata_qstor.c index 5730167d2e74..bfc1dc8e7779 100644 --- a/drivers/scsi/sata_qstor.c +++ b/drivers/scsi/sata_qstor.c | |||
@@ -137,7 +137,6 @@ static struct scsi_host_template qs_ata_sht = { | |||
137 | .can_queue = ATA_DEF_QUEUE, | 137 | .can_queue = ATA_DEF_QUEUE, |
138 | .this_id = ATA_SHT_THIS_ID, | 138 | .this_id = ATA_SHT_THIS_ID, |
139 | .sg_tablesize = QS_MAX_PRD, | 139 | .sg_tablesize = QS_MAX_PRD, |
140 | .max_sectors = ATA_MAX_SECTORS, | ||
141 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, | 140 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, |
142 | .emulated = ATA_SHT_EMULATED, | 141 | .emulated = ATA_SHT_EMULATED, |
143 | //FIXME .use_clustering = ATA_SHT_USE_CLUSTERING, | 142 | //FIXME .use_clustering = ATA_SHT_USE_CLUSTERING, |
diff --git a/drivers/scsi/sata_sil.c b/drivers/scsi/sata_sil.c index bd2887741d78..15346888faf2 100644 --- a/drivers/scsi/sata_sil.c +++ b/drivers/scsi/sata_sil.c | |||
@@ -140,7 +140,6 @@ static struct scsi_host_template sil_sht = { | |||
140 | .can_queue = ATA_DEF_QUEUE, | 140 | .can_queue = ATA_DEF_QUEUE, |
141 | .this_id = ATA_SHT_THIS_ID, | 141 | .this_id = ATA_SHT_THIS_ID, |
142 | .sg_tablesize = LIBATA_MAX_PRD, | 142 | .sg_tablesize = LIBATA_MAX_PRD, |
143 | .max_sectors = ATA_MAX_SECTORS, | ||
144 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, | 143 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, |
145 | .emulated = ATA_SHT_EMULATED, | 144 | .emulated = ATA_SHT_EMULATED, |
146 | .use_clustering = ATA_SHT_USE_CLUSTERING, | 145 | .use_clustering = ATA_SHT_USE_CLUSTERING, |
@@ -337,22 +336,13 @@ static void sil_scr_write (struct ata_port *ap, unsigned int sc_reg, u32 val) | |||
337 | static void sil_dev_config(struct ata_port *ap, struct ata_device *dev) | 336 | static void sil_dev_config(struct ata_port *ap, struct ata_device *dev) |
338 | { | 337 | { |
339 | unsigned int n, quirks = 0; | 338 | unsigned int n, quirks = 0; |
340 | unsigned char model_num[40]; | 339 | unsigned char model_num[41]; |
341 | const char *s; | ||
342 | unsigned int len; | ||
343 | 340 | ||
344 | ata_dev_id_string(dev->id, model_num, ATA_ID_PROD_OFS, | 341 | ata_dev_id_c_string(dev->id, model_num, ATA_ID_PROD_OFS, |
345 | sizeof(model_num)); | 342 | 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 | 343 | ||
353 | for (n = 0; sil_blacklist[n].product; n++) | 344 | for (n = 0; sil_blacklist[n].product; n++) |
354 | if (!memcmp(sil_blacklist[n].product, s, | 345 | if (!strcmp(sil_blacklist[n].product, model_num)) { |
355 | strlen(sil_blacklist[n].product))) { | ||
356 | quirks = sil_blacklist[n].quirk; | 346 | quirks = sil_blacklist[n].quirk; |
357 | break; | 347 | break; |
358 | } | 348 | } |
@@ -363,16 +353,14 @@ static void sil_dev_config(struct ata_port *ap, struct ata_device *dev) | |||
363 | (quirks & SIL_QUIRK_MOD15WRITE))) { | 353 | (quirks & SIL_QUIRK_MOD15WRITE))) { |
364 | printk(KERN_INFO "ata%u(%u): applying Seagate errata fix (mod15write workaround)\n", | 354 | printk(KERN_INFO "ata%u(%u): applying Seagate errata fix (mod15write workaround)\n", |
365 | ap->id, dev->devno); | 355 | ap->id, dev->devno); |
366 | ap->host->max_sectors = 15; | 356 | dev->max_sectors = 15; |
367 | ap->host->hostt->max_sectors = 15; | ||
368 | dev->flags |= ATA_DFLAG_LOCK_SECTORS; | ||
369 | return; | 357 | return; |
370 | } | 358 | } |
371 | 359 | ||
372 | /* limit to udma5 */ | 360 | /* limit to udma5 */ |
373 | if (quirks & SIL_QUIRK_UDMA5MAX) { | 361 | if (quirks & SIL_QUIRK_UDMA5MAX) { |
374 | printk(KERN_INFO "ata%u(%u): applying Maxtor errata fix %s\n", | 362 | printk(KERN_INFO "ata%u(%u): applying Maxtor errata fix %s\n", |
375 | ap->id, dev->devno, s); | 363 | ap->id, dev->devno, model_num); |
376 | ap->udma_mask &= ATA_UDMA5; | 364 | ap->udma_mask &= ATA_UDMA5; |
377 | return; | 365 | return; |
378 | } | 366 | } |
diff --git a/drivers/scsi/sata_sil24.c b/drivers/scsi/sata_sil24.c index 228a7fabffff..a0e35a262156 100644 --- a/drivers/scsi/sata_sil24.c +++ b/drivers/scsi/sata_sil24.c | |||
@@ -285,7 +285,6 @@ static struct scsi_host_template sil24_sht = { | |||
285 | .can_queue = ATA_DEF_QUEUE, | 285 | .can_queue = ATA_DEF_QUEUE, |
286 | .this_id = ATA_SHT_THIS_ID, | 286 | .this_id = ATA_SHT_THIS_ID, |
287 | .sg_tablesize = LIBATA_MAX_PRD, | 287 | .sg_tablesize = LIBATA_MAX_PRD, |
288 | .max_sectors = ATA_MAX_SECTORS, | ||
289 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, | 288 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, |
290 | .emulated = ATA_SHT_EMULATED, | 289 | .emulated = ATA_SHT_EMULATED, |
291 | .use_clustering = ATA_SHT_USE_CLUSTERING, | 290 | .use_clustering = ATA_SHT_USE_CLUSTERING, |
@@ -371,7 +370,7 @@ static void sil24_dev_config(struct ata_port *ap, struct ata_device *dev) | |||
371 | { | 370 | { |
372 | void __iomem *port = (void __iomem *)ap->ioaddr.cmd_addr; | 371 | void __iomem *port = (void __iomem *)ap->ioaddr.cmd_addr; |
373 | 372 | ||
374 | if (ap->cdb_len == 16) | 373 | if (dev->cdb_len == 16) |
375 | writel(PORT_CS_CDB16, port + PORT_CTRL_STAT); | 374 | writel(PORT_CS_CDB16, port + PORT_CTRL_STAT); |
376 | else | 375 | else |
377 | writel(PORT_CS_CDB16, port + PORT_CTRL_CLR); | 376 | writel(PORT_CS_CDB16, port + PORT_CTRL_CLR); |
@@ -543,7 +542,7 @@ static void sil24_qc_prep(struct ata_queued_cmd *qc) | |||
543 | prb = &cb->atapi.prb; | 542 | prb = &cb->atapi.prb; |
544 | sge = cb->atapi.sge; | 543 | sge = cb->atapi.sge; |
545 | memset(cb->atapi.cdb, 0, 32); | 544 | memset(cb->atapi.cdb, 0, 32); |
546 | memcpy(cb->atapi.cdb, qc->cdb, ap->cdb_len); | 545 | memcpy(cb->atapi.cdb, qc->cdb, qc->dev->cdb_len); |
547 | 546 | ||
548 | if (qc->tf.protocol != ATA_PROT_ATAPI_NODATA) { | 547 | if (qc->tf.protocol != ATA_PROT_ATAPI_NODATA) { |
549 | if (qc->tf.flags & ATA_TFLAG_WRITE) | 548 | if (qc->tf.flags & ATA_TFLAG_WRITE) |
diff --git a/drivers/scsi/sata_sis.c b/drivers/scsi/sata_sis.c index 2f1815715705..7fd45f86de99 100644 --- a/drivers/scsi/sata_sis.c +++ b/drivers/scsi/sata_sis.c | |||
@@ -92,7 +92,6 @@ static struct scsi_host_template sis_sht = { | |||
92 | .can_queue = ATA_DEF_QUEUE, | 92 | .can_queue = ATA_DEF_QUEUE, |
93 | .this_id = ATA_SHT_THIS_ID, | 93 | .this_id = ATA_SHT_THIS_ID, |
94 | .sg_tablesize = ATA_MAX_PRD, | 94 | .sg_tablesize = ATA_MAX_PRD, |
95 | .max_sectors = ATA_MAX_SECTORS, | ||
96 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, | 95 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, |
97 | .emulated = ATA_SHT_EMULATED, | 96 | .emulated = ATA_SHT_EMULATED, |
98 | .use_clustering = ATA_SHT_USE_CLUSTERING, | 97 | .use_clustering = ATA_SHT_USE_CLUSTERING, |
diff --git a/drivers/scsi/sata_svw.c b/drivers/scsi/sata_svw.c index f369c3003adf..4aaccd53e736 100644 --- a/drivers/scsi/sata_svw.c +++ b/drivers/scsi/sata_svw.c | |||
@@ -293,7 +293,6 @@ static struct scsi_host_template k2_sata_sht = { | |||
293 | .can_queue = ATA_DEF_QUEUE, | 293 | .can_queue = ATA_DEF_QUEUE, |
294 | .this_id = ATA_SHT_THIS_ID, | 294 | .this_id = ATA_SHT_THIS_ID, |
295 | .sg_tablesize = LIBATA_MAX_PRD, | 295 | .sg_tablesize = LIBATA_MAX_PRD, |
296 | .max_sectors = ATA_MAX_SECTORS, | ||
297 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, | 296 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, |
298 | .emulated = ATA_SHT_EMULATED, | 297 | .emulated = ATA_SHT_EMULATED, |
299 | .use_clustering = ATA_SHT_USE_CLUSTERING, | 298 | .use_clustering = ATA_SHT_USE_CLUSTERING, |
diff --git a/drivers/scsi/sata_sx4.c b/drivers/scsi/sata_sx4.c index 04465fb86e1d..60ebe5ce32c4 100644 --- a/drivers/scsi/sata_sx4.c +++ b/drivers/scsi/sata_sx4.c | |||
@@ -187,7 +187,6 @@ static struct scsi_host_template pdc_sata_sht = { | |||
187 | .can_queue = ATA_DEF_QUEUE, | 187 | .can_queue = ATA_DEF_QUEUE, |
188 | .this_id = ATA_SHT_THIS_ID, | 188 | .this_id = ATA_SHT_THIS_ID, |
189 | .sg_tablesize = LIBATA_MAX_PRD, | 189 | .sg_tablesize = LIBATA_MAX_PRD, |
190 | .max_sectors = ATA_MAX_SECTORS, | ||
191 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, | 190 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, |
192 | .emulated = ATA_SHT_EMULATED, | 191 | .emulated = ATA_SHT_EMULATED, |
193 | .use_clustering = ATA_SHT_USE_CLUSTERING, | 192 | .use_clustering = ATA_SHT_USE_CLUSTERING, |
diff --git a/drivers/scsi/sata_uli.c b/drivers/scsi/sata_uli.c index c500f2490902..37a487b7d655 100644 --- a/drivers/scsi/sata_uli.c +++ b/drivers/scsi/sata_uli.c | |||
@@ -80,7 +80,6 @@ static struct scsi_host_template uli_sht = { | |||
80 | .can_queue = ATA_DEF_QUEUE, | 80 | .can_queue = ATA_DEF_QUEUE, |
81 | .this_id = ATA_SHT_THIS_ID, | 81 | .this_id = ATA_SHT_THIS_ID, |
82 | .sg_tablesize = LIBATA_MAX_PRD, | 82 | .sg_tablesize = LIBATA_MAX_PRD, |
83 | .max_sectors = ATA_MAX_SECTORS, | ||
84 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, | 83 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, |
85 | .emulated = ATA_SHT_EMULATED, | 84 | .emulated = ATA_SHT_EMULATED, |
86 | .use_clustering = ATA_SHT_USE_CLUSTERING, | 85 | .use_clustering = ATA_SHT_USE_CLUSTERING, |
diff --git a/drivers/scsi/sata_via.c b/drivers/scsi/sata_via.c index 2e20887dc88f..ff65a0b0457f 100644 --- a/drivers/scsi/sata_via.c +++ b/drivers/scsi/sata_via.c | |||
@@ -99,7 +99,6 @@ static struct scsi_host_template svia_sht = { | |||
99 | .can_queue = ATA_DEF_QUEUE, | 99 | .can_queue = ATA_DEF_QUEUE, |
100 | .this_id = ATA_SHT_THIS_ID, | 100 | .this_id = ATA_SHT_THIS_ID, |
101 | .sg_tablesize = LIBATA_MAX_PRD, | 101 | .sg_tablesize = LIBATA_MAX_PRD, |
102 | .max_sectors = ATA_MAX_SECTORS, | ||
103 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, | 102 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, |
104 | .emulated = ATA_SHT_EMULATED, | 103 | .emulated = ATA_SHT_EMULATED, |
105 | .use_clustering = ATA_SHT_USE_CLUSTERING, | 104 | .use_clustering = ATA_SHT_USE_CLUSTERING, |
diff --git a/drivers/scsi/sata_vsc.c b/drivers/scsi/sata_vsc.c index 4cfc03018ca3..976a6b124af9 100644 --- a/drivers/scsi/sata_vsc.c +++ b/drivers/scsi/sata_vsc.c | |||
@@ -228,7 +228,6 @@ static struct scsi_host_template vsc_sata_sht = { | |||
228 | .can_queue = ATA_DEF_QUEUE, | 228 | .can_queue = ATA_DEF_QUEUE, |
229 | .this_id = ATA_SHT_THIS_ID, | 229 | .this_id = ATA_SHT_THIS_ID, |
230 | .sg_tablesize = LIBATA_MAX_PRD, | 230 | .sg_tablesize = LIBATA_MAX_PRD, |
231 | .max_sectors = ATA_MAX_SECTORS, | ||
232 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, | 231 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, |
233 | .emulated = ATA_SHT_EMULATED, | 232 | .emulated = ATA_SHT_EMULATED, |
234 | .use_clustering = ATA_SHT_USE_CLUSTERING, | 233 | .use_clustering = ATA_SHT_USE_CLUSTERING, |