aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/ata/libata-scsi.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/ata/libata-scsi.c')
-rw-r--r--drivers/ata/libata-scsi.c30
1 files changed, 13 insertions, 17 deletions
diff --git a/drivers/ata/libata-scsi.c b/drivers/ata/libata-scsi.c
index 1e42cde05f43..307910bd62c3 100644
--- a/drivers/ata/libata-scsi.c
+++ b/drivers/ata/libata-scsi.c
@@ -51,7 +51,7 @@
51 51
52#define SECTOR_SIZE 512 52#define SECTOR_SIZE 512
53 53
54typedef unsigned int (*ata_xlat_func_t)(struct ata_queued_cmd *qc, const u8 *cdb); 54typedef unsigned int (*ata_xlat_func_t)(struct ata_queued_cmd *qc);
55 55
56static struct ata_device * __ata_scsi_find_dev(struct ata_port *ap, 56static struct ata_device * __ata_scsi_find_dev(struct ata_port *ap,
57 const struct scsi_device *scsidev); 57 const struct scsi_device *scsidev);
@@ -935,7 +935,6 @@ int ata_scsi_change_queue_depth(struct scsi_device *sdev, int queue_depth)
935/** 935/**
936 * ata_scsi_start_stop_xlat - Translate SCSI START STOP UNIT command 936 * ata_scsi_start_stop_xlat - Translate SCSI START STOP UNIT command
937 * @qc: Storage for translated ATA taskfile 937 * @qc: Storage for translated ATA taskfile
938 * @cdb: SCSI command to translate
939 * 938 *
940 * Sets up an ATA taskfile to issue STANDBY (to stop) or READ VERIFY 939 * Sets up an ATA taskfile to issue STANDBY (to stop) or READ VERIFY
941 * (to start). Perhaps these commands should be preceded by 940 * (to start). Perhaps these commands should be preceded by
@@ -948,11 +947,11 @@ int ata_scsi_change_queue_depth(struct scsi_device *sdev, int queue_depth)
948 * RETURNS: 947 * RETURNS:
949 * Zero on success, non-zero on error. 948 * Zero on success, non-zero on error.
950 */ 949 */
951static unsigned int ata_scsi_start_stop_xlat(struct ata_queued_cmd *qc, 950static unsigned int ata_scsi_start_stop_xlat(struct ata_queued_cmd *qc)
952 const u8 *cdb)
953{ 951{
954 struct scsi_cmnd *scmd = qc->scsicmd; 952 struct scsi_cmnd *scmd = qc->scsicmd;
955 struct ata_taskfile *tf = &qc->tf; 953 struct ata_taskfile *tf = &qc->tf;
954 const u8 *cdb = scmd->cmnd;
956 955
957 tf->flags |= ATA_TFLAG_DEVICE | ATA_TFLAG_ISADDR; 956 tf->flags |= ATA_TFLAG_DEVICE | ATA_TFLAG_ISADDR;
958 tf->protocol = ATA_PROT_NODATA; 957 tf->protocol = ATA_PROT_NODATA;
@@ -1005,7 +1004,6 @@ invalid_fld:
1005/** 1004/**
1006 * ata_scsi_flush_xlat - Translate SCSI SYNCHRONIZE CACHE command 1005 * ata_scsi_flush_xlat - Translate SCSI SYNCHRONIZE CACHE command
1007 * @qc: Storage for translated ATA taskfile 1006 * @qc: Storage for translated ATA taskfile
1008 * @cdb: SCSI command to translate (ignored)
1009 * 1007 *
1010 * Sets up an ATA taskfile to issue FLUSH CACHE or 1008 * Sets up an ATA taskfile to issue FLUSH CACHE or
1011 * FLUSH CACHE EXT. 1009 * FLUSH CACHE EXT.
@@ -1016,7 +1014,7 @@ invalid_fld:
1016 * RETURNS: 1014 * RETURNS:
1017 * Zero on success, non-zero on error. 1015 * Zero on success, non-zero on error.
1018 */ 1016 */
1019static unsigned int ata_scsi_flush_xlat(struct ata_queued_cmd *qc, const u8 *cdb) 1017static unsigned int ata_scsi_flush_xlat(struct ata_queued_cmd *qc)
1020{ 1018{
1021 struct ata_taskfile *tf = &qc->tf; 1019 struct ata_taskfile *tf = &qc->tf;
1022 1020
@@ -1124,7 +1122,6 @@ static void scsi_16_lba_len(const u8 *cdb, u64 *plba, u32 *plen)
1124/** 1122/**
1125 * ata_scsi_verify_xlat - Translate SCSI VERIFY command into an ATA one 1123 * ata_scsi_verify_xlat - Translate SCSI VERIFY command into an ATA one
1126 * @qc: Storage for translated ATA taskfile 1124 * @qc: Storage for translated ATA taskfile
1127 * @cdb: SCSI command to translate
1128 * 1125 *
1129 * Converts SCSI VERIFY command to an ATA READ VERIFY command. 1126 * Converts SCSI VERIFY command to an ATA READ VERIFY command.
1130 * 1127 *
@@ -1134,12 +1131,13 @@ static void scsi_16_lba_len(const u8 *cdb, u64 *plba, u32 *plen)
1134 * RETURNS: 1131 * RETURNS:
1135 * Zero on success, non-zero on error. 1132 * Zero on success, non-zero on error.
1136 */ 1133 */
1137static unsigned int ata_scsi_verify_xlat(struct ata_queued_cmd *qc, const u8 *cdb) 1134static unsigned int ata_scsi_verify_xlat(struct ata_queued_cmd *qc)
1138{ 1135{
1139 struct scsi_cmnd *scmd = qc->scsicmd; 1136 struct scsi_cmnd *scmd = qc->scsicmd;
1140 struct ata_taskfile *tf = &qc->tf; 1137 struct ata_taskfile *tf = &qc->tf;
1141 struct ata_device *dev = qc->dev; 1138 struct ata_device *dev = qc->dev;
1142 u64 dev_sectors = qc->dev->n_sectors; 1139 u64 dev_sectors = qc->dev->n_sectors;
1140 const u8 *cdb = scmd->cmnd;
1143 u64 block; 1141 u64 block;
1144 u32 n_block; 1142 u32 n_block;
1145 1143
@@ -1242,7 +1240,6 @@ nothing_to_do:
1242/** 1240/**
1243 * ata_scsi_rw_xlat - Translate SCSI r/w command into an ATA one 1241 * ata_scsi_rw_xlat - Translate SCSI r/w command into an ATA one
1244 * @qc: Storage for translated ATA taskfile 1242 * @qc: Storage for translated ATA taskfile
1245 * @cdb: SCSI command to translate
1246 * 1243 *
1247 * Converts any of six SCSI read/write commands into the 1244 * Converts any of six SCSI read/write commands into the
1248 * ATA counterpart, including starting sector (LBA), 1245 * ATA counterpart, including starting sector (LBA),
@@ -1258,9 +1255,10 @@ nothing_to_do:
1258 * RETURNS: 1255 * RETURNS:
1259 * Zero on success, non-zero on error. 1256 * Zero on success, non-zero on error.
1260 */ 1257 */
1261static unsigned int ata_scsi_rw_xlat(struct ata_queued_cmd *qc, const u8 *cdb) 1258static unsigned int ata_scsi_rw_xlat(struct ata_queued_cmd *qc)
1262{ 1259{
1263 struct scsi_cmnd *scmd = qc->scsicmd; 1260 struct scsi_cmnd *scmd = qc->scsicmd;
1261 const u8 *cdb = scmd->cmnd;
1264 unsigned int tf_flags = 0; 1262 unsigned int tf_flags = 0;
1265 u64 block; 1263 u64 block;
1266 u32 n_block; 1264 u32 n_block;
@@ -1451,7 +1449,6 @@ static int ata_scsi_translate(struct ata_device *dev, struct scsi_cmnd *cmd,
1451 ata_xlat_func_t xlat_func) 1449 ata_xlat_func_t xlat_func)
1452{ 1450{
1453 struct ata_queued_cmd *qc; 1451 struct ata_queued_cmd *qc;
1454 u8 *cdb = cmd->cmnd;
1455 int is_io = xlat_func == ata_scsi_rw_xlat; 1452 int is_io = xlat_func == ata_scsi_rw_xlat;
1456 1453
1457 VPRINTK("ENTER\n"); 1454 VPRINTK("ENTER\n");
@@ -1483,7 +1480,7 @@ static int ata_scsi_translate(struct ata_device *dev, struct scsi_cmnd *cmd,
1483 1480
1484 qc->complete_fn = ata_scsi_qc_complete; 1481 qc->complete_fn = ata_scsi_qc_complete;
1485 1482
1486 if (xlat_func(qc, cdb)) 1483 if (xlat_func(qc))
1487 goto early_finish; 1484 goto early_finish;
1488 1485
1489 /* select device, send command to hardware */ 1486 /* select device, send command to hardware */
@@ -2339,7 +2336,6 @@ static void atapi_qc_complete(struct ata_queued_cmd *qc)
2339/** 2336/**
2340 * atapi_xlat - Initialize PACKET taskfile 2337 * atapi_xlat - Initialize PACKET taskfile
2341 * @qc: command structure to be initialized 2338 * @qc: command structure to be initialized
2342 * @cdb: SCSI CDB associated with this PACKET command
2343 * 2339 *
2344 * LOCKING: 2340 * LOCKING:
2345 * spin_lock_irqsave(host lock) 2341 * spin_lock_irqsave(host lock)
@@ -2347,7 +2343,7 @@ static void atapi_qc_complete(struct ata_queued_cmd *qc)
2347 * RETURNS: 2343 * RETURNS:
2348 * Zero on success, non-zero on failure. 2344 * Zero on success, non-zero on failure.
2349 */ 2345 */
2350static unsigned int atapi_xlat(struct ata_queued_cmd *qc, const u8 *cdb) 2346static unsigned int atapi_xlat(struct ata_queued_cmd *qc)
2351{ 2347{
2352 struct scsi_cmnd *scmd = qc->scsicmd; 2348 struct scsi_cmnd *scmd = qc->scsicmd;
2353 struct ata_device *dev = qc->dev; 2349 struct ata_device *dev = qc->dev;
@@ -2359,7 +2355,7 @@ static unsigned int atapi_xlat(struct ata_queued_cmd *qc, const u8 *cdb)
2359 if (ata_check_atapi_dma(qc)) 2355 if (ata_check_atapi_dma(qc))
2360 using_pio = 1; 2356 using_pio = 1;
2361 2357
2362 memcpy(&qc->cdb, cdb, dev->cdb_len); 2358 memcpy(&qc->cdb, scmd->cmnd, dev->cdb_len);
2363 2359
2364 qc->complete_fn = atapi_qc_complete; 2360 qc->complete_fn = atapi_qc_complete;
2365 2361
@@ -2511,18 +2507,18 @@ ata_scsi_map_proto(u8 byte1)
2511/** 2507/**
2512 * ata_scsi_pass_thru - convert ATA pass-thru CDB to taskfile 2508 * ata_scsi_pass_thru - convert ATA pass-thru CDB to taskfile
2513 * @qc: command structure to be initialized 2509 * @qc: command structure to be initialized
2514 * @cdb: SCSI command to convert
2515 * 2510 *
2516 * Handles either 12 or 16-byte versions of the CDB. 2511 * Handles either 12 or 16-byte versions of the CDB.
2517 * 2512 *
2518 * RETURNS: 2513 * RETURNS:
2519 * Zero on success, non-zero on failure. 2514 * Zero on success, non-zero on failure.
2520 */ 2515 */
2521static unsigned int ata_scsi_pass_thru(struct ata_queued_cmd *qc, const u8 *cdb) 2516static unsigned int ata_scsi_pass_thru(struct ata_queued_cmd *qc)
2522{ 2517{
2523 struct ata_taskfile *tf = &(qc->tf); 2518 struct ata_taskfile *tf = &(qc->tf);
2524 struct scsi_cmnd *scmd = qc->scsicmd; 2519 struct scsi_cmnd *scmd = qc->scsicmd;
2525 struct ata_device *dev = qc->dev; 2520 struct ata_device *dev = qc->dev;
2521 const u8 *cdb = scmd->cmnd;
2526 2522
2527 if ((tf->protocol = ata_scsi_map_proto(cdb[1])) == ATA_PROT_UNKNOWN) 2523 if ((tf->protocol = ata_scsi_map_proto(cdb[1])) == ATA_PROT_UNKNOWN)
2528 goto invalid_fld; 2524 goto invalid_fld;