Lines Matching +full:tf +full:- +full:a
1 // SPDX-License-Identifier: GPL-2.0-or-later
3 * sata_svw.c - ServerWorks / Apple K2 SATA
7 * Please ALWAYS copy linux-ide@vger.kernel.org
14 * This driver probably works with non-Apple versions of the
18 * as Documentation/driver-api/libata.rst
40 /* ap->flags bits */
84 u8 cmnd = qc->scsicmd->cmnd[0]; in k2_sata_check_atapi_dma()
86 if (qc->ap->flags & K2_FLAG_NO_ATAPI_DMA) in k2_sata_check_atapi_dma()
87 return -1; /* ATAPI DMA not supported */ in k2_sata_check_atapi_dma()
99 return -1; in k2_sata_check_atapi_dma()
109 return -EINVAL; in k2_sata_scr_read()
110 *val = readl(link->ap->ioaddr.scr_addr + (sc_reg * 4)); in k2_sata_scr_read()
119 return -EINVAL; in k2_sata_scr_write()
120 writel(val, link->ap->ioaddr.scr_addr + (sc_reg * 4)); in k2_sata_scr_write()
128 void __iomem *mmio = link->ap->ioaddr.bmdma_addr; in k2_sata_softreset()
145 void __iomem *mmio = link->ap->ioaddr.bmdma_addr; in k2_sata_hardreset()
158 static void k2_sata_tf_load(struct ata_port *ap, const struct ata_taskfile *tf) in k2_sata_tf_load() argument
160 struct ata_ioports *ioaddr = &ap->ioaddr; in k2_sata_tf_load()
161 unsigned int is_addr = tf->flags & ATA_TFLAG_ISADDR; in k2_sata_tf_load()
163 if (tf->ctl != ap->last_ctl) { in k2_sata_tf_load()
164 writeb(tf->ctl, ioaddr->ctl_addr); in k2_sata_tf_load()
165 ap->last_ctl = tf->ctl; in k2_sata_tf_load()
168 if (is_addr && (tf->flags & ATA_TFLAG_LBA48)) { in k2_sata_tf_load()
169 writew(tf->feature | (((u16)tf->hob_feature) << 8), in k2_sata_tf_load()
170 ioaddr->feature_addr); in k2_sata_tf_load()
171 writew(tf->nsect | (((u16)tf->hob_nsect) << 8), in k2_sata_tf_load()
172 ioaddr->nsect_addr); in k2_sata_tf_load()
173 writew(tf->lbal | (((u16)tf->hob_lbal) << 8), in k2_sata_tf_load()
174 ioaddr->lbal_addr); in k2_sata_tf_load()
175 writew(tf->lbam | (((u16)tf->hob_lbam) << 8), in k2_sata_tf_load()
176 ioaddr->lbam_addr); in k2_sata_tf_load()
177 writew(tf->lbah | (((u16)tf->hob_lbah) << 8), in k2_sata_tf_load()
178 ioaddr->lbah_addr); in k2_sata_tf_load()
180 writew(tf->feature, ioaddr->feature_addr); in k2_sata_tf_load()
181 writew(tf->nsect, ioaddr->nsect_addr); in k2_sata_tf_load()
182 writew(tf->lbal, ioaddr->lbal_addr); in k2_sata_tf_load()
183 writew(tf->lbam, ioaddr->lbam_addr); in k2_sata_tf_load()
184 writew(tf->lbah, ioaddr->lbah_addr); in k2_sata_tf_load()
187 if (tf->flags & ATA_TFLAG_DEVICE) in k2_sata_tf_load()
188 writeb(tf->device, ioaddr->device_addr); in k2_sata_tf_load()
194 static void k2_sata_tf_read(struct ata_port *ap, struct ata_taskfile *tf) in k2_sata_tf_read() argument
196 struct ata_ioports *ioaddr = &ap->ioaddr; in k2_sata_tf_read()
199 tf->command = k2_stat_check_status(ap); in k2_sata_tf_read()
200 tf->device = readw(ioaddr->device_addr); in k2_sata_tf_read()
201 feature = readw(ioaddr->error_addr); in k2_sata_tf_read()
202 nsect = readw(ioaddr->nsect_addr); in k2_sata_tf_read()
203 lbal = readw(ioaddr->lbal_addr); in k2_sata_tf_read()
204 lbam = readw(ioaddr->lbam_addr); in k2_sata_tf_read()
205 lbah = readw(ioaddr->lbah_addr); in k2_sata_tf_read()
207 tf->feature = feature; in k2_sata_tf_read()
208 tf->nsect = nsect; in k2_sata_tf_read()
209 tf->lbal = lbal; in k2_sata_tf_read()
210 tf->lbam = lbam; in k2_sata_tf_read()
211 tf->lbah = lbah; in k2_sata_tf_read()
213 if (tf->flags & ATA_TFLAG_LBA48) { in k2_sata_tf_read()
214 tf->hob_feature = feature >> 8; in k2_sata_tf_read()
215 tf->hob_nsect = nsect >> 8; in k2_sata_tf_read()
216 tf->hob_lbal = lbal >> 8; in k2_sata_tf_read()
217 tf->hob_lbam = lbam >> 8; in k2_sata_tf_read()
218 tf->hob_lbah = lbah >> 8; in k2_sata_tf_read()
223 * k2_bmdma_setup_mmio - Set up PCI IDE BMDMA transaction (MMIO)
232 struct ata_port *ap = qc->ap; in k2_bmdma_setup_mmio()
233 unsigned int rw = (qc->tf.flags & ATA_TFLAG_WRITE); in k2_bmdma_setup_mmio()
235 void __iomem *mmio = ap->ioaddr.bmdma_addr; in k2_bmdma_setup_mmio()
239 writel(ap->bmdma_prd_dma, mmio + ATA_DMA_TABLE_OFS); in k2_bmdma_setup_mmio()
241 /* specify data direction, triple-check start bit is clear */ in k2_bmdma_setup_mmio()
248 /* issue r/w command if this is not a ATA DMA command*/ in k2_bmdma_setup_mmio()
249 if (qc->tf.protocol != ATA_PROT_DMA) in k2_bmdma_setup_mmio()
250 ap->ops->sff_exec_command(ap, &qc->tf); in k2_bmdma_setup_mmio()
254 * k2_bmdma_start_mmio - Start a PCI IDE BMDMA transaction (MMIO)
263 struct ata_port *ap = qc->ap; in k2_bmdma_start_mmio()
264 void __iomem *mmio = ap->ioaddr.bmdma_addr; in k2_bmdma_start_mmio()
276 On a Read command, the controller would initiate the in k2_bmdma_start_mmio()
280 cache, there is the possibility that the drive returns a in k2_bmdma_start_mmio()
289 the SATA controller is sitting behind a number of bridges, in k2_bmdma_start_mmio()
293 if (qc->tf.protocol == ATA_PROT_DMA) in k2_bmdma_start_mmio()
294 ap->ops->sff_exec_command(ap, &qc->tf); in k2_bmdma_start_mmio()
300 return readl(ap->ioaddr.status_addr); in k2_stat_check_status()
315 np = pci_device_to_OF_node(to_pci_dev(ap->host->dev)); in k2_sata_show_info()
319 /* Match it to a port node */ in k2_sata_show_info()
320 index = (ap == ap->host->ports[0]) ? 0 : 1; in k2_sata_show_info()
321 for (np = np->child; np != NULL; np = np->sibling) { in k2_sata_show_info()
391 port->cmd_addr = base + K2_SATA_TF_CMD_OFFSET; in k2_sata_setup_port()
392 port->data_addr = base + K2_SATA_TF_DATA_OFFSET; in k2_sata_setup_port()
393 port->feature_addr = in k2_sata_setup_port()
394 port->error_addr = base + K2_SATA_TF_ERROR_OFFSET; in k2_sata_setup_port()
395 port->nsect_addr = base + K2_SATA_TF_NSECT_OFFSET; in k2_sata_setup_port()
396 port->lbal_addr = base + K2_SATA_TF_LBAL_OFFSET; in k2_sata_setup_port()
397 port->lbam_addr = base + K2_SATA_TF_LBAM_OFFSET; in k2_sata_setup_port()
398 port->lbah_addr = base + K2_SATA_TF_LBAH_OFFSET; in k2_sata_setup_port()
399 port->device_addr = base + K2_SATA_TF_DEVICE_OFFSET; in k2_sata_setup_port()
400 port->command_addr = in k2_sata_setup_port()
401 port->status_addr = base + K2_SATA_TF_CMDSTAT_OFFSET; in k2_sata_setup_port()
402 port->altstatus_addr = in k2_sata_setup_port()
403 port->ctl_addr = base + K2_SATA_TF_CTL_OFFSET; in k2_sata_setup_port()
404 port->bmdma_addr = base + K2_SATA_DMA_CMD_OFFSET; in k2_sata_setup_port()
405 port->scr_addr = base + K2_SATA_SCR_STATUS_OFFSET; in k2_sata_setup_port()
412 { &k2_port_info[ent->driver_data], NULL }; in k2_sata_init_one()
417 ata_print_version_once(&pdev->dev, DRV_VERSION); in k2_sata_init_one()
421 if (ppi[0]->flags & K2_FLAG_SATA_8_PORTS) in k2_sata_init_one()
424 host = ata_host_alloc_pinfo(&pdev->dev, ppi, n_ports); in k2_sata_init_one()
426 return -ENOMEM; in k2_sata_init_one()
429 if (ppi[0]->flags & K2_FLAG_BAR_POS_3) in k2_sata_init_one()
433 * we should check that here as it has a normal Serverworks ID in k2_sata_init_one()
449 return -ENODEV; in k2_sata_init_one()
454 if (rc == -EBUSY) in k2_sata_init_one()
458 host->iomap = pcim_iomap_table(pdev); in k2_sata_init_one()
459 mmio_base = host->iomap[bar_pos]; in k2_sata_init_one()
461 /* different controllers have different number of ports - currently 4 or 8 */ in k2_sata_init_one()
462 /* All ports are on the same function. Multi-function device is no in k2_sata_init_one()
464 for (i = 0; i < host->n_ports; i++) { in k2_sata_init_one()
465 struct ata_port *ap = host->ports[i]; in k2_sata_init_one()
468 k2_sata_setup_port(&ap->ioaddr, mmio_base + offset); in k2_sata_init_one()
470 ata_port_pbar_desc(ap, 5, -1, "mmio"); in k2_sata_init_one()
474 rc = dma_set_mask_and_coherent(&pdev->dev, ATA_DMA_MASK); in k2_sata_init_one()
478 /* Clear a magic bit in SCR1 according to Darwin, those help in k2_sata_init_one()
490 return ata_host_activate(host, pdev->irq, ata_bmdma_interrupt, in k2_sata_init_one()
522 MODULE_DESCRIPTION("low-level driver for K2 SATA controller");