aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi/libata-scsi.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/scsi/libata-scsi.c')
-rw-r--r--drivers/scsi/libata-scsi.c40
1 files changed, 17 insertions, 23 deletions
diff --git a/drivers/scsi/libata-scsi.c b/drivers/scsi/libata-scsi.c
index ce90b6352a81..fcbf64e741bb 100644
--- a/drivers/scsi/libata-scsi.c
+++ b/drivers/scsi/libata-scsi.c
@@ -302,7 +302,6 @@ int ata_scsi_ioctl(struct scsi_device *scsidev, int cmd, void __user *arg)
302 302
303/** 303/**
304 * ata_scsi_qc_new - acquire new ata_queued_cmd reference 304 * ata_scsi_qc_new - acquire new ata_queued_cmd reference
305 * @ap: ATA port to which the new command is attached
306 * @dev: ATA device to which the new command is attached 305 * @dev: ATA device to which the new command is attached
307 * @cmd: SCSI command that originated this ATA command 306 * @cmd: SCSI command that originated this ATA command
308 * @done: SCSI command completion function 307 * @done: SCSI command completion function
@@ -321,14 +320,13 @@ int ata_scsi_ioctl(struct scsi_device *scsidev, int cmd, void __user *arg)
321 * RETURNS: 320 * RETURNS:
322 * Command allocated, or %NULL if none available. 321 * Command allocated, or %NULL if none available.
323 */ 322 */
324struct ata_queued_cmd *ata_scsi_qc_new(struct ata_port *ap, 323struct ata_queued_cmd *ata_scsi_qc_new(struct ata_device *dev,
325 struct ata_device *dev,
326 struct scsi_cmnd *cmd, 324 struct scsi_cmnd *cmd,
327 void (*done)(struct scsi_cmnd *)) 325 void (*done)(struct scsi_cmnd *))
328{ 326{
329 struct ata_queued_cmd *qc; 327 struct ata_queued_cmd *qc;
330 328
331 qc = ata_qc_new_init(ap, dev); 329 qc = ata_qc_new_init(dev);
332 if (qc) { 330 if (qc) {
333 qc->scsicmd = cmd; 331 qc->scsicmd = cmd;
334 qc->scsidone = done; 332 qc->scsidone = done;
@@ -398,7 +396,7 @@ int ata_scsi_device_resume(struct scsi_device *sdev)
398 struct ata_port *ap = ata_shost_to_port(sdev->host); 396 struct ata_port *ap = ata_shost_to_port(sdev->host);
399 struct ata_device *dev = &ap->device[sdev->id]; 397 struct ata_device *dev = &ap->device[sdev->id];
400 398
401 return ata_device_resume(ap, dev); 399 return ata_device_resume(dev);
402} 400}
403 401
404int ata_scsi_device_suspend(struct scsi_device *sdev, pm_message_t state) 402int ata_scsi_device_suspend(struct scsi_device *sdev, pm_message_t state)
@@ -406,7 +404,7 @@ int ata_scsi_device_suspend(struct scsi_device *sdev, pm_message_t state)
406 struct ata_port *ap = ata_shost_to_port(sdev->host); 404 struct ata_port *ap = ata_shost_to_port(sdev->host);
407 struct ata_device *dev = &ap->device[sdev->id]; 405 struct ata_device *dev = &ap->device[sdev->id];
408 406
409 return ata_device_suspend(ap, dev, state); 407 return ata_device_suspend(dev, state);
410} 408}
411 409
412/** 410/**
@@ -1224,7 +1222,6 @@ static void ata_scsi_qc_complete(struct ata_queued_cmd *qc)
1224 1222
1225/** 1223/**
1226 * ata_scsi_translate - Translate then issue SCSI command to ATA device 1224 * ata_scsi_translate - Translate then issue SCSI command to ATA device
1227 * @ap: ATA port to which the command is addressed
1228 * @dev: ATA device to which the command is addressed 1225 * @dev: ATA device to which the command is addressed
1229 * @cmd: SCSI command to execute 1226 * @cmd: SCSI command to execute
1230 * @done: SCSI command completion function 1227 * @done: SCSI command completion function
@@ -1247,17 +1244,16 @@ static void ata_scsi_qc_complete(struct ata_queued_cmd *qc)
1247 * spin_lock_irqsave(host_set lock) 1244 * spin_lock_irqsave(host_set lock)
1248 */ 1245 */
1249 1246
1250static void ata_scsi_translate(struct ata_port *ap, struct ata_device *dev, 1247static void ata_scsi_translate(struct ata_device *dev, struct scsi_cmnd *cmd,
1251 struct scsi_cmnd *cmd, 1248 void (*done)(struct scsi_cmnd *),
1252 void (*done)(struct scsi_cmnd *), 1249 ata_xlat_func_t xlat_func)
1253 ata_xlat_func_t xlat_func)
1254{ 1250{
1255 struct ata_queued_cmd *qc; 1251 struct ata_queued_cmd *qc;
1256 u8 *scsicmd = cmd->cmnd; 1252 u8 *scsicmd = cmd->cmnd;
1257 1253
1258 VPRINTK("ENTER\n"); 1254 VPRINTK("ENTER\n");
1259 1255
1260 qc = ata_scsi_qc_new(ap, dev, cmd, done); 1256 qc = ata_scsi_qc_new(dev, cmd, done);
1261 if (!qc) 1257 if (!qc)
1262 goto err_mem; 1258 goto err_mem;
1263 1259
@@ -1266,7 +1262,7 @@ static void ata_scsi_translate(struct ata_port *ap, struct ata_device *dev,
1266 cmd->sc_data_direction == DMA_TO_DEVICE) { 1262 cmd->sc_data_direction == DMA_TO_DEVICE) {
1267 if (unlikely(cmd->request_bufflen < 1)) { 1263 if (unlikely(cmd->request_bufflen < 1)) {
1268 printk(KERN_WARNING "ata%u(%u): WARNING: zero len r/w req\n", 1264 printk(KERN_WARNING "ata%u(%u): WARNING: zero len r/w req\n",
1269 ap->id, dev->devno); 1265 dev->ap->id, dev->devno);
1270 goto err_did; 1266 goto err_did;
1271 } 1267 }
1272 1268
@@ -2433,19 +2429,20 @@ static inline void ata_scsi_dump_cdb(struct ata_port *ap,
2433#endif 2429#endif
2434} 2430}
2435 2431
2436static inline void __ata_scsi_queuecmd(struct scsi_cmnd *cmd, void (*done)(struct scsi_cmnd *), 2432static inline void __ata_scsi_queuecmd(struct scsi_cmnd *cmd,
2437 struct ata_port *ap, struct ata_device *dev) 2433 void (*done)(struct scsi_cmnd *),
2434 struct ata_device *dev)
2438{ 2435{
2439 if (dev->class == ATA_DEV_ATA) { 2436 if (dev->class == ATA_DEV_ATA) {
2440 ata_xlat_func_t xlat_func = ata_get_xlat_func(dev, 2437 ata_xlat_func_t xlat_func = ata_get_xlat_func(dev,
2441 cmd->cmnd[0]); 2438 cmd->cmnd[0]);
2442 2439
2443 if (xlat_func) 2440 if (xlat_func)
2444 ata_scsi_translate(ap, dev, cmd, done, xlat_func); 2441 ata_scsi_translate(dev, cmd, done, xlat_func);
2445 else 2442 else
2446 ata_scsi_simulate(ap, dev, cmd, done); 2443 ata_scsi_simulate(dev, cmd, done);
2447 } else 2444 } else
2448 ata_scsi_translate(ap, dev, cmd, done, atapi_xlat); 2445 ata_scsi_translate(dev, cmd, done, atapi_xlat);
2449} 2446}
2450 2447
2451/** 2448/**
@@ -2483,7 +2480,7 @@ int ata_scsi_queuecmd(struct scsi_cmnd *cmd, void (*done)(struct scsi_cmnd *))
2483 2480
2484 dev = ata_scsi_find_dev(ap, scsidev); 2481 dev = ata_scsi_find_dev(ap, scsidev);
2485 if (likely(dev)) 2482 if (likely(dev))
2486 __ata_scsi_queuecmd(cmd, done, ap, dev); 2483 __ata_scsi_queuecmd(cmd, done, dev);
2487 else { 2484 else {
2488 cmd->result = (DID_BAD_TARGET << 16); 2485 cmd->result = (DID_BAD_TARGET << 16);
2489 done(cmd); 2486 done(cmd);
@@ -2496,7 +2493,6 @@ int ata_scsi_queuecmd(struct scsi_cmnd *cmd, void (*done)(struct scsi_cmnd *))
2496 2493
2497/** 2494/**
2498 * ata_scsi_simulate - simulate SCSI command on ATA device 2495 * ata_scsi_simulate - simulate SCSI command on ATA device
2499 * @ap: port the device is connected to
2500 * @dev: the target device 2496 * @dev: the target device
2501 * @cmd: SCSI command being sent to device. 2497 * @cmd: SCSI command being sent to device.
2502 * @done: SCSI command completion function. 2498 * @done: SCSI command completion function.
@@ -2508,14 +2504,12 @@ int ata_scsi_queuecmd(struct scsi_cmnd *cmd, void (*done)(struct scsi_cmnd *))
2508 * spin_lock_irqsave(host_set lock) 2504 * spin_lock_irqsave(host_set lock)
2509 */ 2505 */
2510 2506
2511void ata_scsi_simulate(struct ata_port *ap, struct ata_device *dev, 2507void ata_scsi_simulate(struct ata_device *dev, struct scsi_cmnd *cmd,
2512 struct scsi_cmnd *cmd,
2513 void (*done)(struct scsi_cmnd *)) 2508 void (*done)(struct scsi_cmnd *))
2514{ 2509{
2515 struct ata_scsi_args args; 2510 struct ata_scsi_args args;
2516 const u8 *scsicmd = cmd->cmnd; 2511 const u8 *scsicmd = cmd->cmnd;
2517 2512
2518 args.ap = ap;
2519 args.dev = dev; 2513 args.dev = dev;
2520 args.id = dev->id; 2514 args.id = dev->id;
2521 args.cmd = cmd; 2515 args.cmd = cmd;