diff options
Diffstat (limited to 'drivers/ata/libata-scsi.c')
-rw-r--r-- | drivers/ata/libata-scsi.c | 33 |
1 files changed, 16 insertions, 17 deletions
diff --git a/drivers/ata/libata-scsi.c b/drivers/ata/libata-scsi.c index 57111f842d66..6a99c0824751 100644 --- a/drivers/ata/libata-scsi.c +++ b/drivers/ata/libata-scsi.c | |||
@@ -1698,8 +1698,8 @@ unsigned int ata_scsiop_inq_std(struct ata_scsi_args *args, u8 *rbuf, | |||
1698 | 1698 | ||
1699 | if (buflen > 35) { | 1699 | if (buflen > 35) { |
1700 | memcpy(&rbuf[8], "ATA ", 8); | 1700 | memcpy(&rbuf[8], "ATA ", 8); |
1701 | ata_id_string(args->id, &rbuf[16], ATA_ID_PROD_OFS, 16); | 1701 | ata_id_string(args->id, &rbuf[16], ATA_ID_PROD, 16); |
1702 | ata_id_string(args->id, &rbuf[32], ATA_ID_FW_REV_OFS, 4); | 1702 | ata_id_string(args->id, &rbuf[32], ATA_ID_FW_REV, 4); |
1703 | if (rbuf[32] == 0 || rbuf[32] == ' ') | 1703 | if (rbuf[32] == 0 || rbuf[32] == ' ') |
1704 | memcpy(&rbuf[32], "n/a ", 4); | 1704 | memcpy(&rbuf[32], "n/a ", 4); |
1705 | } | 1705 | } |
@@ -1768,13 +1768,13 @@ unsigned int ata_scsiop_inq_80(struct ata_scsi_args *args, u8 *rbuf, | |||
1768 | 0, | 1768 | 0, |
1769 | 0x80, /* this page code */ | 1769 | 0x80, /* this page code */ |
1770 | 0, | 1770 | 0, |
1771 | ATA_SERNO_LEN, /* page len */ | 1771 | ATA_ID_SERNO_LEN, /* page len */ |
1772 | }; | 1772 | }; |
1773 | memcpy(rbuf, hdr, sizeof(hdr)); | 1773 | memcpy(rbuf, hdr, sizeof(hdr)); |
1774 | 1774 | ||
1775 | if (buflen > (ATA_SERNO_LEN + 4 - 1)) | 1775 | if (buflen > (ATA_ID_SERNO_LEN + 4 - 1)) |
1776 | ata_id_string(args->id, (unsigned char *) &rbuf[4], | 1776 | ata_id_string(args->id, (unsigned char *) &rbuf[4], |
1777 | ATA_ID_SERNO_OFS, ATA_SERNO_LEN); | 1777 | ATA_ID_SERNO, ATA_ID_SERNO_LEN); |
1778 | 1778 | ||
1779 | return 0; | 1779 | return 0; |
1780 | } | 1780 | } |
@@ -1799,19 +1799,18 @@ unsigned int ata_scsiop_inq_83(struct ata_scsi_args *args, u8 *rbuf, | |||
1799 | { | 1799 | { |
1800 | int num; | 1800 | int num; |
1801 | const int sat_model_serial_desc_len = 68; | 1801 | const int sat_model_serial_desc_len = 68; |
1802 | const int ata_model_byte_len = 40; | ||
1803 | 1802 | ||
1804 | rbuf[1] = 0x83; /* this page code */ | 1803 | rbuf[1] = 0x83; /* this page code */ |
1805 | num = 4; | 1804 | num = 4; |
1806 | 1805 | ||
1807 | if (buflen > (ATA_SERNO_LEN + num + 3)) { | 1806 | if (buflen > (ATA_ID_SERNO_LEN + num + 3)) { |
1808 | /* piv=0, assoc=lu, code_set=ACSII, designator=vendor */ | 1807 | /* piv=0, assoc=lu, code_set=ACSII, designator=vendor */ |
1809 | rbuf[num + 0] = 2; | 1808 | rbuf[num + 0] = 2; |
1810 | rbuf[num + 3] = ATA_SERNO_LEN; | 1809 | rbuf[num + 3] = ATA_ID_SERNO_LEN; |
1811 | num += 4; | 1810 | num += 4; |
1812 | ata_id_string(args->id, (unsigned char *) rbuf + num, | 1811 | ata_id_string(args->id, (unsigned char *) rbuf + num, |
1813 | ATA_ID_SERNO_OFS, ATA_SERNO_LEN); | 1812 | ATA_ID_SERNO, ATA_ID_SERNO_LEN); |
1814 | num += ATA_SERNO_LEN; | 1813 | num += ATA_ID_SERNO_LEN; |
1815 | } | 1814 | } |
1816 | if (buflen > (sat_model_serial_desc_len + num + 3)) { | 1815 | if (buflen > (sat_model_serial_desc_len + num + 3)) { |
1817 | /* SAT defined lu model and serial numbers descriptor */ | 1816 | /* SAT defined lu model and serial numbers descriptor */ |
@@ -1823,11 +1822,11 @@ unsigned int ata_scsiop_inq_83(struct ata_scsi_args *args, u8 *rbuf, | |||
1823 | memcpy(rbuf + num, "ATA ", 8); | 1822 | memcpy(rbuf + num, "ATA ", 8); |
1824 | num += 8; | 1823 | num += 8; |
1825 | ata_id_string(args->id, (unsigned char *) rbuf + num, | 1824 | ata_id_string(args->id, (unsigned char *) rbuf + num, |
1826 | ATA_ID_PROD_OFS, ata_model_byte_len); | 1825 | ATA_ID_PROD, ATA_ID_PROD_LEN); |
1827 | num += ata_model_byte_len; | 1826 | num += ATA_ID_PROD_LEN; |
1828 | ata_id_string(args->id, (unsigned char *) rbuf + num, | 1827 | ata_id_string(args->id, (unsigned char *) rbuf + num, |
1829 | ATA_ID_SERNO_OFS, ATA_SERNO_LEN); | 1828 | ATA_ID_SERNO, ATA_ID_SERNO_LEN); |
1830 | num += ATA_SERNO_LEN; | 1829 | num += ATA_ID_SERNO_LEN; |
1831 | } | 1830 | } |
1832 | rbuf[3] = num - 4; /* page len (assume less than 256 bytes) */ | 1831 | rbuf[3] = num - 4; /* page len (assume less than 256 bytes) */ |
1833 | return 0; | 1832 | return 0; |
@@ -1955,15 +1954,15 @@ static unsigned int ata_msense_rw_recovery(u8 **ptr_io, const u8 *last) | |||
1955 | */ | 1954 | */ |
1956 | static int ata_dev_supports_fua(u16 *id) | 1955 | static int ata_dev_supports_fua(u16 *id) |
1957 | { | 1956 | { |
1958 | unsigned char model[41], fw[9]; | 1957 | unsigned char model[ATA_ID_PROD_LEN + 1], fw[ATA_ID_FW_REV_LEN + 1]; |
1959 | 1958 | ||
1960 | if (!libata_fua) | 1959 | if (!libata_fua) |
1961 | return 0; | 1960 | return 0; |
1962 | if (!ata_id_has_fua(id)) | 1961 | if (!ata_id_has_fua(id)) |
1963 | return 0; | 1962 | return 0; |
1964 | 1963 | ||
1965 | ata_id_c_string(id, model, ATA_ID_PROD_OFS, sizeof(model)); | 1964 | ata_id_c_string(id, model, ATA_ID_PROD, sizeof(model)); |
1966 | ata_id_c_string(id, fw, ATA_ID_FW_REV_OFS, sizeof(fw)); | 1965 | ata_id_c_string(id, fw, ATA_ID_FW_REV, sizeof(fw)); |
1967 | 1966 | ||
1968 | if (strcmp(model, "Maxtor")) | 1967 | if (strcmp(model, "Maxtor")) |
1969 | return 1; | 1968 | return 1; |