2 * Driver for the Octeon bootbus compact flash.
4 * This file is subject to the terms and conditions of the GNU General Public
5 * License. See the file "COPYING" in the main directory of this archive
8 * Copyright (C) 2005 - 2009 Cavium Networks
9 * Copyright (C) 2008 Wind River Systems
12 #include <linux/kernel.h>
13 #include <linux/module.h>
14 #include <linux/libata.h>
15 #include <linux/irq.h>
16 #include <linux/slab.h>
17 #include <linux/platform_device.h>
18 #include <linux/workqueue.h>
19 #include <scsi/scsi_host.h>
21 #include <asm/octeon/octeon.h>
24 * The Octeon bootbus compact flash interface is connected in at least
25 * 3 different configurations on various evaluation boards:
27 * -- 8 bits no irq, no DMA
28 * -- 16 bits no irq, no DMA
29 * -- 16 bits True IDE mode with DMA, but no irq.
31 * In the last case the DMA engine can generate an interrupt when the
32 * transfer is complete. For the first two cases only PIO is supported.
36 #define DRV_NAME "pata_octeon_cf"
37 #define DRV_VERSION "2.1"
40 struct octeon_cf_port
{
41 struct workqueue_struct
*wq
;
42 struct delayed_work delayed_finish
;
47 static struct scsi_host_template octeon_cf_sht
= {
48 ATA_PIO_SHT(DRV_NAME
),
52 * Convert nanosecond based time to setting used in the
53 * boot bus timing register, based on timing multiple
55 static unsigned int ns_to_tim_reg(unsigned int tim_mult
, unsigned int nsecs
)
60 * Compute # of eclock periods to get desired duration in
63 val
= DIV_ROUND_UP(nsecs
* (octeon_get_clock_rate() / 1000000),
69 static void octeon_cf_set_boot_reg_cfg(int cs
)
71 union cvmx_mio_boot_reg_cfgx reg_cfg
;
72 reg_cfg
.u64
= cvmx_read_csr(CVMX_MIO_BOOT_REG_CFGX(cs
));
73 reg_cfg
.s
.dmack
= 0; /* Don't assert DMACK on access */
74 reg_cfg
.s
.tim_mult
= 2; /* Timing mutiplier 2x */
75 reg_cfg
.s
.rd_dly
= 0; /* Sample on falling edge of BOOT_OE */
76 reg_cfg
.s
.sam
= 0; /* Don't combine write and output enable */
77 reg_cfg
.s
.we_ext
= 0; /* No write enable extension */
78 reg_cfg
.s
.oe_ext
= 0; /* No read enable extension */
79 reg_cfg
.s
.en
= 1; /* Enable this region */
80 reg_cfg
.s
.orbit
= 0; /* Don't combine with previous region */
81 reg_cfg
.s
.ale
= 0; /* Don't do address multiplexing */
82 cvmx_write_csr(CVMX_MIO_BOOT_REG_CFGX(cs
), reg_cfg
.u64
);
86 * Called after libata determines the needed PIO mode. This
87 * function programs the Octeon bootbus regions to support the
88 * timing requirements of the PIO mode.
90 * @ap: ATA port information
93 static void octeon_cf_set_piomode(struct ata_port
*ap
, struct ata_device
*dev
)
95 struct octeon_cf_data
*ocd
= ap
->dev
->platform_data
;
96 union cvmx_mio_boot_reg_timx reg_tim
;
97 int cs
= ocd
->base_region
;
99 struct ata_timing timing
;
104 /* These names are timing parameters from the ATA spec */
109 T
= (int)(2000000000000LL / octeon_get_clock_rate());
111 if (ata_timing_compute(dev
, dev
->pio_mode
, &timing
, T
, T
))
124 trh
= ns_to_tim_reg(2, 20);
128 pause
= timing
.cycle
- timing
.active
- timing
.setup
- trh
;
132 octeon_cf_set_boot_reg_cfg(cs
);
133 if (ocd
->dma_engine
>= 0)
134 /* True IDE mode, program both chip selects. */
135 octeon_cf_set_boot_reg_cfg(cs
+ 1);
138 use_iordy
= ata_pio_need_iordy(dev
);
140 reg_tim
.u64
= cvmx_read_csr(CVMX_MIO_BOOT_REG_TIMX(cs
));
141 /* Disable page mode */
143 /* Enable dynamic timing */
144 reg_tim
.s
.waitm
= use_iordy
;
145 /* Pages are disabled */
147 /* We don't use multiplexed address mode */
151 /* Time after IORDY to coninue to assert the data */
153 /* Time to wait to complete the cycle. */
154 reg_tim
.s
.pause
= pause
;
155 /* How long to hold after a write to de-assert CE. */
156 reg_tim
.s
.wr_hld
= trh
;
157 /* How long to wait after a read to de-assert CE. */
158 reg_tim
.s
.rd_hld
= trh
;
159 /* How long write enable is asserted */
161 /* How long read enable is asserted */
163 /* Time after CE that read/write starts */
164 reg_tim
.s
.ce
= ns_to_tim_reg(2, 5);
165 /* Time before CE that address is valid */
168 /* Program the bootbus region timing for the data port chip select. */
169 cvmx_write_csr(CVMX_MIO_BOOT_REG_TIMX(cs
), reg_tim
.u64
);
170 if (ocd
->dma_engine
>= 0)
171 /* True IDE mode, program both chip selects. */
172 cvmx_write_csr(CVMX_MIO_BOOT_REG_TIMX(cs
+ 1), reg_tim
.u64
);
175 static void octeon_cf_set_dmamode(struct ata_port
*ap
, struct ata_device
*dev
)
177 struct octeon_cf_data
*ocd
= dev
->link
->ap
->dev
->platform_data
;
178 union cvmx_mio_boot_dma_timx dma_tim
;
181 unsigned int dma_ackh
;
182 unsigned int dma_arq
;
184 unsigned int T0
, Tkr
, Td
;
185 unsigned int tim_mult
;
187 const struct ata_timing
*timing
;
189 timing
= ata_timing_find_mode(dev
->dma_mode
);
192 Tkr
= timing
->recover
;
193 dma_ackh
= timing
->dmack_hold
;
196 /* dma_tim.s.tim_mult = 0 --> 4x */
199 /* not spec'ed, value in eclocks, not affected by tim_mult */
201 pause
= 25 - dma_arq
* 1000 /
202 (octeon_get_clock_rate() / 1000000); /* Tz */
205 /* Tkr from cf spec, lengthened to meet T0 */
206 oe_n
= max(T0
- oe_a
, Tkr
);
208 dma_tim
.s
.dmack_pi
= 1;
210 dma_tim
.s
.oe_n
= ns_to_tim_reg(tim_mult
, oe_n
);
211 dma_tim
.s
.oe_a
= ns_to_tim_reg(tim_mult
, oe_a
);
214 * This is tI, C.F. spec. says 0, but Sony CF card requires
215 * more, we use 20 nS.
217 dma_tim
.s
.dmack_s
= ns_to_tim_reg(tim_mult
, 20);
218 dma_tim
.s
.dmack_h
= ns_to_tim_reg(tim_mult
, dma_ackh
);
220 dma_tim
.s
.dmarq
= dma_arq
;
221 dma_tim
.s
.pause
= ns_to_tim_reg(tim_mult
, pause
);
223 dma_tim
.s
.rd_dly
= 0; /* Sample right on edge */
226 dma_tim
.s
.we_n
= ns_to_tim_reg(tim_mult
, oe_n
);
227 dma_tim
.s
.we_a
= ns_to_tim_reg(tim_mult
, oe_a
);
229 pr_debug("ns to ticks (mult %d) of %d is: %d\n", tim_mult
, 60,
230 ns_to_tim_reg(tim_mult
, 60));
231 pr_debug("oe_n: %d, oe_a: %d, dmack_s: %d, dmack_h: "
232 "%d, dmarq: %d, pause: %d\n",
233 dma_tim
.s
.oe_n
, dma_tim
.s
.oe_a
, dma_tim
.s
.dmack_s
,
234 dma_tim
.s
.dmack_h
, dma_tim
.s
.dmarq
, dma_tim
.s
.pause
);
236 cvmx_write_csr(CVMX_MIO_BOOT_DMA_TIMX(ocd
->dma_engine
),
242 * Handle an 8 bit I/O request.
244 * @dev: Device to access
245 * @buffer: Data buffer
246 * @buflen: Length of the buffer.
247 * @rw: True to write.
249 static unsigned int octeon_cf_data_xfer8(struct ata_device
*dev
,
250 unsigned char *buffer
,
254 struct ata_port
*ap
= dev
->link
->ap
;
255 void __iomem
*data_addr
= ap
->ioaddr
.data_addr
;
263 iowrite8(*buffer
, data_addr
);
266 * Every 16 writes do a read so the bootbus
267 * FIFO doesn't fill up.
270 ioread8(ap
->ioaddr
.altstatus_addr
);
275 ioread8_rep(data_addr
, buffer
, words
);
281 * Handle a 16 bit I/O request.
283 * @dev: Device to access
284 * @buffer: Data buffer
285 * @buflen: Length of the buffer.
286 * @rw: True to write.
288 static unsigned int octeon_cf_data_xfer16(struct ata_device
*dev
,
289 unsigned char *buffer
,
293 struct ata_port
*ap
= dev
->link
->ap
;
294 void __iomem
*data_addr
= ap
->ioaddr
.data_addr
;
302 iowrite16(*(uint16_t *)buffer
, data_addr
);
303 buffer
+= sizeof(uint16_t);
305 * Every 16 writes do a read so the bootbus
306 * FIFO doesn't fill up.
309 ioread8(ap
->ioaddr
.altstatus_addr
);
315 *(uint16_t *)buffer
= ioread16(data_addr
);
316 buffer
+= sizeof(uint16_t);
319 /* Transfer trailing 1 byte, if any. */
320 if (unlikely(buflen
& 0x01)) {
321 __le16 align_buf
[1] = { 0 };
324 align_buf
[0] = cpu_to_le16(ioread16(data_addr
));
325 memcpy(buffer
, align_buf
, 1);
327 memcpy(align_buf
, buffer
, 1);
328 iowrite16(le16_to_cpu(align_buf
[0]), data_addr
);
336 * Read the taskfile for 16bit non-True IDE only.
338 static void octeon_cf_tf_read16(struct ata_port
*ap
, struct ata_taskfile
*tf
)
341 /* The base of the registers is at ioaddr.data_addr. */
342 void __iomem
*base
= ap
->ioaddr
.data_addr
;
344 blob
= __raw_readw(base
+ 0xc);
345 tf
->feature
= blob
>> 8;
347 blob
= __raw_readw(base
+ 2);
348 tf
->nsect
= blob
& 0xff;
349 tf
->lbal
= blob
>> 8;
351 blob
= __raw_readw(base
+ 4);
352 tf
->lbam
= blob
& 0xff;
353 tf
->lbah
= blob
>> 8;
355 blob
= __raw_readw(base
+ 6);
356 tf
->device
= blob
& 0xff;
357 tf
->command
= blob
>> 8;
359 if (tf
->flags
& ATA_TFLAG_LBA48
) {
360 if (likely(ap
->ioaddr
.ctl_addr
)) {
361 iowrite8(tf
->ctl
| ATA_HOB
, ap
->ioaddr
.ctl_addr
);
363 blob
= __raw_readw(base
+ 0xc);
364 tf
->hob_feature
= blob
>> 8;
366 blob
= __raw_readw(base
+ 2);
367 tf
->hob_nsect
= blob
& 0xff;
368 tf
->hob_lbal
= blob
>> 8;
370 blob
= __raw_readw(base
+ 4);
371 tf
->hob_lbam
= blob
& 0xff;
372 tf
->hob_lbah
= blob
>> 8;
374 iowrite8(tf
->ctl
, ap
->ioaddr
.ctl_addr
);
375 ap
->last_ctl
= tf
->ctl
;
382 static u8
octeon_cf_check_status16(struct ata_port
*ap
)
385 void __iomem
*base
= ap
->ioaddr
.data_addr
;
387 blob
= __raw_readw(base
+ 6);
391 static int octeon_cf_softreset16(struct ata_link
*link
, unsigned int *classes
,
392 unsigned long deadline
)
394 struct ata_port
*ap
= link
->ap
;
395 void __iomem
*base
= ap
->ioaddr
.data_addr
;
399 DPRINTK("about to softreset\n");
400 __raw_writew(ap
->ctl
, base
+ 0xe);
402 __raw_writew(ap
->ctl
| ATA_SRST
, base
+ 0xe);
404 __raw_writew(ap
->ctl
, base
+ 0xe);
406 rc
= ata_sff_wait_after_reset(link
, 1, deadline
);
408 ata_link_printk(link
, KERN_ERR
, "SRST failed (errno=%d)\n", rc
);
412 /* determine by signature whether we have ATA or ATAPI devices */
413 classes
[0] = ata_sff_dev_classify(&link
->device
[0], 1, &err
);
414 DPRINTK("EXIT, classes[0]=%u [1]=%u\n", classes
[0], classes
[1]);
419 * Load the taskfile for 16bit non-True IDE only. The device_addr is
420 * not loaded, we do this as part of octeon_cf_exec_command16.
422 static void octeon_cf_tf_load16(struct ata_port
*ap
,
423 const struct ata_taskfile
*tf
)
425 unsigned int is_addr
= tf
->flags
& ATA_TFLAG_ISADDR
;
426 /* The base of the registers is at ioaddr.data_addr. */
427 void __iomem
*base
= ap
->ioaddr
.data_addr
;
429 if (tf
->ctl
!= ap
->last_ctl
) {
430 iowrite8(tf
->ctl
, ap
->ioaddr
.ctl_addr
);
431 ap
->last_ctl
= tf
->ctl
;
434 if (is_addr
&& (tf
->flags
& ATA_TFLAG_LBA48
)) {
435 __raw_writew(tf
->hob_feature
<< 8, base
+ 0xc);
436 __raw_writew(tf
->hob_nsect
| tf
->hob_lbal
<< 8, base
+ 2);
437 __raw_writew(tf
->hob_lbam
| tf
->hob_lbah
<< 8, base
+ 4);
438 VPRINTK("hob: feat 0x%X nsect 0x%X, lba 0x%X 0x%X 0x%X\n",
446 __raw_writew(tf
->feature
<< 8, base
+ 0xc);
447 __raw_writew(tf
->nsect
| tf
->lbal
<< 8, base
+ 2);
448 __raw_writew(tf
->lbam
| tf
->lbah
<< 8, base
+ 4);
449 VPRINTK("feat 0x%X nsect 0x%X, lba 0x%X 0x%X 0x%X\n",
460 static void octeon_cf_dev_select(struct ata_port
*ap
, unsigned int device
)
462 /* There is only one device, do nothing. */
467 * Issue ATA command to host controller. The device_addr is also sent
468 * as it must be written in a combined write with the command.
470 static void octeon_cf_exec_command16(struct ata_port
*ap
,
471 const struct ata_taskfile
*tf
)
473 /* The base of the registers is at ioaddr.data_addr. */
474 void __iomem
*base
= ap
->ioaddr
.data_addr
;
477 if (tf
->flags
& ATA_TFLAG_DEVICE
) {
478 VPRINTK("device 0x%X\n", tf
->device
);
484 DPRINTK("ata%u: cmd 0x%X\n", ap
->print_id
, tf
->command
);
485 blob
|= (tf
->command
<< 8);
486 __raw_writew(blob
, base
+ 6);
492 static u8
octeon_cf_irq_on(struct ata_port
*ap
)
497 static void octeon_cf_irq_clear(struct ata_port
*ap
)
502 static void octeon_cf_dma_setup(struct ata_queued_cmd
*qc
)
504 struct ata_port
*ap
= qc
->ap
;
505 struct octeon_cf_port
*cf_port
;
507 cf_port
= ap
->private_data
;
509 /* issue r/w command */
511 cf_port
->dma_finished
= 0;
512 ap
->ops
->sff_exec_command(ap
, &qc
->tf
);
517 * Start a DMA transfer that was already setup
519 * @qc: Information about the DMA
521 static void octeon_cf_dma_start(struct ata_queued_cmd
*qc
)
523 struct octeon_cf_data
*ocd
= qc
->ap
->dev
->platform_data
;
524 union cvmx_mio_boot_dma_cfgx mio_boot_dma_cfg
;
525 union cvmx_mio_boot_dma_intx mio_boot_dma_int
;
526 struct scatterlist
*sg
;
528 VPRINTK("%d scatterlists\n", qc
->n_elem
);
530 /* Get the scatter list entry we need to DMA into */
535 * Clear the DMA complete status.
537 mio_boot_dma_int
.u64
= 0;
538 mio_boot_dma_int
.s
.done
= 1;
539 cvmx_write_csr(CVMX_MIO_BOOT_DMA_INTX(ocd
->dma_engine
),
540 mio_boot_dma_int
.u64
);
542 /* Enable the interrupt. */
543 cvmx_write_csr(CVMX_MIO_BOOT_DMA_INT_ENX(ocd
->dma_engine
),
544 mio_boot_dma_int
.u64
);
546 /* Set the direction of the DMA */
547 mio_boot_dma_cfg
.u64
= 0;
548 mio_boot_dma_cfg
.s
.en
= 1;
549 mio_boot_dma_cfg
.s
.rw
= ((qc
->tf
.flags
& ATA_TFLAG_WRITE
) != 0);
552 * Don't stop the DMA if the device deasserts DMARQ. Many
553 * compact flashes deassert DMARQ for a short time between
554 * sectors. Instead of stopping and restarting the DMA, we'll
555 * let the hardware do it. If the DMA is really stopped early
556 * due to an error condition, a later timeout will force us to
559 mio_boot_dma_cfg
.s
.clr
= 0;
561 /* Size is specified in 16bit words and minus one notation */
562 mio_boot_dma_cfg
.s
.size
= sg_dma_len(sg
) / 2 - 1;
564 /* We need to swap the high and low bytes of every 16 bits */
565 mio_boot_dma_cfg
.s
.swap8
= 1;
567 mio_boot_dma_cfg
.s
.adr
= sg_dma_address(sg
);
569 VPRINTK("%s %d bytes address=%p\n",
570 (mio_boot_dma_cfg
.s
.rw
) ? "write" : "read", sg
->length
,
571 (void *)(unsigned long)mio_boot_dma_cfg
.s
.adr
);
573 cvmx_write_csr(CVMX_MIO_BOOT_DMA_CFGX(ocd
->dma_engine
),
574 mio_boot_dma_cfg
.u64
);
580 * spin_lock_irqsave(host lock)
583 static unsigned int octeon_cf_dma_finished(struct ata_port
*ap
,
584 struct ata_queued_cmd
*qc
)
586 struct ata_eh_info
*ehi
= &ap
->link
.eh_info
;
587 struct octeon_cf_data
*ocd
= ap
->dev
->platform_data
;
588 union cvmx_mio_boot_dma_cfgx dma_cfg
;
589 union cvmx_mio_boot_dma_intx dma_int
;
590 struct octeon_cf_port
*cf_port
;
593 VPRINTK("ata%u: protocol %d task_state %d\n",
594 ap
->print_id
, qc
->tf
.protocol
, ap
->hsm_task_state
);
597 if (ap
->hsm_task_state
!= HSM_ST_LAST
)
600 cf_port
= ap
->private_data
;
602 dma_cfg
.u64
= cvmx_read_csr(CVMX_MIO_BOOT_DMA_CFGX(ocd
->dma_engine
));
603 if (dma_cfg
.s
.size
!= 0xfffff) {
604 /* Error, the transfer was not complete. */
605 qc
->err_mask
|= AC_ERR_HOST_BUS
;
606 ap
->hsm_task_state
= HSM_ST_ERR
;
609 /* Stop and clear the dma engine. */
612 cvmx_write_csr(CVMX_MIO_BOOT_DMA_CFGX(ocd
->dma_engine
), dma_cfg
.u64
);
614 /* Disable the interrupt. */
616 cvmx_write_csr(CVMX_MIO_BOOT_DMA_INT_ENX(ocd
->dma_engine
), dma_int
.u64
);
618 /* Clear the DMA complete status */
620 cvmx_write_csr(CVMX_MIO_BOOT_DMA_INTX(ocd
->dma_engine
), dma_int
.u64
);
622 status
= ap
->ops
->sff_check_status(ap
);
624 ata_sff_hsm_move(ap
, qc
, status
, 0);
626 if (unlikely(qc
->err_mask
) && (qc
->tf
.protocol
== ATA_PROT_DMA
))
627 ata_ehi_push_desc(ehi
, "DMA stat 0x%x", status
);
633 * Check if any queued commands have more DMAs, if so start the next
634 * transfer, else do end of transfer handling.
636 static irqreturn_t
octeon_cf_interrupt(int irq
, void *dev_instance
)
638 struct ata_host
*host
= dev_instance
;
639 struct octeon_cf_port
*cf_port
;
641 unsigned int handled
= 0;
644 spin_lock_irqsave(&host
->lock
, flags
);
647 for (i
= 0; i
< host
->n_ports
; i
++) {
650 struct ata_queued_cmd
*qc
;
651 union cvmx_mio_boot_dma_intx dma_int
;
652 union cvmx_mio_boot_dma_cfgx dma_cfg
;
653 struct octeon_cf_data
*ocd
;
656 ocd
= ap
->dev
->platform_data
;
658 if (ap
->flags
& ATA_FLAG_DISABLED
)
661 ocd
= ap
->dev
->platform_data
;
662 cf_port
= ap
->private_data
;
664 cvmx_read_csr(CVMX_MIO_BOOT_DMA_INTX(ocd
->dma_engine
));
666 cvmx_read_csr(CVMX_MIO_BOOT_DMA_CFGX(ocd
->dma_engine
));
668 qc
= ata_qc_from_tag(ap
, ap
->link
.active_tag
);
670 if (qc
&& (!(qc
->tf
.flags
& ATA_TFLAG_POLLING
)) &&
671 (qc
->flags
& ATA_QCFLAG_ACTIVE
)) {
672 if (dma_int
.s
.done
&& !dma_cfg
.s
.en
) {
673 if (!sg_is_last(qc
->cursg
)) {
674 qc
->cursg
= sg_next(qc
->cursg
);
676 octeon_cf_dma_start(qc
);
679 cf_port
->dma_finished
= 1;
682 if (!cf_port
->dma_finished
)
684 status
= ioread8(ap
->ioaddr
.altstatus_addr
);
685 if (status
& (ATA_BUSY
| ATA_DRQ
)) {
687 * We are busy, try to handle it
688 * later. This is the DMA finished
689 * interrupt, and it could take a
690 * little while for the card to be
691 * ready for more commands.
696 cvmx_write_csr(CVMX_MIO_BOOT_DMA_INTX(ocd
->dma_engine
),
699 queue_delayed_work(cf_port
->wq
,
700 &cf_port
->delayed_finish
, 1);
703 handled
|= octeon_cf_dma_finished(ap
, qc
);
707 spin_unlock_irqrestore(&host
->lock
, flags
);
709 return IRQ_RETVAL(handled
);
712 static void octeon_cf_delayed_finish(struct work_struct
*work
)
714 struct octeon_cf_port
*cf_port
= container_of(work
,
715 struct octeon_cf_port
,
716 delayed_finish
.work
);
717 struct ata_port
*ap
= cf_port
->ap
;
718 struct ata_host
*host
= ap
->host
;
719 struct ata_queued_cmd
*qc
;
723 spin_lock_irqsave(&host
->lock
, flags
);
726 * If the port is not waiting for completion, it must have
727 * handled it previously. The hsm_task_state is
728 * protected by host->lock.
730 if (ap
->hsm_task_state
!= HSM_ST_LAST
|| !cf_port
->dma_finished
)
733 status
= ioread8(ap
->ioaddr
.altstatus_addr
);
734 if (status
& (ATA_BUSY
| ATA_DRQ
)) {
735 /* Still busy, try again. */
736 queue_delayed_work(cf_port
->wq
,
737 &cf_port
->delayed_finish
, 1);
740 qc
= ata_qc_from_tag(ap
, ap
->link
.active_tag
);
741 if (qc
&& (!(qc
->tf
.flags
& ATA_TFLAG_POLLING
)) &&
742 (qc
->flags
& ATA_QCFLAG_ACTIVE
))
743 octeon_cf_dma_finished(ap
, qc
);
745 spin_unlock_irqrestore(&host
->lock
, flags
);
748 static void octeon_cf_dev_config(struct ata_device
*dev
)
751 * A maximum of 2^20 - 1 16 bit transfers are possible with
752 * the bootbus DMA. So we need to throttle max_sectors to
753 * (2^12 - 1 == 4095) to assure that this can never happen.
755 dev
->max_sectors
= min(dev
->max_sectors
, 4095U);
759 * Trap if driver tries to do standard bmdma commands. They are not
762 static void unreachable_qc(struct ata_queued_cmd
*qc
)
767 static u8
unreachable_port(struct ata_port
*ap
)
773 * We don't do ATAPI DMA so return 0.
775 static int octeon_cf_check_atapi_dma(struct ata_queued_cmd
*qc
)
780 static unsigned int octeon_cf_qc_issue(struct ata_queued_cmd
*qc
)
782 struct ata_port
*ap
= qc
->ap
;
784 switch (qc
->tf
.protocol
) {
786 WARN_ON(qc
->tf
.flags
& ATA_TFLAG_POLLING
);
788 ap
->ops
->sff_tf_load(ap
, &qc
->tf
); /* load tf registers */
789 octeon_cf_dma_setup(qc
); /* set up dma */
790 octeon_cf_dma_start(qc
); /* initiate dma */
791 ap
->hsm_task_state
= HSM_ST_LAST
;
795 dev_err(ap
->dev
, "Error, ATAPI not supported\n");
799 return ata_sff_qc_issue(qc
);
805 static struct ata_port_operations octeon_cf_ops
= {
806 .inherits
= &ata_sff_port_ops
,
807 .check_atapi_dma
= octeon_cf_check_atapi_dma
,
808 .qc_prep
= ata_noop_qc_prep
,
809 .qc_issue
= octeon_cf_qc_issue
,
810 .sff_dev_select
= octeon_cf_dev_select
,
811 .sff_irq_on
= octeon_cf_irq_on
,
812 .sff_irq_clear
= octeon_cf_irq_clear
,
813 .bmdma_setup
= unreachable_qc
,
814 .bmdma_start
= unreachable_qc
,
815 .bmdma_stop
= unreachable_qc
,
816 .bmdma_status
= unreachable_port
,
817 .cable_detect
= ata_cable_40wire
,
818 .set_piomode
= octeon_cf_set_piomode
,
819 .set_dmamode
= octeon_cf_set_dmamode
,
820 .dev_config
= octeon_cf_dev_config
,
823 static int __devinit
octeon_cf_probe(struct platform_device
*pdev
)
825 struct resource
*res_cs0
, *res_cs1
;
828 void __iomem
*cs1
= NULL
;
829 struct ata_host
*host
;
831 struct octeon_cf_data
*ocd
;
833 irq_handler_t irq_handler
= NULL
;
835 struct octeon_cf_port
*cf_port
;
837 res_cs0
= platform_get_resource(pdev
, IORESOURCE_MEM
, 0);
842 ocd
= pdev
->dev
.platform_data
;
844 cs0
= devm_ioremap_nocache(&pdev
->dev
, res_cs0
->start
,
845 resource_size(res_cs0
));
850 /* Determine from availability of DMA if True IDE mode or not */
851 if (ocd
->dma_engine
>= 0) {
852 res_cs1
= platform_get_resource(pdev
, IORESOURCE_MEM
, 1);
856 cs1
= devm_ioremap_nocache(&pdev
->dev
, res_cs1
->start
,
857 resource_size(res_cs1
));
863 cf_port
= kzalloc(sizeof(*cf_port
), GFP_KERNEL
);
868 host
= ata_host_alloc(&pdev
->dev
, 1);
873 ap
->private_data
= cf_port
;
875 ap
->ops
= &octeon_cf_ops
;
876 ap
->pio_mask
= ATA_PIO6
;
877 ap
->flags
|= ATA_FLAG_MMIO
| ATA_FLAG_NO_LEGACY
878 | ATA_FLAG_NO_ATAPI
| ATA_FLAG_PIO_POLLING
;
880 base
= cs0
+ ocd
->base_region_bias
;
882 ap
->ioaddr
.cmd_addr
= base
;
883 ata_sff_std_ports(&ap
->ioaddr
);
885 ap
->ioaddr
.altstatus_addr
= base
+ 0xe;
886 ap
->ioaddr
.ctl_addr
= base
+ 0xe;
887 octeon_cf_ops
.sff_data_xfer
= octeon_cf_data_xfer8
;
889 /* Presence of cs1 indicates True IDE mode. */
890 ap
->ioaddr
.cmd_addr
= base
+ (ATA_REG_CMD
<< 1) + 1;
891 ap
->ioaddr
.data_addr
= base
+ (ATA_REG_DATA
<< 1);
892 ap
->ioaddr
.error_addr
= base
+ (ATA_REG_ERR
<< 1) + 1;
893 ap
->ioaddr
.feature_addr
= base
+ (ATA_REG_FEATURE
<< 1) + 1;
894 ap
->ioaddr
.nsect_addr
= base
+ (ATA_REG_NSECT
<< 1) + 1;
895 ap
->ioaddr
.lbal_addr
= base
+ (ATA_REG_LBAL
<< 1) + 1;
896 ap
->ioaddr
.lbam_addr
= base
+ (ATA_REG_LBAM
<< 1) + 1;
897 ap
->ioaddr
.lbah_addr
= base
+ (ATA_REG_LBAH
<< 1) + 1;
898 ap
->ioaddr
.device_addr
= base
+ (ATA_REG_DEVICE
<< 1) + 1;
899 ap
->ioaddr
.status_addr
= base
+ (ATA_REG_STATUS
<< 1) + 1;
900 ap
->ioaddr
.command_addr
= base
+ (ATA_REG_CMD
<< 1) + 1;
901 ap
->ioaddr
.altstatus_addr
= cs1
+ (6 << 1) + 1;
902 ap
->ioaddr
.ctl_addr
= cs1
+ (6 << 1) + 1;
903 octeon_cf_ops
.sff_data_xfer
= octeon_cf_data_xfer16
;
905 ap
->mwdma_mask
= ATA_MWDMA4
;
906 irq
= platform_get_irq(pdev
, 0);
907 irq_handler
= octeon_cf_interrupt
;
909 /* True IDE mode needs delayed work to poll for not-busy. */
910 cf_port
->wq
= create_singlethread_workqueue(DRV_NAME
);
913 INIT_DELAYED_WORK(&cf_port
->delayed_finish
,
914 octeon_cf_delayed_finish
);
917 /* 16 bit but not True IDE */
918 octeon_cf_ops
.sff_data_xfer
= octeon_cf_data_xfer16
;
919 octeon_cf_ops
.softreset
= octeon_cf_softreset16
;
920 octeon_cf_ops
.sff_check_status
= octeon_cf_check_status16
;
921 octeon_cf_ops
.sff_tf_read
= octeon_cf_tf_read16
;
922 octeon_cf_ops
.sff_tf_load
= octeon_cf_tf_load16
;
923 octeon_cf_ops
.sff_exec_command
= octeon_cf_exec_command16
;
925 ap
->ioaddr
.data_addr
= base
+ ATA_REG_DATA
;
926 ap
->ioaddr
.nsect_addr
= base
+ ATA_REG_NSECT
;
927 ap
->ioaddr
.lbal_addr
= base
+ ATA_REG_LBAL
;
928 ap
->ioaddr
.ctl_addr
= base
+ 0xe;
929 ap
->ioaddr
.altstatus_addr
= base
+ 0xe;
932 ata_port_desc(ap
, "cmd %p ctl %p", base
, ap
->ioaddr
.ctl_addr
);
935 dev_info(&pdev
->dev
, "version " DRV_VERSION
" %d bit%s.\n",
936 (ocd
->is16bit
) ? 16 : 8,
937 (cs1
) ? ", True IDE" : "");
940 return ata_host_activate(host
, irq
, irq_handler
, 0, &octeon_cf_sht
);
947 static struct platform_driver octeon_cf_driver
= {
948 .probe
= octeon_cf_probe
,
951 .owner
= THIS_MODULE
,
955 static int __init
octeon_cf_init(void)
957 return platform_driver_register(&octeon_cf_driver
);
961 MODULE_AUTHOR("David Daney <ddaney@caviumnetworks.com>");
962 MODULE_DESCRIPTION("low-level driver for Cavium OCTEON Compact Flash PATA");
963 MODULE_LICENSE("GPL");
964 MODULE_VERSION(DRV_VERSION
);
965 MODULE_ALIAS("platform:" DRV_NAME
);
967 module_init(octeon_cf_init
);