qc->private_data = &wait;
qc->complete_fn = ata_qc_complete_internal;
- ata_qc_issue(qc);
+ ata_qc_issue(ap, qc);
spin_unlock_irqrestore(ap->lock, flags);
/**
* ata_qc_issue - issue taskfile to device
+ * @ap: ATA port of interest
* @qc: command to issue to device
*
* Prepare an ATA command to submission to device.
* LOCKING:
* spin_lock_irqsave(host lock)
*/
-void ata_qc_issue(struct ata_queued_cmd *qc)
+void ata_qc_issue(struct ata_port *ap, struct ata_queued_cmd *qc)
{
- struct ata_port *ap = qc->ap;
struct ata_link *link = qc->dev->link;
u8 prot = qc->tf.protocol;
int ata_sas_queuecmd(struct scsi_cmnd *cmd, struct ata_port *ap)
{
if (likely(ata_dev_enabled(ap->link.device)))
- return __ata_scsi_queuecmd(cmd, ap->link.device);
+ return __ata_scsi_queuecmd(cmd, ap->link.device, ap);
cmd->result = (DID_BAD_TARGET << 16);
scsi_done(cmd);
if (qc && !ata_port_eh_scheduled(ap)) {
WARN_ON_ONCE(ap->ops->qc_defer(qc));
link->deferred_qc = NULL;
- ata_qc_issue(qc);
+ ata_qc_issue(ap, qc);
}
spin_unlock_irqrestore(ap->lock, flags);
}
issue_qc:
- ata_qc_issue(qc);
+ ata_qc_issue(ap, qc);
return 0;
defer_qc:
* @dev: ATA device to which the command is addressed
* @cmd: SCSI command to execute
* @xlat_func: Actor which translates @cmd to an ATA taskfile
+ * @ap: ATA port of interest
*
* Our ->queuecommand() function has decided that the SCSI
* command issued can be directly translated into an ATA
* command needs to be deferred.
*/
static int ata_scsi_translate(struct ata_device *dev, struct scsi_cmnd *cmd,
- ata_xlat_func_t xlat_func)
+ ata_xlat_func_t xlat_func, struct ata_port *ap)
{
- struct ata_port *ap = dev->link->ap;
struct ata_queued_cmd *qc;
lockdep_assert_held(ap->lock);
}
enum scsi_qc_status __ata_scsi_queuecmd(struct scsi_cmnd *scmd,
- struct ata_device *dev)
+ struct ata_device *dev,
+ struct ata_port *ap)
{
- struct ata_port *ap = dev->link->ap;
u8 scsi_op = scmd->cmnd[0];
ata_xlat_func_t xlat_func;
}
if (xlat_func)
- return ata_scsi_translate(dev, scmd, xlat_func);
+ return ata_scsi_translate(dev, scmd, xlat_func, ap);
ata_scsi_simulate(dev, scmd);
dev = ata_scsi_find_dev(ap, scsidev);
if (likely(dev))
- rc = __ata_scsi_queuecmd(cmd, dev);
+ rc = __ata_scsi_queuecmd(cmd, dev, ap);
else {
cmd->result = (DID_BAD_TARGET << 16);
scsi_done(cmd);
extern unsigned int ata_dev_set_feature(struct ata_device *dev,
u8 subcmd, u8 action);
extern void ata_qc_free(struct ata_queued_cmd *qc);
-extern void ata_qc_issue(struct ata_queued_cmd *qc);
+extern void ata_qc_issue(struct ata_port *ap, struct ata_queued_cmd *qc);
extern void __ata_qc_complete(struct ata_queued_cmd *qc);
extern int atapi_check_dma(struct ata_queued_cmd *qc);
extern void swap_buf_le16(u16 *buf, unsigned int buf_words);
int ata_scsi_dev_config(struct scsi_device *sdev, struct queue_limits *lim,
struct ata_device *dev);
enum scsi_qc_status __ata_scsi_queuecmd(struct scsi_cmnd *scmd,
- struct ata_device *dev);
+ struct ata_device *dev,
+ struct ata_port *ap);
void ata_scsi_deferred_qc_work(struct work_struct *work);
void ata_scsi_requeue_deferred_qc(struct ata_port *ap);