aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/ata/libata-scsi.c217
1 files changed, 105 insertions, 112 deletions
diff --git a/drivers/ata/libata-scsi.c b/drivers/ata/libata-scsi.c
index a4790be41d1c..1e42cde05f43 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 *scsicmd); 54typedef unsigned int (*ata_xlat_func_t)(struct ata_queued_cmd *qc, const u8 *cdb);
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,7 @@ 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 * @scsicmd: SCSI command to translate 938 * @cdb: SCSI command to translate
939 * 939 *
940 * Sets up an ATA taskfile to issue STANDBY (to stop) or READ VERIFY 940 * Sets up an ATA taskfile to issue STANDBY (to stop) or READ VERIFY
941 * (to start). Perhaps these commands should be preceded by 941 * (to start). Perhaps these commands should be preceded by
@@ -948,22 +948,22 @@ int ata_scsi_change_queue_depth(struct scsi_device *sdev, int queue_depth)
948 * RETURNS: 948 * RETURNS:
949 * Zero on success, non-zero on error. 949 * Zero on success, non-zero on error.
950 */ 950 */
951
952static unsigned int ata_scsi_start_stop_xlat(struct ata_queued_cmd *qc, 951static unsigned int ata_scsi_start_stop_xlat(struct ata_queued_cmd *qc,
953 const u8 *scsicmd) 952 const u8 *cdb)
954{ 953{
954 struct scsi_cmnd *scmd = qc->scsicmd;
955 struct ata_taskfile *tf = &qc->tf; 955 struct ata_taskfile *tf = &qc->tf;
956 956
957 tf->flags |= ATA_TFLAG_DEVICE | ATA_TFLAG_ISADDR; 957 tf->flags |= ATA_TFLAG_DEVICE | ATA_TFLAG_ISADDR;
958 tf->protocol = ATA_PROT_NODATA; 958 tf->protocol = ATA_PROT_NODATA;
959 if (scsicmd[1] & 0x1) { 959 if (cdb[1] & 0x1) {
960 ; /* ignore IMMED bit, violates sat-r05 */ 960 ; /* ignore IMMED bit, violates sat-r05 */
961 } 961 }
962 if (scsicmd[4] & 0x2) 962 if (cdb[4] & 0x2)
963 goto invalid_fld; /* LOEJ bit set not supported */ 963 goto invalid_fld; /* LOEJ bit set not supported */
964 if (((scsicmd[4] >> 4) & 0xf) != 0) 964 if (((cdb[4] >> 4) & 0xf) != 0)
965 goto invalid_fld; /* power conditions not supported */ 965 goto invalid_fld; /* power conditions not supported */
966 if (scsicmd[4] & 0x1) { 966 if (cdb[4] & 0x1) {
967 tf->nsect = 1; /* 1 sector, lba=0 */ 967 tf->nsect = 1; /* 1 sector, lba=0 */
968 968
969 if (qc->dev->flags & ATA_DFLAG_LBA) { 969 if (qc->dev->flags & ATA_DFLAG_LBA) {
@@ -996,7 +996,7 @@ static unsigned int ata_scsi_start_stop_xlat(struct ata_queued_cmd *qc,
996 return 0; 996 return 0;
997 997
998invalid_fld: 998invalid_fld:
999 ata_scsi_set_sense(qc->scsicmd, ILLEGAL_REQUEST, 0x24, 0x0); 999 ata_scsi_set_sense(scmd, ILLEGAL_REQUEST, 0x24, 0x0);
1000 /* "Invalid field in cbd" */ 1000 /* "Invalid field in cbd" */
1001 return 1; 1001 return 1;
1002} 1002}
@@ -1005,7 +1005,7 @@ invalid_fld:
1005/** 1005/**
1006 * ata_scsi_flush_xlat - Translate SCSI SYNCHRONIZE CACHE command 1006 * ata_scsi_flush_xlat - Translate SCSI SYNCHRONIZE CACHE command
1007 * @qc: Storage for translated ATA taskfile 1007 * @qc: Storage for translated ATA taskfile
1008 * @scsicmd: SCSI command to translate (ignored) 1008 * @cdb: SCSI command to translate (ignored)
1009 * 1009 *
1010 * Sets up an ATA taskfile to issue FLUSH CACHE or 1010 * Sets up an ATA taskfile to issue FLUSH CACHE or
1011 * FLUSH CACHE EXT. 1011 * FLUSH CACHE EXT.
@@ -1016,8 +1016,7 @@ invalid_fld:
1016 * RETURNS: 1016 * RETURNS:
1017 * Zero on success, non-zero on error. 1017 * Zero on success, non-zero on error.
1018 */ 1018 */
1019 1019static unsigned int ata_scsi_flush_xlat(struct ata_queued_cmd *qc, const u8 *cdb)
1020static unsigned int ata_scsi_flush_xlat(struct ata_queued_cmd *qc, const u8 *scsicmd)
1021{ 1020{
1022 struct ata_taskfile *tf = &qc->tf; 1021 struct ata_taskfile *tf = &qc->tf;
1023 1022
@@ -1034,7 +1033,7 @@ static unsigned int ata_scsi_flush_xlat(struct ata_queued_cmd *qc, const u8 *scs
1034 1033
1035/** 1034/**
1036 * scsi_6_lba_len - Get LBA and transfer length 1035 * scsi_6_lba_len - Get LBA and transfer length
1037 * @scsicmd: SCSI command to translate 1036 * @cdb: SCSI command to translate
1038 * 1037 *
1039 * Calculate LBA and transfer length for 6-byte commands. 1038 * Calculate LBA and transfer length for 6-byte commands.
1040 * 1039 *
@@ -1042,18 +1041,17 @@ static unsigned int ata_scsi_flush_xlat(struct ata_queued_cmd *qc, const u8 *scs
1042 * @plba: the LBA 1041 * @plba: the LBA
1043 * @plen: the transfer length 1042 * @plen: the transfer length
1044 */ 1043 */
1045 1044static void scsi_6_lba_len(const u8 *cdb, u64 *plba, u32 *plen)
1046static void scsi_6_lba_len(const u8 *scsicmd, u64 *plba, u32 *plen)
1047{ 1045{
1048 u64 lba = 0; 1046 u64 lba = 0;
1049 u32 len = 0; 1047 u32 len = 0;
1050 1048
1051 VPRINTK("six-byte command\n"); 1049 VPRINTK("six-byte command\n");
1052 1050
1053 lba |= ((u64)scsicmd[2]) << 8; 1051 lba |= ((u64)cdb[2]) << 8;
1054 lba |= ((u64)scsicmd[3]); 1052 lba |= ((u64)cdb[3]);
1055 1053
1056 len |= ((u32)scsicmd[4]); 1054 len |= ((u32)cdb[4]);
1057 1055
1058 *plba = lba; 1056 *plba = lba;
1059 *plen = len; 1057 *plen = len;
@@ -1061,7 +1059,7 @@ static void scsi_6_lba_len(const u8 *scsicmd, u64 *plba, u32 *plen)
1061 1059
1062/** 1060/**
1063 * scsi_10_lba_len - Get LBA and transfer length 1061 * scsi_10_lba_len - Get LBA and transfer length
1064 * @scsicmd: SCSI command to translate 1062 * @cdb: SCSI command to translate
1065 * 1063 *
1066 * Calculate LBA and transfer length for 10-byte commands. 1064 * Calculate LBA and transfer length for 10-byte commands.
1067 * 1065 *
@@ -1069,21 +1067,20 @@ static void scsi_6_lba_len(const u8 *scsicmd, u64 *plba, u32 *plen)
1069 * @plba: the LBA 1067 * @plba: the LBA
1070 * @plen: the transfer length 1068 * @plen: the transfer length
1071 */ 1069 */
1072 1070static void scsi_10_lba_len(const u8 *cdb, u64 *plba, u32 *plen)
1073static void scsi_10_lba_len(const u8 *scsicmd, u64 *plba, u32 *plen)
1074{ 1071{
1075 u64 lba = 0; 1072 u64 lba = 0;
1076 u32 len = 0; 1073 u32 len = 0;
1077 1074
1078 VPRINTK("ten-byte command\n"); 1075 VPRINTK("ten-byte command\n");
1079 1076
1080 lba |= ((u64)scsicmd[2]) << 24; 1077 lba |= ((u64)cdb[2]) << 24;
1081 lba |= ((u64)scsicmd[3]) << 16; 1078 lba |= ((u64)cdb[3]) << 16;
1082 lba |= ((u64)scsicmd[4]) << 8; 1079 lba |= ((u64)cdb[4]) << 8;
1083 lba |= ((u64)scsicmd[5]); 1080 lba |= ((u64)cdb[5]);
1084 1081
1085 len |= ((u32)scsicmd[7]) << 8; 1082 len |= ((u32)cdb[7]) << 8;
1086 len |= ((u32)scsicmd[8]); 1083 len |= ((u32)cdb[8]);
1087 1084
1088 *plba = lba; 1085 *plba = lba;
1089 *plen = len; 1086 *plen = len;
@@ -1091,7 +1088,7 @@ static void scsi_10_lba_len(const u8 *scsicmd, u64 *plba, u32 *plen)
1091 1088
1092/** 1089/**
1093 * scsi_16_lba_len - Get LBA and transfer length 1090 * scsi_16_lba_len - Get LBA and transfer length
1094 * @scsicmd: SCSI command to translate 1091 * @cdb: SCSI command to translate
1095 * 1092 *
1096 * Calculate LBA and transfer length for 16-byte commands. 1093 * Calculate LBA and transfer length for 16-byte commands.
1097 * 1094 *
@@ -1099,27 +1096,26 @@ static void scsi_10_lba_len(const u8 *scsicmd, u64 *plba, u32 *plen)
1099 * @plba: the LBA 1096 * @plba: the LBA
1100 * @plen: the transfer length 1097 * @plen: the transfer length
1101 */ 1098 */
1102 1099static void scsi_16_lba_len(const u8 *cdb, u64 *plba, u32 *plen)
1103static void scsi_16_lba_len(const u8 *scsicmd, u64 *plba, u32 *plen)
1104{ 1100{
1105 u64 lba = 0; 1101 u64 lba = 0;
1106 u32 len = 0; 1102 u32 len = 0;
1107 1103
1108 VPRINTK("sixteen-byte command\n"); 1104 VPRINTK("sixteen-byte command\n");
1109 1105
1110 lba |= ((u64)scsicmd[2]) << 56; 1106 lba |= ((u64)cdb[2]) << 56;
1111 lba |= ((u64)scsicmd[3]) << 48; 1107 lba |= ((u64)cdb[3]) << 48;
1112 lba |= ((u64)scsicmd[4]) << 40; 1108 lba |= ((u64)cdb[4]) << 40;
1113 lba |= ((u64)scsicmd[5]) << 32; 1109 lba |= ((u64)cdb[5]) << 32;
1114 lba |= ((u64)scsicmd[6]) << 24; 1110 lba |= ((u64)cdb[6]) << 24;
1115 lba |= ((u64)scsicmd[7]) << 16; 1111 lba |= ((u64)cdb[7]) << 16;
1116 lba |= ((u64)scsicmd[8]) << 8; 1112 lba |= ((u64)cdb[8]) << 8;
1117 lba |= ((u64)scsicmd[9]); 1113 lba |= ((u64)cdb[9]);
1118 1114
1119 len |= ((u32)scsicmd[10]) << 24; 1115 len |= ((u32)cdb[10]) << 24;
1120 len |= ((u32)scsicmd[11]) << 16; 1116 len |= ((u32)cdb[11]) << 16;
1121 len |= ((u32)scsicmd[12]) << 8; 1117 len |= ((u32)cdb[12]) << 8;
1122 len |= ((u32)scsicmd[13]); 1118 len |= ((u32)cdb[13]);
1123 1119
1124 *plba = lba; 1120 *plba = lba;
1125 *plen = len; 1121 *plen = len;
@@ -1128,7 +1124,7 @@ static void scsi_16_lba_len(const u8 *scsicmd, u64 *plba, u32 *plen)
1128/** 1124/**
1129 * ata_scsi_verify_xlat - Translate SCSI VERIFY command into an ATA one 1125 * ata_scsi_verify_xlat - Translate SCSI VERIFY command into an ATA one
1130 * @qc: Storage for translated ATA taskfile 1126 * @qc: Storage for translated ATA taskfile
1131 * @scsicmd: SCSI command to translate 1127 * @cdb: SCSI command to translate
1132 * 1128 *
1133 * Converts SCSI VERIFY command to an ATA READ VERIFY command. 1129 * Converts SCSI VERIFY command to an ATA READ VERIFY command.
1134 * 1130 *
@@ -1138,9 +1134,9 @@ static void scsi_16_lba_len(const u8 *scsicmd, u64 *plba, u32 *plen)
1138 * RETURNS: 1134 * RETURNS:
1139 * Zero on success, non-zero on error. 1135 * Zero on success, non-zero on error.
1140 */ 1136 */
1141 1137static unsigned int ata_scsi_verify_xlat(struct ata_queued_cmd *qc, const u8 *cdb)
1142static unsigned int ata_scsi_verify_xlat(struct ata_queued_cmd *qc, const u8 *scsicmd)
1143{ 1138{
1139 struct scsi_cmnd *scmd = qc->scsicmd;
1144 struct ata_taskfile *tf = &qc->tf; 1140 struct ata_taskfile *tf = &qc->tf;
1145 struct ata_device *dev = qc->dev; 1141 struct ata_device *dev = qc->dev;
1146 u64 dev_sectors = qc->dev->n_sectors; 1142 u64 dev_sectors = qc->dev->n_sectors;
@@ -1150,10 +1146,10 @@ static unsigned int ata_scsi_verify_xlat(struct ata_queued_cmd *qc, const u8 *sc
1150 tf->flags |= ATA_TFLAG_ISADDR | ATA_TFLAG_DEVICE; 1146 tf->flags |= ATA_TFLAG_ISADDR | ATA_TFLAG_DEVICE;
1151 tf->protocol = ATA_PROT_NODATA; 1147 tf->protocol = ATA_PROT_NODATA;
1152 1148
1153 if (scsicmd[0] == VERIFY) 1149 if (cdb[0] == VERIFY)
1154 scsi_10_lba_len(scsicmd, &block, &n_block); 1150 scsi_10_lba_len(cdb, &block, &n_block);
1155 else if (scsicmd[0] == VERIFY_16) 1151 else if (cdb[0] == VERIFY_16)
1156 scsi_16_lba_len(scsicmd, &block, &n_block); 1152 scsi_16_lba_len(cdb, &block, &n_block);
1157 else 1153 else
1158 goto invalid_fld; 1154 goto invalid_fld;
1159 1155
@@ -1229,24 +1225,24 @@ static unsigned int ata_scsi_verify_xlat(struct ata_queued_cmd *qc, const u8 *sc
1229 return 0; 1225 return 0;
1230 1226
1231invalid_fld: 1227invalid_fld:
1232 ata_scsi_set_sense(qc->scsicmd, ILLEGAL_REQUEST, 0x24, 0x0); 1228 ata_scsi_set_sense(scmd, ILLEGAL_REQUEST, 0x24, 0x0);
1233 /* "Invalid field in cbd" */ 1229 /* "Invalid field in cbd" */
1234 return 1; 1230 return 1;
1235 1231
1236out_of_range: 1232out_of_range:
1237 ata_scsi_set_sense(qc->scsicmd, ILLEGAL_REQUEST, 0x21, 0x0); 1233 ata_scsi_set_sense(scmd, ILLEGAL_REQUEST, 0x21, 0x0);
1238 /* "Logical Block Address out of range" */ 1234 /* "Logical Block Address out of range" */
1239 return 1; 1235 return 1;
1240 1236
1241nothing_to_do: 1237nothing_to_do:
1242 qc->scsicmd->result = SAM_STAT_GOOD; 1238 scmd->result = SAM_STAT_GOOD;
1243 return 1; 1239 return 1;
1244} 1240}
1245 1241
1246/** 1242/**
1247 * ata_scsi_rw_xlat - Translate SCSI r/w command into an ATA one 1243 * ata_scsi_rw_xlat - Translate SCSI r/w command into an ATA one
1248 * @qc: Storage for translated ATA taskfile 1244 * @qc: Storage for translated ATA taskfile
1249 * @scsicmd: SCSI command to translate 1245 * @cdb: SCSI command to translate
1250 * 1246 *
1251 * Converts any of six SCSI read/write commands into the 1247 * Converts any of six SCSI read/write commands into the
1252 * ATA counterpart, including starting sector (LBA), 1248 * ATA counterpart, including starting sector (LBA),
@@ -1262,29 +1258,28 @@ nothing_to_do:
1262 * RETURNS: 1258 * RETURNS:
1263 * Zero on success, non-zero on error. 1259 * Zero on success, non-zero on error.
1264 */ 1260 */
1265 1261static unsigned int ata_scsi_rw_xlat(struct ata_queued_cmd *qc, const u8 *cdb)
1266static unsigned int ata_scsi_rw_xlat(struct ata_queued_cmd *qc, const u8 *scsicmd)
1267{ 1262{
1263 struct scsi_cmnd *scmd = qc->scsicmd;
1268 unsigned int tf_flags = 0; 1264 unsigned int tf_flags = 0;
1269 u64 block; 1265 u64 block;
1270 u32 n_block; 1266 u32 n_block;
1271 int rc; 1267 int rc;
1272 1268
1273 if (scsicmd[0] == WRITE_10 || scsicmd[0] == WRITE_6 || 1269 if (cdb[0] == WRITE_10 || cdb[0] == WRITE_6 || cdb[0] == WRITE_16)
1274 scsicmd[0] == WRITE_16)
1275 tf_flags |= ATA_TFLAG_WRITE; 1270 tf_flags |= ATA_TFLAG_WRITE;
1276 1271
1277 /* Calculate the SCSI LBA, transfer length and FUA. */ 1272 /* Calculate the SCSI LBA, transfer length and FUA. */
1278 switch (scsicmd[0]) { 1273 switch (cdb[0]) {
1279 case READ_10: 1274 case READ_10:
1280 case WRITE_10: 1275 case WRITE_10:
1281 scsi_10_lba_len(scsicmd, &block, &n_block); 1276 scsi_10_lba_len(cdb, &block, &n_block);
1282 if (unlikely(scsicmd[1] & (1 << 3))) 1277 if (unlikely(cdb[1] & (1 << 3)))
1283 tf_flags |= ATA_TFLAG_FUA; 1278 tf_flags |= ATA_TFLAG_FUA;
1284 break; 1279 break;
1285 case READ_6: 1280 case READ_6:
1286 case WRITE_6: 1281 case WRITE_6:
1287 scsi_6_lba_len(scsicmd, &block, &n_block); 1282 scsi_6_lba_len(cdb, &block, &n_block);
1288 1283
1289 /* for 6-byte r/w commands, transfer length 0 1284 /* for 6-byte r/w commands, transfer length 0
1290 * means 256 blocks of data, not 0 block. 1285 * means 256 blocks of data, not 0 block.
@@ -1294,8 +1289,8 @@ static unsigned int ata_scsi_rw_xlat(struct ata_queued_cmd *qc, const u8 *scsicm
1294 break; 1289 break;
1295 case READ_16: 1290 case READ_16:
1296 case WRITE_16: 1291 case WRITE_16:
1297 scsi_16_lba_len(scsicmd, &block, &n_block); 1292 scsi_16_lba_len(cdb, &block, &n_block);
1298 if (unlikely(scsicmd[1] & (1 << 3))) 1293 if (unlikely(cdb[1] & (1 << 3)))
1299 tf_flags |= ATA_TFLAG_FUA; 1294 tf_flags |= ATA_TFLAG_FUA;
1300 break; 1295 break;
1301 default: 1296 default:
@@ -1326,17 +1321,17 @@ static unsigned int ata_scsi_rw_xlat(struct ata_queued_cmd *qc, const u8 *scsicm
1326 goto out_of_range; 1321 goto out_of_range;
1327 /* treat all other errors as -EINVAL, fall through */ 1322 /* treat all other errors as -EINVAL, fall through */
1328invalid_fld: 1323invalid_fld:
1329 ata_scsi_set_sense(qc->scsicmd, ILLEGAL_REQUEST, 0x24, 0x0); 1324 ata_scsi_set_sense(scmd, ILLEGAL_REQUEST, 0x24, 0x0);
1330 /* "Invalid field in cbd" */ 1325 /* "Invalid field in cbd" */
1331 return 1; 1326 return 1;
1332 1327
1333out_of_range: 1328out_of_range:
1334 ata_scsi_set_sense(qc->scsicmd, ILLEGAL_REQUEST, 0x21, 0x0); 1329 ata_scsi_set_sense(scmd, ILLEGAL_REQUEST, 0x21, 0x0);
1335 /* "Logical Block Address out of range" */ 1330 /* "Logical Block Address out of range" */
1336 return 1; 1331 return 1;
1337 1332
1338nothing_to_do: 1333nothing_to_do:
1339 qc->scsicmd->result = SAM_STAT_GOOD; 1334 scmd->result = SAM_STAT_GOOD;
1340 return 1; 1335 return 1;
1341} 1336}
1342 1337
@@ -1456,7 +1451,7 @@ static int ata_scsi_translate(struct ata_device *dev, struct scsi_cmnd *cmd,
1456 ata_xlat_func_t xlat_func) 1451 ata_xlat_func_t xlat_func)
1457{ 1452{
1458 struct ata_queued_cmd *qc; 1453 struct ata_queued_cmd *qc;
1459 u8 *scsicmd = cmd->cmnd; 1454 u8 *cdb = cmd->cmnd;
1460 int is_io = xlat_func == ata_scsi_rw_xlat; 1455 int is_io = xlat_func == ata_scsi_rw_xlat;
1461 1456
1462 VPRINTK("ENTER\n"); 1457 VPRINTK("ENTER\n");
@@ -1488,7 +1483,7 @@ static int ata_scsi_translate(struct ata_device *dev, struct scsi_cmnd *cmd,
1488 1483
1489 qc->complete_fn = ata_scsi_qc_complete; 1484 qc->complete_fn = ata_scsi_qc_complete;
1490 1485
1491 if (xlat_func(qc, scsicmd)) 1486 if (xlat_func(qc, cdb))
1492 goto early_finish; 1487 goto early_finish;
1493 1488
1494 /* select device, send command to hardware */ 1489 /* select device, send command to hardware */
@@ -2344,7 +2339,7 @@ static void atapi_qc_complete(struct ata_queued_cmd *qc)
2344/** 2339/**
2345 * atapi_xlat - Initialize PACKET taskfile 2340 * atapi_xlat - Initialize PACKET taskfile
2346 * @qc: command structure to be initialized 2341 * @qc: command structure to be initialized
2347 * @scsicmd: SCSI CDB associated with this PACKET command 2342 * @cdb: SCSI CDB associated with this PACKET command
2348 * 2343 *
2349 * LOCKING: 2344 * LOCKING:
2350 * spin_lock_irqsave(host lock) 2345 * spin_lock_irqsave(host lock)
@@ -2352,25 +2347,24 @@ static void atapi_qc_complete(struct ata_queued_cmd *qc)
2352 * RETURNS: 2347 * RETURNS:
2353 * Zero on success, non-zero on failure. 2348 * Zero on success, non-zero on failure.
2354 */ 2349 */
2355 2350static unsigned int atapi_xlat(struct ata_queued_cmd *qc, const u8 *cdb)
2356static unsigned int atapi_xlat(struct ata_queued_cmd *qc, const u8 *scsicmd)
2357{ 2351{
2358 struct scsi_cmnd *cmd = qc->scsicmd; 2352 struct scsi_cmnd *scmd = qc->scsicmd;
2359 struct ata_device *dev = qc->dev; 2353 struct ata_device *dev = qc->dev;
2360 int using_pio = (dev->flags & ATA_DFLAG_PIO); 2354 int using_pio = (dev->flags & ATA_DFLAG_PIO);
2361 int nodata = (cmd->sc_data_direction == DMA_NONE); 2355 int nodata = (scmd->sc_data_direction == DMA_NONE);
2362 2356
2363 if (!using_pio) 2357 if (!using_pio)
2364 /* Check whether ATAPI DMA is safe */ 2358 /* Check whether ATAPI DMA is safe */
2365 if (ata_check_atapi_dma(qc)) 2359 if (ata_check_atapi_dma(qc))
2366 using_pio = 1; 2360 using_pio = 1;
2367 2361
2368 memcpy(&qc->cdb, scsicmd, dev->cdb_len); 2362 memcpy(&qc->cdb, cdb, dev->cdb_len);
2369 2363
2370 qc->complete_fn = atapi_qc_complete; 2364 qc->complete_fn = atapi_qc_complete;
2371 2365
2372 qc->tf.flags |= ATA_TFLAG_ISADDR | ATA_TFLAG_DEVICE; 2366 qc->tf.flags |= ATA_TFLAG_ISADDR | ATA_TFLAG_DEVICE;
2373 if (cmd->sc_data_direction == DMA_TO_DEVICE) { 2367 if (scmd->sc_data_direction == DMA_TO_DEVICE) {
2374 qc->tf.flags |= ATA_TFLAG_WRITE; 2368 qc->tf.flags |= ATA_TFLAG_WRITE;
2375 DPRINTK("direction: write\n"); 2369 DPRINTK("direction: write\n");
2376 } 2370 }
@@ -2392,12 +2386,12 @@ static unsigned int atapi_xlat(struct ata_queued_cmd *qc, const u8 *scsicmd)
2392 qc->tf.protocol = ATA_PROT_ATAPI_DMA; 2386 qc->tf.protocol = ATA_PROT_ATAPI_DMA;
2393 qc->tf.feature |= ATAPI_PKT_DMA; 2387 qc->tf.feature |= ATAPI_PKT_DMA;
2394 2388
2395 if (atapi_dmadir && (cmd->sc_data_direction != DMA_TO_DEVICE)) 2389 if (atapi_dmadir && (scmd->sc_data_direction != DMA_TO_DEVICE))
2396 /* some SATA bridges need us to indicate data xfer direction */ 2390 /* some SATA bridges need us to indicate data xfer direction */
2397 qc->tf.feature |= ATAPI_DMADIR; 2391 qc->tf.feature |= ATAPI_DMADIR;
2398 } 2392 }
2399 2393
2400 qc->nbytes = cmd->request_bufflen; 2394 qc->nbytes = scmd->request_bufflen;
2401 2395
2402 return 0; 2396 return 0;
2403} 2397}
@@ -2517,28 +2511,27 @@ ata_scsi_map_proto(u8 byte1)
2517/** 2511/**
2518 * ata_scsi_pass_thru - convert ATA pass-thru CDB to taskfile 2512 * ata_scsi_pass_thru - convert ATA pass-thru CDB to taskfile
2519 * @qc: command structure to be initialized 2513 * @qc: command structure to be initialized
2520 * @scsicmd: SCSI command to convert 2514 * @cdb: SCSI command to convert
2521 * 2515 *
2522 * Handles either 12 or 16-byte versions of the CDB. 2516 * Handles either 12 or 16-byte versions of the CDB.
2523 * 2517 *
2524 * RETURNS: 2518 * RETURNS:
2525 * Zero on success, non-zero on failure. 2519 * Zero on success, non-zero on failure.
2526 */ 2520 */
2527static unsigned int 2521static unsigned int ata_scsi_pass_thru(struct ata_queued_cmd *qc, const u8 *cdb)
2528ata_scsi_pass_thru(struct ata_queued_cmd *qc, const u8 *scsicmd)
2529{ 2522{
2530 struct ata_taskfile *tf = &(qc->tf); 2523 struct ata_taskfile *tf = &(qc->tf);
2531 struct scsi_cmnd *cmd = qc->scsicmd; 2524 struct scsi_cmnd *scmd = qc->scsicmd;
2532 struct ata_device *dev = qc->dev; 2525 struct ata_device *dev = qc->dev;
2533 2526
2534 if ((tf->protocol = ata_scsi_map_proto(scsicmd[1])) == ATA_PROT_UNKNOWN) 2527 if ((tf->protocol = ata_scsi_map_proto(cdb[1])) == ATA_PROT_UNKNOWN)
2535 goto invalid_fld; 2528 goto invalid_fld;
2536 2529
2537 /* We may not issue DMA commands if no DMA mode is set */ 2530 /* We may not issue DMA commands if no DMA mode is set */
2538 if (tf->protocol == ATA_PROT_DMA && dev->dma_mode == 0) 2531 if (tf->protocol == ATA_PROT_DMA && dev->dma_mode == 0)
2539 goto invalid_fld; 2532 goto invalid_fld;
2540 2533
2541 if (scsicmd[1] & 0xe0) 2534 if (cdb[1] & 0xe0)
2542 /* PIO multi not supported yet */ 2535 /* PIO multi not supported yet */
2543 goto invalid_fld; 2536 goto invalid_fld;
2544 2537
@@ -2546,18 +2539,18 @@ ata_scsi_pass_thru(struct ata_queued_cmd *qc, const u8 *scsicmd)
2546 * 12 and 16 byte CDBs use different offsets to 2539 * 12 and 16 byte CDBs use different offsets to
2547 * provide the various register values. 2540 * provide the various register values.
2548 */ 2541 */
2549 if (scsicmd[0] == ATA_16) { 2542 if (cdb[0] == ATA_16) {
2550 /* 2543 /*
2551 * 16-byte CDB - may contain extended commands. 2544 * 16-byte CDB - may contain extended commands.
2552 * 2545 *
2553 * If that is the case, copy the upper byte register values. 2546 * If that is the case, copy the upper byte register values.
2554 */ 2547 */
2555 if (scsicmd[1] & 0x01) { 2548 if (cdb[1] & 0x01) {
2556 tf->hob_feature = scsicmd[3]; 2549 tf->hob_feature = cdb[3];
2557 tf->hob_nsect = scsicmd[5]; 2550 tf->hob_nsect = cdb[5];
2558 tf->hob_lbal = scsicmd[7]; 2551 tf->hob_lbal = cdb[7];
2559 tf->hob_lbam = scsicmd[9]; 2552 tf->hob_lbam = cdb[9];
2560 tf->hob_lbah = scsicmd[11]; 2553 tf->hob_lbah = cdb[11];
2561 tf->flags |= ATA_TFLAG_LBA48; 2554 tf->flags |= ATA_TFLAG_LBA48;
2562 } else 2555 } else
2563 tf->flags &= ~ATA_TFLAG_LBA48; 2556 tf->flags &= ~ATA_TFLAG_LBA48;
@@ -2565,26 +2558,26 @@ ata_scsi_pass_thru(struct ata_queued_cmd *qc, const u8 *scsicmd)
2565 /* 2558 /*
2566 * Always copy low byte, device and command registers. 2559 * Always copy low byte, device and command registers.
2567 */ 2560 */
2568 tf->feature = scsicmd[4]; 2561 tf->feature = cdb[4];
2569 tf->nsect = scsicmd[6]; 2562 tf->nsect = cdb[6];
2570 tf->lbal = scsicmd[8]; 2563 tf->lbal = cdb[8];
2571 tf->lbam = scsicmd[10]; 2564 tf->lbam = cdb[10];
2572 tf->lbah = scsicmd[12]; 2565 tf->lbah = cdb[12];
2573 tf->device = scsicmd[13]; 2566 tf->device = cdb[13];
2574 tf->command = scsicmd[14]; 2567 tf->command = cdb[14];
2575 } else { 2568 } else {
2576 /* 2569 /*
2577 * 12-byte CDB - incapable of extended commands. 2570 * 12-byte CDB - incapable of extended commands.
2578 */ 2571 */
2579 tf->flags &= ~ATA_TFLAG_LBA48; 2572 tf->flags &= ~ATA_TFLAG_LBA48;
2580 2573
2581 tf->feature = scsicmd[3]; 2574 tf->feature = cdb[3];
2582 tf->nsect = scsicmd[4]; 2575 tf->nsect = cdb[4];
2583 tf->lbal = scsicmd[5]; 2576 tf->lbal = cdb[5];
2584 tf->lbam = scsicmd[6]; 2577 tf->lbam = cdb[6];
2585 tf->lbah = scsicmd[7]; 2578 tf->lbah = cdb[7];
2586 tf->device = scsicmd[8]; 2579 tf->device = cdb[8];
2587 tf->command = scsicmd[9]; 2580 tf->command = cdb[9];
2588 } 2581 }
2589 /* 2582 /*
2590 * If slave is possible, enforce correct master/slave bit 2583 * If slave is possible, enforce correct master/slave bit
@@ -2611,7 +2604,7 @@ ata_scsi_pass_thru(struct ata_queued_cmd *qc, const u8 *scsicmd)
2611 */ 2604 */
2612 tf->flags |= (ATA_TFLAG_ISADDR | ATA_TFLAG_DEVICE); 2605 tf->flags |= (ATA_TFLAG_ISADDR | ATA_TFLAG_DEVICE);
2613 2606
2614 if (cmd->sc_data_direction == DMA_TO_DEVICE) 2607 if (scmd->sc_data_direction == DMA_TO_DEVICE)
2615 tf->flags |= ATA_TFLAG_WRITE; 2608 tf->flags |= ATA_TFLAG_WRITE;
2616 2609
2617 /* 2610 /*
@@ -2620,7 +2613,7 @@ ata_scsi_pass_thru(struct ata_queued_cmd *qc, const u8 *scsicmd)
2620 * TODO: find out if we need to do more here to 2613 * TODO: find out if we need to do more here to
2621 * cover scatter/gather case. 2614 * cover scatter/gather case.
2622 */ 2615 */
2623 qc->nsect = cmd->request_bufflen / ATA_SECT_SIZE; 2616 qc->nsect = scmd->request_bufflen / ATA_SECT_SIZE;
2624 2617
2625 /* request result TF */ 2618 /* request result TF */
2626 qc->flags |= ATA_QCFLAG_RESULT_TF; 2619 qc->flags |= ATA_QCFLAG_RESULT_TF;
@@ -2628,7 +2621,7 @@ ata_scsi_pass_thru(struct ata_queued_cmd *qc, const u8 *scsicmd)
2628 return 0; 2621 return 0;
2629 2622
2630 invalid_fld: 2623 invalid_fld:
2631 ata_scsi_set_sense(qc->scsicmd, ILLEGAL_REQUEST, 0x24, 0x00); 2624 ata_scsi_set_sense(scmd, ILLEGAL_REQUEST, 0x24, 0x00);
2632 /* "Invalid field in cdb" */ 2625 /* "Invalid field in cdb" */
2633 return 1; 2626 return 1;
2634} 2627}
@@ -2701,7 +2694,7 @@ static inline void ata_scsi_dump_cdb(struct ata_port *ap,
2701#endif 2694#endif
2702} 2695}
2703 2696
2704static inline int __ata_scsi_queuecmd(struct scsi_cmnd *cmd, 2697static inline int __ata_scsi_queuecmd(struct scsi_cmnd *scmd,
2705 void (*done)(struct scsi_cmnd *), 2698 void (*done)(struct scsi_cmnd *),
2706 struct ata_device *dev) 2699 struct ata_device *dev)
2707{ 2700{
@@ -2709,14 +2702,14 @@ static inline int __ata_scsi_queuecmd(struct scsi_cmnd *cmd,
2709 2702
2710 if (dev->class == ATA_DEV_ATA) { 2703 if (dev->class == ATA_DEV_ATA) {
2711 ata_xlat_func_t xlat_func = ata_get_xlat_func(dev, 2704 ata_xlat_func_t xlat_func = ata_get_xlat_func(dev,
2712 cmd->cmnd[0]); 2705 scmd->cmnd[0]);
2713 2706
2714 if (xlat_func) 2707 if (xlat_func)
2715 rc = ata_scsi_translate(dev, cmd, done, xlat_func); 2708 rc = ata_scsi_translate(dev, scmd, done, xlat_func);
2716 else 2709 else
2717 ata_scsi_simulate(dev, cmd, done); 2710 ata_scsi_simulate(dev, scmd, done);
2718 } else 2711 } else
2719 rc = ata_scsi_translate(dev, cmd, done, atapi_xlat); 2712 rc = ata_scsi_translate(dev, scmd, done, atapi_xlat);
2720 2713
2721 return rc; 2714 return rc;
2722} 2715}