Lines Matching full:ap
49 /* per-port ATA register offsets (from ap->ioaddr.cmd_addr) */
62 /* per-port SATA register offsets (from ap->ioaddr.scr_addr) */
122 /* ap->flags bits */
140 static int pdc_common_port_start(struct ata_port *ap);
141 static int pdc_sata_port_start(struct ata_port *ap);
143 static void pdc_tf_load_mmio(struct ata_port *ap, const struct ata_taskfile *tf);
144 static void pdc_exec_command_mmio(struct ata_port *ap, const struct ata_taskfile *tf);
147 static void pdc_irq_clear(struct ata_port *ap);
149 static void pdc_freeze(struct ata_port *ap);
150 static void pdc_sata_freeze(struct ata_port *ap);
151 static void pdc_thaw(struct ata_port *ap);
152 static void pdc_sata_thaw(struct ata_port *ap);
157 static void pdc_error_handler(struct ata_port *ap);
159 static int pdc_pata_cable_detect(struct ata_port *ap);
314 static int pdc_common_port_start(struct ata_port *ap) in pdc_common_port_start() argument
316 struct device *dev = ap->host->dev; in pdc_common_port_start()
321 rc = ata_bmdma_port_start(ap); in pdc_common_port_start()
333 ap->private_data = pp; in pdc_common_port_start()
338 static int pdc_sata_port_start(struct ata_port *ap) in pdc_sata_port_start() argument
342 rc = pdc_common_port_start(ap); in pdc_sata_port_start()
347 if (ap->flags & PDC_FLAG_GEN_II) { in pdc_sata_port_start()
348 void __iomem *sata_mmio = ap->ioaddr.scr_addr; in pdc_sata_port_start()
359 static void pdc_fpdma_clear_interrupt_flag(struct ata_port *ap) in pdc_fpdma_clear_interrupt_flag() argument
361 void __iomem *sata_mmio = ap->ioaddr.scr_addr; in pdc_fpdma_clear_interrupt_flag()
374 static void pdc_fpdma_reset(struct ata_port *ap) in pdc_fpdma_reset() argument
376 void __iomem *sata_mmio = ap->ioaddr.scr_addr; in pdc_fpdma_reset()
389 pdc_fpdma_clear_interrupt_flag(ap); in pdc_fpdma_reset()
392 static void pdc_not_at_command_packet_phase(struct ata_port *ap) in pdc_not_at_command_packet_phase() argument
394 void __iomem *sata_mmio = ap->ioaddr.scr_addr; in pdc_not_at_command_packet_phase()
408 static void pdc_clear_internal_debug_record_error_register(struct ata_port *ap) in pdc_clear_internal_debug_record_error_register() argument
410 void __iomem *sata_mmio = ap->ioaddr.scr_addr; in pdc_clear_internal_debug_record_error_register()
416 static void pdc_reset_port(struct ata_port *ap) in pdc_reset_port() argument
418 void __iomem *ata_ctlstat_mmio = ap->ioaddr.cmd_addr + PDC_CTLSTAT; in pdc_reset_port()
422 if (ap->flags & PDC_FLAG_GEN_II) in pdc_reset_port()
423 pdc_not_at_command_packet_phase(ap); in pdc_reset_port()
444 if (sata_scr_valid(&ap->link) && (ap->flags & PDC_FLAG_GEN_II)) { in pdc_reset_port()
445 pdc_fpdma_reset(ap); in pdc_reset_port()
446 pdc_clear_internal_debug_record_error_register(ap); in pdc_reset_port()
450 static int pdc_pata_cable_detect(struct ata_port *ap) in pdc_pata_cable_detect() argument
453 void __iomem *ata_mmio = ap->ioaddr.cmd_addr; in pdc_pata_cable_detect()
466 *val = readl(link->ap->ioaddr.scr_addr + (sc_reg * 4)); in pdc_sata_scr_read()
475 writel(val, link->ap->ioaddr.scr_addr + (sc_reg * 4)); in pdc_sata_scr_write()
481 struct ata_port *ap = qc->ap; in pdc_atapi_pkt() local
482 dma_addr_t sg_table = ap->bmdma_prd_dma; in pdc_atapi_pkt()
485 struct pdc_port_priv *pp = ap->private_data; in pdc_atapi_pkt()
511 if (sata_scr_valid(&ap->link)) in pdc_atapi_pkt()
569 struct ata_port *ap = qc->ap; in pdc_fill_sg() local
570 struct ata_bmdma_prd *prd = ap->bmdma_prd; in pdc_fill_sg()
599 ata_port_dbg(ap, "PRD[%u] = (0x%X, 0x%X)\n", in pdc_fill_sg()
615 ata_port_dbg(ap, "PRD[%u] = (0x%X, 0x%X)\n", in pdc_fill_sg()
622 ata_port_dbg(ap, "PRD[%u] = (0x%X, 0x%X)\n", idx, addr, len); in pdc_fill_sg()
632 struct pdc_port_priv *pp = qc->ap->private_data; in pdc_qc_prep()
640 i = pdc_pkt_header(&qc->tf, qc->ap->bmdma_prd_dma, in pdc_qc_prep()
677 static unsigned int pdc_sata_nr_ports(const struct ata_port *ap) in pdc_sata_nr_ports() argument
679 return (ap->flags & PDC_FLAG_4_PORTS) ? 4 : 2; in pdc_sata_nr_ports()
682 static unsigned int pdc_sata_ata_port_to_ata_no(const struct ata_port *ap) in pdc_sata_ata_port_to_ata_no() argument
684 const struct ata_host *host = ap->host; in pdc_sata_ata_port_to_ata_no()
685 unsigned int nr_ports = pdc_sata_nr_ports(ap); in pdc_sata_ata_port_to_ata_no()
688 for (i = 0; i < nr_ports && host->ports[i] != ap; ++i) in pdc_sata_ata_port_to_ata_no()
691 return pdc_port_no_to_ata_no(i, pdc_is_sataii_tx4(ap->flags)); in pdc_sata_ata_port_to_ata_no()
694 static void pdc_freeze(struct ata_port *ap) in pdc_freeze() argument
696 void __iomem *ata_mmio = ap->ioaddr.cmd_addr; in pdc_freeze()
706 static void pdc_sata_freeze(struct ata_port *ap) in pdc_sata_freeze() argument
708 struct ata_host *host = ap->host; in pdc_sata_freeze()
711 unsigned int ata_no = pdc_sata_ata_port_to_ata_no(ap); in pdc_sata_freeze()
718 * 2) ap->lock == &ap->host->lock in pdc_sata_freeze()
719 * 3) ->freeze() and ->thaw() are called with ap->lock held in pdc_sata_freeze()
726 pdc_freeze(ap); in pdc_sata_freeze()
729 static void pdc_thaw(struct ata_port *ap) in pdc_thaw() argument
731 void __iomem *ata_mmio = ap->ioaddr.cmd_addr; in pdc_thaw()
744 static void pdc_sata_thaw(struct ata_port *ap) in pdc_sata_thaw() argument
746 struct ata_host *host = ap->host; in pdc_sata_thaw()
749 unsigned int ata_no = pdc_sata_ata_port_to_ata_no(ap); in pdc_sata_thaw()
752 pdc_thaw(ap); in pdc_sata_thaw()
767 pdc_reset_port(link->ap); in pdc_pata_softreset()
771 static unsigned int pdc_ata_port_to_ata_no(const struct ata_port *ap) in pdc_ata_port_to_ata_no() argument
773 void __iomem *ata_mmio = ap->ioaddr.cmd_addr; in pdc_ata_port_to_ata_no()
774 void __iomem *host_mmio = ap->host->iomap[PDC_MMIO_BAR]; in pdc_ata_port_to_ata_no()
780 static void pdc_hard_reset_port(struct ata_port *ap) in pdc_hard_reset_port() argument
782 void __iomem *host_mmio = ap->host->iomap[PDC_MMIO_BAR]; in pdc_hard_reset_port()
784 unsigned int ata_no = pdc_ata_port_to_ata_no(ap); in pdc_hard_reset_port()
785 struct pdc_host_priv *hpriv = ap->host->private_data; in pdc_hard_reset_port()
805 if (link->ap->flags & PDC_FLAG_GEN_II) in pdc_sata_hardreset()
806 pdc_not_at_command_packet_phase(link->ap); in pdc_sata_hardreset()
808 pdc_hard_reset_port(link->ap); in pdc_sata_hardreset()
809 pdc_reset_port(link->ap); in pdc_sata_hardreset()
818 static void pdc_error_handler(struct ata_port *ap) in pdc_error_handler() argument
820 if (!(ap->pflags & ATA_PFLAG_FROZEN)) in pdc_error_handler()
821 pdc_reset_port(ap); in pdc_error_handler()
823 ata_sff_error_handler(ap); in pdc_error_handler()
828 struct ata_port *ap = qc->ap; in pdc_post_internal_cmd() local
832 pdc_reset_port(ap); in pdc_post_internal_cmd()
835 static void pdc_error_intr(struct ata_port *ap, struct ata_queued_cmd *qc, in pdc_error_intr() argument
838 struct ata_eh_info *ehi = &ap->link.eh_info; in pdc_error_intr()
855 if (sata_scr_valid(&ap->link)) { in pdc_error_intr()
858 pdc_sata_scr_read(&ap->link, SCR_ERROR, &serror); in pdc_error_intr()
864 pdc_reset_port(ap); in pdc_error_intr()
866 ata_port_abort(ap); in pdc_error_intr()
869 static unsigned int pdc_host_intr(struct ata_port *ap, in pdc_host_intr() argument
873 void __iomem *ata_mmio = ap->ioaddr.cmd_addr; in pdc_host_intr()
877 if (ap->flags & PDC_FLAG_GEN_II) in pdc_host_intr()
883 pdc_error_intr(ap, qc, port_status, err_mask); in pdc_host_intr()
892 qc->err_mask |= ac_err_mask(ata_wait_idle(ap)); in pdc_host_intr()
897 ap->stats.idle_irq++; in pdc_host_intr()
904 static void pdc_irq_clear(struct ata_port *ap) in pdc_irq_clear() argument
906 void __iomem *ata_mmio = ap->ioaddr.cmd_addr; in pdc_irq_clear()
914 struct ata_port *ap; in pdc_interrupt() local
955 ap = host->ports[i]; in pdc_interrupt()
961 struct ata_eh_info *ehi = &ap->link.eh_info; in pdc_interrupt()
965 ata_port_freeze(ap); in pdc_interrupt()
975 qc = ata_qc_from_tag(ap, ap->link.active_tag); in pdc_interrupt()
977 handled += pdc_host_intr(ap, qc); in pdc_interrupt()
988 struct ata_port *ap = qc->ap; in pdc_packet_start() local
989 struct pdc_port_priv *pp = ap->private_data; in pdc_packet_start()
990 void __iomem *host_mmio = ap->host->iomap[PDC_MMIO_BAR]; in pdc_packet_start()
991 void __iomem *ata_mmio = ap->ioaddr.cmd_addr; in pdc_packet_start()
992 unsigned int port_no = ap->port_no; in pdc_packet_start()
1025 static void pdc_tf_load_mmio(struct ata_port *ap, const struct ata_taskfile *tf) in pdc_tf_load_mmio() argument
1028 ata_sff_tf_load(ap, tf); in pdc_tf_load_mmio()
1031 static void pdc_exec_command_mmio(struct ata_port *ap, in pdc_exec_command_mmio() argument
1035 ata_sff_exec_command(ap, tf); in pdc_exec_command_mmio()
1074 static void pdc_ata_setup_port(struct ata_port *ap, in pdc_ata_setup_port() argument
1077 ap->ioaddr.cmd_addr = base; in pdc_ata_setup_port()
1078 ap->ioaddr.data_addr = base; in pdc_ata_setup_port()
1079 ap->ioaddr.feature_addr = in pdc_ata_setup_port()
1080 ap->ioaddr.error_addr = base + 0x4; in pdc_ata_setup_port()
1081 ap->ioaddr.nsect_addr = base + 0x8; in pdc_ata_setup_port()
1082 ap->ioaddr.lbal_addr = base + 0xc; in pdc_ata_setup_port()
1083 ap->ioaddr.lbam_addr = base + 0x10; in pdc_ata_setup_port()
1084 ap->ioaddr.lbah_addr = base + 0x14; in pdc_ata_setup_port()
1085 ap->ioaddr.device_addr = base + 0x18; in pdc_ata_setup_port()
1086 ap->ioaddr.command_addr = in pdc_ata_setup_port()
1087 ap->ioaddr.status_addr = base + 0x1c; in pdc_ata_setup_port()
1088 ap->ioaddr.altstatus_addr = in pdc_ata_setup_port()
1089 ap->ioaddr.ctl_addr = base + 0x38; in pdc_ata_setup_port()
1090 ap->ioaddr.scr_addr = scr_addr; in pdc_ata_setup_port()
1200 struct ata_port *ap = host->ports[i]; in pdc_ata_init_one() local
1205 pdc_ata_setup_port(ap, host_mmio + ata_offset, host_mmio + scr_offset); in pdc_ata_init_one()
1207 ata_port_pbar_desc(ap, PDC_MMIO_BAR, -1, "mmio"); in pdc_ata_init_one()
1208 ata_port_pbar_desc(ap, PDC_MMIO_BAR, ata_offset, "ata"); in pdc_ata_init_one()