aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/ata/libata-sff.c443
1 files changed, 220 insertions, 223 deletions
diff --git a/drivers/ata/libata-sff.c b/drivers/ata/libata-sff.c
index 2a229a1d3211..40645ed125b1 100644
--- a/drivers/ata/libata-sff.c
+++ b/drivers/ata/libata-sff.c
@@ -39,6 +39,43 @@
39#include "libata.h" 39#include "libata.h"
40 40
41/** 41/**
42 * ata_check_status - Read device status reg & clear interrupt
43 * @ap: port where the device is
44 *
45 * Reads ATA taskfile status register for currently-selected device
46 * and return its value. This also clears pending interrupts
47 * from this device
48 *
49 * LOCKING:
50 * Inherited from caller.
51 */
52u8 ata_check_status(struct ata_port *ap)
53{
54 return ioread8(ap->ioaddr.status_addr);
55}
56
57/**
58 * ata_altstatus - Read device alternate status reg
59 * @ap: port where the device is
60 *
61 * Reads ATA taskfile alternate status register for
62 * currently-selected device and return its value.
63 *
64 * Note: may NOT be used as the check_altstatus() entry in
65 * ata_port_operations.
66 *
67 * LOCKING:
68 * Inherited from caller.
69 */
70u8 ata_altstatus(struct ata_port *ap)
71{
72 if (ap->ops->check_altstatus)
73 return ap->ops->check_altstatus(ap);
74
75 return ioread8(ap->ioaddr.altstatus_addr);
76}
77
78/**
42 * ata_irq_on - Enable interrupts on a port. 79 * ata_irq_on - Enable interrupts on a port.
43 * @ap: Port on which interrupts are enabled. 80 * @ap: Port on which interrupts are enabled.
44 * 81 *
@@ -66,6 +103,27 @@ u8 ata_irq_on(struct ata_port *ap)
66} 103}
67 104
68/** 105/**
106 * ata_bmdma_irq_clear - Clear PCI IDE BMDMA interrupt.
107 * @ap: Port associated with this ATA transaction.
108 *
109 * Clear interrupt and error flags in DMA status register.
110 *
111 * May be used as the irq_clear() entry in ata_port_operations.
112 *
113 * LOCKING:
114 * spin_lock_irqsave(host lock)
115 */
116void ata_bmdma_irq_clear(struct ata_port *ap)
117{
118 void __iomem *mmio = ap->ioaddr.bmdma_addr;
119
120 if (!mmio)
121 return;
122
123 iowrite8(ioread8(mmio + ATA_DMA_STATUS), mmio + ATA_DMA_STATUS);
124}
125
126/**
69 * ata_tf_load - send taskfile registers to host controller 127 * ata_tf_load - send taskfile registers to host controller
70 * @ap: Port to which output is sent 128 * @ap: Port to which output is sent
71 * @tf: ATA taskfile register set 129 * @tf: ATA taskfile register set
@@ -75,7 +133,6 @@ u8 ata_irq_on(struct ata_port *ap)
75 * LOCKING: 133 * LOCKING:
76 * Inherited from caller. 134 * Inherited from caller.
77 */ 135 */
78
79void ata_tf_load(struct ata_port *ap, const struct ata_taskfile *tf) 136void ata_tf_load(struct ata_port *ap, const struct ata_taskfile *tf)
80{ 137{
81 struct ata_ioports *ioaddr = &ap->ioaddr; 138 struct ata_ioports *ioaddr = &ap->ioaddr;
@@ -126,25 +183,6 @@ void ata_tf_load(struct ata_port *ap, const struct ata_taskfile *tf)
126} 183}
127 184
128/** 185/**
129 * ata_exec_command - issue ATA command to host controller
130 * @ap: port to which command is being issued
131 * @tf: ATA taskfile register set
132 *
133 * Issues ATA command, with proper synchronization with interrupt
134 * handler / other threads.
135 *
136 * LOCKING:
137 * spin_lock_irqsave(host lock)
138 */
139void ata_exec_command(struct ata_port *ap, const struct ata_taskfile *tf)
140{
141 DPRINTK("ata%u: cmd 0x%X\n", ap->print_id, tf->command);
142
143 iowrite8(tf->command, ap->ioaddr.command_addr);
144 ata_pause(ap);
145}
146
147/**
148 * ata_tf_read - input device's ATA taskfile shadow registers 186 * ata_tf_read - input device's ATA taskfile shadow registers
149 * @ap: Port from which input is read 187 * @ap: Port from which input is read
150 * @tf: ATA taskfile register set for storing input 188 * @tf: ATA taskfile register set for storing input
@@ -185,169 +223,22 @@ void ata_tf_read(struct ata_port *ap, struct ata_taskfile *tf)
185} 223}
186 224
187/** 225/**
188 * ata_check_status - Read device status reg & clear interrupt 226 * ata_exec_command - issue ATA command to host controller
189 * @ap: port where the device is 227 * @ap: port to which command is being issued
190 * 228 * @tf: ATA taskfile register set
191 * Reads ATA taskfile status register for currently-selected device
192 * and return its value. This also clears pending interrupts
193 * from this device
194 *
195 * LOCKING:
196 * Inherited from caller.
197 */
198u8 ata_check_status(struct ata_port *ap)
199{
200 return ioread8(ap->ioaddr.status_addr);
201}
202
203/**
204 * ata_altstatus - Read device alternate status reg
205 * @ap: port where the device is
206 *
207 * Reads ATA taskfile alternate status register for
208 * currently-selected device and return its value.
209 *
210 * Note: may NOT be used as the check_altstatus() entry in
211 * ata_port_operations.
212 *
213 * LOCKING:
214 * Inherited from caller.
215 */
216u8 ata_altstatus(struct ata_port *ap)
217{
218 if (ap->ops->check_altstatus)
219 return ap->ops->check_altstatus(ap);
220
221 return ioread8(ap->ioaddr.altstatus_addr);
222}
223
224/**
225 * ata_bmdma_setup - Set up PCI IDE BMDMA transaction
226 * @qc: Info associated with this ATA transaction.
227 *
228 * LOCKING:
229 * spin_lock_irqsave(host lock)
230 */
231void ata_bmdma_setup(struct ata_queued_cmd *qc)
232{
233 struct ata_port *ap = qc->ap;
234 unsigned int rw = (qc->tf.flags & ATA_TFLAG_WRITE);
235 u8 dmactl;
236
237 /* load PRD table addr. */
238 mb(); /* make sure PRD table writes are visible to controller */
239 iowrite32(ap->prd_dma, ap->ioaddr.bmdma_addr + ATA_DMA_TABLE_OFS);
240
241 /* specify data direction, triple-check start bit is clear */
242 dmactl = ioread8(ap->ioaddr.bmdma_addr + ATA_DMA_CMD);
243 dmactl &= ~(ATA_DMA_WR | ATA_DMA_START);
244 if (!rw)
245 dmactl |= ATA_DMA_WR;
246 iowrite8(dmactl, ap->ioaddr.bmdma_addr + ATA_DMA_CMD);
247
248 /* issue r/w command */
249 ap->ops->exec_command(ap, &qc->tf);
250}
251
252/**
253 * ata_bmdma_start - Start a PCI IDE BMDMA transaction
254 * @qc: Info associated with this ATA transaction.
255 *
256 * LOCKING:
257 * spin_lock_irqsave(host lock)
258 */
259void ata_bmdma_start(struct ata_queued_cmd *qc)
260{
261 struct ata_port *ap = qc->ap;
262 u8 dmactl;
263
264 /* start host DMA transaction */
265 dmactl = ioread8(ap->ioaddr.bmdma_addr + ATA_DMA_CMD);
266 iowrite8(dmactl | ATA_DMA_START, ap->ioaddr.bmdma_addr + ATA_DMA_CMD);
267
268 /* Strictly, one may wish to issue an ioread8() here, to
269 * flush the mmio write. However, control also passes
270 * to the hardware at this point, and it will interrupt
271 * us when we are to resume control. So, in effect,
272 * we don't care when the mmio write flushes.
273 * Further, a read of the DMA status register _immediately_
274 * following the write may not be what certain flaky hardware
275 * is expected, so I think it is best to not add a readb()
276 * without first all the MMIO ATA cards/mobos.
277 * Or maybe I'm just being paranoid.
278 *
279 * FIXME: The posting of this write means I/O starts are
280 * unneccessarily delayed for MMIO
281 */
282}
283
284/**
285 * ata_bmdma_irq_clear - Clear PCI IDE BMDMA interrupt.
286 * @ap: Port associated with this ATA transaction.
287 *
288 * Clear interrupt and error flags in DMA status register.
289 *
290 * May be used as the irq_clear() entry in ata_port_operations.
291 *
292 * LOCKING:
293 * spin_lock_irqsave(host lock)
294 */
295void ata_bmdma_irq_clear(struct ata_port *ap)
296{
297 void __iomem *mmio = ap->ioaddr.bmdma_addr;
298
299 if (!mmio)
300 return;
301
302 iowrite8(ioread8(mmio + ATA_DMA_STATUS), mmio + ATA_DMA_STATUS);
303}
304
305/**
306 * ata_noop_irq_clear - Noop placeholder for irq_clear
307 * @ap: Port associated with this ATA transaction.
308 */
309void ata_noop_irq_clear(struct ata_port *ap)
310{
311}
312
313/**
314 * ata_bmdma_status - Read PCI IDE BMDMA status
315 * @ap: Port associated with this ATA transaction.
316 *
317 * Read and return BMDMA status register.
318 *
319 * May be used as the bmdma_status() entry in ata_port_operations.
320 *
321 * LOCKING:
322 * spin_lock_irqsave(host lock)
323 */
324u8 ata_bmdma_status(struct ata_port *ap)
325{
326 return ioread8(ap->ioaddr.bmdma_addr + ATA_DMA_STATUS);
327}
328
329/**
330 * ata_bmdma_stop - Stop PCI IDE BMDMA transfer
331 * @qc: Command we are ending DMA for
332 *
333 * Clears the ATA_DMA_START flag in the dma control register
334 * 229 *
335 * May be used as the bmdma_stop() entry in ata_port_operations. 230 * Issues ATA command, with proper synchronization with interrupt
231 * handler / other threads.
336 * 232 *
337 * LOCKING: 233 * LOCKING:
338 * spin_lock_irqsave(host lock) 234 * spin_lock_irqsave(host lock)
339 */ 235 */
340void ata_bmdma_stop(struct ata_queued_cmd *qc) 236void ata_exec_command(struct ata_port *ap, const struct ata_taskfile *tf)
341{ 237{
342 struct ata_port *ap = qc->ap; 238 DPRINTK("ata%u: cmd 0x%X\n", ap->print_id, tf->command);
343 void __iomem *mmio = ap->ioaddr.bmdma_addr;
344
345 /* clear start/stop bit */
346 iowrite8(ioread8(mmio + ATA_DMA_CMD) & ~ATA_DMA_START,
347 mmio + ATA_DMA_CMD);
348 239
349 /* one-PIO-cycle guaranteed wait, per spec, for HDMA1:0 transition */ 240 iowrite8(tf->command, ap->ioaddr.command_addr);
350 ata_altstatus(ap); /* dummy read */ 241 ata_pause(ap);
351} 242}
352 243
353/** 244/**
@@ -495,7 +386,6 @@ void ata_bmdma_post_internal_cmd(struct ata_queued_cmd *qc)
495 * LOCKING: 386 * LOCKING:
496 * Inherited from caller. 387 * Inherited from caller.
497 */ 388 */
498
499int ata_sff_port_start(struct ata_port *ap) 389int ata_sff_port_start(struct ata_port *ap)
500{ 390{
501 if (ap->ioaddr.bmdma_addr) 391 if (ap->ioaddr.bmdma_addr)
@@ -503,20 +393,149 @@ int ata_sff_port_start(struct ata_port *ap)
503 return 0; 393 return 0;
504} 394}
505 395
396/**
397 * ata_bmdma_setup - Set up PCI IDE BMDMA transaction
398 * @qc: Info associated with this ATA transaction.
399 *
400 * LOCKING:
401 * spin_lock_irqsave(host lock)
402 */
403void ata_bmdma_setup(struct ata_queued_cmd *qc)
404{
405 struct ata_port *ap = qc->ap;
406 unsigned int rw = (qc->tf.flags & ATA_TFLAG_WRITE);
407 u8 dmactl;
408
409 /* load PRD table addr. */
410 mb(); /* make sure PRD table writes are visible to controller */
411 iowrite32(ap->prd_dma, ap->ioaddr.bmdma_addr + ATA_DMA_TABLE_OFS);
412
413 /* specify data direction, triple-check start bit is clear */
414 dmactl = ioread8(ap->ioaddr.bmdma_addr + ATA_DMA_CMD);
415 dmactl &= ~(ATA_DMA_WR | ATA_DMA_START);
416 if (!rw)
417 dmactl |= ATA_DMA_WR;
418 iowrite8(dmactl, ap->ioaddr.bmdma_addr + ATA_DMA_CMD);
419
420 /* issue r/w command */
421 ap->ops->exec_command(ap, &qc->tf);
422}
423
424/**
425 * ata_bmdma_start - Start a PCI IDE BMDMA transaction
426 * @qc: Info associated with this ATA transaction.
427 *
428 * LOCKING:
429 * spin_lock_irqsave(host lock)
430 */
431void ata_bmdma_start(struct ata_queued_cmd *qc)
432{
433 struct ata_port *ap = qc->ap;
434 u8 dmactl;
435
436 /* start host DMA transaction */
437 dmactl = ioread8(ap->ioaddr.bmdma_addr + ATA_DMA_CMD);
438 iowrite8(dmactl | ATA_DMA_START, ap->ioaddr.bmdma_addr + ATA_DMA_CMD);
439
440 /* Strictly, one may wish to issue an ioread8() here, to
441 * flush the mmio write. However, control also passes
442 * to the hardware at this point, and it will interrupt
443 * us when we are to resume control. So, in effect,
444 * we don't care when the mmio write flushes.
445 * Further, a read of the DMA status register _immediately_
446 * following the write may not be what certain flaky hardware
447 * is expected, so I think it is best to not add a readb()
448 * without first all the MMIO ATA cards/mobos.
449 * Or maybe I'm just being paranoid.
450 *
451 * FIXME: The posting of this write means I/O starts are
452 * unneccessarily delayed for MMIO
453 */
454}
455
456/**
457 * ata_bmdma_stop - Stop PCI IDE BMDMA transfer
458 * @qc: Command we are ending DMA for
459 *
460 * Clears the ATA_DMA_START flag in the dma control register
461 *
462 * May be used as the bmdma_stop() entry in ata_port_operations.
463 *
464 * LOCKING:
465 * spin_lock_irqsave(host lock)
466 */
467void ata_bmdma_stop(struct ata_queued_cmd *qc)
468{
469 struct ata_port *ap = qc->ap;
470 void __iomem *mmio = ap->ioaddr.bmdma_addr;
471
472 /* clear start/stop bit */
473 iowrite8(ioread8(mmio + ATA_DMA_CMD) & ~ATA_DMA_START,
474 mmio + ATA_DMA_CMD);
475
476 /* one-PIO-cycle guaranteed wait, per spec, for HDMA1:0 transition */
477 ata_altstatus(ap); /* dummy read */
478}
479
480/**
481 * ata_bmdma_status - Read PCI IDE BMDMA status
482 * @ap: Port associated with this ATA transaction.
483 *
484 * Read and return BMDMA status register.
485 *
486 * May be used as the bmdma_status() entry in ata_port_operations.
487 *
488 * LOCKING:
489 * spin_lock_irqsave(host lock)
490 */
491u8 ata_bmdma_status(struct ata_port *ap)
492{
493 return ioread8(ap->ioaddr.bmdma_addr + ATA_DMA_STATUS);
494}
495
496/**
497 * ata_noop_irq_clear - Noop placeholder for irq_clear
498 * @ap: Port associated with this ATA transaction.
499 */
500void ata_noop_irq_clear(struct ata_port *ap)
501{
502}
503
506#ifdef CONFIG_PCI 504#ifdef CONFIG_PCI
507 505
508static int ata_resources_present(struct pci_dev *pdev, int port) 506/**
507 * ata_pci_clear_simplex - attempt to kick device out of simplex
508 * @pdev: PCI device
509 *
510 * Some PCI ATA devices report simplex mode but in fact can be told to
511 * enter non simplex mode. This implements the necessary logic to
512 * perform the task on such devices. Calling it on other devices will
513 * have -undefined- behaviour.
514 */
515int ata_pci_clear_simplex(struct pci_dev *pdev)
509{ 516{
510 int i; 517 unsigned long bmdma = pci_resource_start(pdev, 4);
518 u8 simplex;
511 519
512 /* Check the PCI resources for this channel are enabled */ 520 if (bmdma == 0)
513 port = port * 2; 521 return -ENOENT;
514 for (i = 0; i < 2; i ++) { 522
515 if (pci_resource_start(pdev, port + i) == 0 || 523 simplex = inb(bmdma + 0x02);
516 pci_resource_len(pdev, port + i) == 0) 524 outb(simplex & 0x60, bmdma + 0x02);
517 return 0; 525 simplex = inb(bmdma + 0x02);
518 } 526 if (simplex & 0x80)
519 return 1; 527 return -EOPNOTSUPP;
528 return 0;
529}
530
531unsigned long ata_pci_default_filter(struct ata_device *adev, unsigned long xfer_mask)
532{
533 /* Filter out DMA modes if the device has been configured by
534 the BIOS as PIO only */
535
536 if (adev->link->ap->ioaddr.bmdma_addr == NULL)
537 xfer_mask &= ~(ATA_MASK_MWDMA | ATA_MASK_UDMA);
538 return xfer_mask;
520} 539}
521 540
522/** 541/**
@@ -576,6 +595,20 @@ int ata_pci_init_bmdma(struct ata_host *host)
576 return 0; 595 return 0;
577} 596}
578 597
598static int ata_resources_present(struct pci_dev *pdev, int port)
599{
600 int i;
601
602 /* Check the PCI resources for this channel are enabled */
603 port = port * 2;
604 for (i = 0; i < 2; i ++) {
605 if (pci_resource_start(pdev, port + i) == 0 ||
606 pci_resource_len(pdev, port + i) == 0)
607 return 0;
608 }
609 return 1;
610}
611
579/** 612/**
580 * ata_pci_init_sff_host - acquire native PCI ATA resources and init host 613 * ata_pci_init_sff_host - acquire native PCI ATA resources and init host
581 * @host: target ATA host 614 * @host: target ATA host
@@ -879,41 +912,5 @@ int ata_pci_init_one(struct pci_dev *pdev,
879 return rc; 912 return rc;
880} 913}
881 914
882/**
883 * ata_pci_clear_simplex - attempt to kick device out of simplex
884 * @pdev: PCI device
885 *
886 * Some PCI ATA devices report simplex mode but in fact can be told to
887 * enter non simplex mode. This implements the necessary logic to
888 * perform the task on such devices. Calling it on other devices will
889 * have -undefined- behaviour.
890 */
891
892int ata_pci_clear_simplex(struct pci_dev *pdev)
893{
894 unsigned long bmdma = pci_resource_start(pdev, 4);
895 u8 simplex;
896
897 if (bmdma == 0)
898 return -ENOENT;
899
900 simplex = inb(bmdma + 0x02);
901 outb(simplex & 0x60, bmdma + 0x02);
902 simplex = inb(bmdma + 0x02);
903 if (simplex & 0x80)
904 return -EOPNOTSUPP;
905 return 0;
906}
907
908unsigned long ata_pci_default_filter(struct ata_device *adev, unsigned long xfer_mask)
909{
910 /* Filter out DMA modes if the device has been configured by
911 the BIOS as PIO only */
912
913 if (adev->link->ap->ioaddr.bmdma_addr == NULL)
914 xfer_mask &= ~(ATA_MASK_MWDMA | ATA_MASK_UDMA);
915 return xfer_mask;
916}
917
918#endif /* CONFIG_PCI */ 915#endif /* CONFIG_PCI */
919 916