Commit 2505cc5c authored by Jeff Garzik's avatar Jeff Garzik

[libata] clean up command queue/submit path a bit

This change is part of a series that compartmentalizes and consolidates
ATA taskfile submission.

Here, the device-location-related checks are moved out of the ->queuecommand()
hook and into an inline helper function.
parent baf3f9d4
...@@ -938,6 +938,32 @@ static void atapi_scsi_queuecmd(struct ata_port *ap, struct ata_device *dev, ...@@ -938,6 +938,32 @@ static void atapi_scsi_queuecmd(struct ata_port *ap, struct ata_device *dev,
DPRINTK("EXIT - badcmd\n"); DPRINTK("EXIT - badcmd\n");
} }
static inline struct ata_device *
ata_scsi_find_dev(struct ata_port *ap, struct scsi_cmnd *cmd)
{
struct ata_device *dev;
/* skip commands not addressed to targets we simulate */
if (likely(cmd->device->id < ATA_MAX_DEVICES))
dev = &ap->device[cmd->device->id];
else
return NULL;
if (unlikely((cmd->device->channel != 0) ||
(cmd->device->lun != 0)))
return NULL;
if (unlikely(!ata_dev_present(dev)))
return NULL;
#ifndef ATA_ENABLE_ATAPI
if (unlikely(dev->class == ATA_DEV_ATAPI))
return NULL;
#endif
return dev;
}
/** /**
* ata_scsi_queuecmd - Issue SCSI cdb to libata-managed device * ata_scsi_queuecmd - Issue SCSI cdb to libata-managed device
* @cmd: SCSI command to be sent * @cmd: SCSI command to be sent
...@@ -963,12 +989,6 @@ int ata_scsi_queuecmd(struct scsi_cmnd *cmd, void (*done)(struct scsi_cmnd *)) ...@@ -963,12 +989,6 @@ int ata_scsi_queuecmd(struct scsi_cmnd *cmd, void (*done)(struct scsi_cmnd *))
struct ata_port *ap; struct ata_port *ap;
struct ata_device *dev; struct ata_device *dev;
struct ata_scsi_args args; struct ata_scsi_args args;
const unsigned int atapi_support =
#ifdef ATA_ENABLE_ATAPI
1;
#else
0;
#endif
ap = (struct ata_port *) &cmd->device->host->hostdata[0]; ap = (struct ata_port *) &cmd->device->host->hostdata[0];
...@@ -979,34 +999,15 @@ int ata_scsi_queuecmd(struct scsi_cmnd *cmd, void (*done)(struct scsi_cmnd *)) ...@@ -979,34 +999,15 @@ int ata_scsi_queuecmd(struct scsi_cmnd *cmd, void (*done)(struct scsi_cmnd *))
scsicmd[4], scsicmd[5], scsicmd[6], scsicmd[7], scsicmd[4], scsicmd[5], scsicmd[6], scsicmd[7],
scsicmd[8]); scsicmd[8]);
/* skip commands not addressed to targets we care about */ dev = ata_scsi_find_dev(ap, cmd);
if ((cmd->device->channel != 0) || (cmd->device->lun != 0) || if (unlikely(!dev)) {
(cmd->device->id >= ATA_MAX_DEVICES)) { cmd->result = (DID_BAD_TARGET << 16);
cmd->result = (DID_BAD_TARGET << 16); /* FIXME: correct? */
done(cmd);
goto out;
}
dev = &ap->device[cmd->device->id];
if (!ata_dev_present(dev)) {
DPRINTK("no device\n");
cmd->result = (DID_BAD_TARGET << 16); /* FIXME: correct? */
done(cmd); done(cmd);
goto out_unlock; goto out_unlock;
} }
if (dev->class == ATA_DEV_ATAPI) {
if (atapi_support)
atapi_scsi_queuecmd(ap, dev, cmd, done);
else {
cmd->result = (DID_BAD_TARGET << 16); /* correct? */
done(cmd);
}
goto out_unlock;
}
/* fast path */ /* fast path */
if (dev->class == ATA_DEV_ATA) {
switch(scsicmd[0]) { switch(scsicmd[0]) {
case READ_6: case READ_6:
case WRITE_6: case WRITE_6:
...@@ -1028,6 +1029,12 @@ int ata_scsi_queuecmd(struct scsi_cmnd *cmd, void (*done)(struct scsi_cmnd *)) ...@@ -1028,6 +1029,12 @@ int ata_scsi_queuecmd(struct scsi_cmnd *cmd, void (*done)(struct scsi_cmnd *))
break; break;
} }
} else {
assert (dev->class == ATA_DEV_ATAPI);
atapi_scsi_queuecmd(ap, dev, cmd, done);
goto out_unlock;
}
/* /*
* slow path * slow path
*/ */
...@@ -1100,8 +1107,7 @@ int ata_scsi_queuecmd(struct scsi_cmnd *cmd, void (*done)(struct scsi_cmnd *)) ...@@ -1100,8 +1107,7 @@ int ata_scsi_queuecmd(struct scsi_cmnd *cmd, void (*done)(struct scsi_cmnd *))
break; break;
} }
out_unlock: /* I will kill this soon... reduces 2.4 diff */ out_unlock:
out:
return 0; return 0;
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment