Lines Matching refs:qc
119 static void qs_qc_prep(struct ata_queued_cmd *qc);
120 static unsigned int qs_qc_issue(struct ata_queued_cmd *qc);
121 static int qs_check_atapi_dma(struct ata_queued_cmd *qc);
182 static int qs_check_atapi_dma(struct ata_queued_cmd *qc) in qs_check_atapi_dma() argument
252 static unsigned int qs_fill_sg(struct ata_queued_cmd *qc) in qs_fill_sg() argument
255 struct ata_port *ap = qc->ap; in qs_fill_sg()
260 for_each_sg(qc->sg, sg, qc->n_elem, si) { in qs_fill_sg()
279 static void qs_qc_prep(struct ata_queued_cmd *qc) in qs_qc_prep() argument
281 struct qs_port_priv *pp = qc->ap->private_data; in qs_qc_prep()
289 qs_enter_reg_mode(qc->ap); in qs_qc_prep()
290 if (qc->tf.protocol != ATA_PROT_DMA) in qs_qc_prep()
293 nelem = qs_fill_sg(qc); in qs_qc_prep()
295 if ((qc->tf.flags & ATA_TFLAG_WRITE)) in qs_qc_prep()
297 if ((qc->tf.flags & ATA_TFLAG_LBA48)) in qs_qc_prep()
303 *(__le32 *)(&buf[ 4]) = cpu_to_le32(qc->nbytes); in qs_qc_prep()
313 ata_tf_to_fis(&qc->tf, 0, 1, &buf[32]); in qs_qc_prep()
316 static inline void qs_packet_start(struct ata_queued_cmd *qc) in qs_packet_start() argument
318 struct ata_port *ap = qc->ap; in qs_packet_start()
329 static unsigned int qs_qc_issue(struct ata_queued_cmd *qc) in qs_qc_issue() argument
331 struct qs_port_priv *pp = qc->ap->private_data; in qs_qc_issue()
333 switch (qc->tf.protocol) { in qs_qc_issue()
336 qs_packet_start(qc); in qs_qc_issue()
348 return ata_sff_qc_issue(qc); in qs_qc_issue()
351 static void qs_do_or_die(struct ata_queued_cmd *qc, u8 status) in qs_do_or_die() argument
353 qc->err_mask |= ac_err_mask(status); in qs_do_or_die()
355 if (!qc->err_mask) { in qs_do_or_die()
356 ata_qc_complete(qc); in qs_do_or_die()
358 struct ata_port *ap = qc->ap; in qs_do_or_die()
364 if (qc->err_mask == AC_ERR_DEV) in qs_do_or_die()
389 struct ata_queued_cmd *qc; in qs_intr_pkt() local
396 qc = ata_qc_from_tag(ap, ap->link.active_tag); in qs_intr_pkt()
397 if (qc && (!(qc->tf.flags & ATA_TFLAG_POLLING))) { in qs_intr_pkt()
401 qs_enter_reg_mode(qc->ap); in qs_intr_pkt()
402 qs_do_or_die(qc, sDST); in qs_intr_pkt()
420 struct ata_queued_cmd *qc; in qs_intr_mmio() local
422 qc = ata_qc_from_tag(ap, ap->link.active_tag); in qs_intr_mmio()
423 if (!qc) { in qs_intr_mmio()
440 if (!(qc->tf.flags & ATA_TFLAG_POLLING)) in qs_intr_mmio()
441 handled |= ata_sff_port_intr(ap, qc); in qs_intr_mmio()