3 Hardware driver for NI Mite PCI interface chip
5 COMEDI - Linux Control and Measurement Device Interface
6 Copyright (C) 1997-2002 David A. Schleef <ds@schleef.org>
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
25 The PCI-MIO E series driver was originally written by
26 Tomasz Motylewski <...>, and ported to comedi by ds.
28 References for specifications:
30 321747b.pdf Register Level Programmer Manual (obsolete)
31 321747c.pdf Register Level Programmer Manual (new)
32 DAQ-STC reference manual
34 Other possibly relevant info:
36 320517c.pdf User manual (obsolete)
37 320517f.pdf User manual (new)
39 320906c.pdf maximum signal ratings
41 321791a.pdf discontinuation of at-mio-16e-10 rev. c
42 321808a.pdf about at-mio-16e-10 rev P
43 321837a.pdf discontinuation of at-mio-16de-10 rev d
44 321838a.pdf about at-mio-16de-10 rev N
54 #include "comedi_fc.h"
55 #include "comedi_pci.h"
56 #include "../comedidev.h"
58 #include <asm/system.h>
60 #define PCI_MITE_SIZE 4096
61 #define PCI_DAQ_SIZE 4096
62 #define PCI_DAQ_SIZE_660X 8192
64 MODULE_LICENSE("GPL");
66 struct mite_struct *mite_devices = NULL;
68 #define TOP_OF_PAGE(x) ((x)|(~(PAGE_MASK)))
72 struct pci_dev *pcidev;
73 struct mite_struct *mite;
75 for (pcidev = pci_get_device(PCI_ANY_ID, PCI_ANY_ID, NULL);
77 pcidev = pci_get_device(PCI_ANY_ID, PCI_ANY_ID, pcidev)) {
78 if (pcidev->vendor == PCI_VENDOR_ID_NATINST) {
81 mite = kzalloc(sizeof(*mite), GFP_KERNEL);
83 printk("mite: allocation failed\n");
87 spin_lock_init(&mite->lock);
88 mite->pcidev = pci_dev_get(pcidev);
89 for (i = 0; i < MAX_MITE_DMA_CHANNELS; ++i) {
90 mite->channels[i].mite = mite;
91 mite->channels[i].channel = i;
92 mite->channels[i].done = 1;
94 mite->next = mite_devices;
100 static void dump_chip_signature(u32 csigr_bits)
102 printk("mite: version = %i, type = %i, mite mode = %i, interface mode = %i\n", mite_csigr_version(csigr_bits), mite_csigr_type(csigr_bits), mite_csigr_mmode(csigr_bits), mite_csigr_imode(csigr_bits));
103 printk("mite: num channels = %i, write post fifo depth = %i, wins = %i, iowins = %i\n", mite_csigr_dmac(csigr_bits), mite_csigr_wpdep(csigr_bits), mite_csigr_wins(csigr_bits), mite_csigr_iowins(csigr_bits));
106 unsigned mite_fifo_size(struct mite_struct * mite, unsigned channel)
108 unsigned fcr_bits = readl(mite->mite_io_addr +
110 unsigned empty_count = (fcr_bits >> 16) & 0xff;
111 unsigned full_count = fcr_bits & 0xff;
112 return empty_count + full_count;
115 int mite_setup2(struct mite_struct *mite, unsigned use_iodwbsr_1)
117 unsigned long length;
118 resource_size_t addr;
121 unsigned unknown_dma_burst_bits;
123 if (comedi_pci_enable(mite->pcidev, "mite")) {
124 printk("error enabling mite and requesting io regions\n");
127 pci_set_master(mite->pcidev);
129 addr = pci_resource_start(mite->pcidev, 0);
130 mite->mite_phys_addr = addr;
131 mite->mite_io_addr = ioremap(addr, PCI_MITE_SIZE);
132 if (!mite->mite_io_addr) {
133 printk("failed to remap mite io memory address\n");
136 printk("MITE:0x%08llx mapped to %p ",
137 (unsigned long long)mite->mite_phys_addr, mite->mite_io_addr);
139 addr = pci_resource_start(mite->pcidev, 1);
140 mite->daq_phys_addr = addr;
141 length = pci_resource_len(mite->pcidev, 1);
142 // In case of a 660x board, DAQ size is 8k instead of 4k (see as shown by lspci output)
143 mite->daq_io_addr = ioremap(mite->daq_phys_addr, length);
144 if (!mite->daq_io_addr) {
145 printk("failed to remap daq io memory address\n");
148 printk("DAQ:0x%08llx mapped to %p\n",
149 (unsigned long long)mite->daq_phys_addr, mite->daq_io_addr);
152 writel(0, mite->mite_io_addr + MITE_IODWBSR);
153 printk("mite: using I/O Window Base Size register 1\n");
155 daq_phys_addr | WENAB |
156 MITE_IODWBSR_1_WSIZE_bits(length),
157 mite->mite_io_addr + MITE_IODWBSR_1);
158 writel(0, mite->mite_io_addr + MITE_IODWCR_1);
160 writel(mite->daq_phys_addr | WENAB,
161 mite->mite_io_addr + MITE_IODWBSR);
163 /* make sure dma bursts work. I got this from running a bus analyzer
164 on a pxi-6281 and a pxi-6713. 6713 powered up with register value
165 of 0x61f and bursts worked. 6281 powered up with register value of
166 0x1f and bursts didn't work. The NI windows driver reads the register,
167 then does a bitwise-or of 0x600 with it and writes it back.
169 unknown_dma_burst_bits =
170 readl(mite->mite_io_addr + MITE_UNKNOWN_DMA_BURST_REG);
171 unknown_dma_burst_bits |= UNKNOWN_DMA_BURST_ENABLE_BITS;
172 writel(unknown_dma_burst_bits,
173 mite->mite_io_addr + MITE_UNKNOWN_DMA_BURST_REG);
175 csigr_bits = readl(mite->mite_io_addr + MITE_CSIGR);
176 mite->num_channels = mite_csigr_dmac(csigr_bits);
177 if (mite->num_channels > MAX_MITE_DMA_CHANNELS) {
178 printk("mite: bug? chip claims to have %i dma channels. Setting to %i.\n", mite->num_channels, MAX_MITE_DMA_CHANNELS);
179 mite->num_channels = MAX_MITE_DMA_CHANNELS;
181 dump_chip_signature(csigr_bits);
182 for (i = 0; i < mite->num_channels; i++) {
183 writel(CHOR_DMARESET, mite->mite_io_addr + MITE_CHOR(i));
184 /* disable interrupts */
185 writel(CHCR_CLR_DMA_IE | CHCR_CLR_LINKP_IE | CHCR_CLR_SAR_IE |
186 CHCR_CLR_DONE_IE | CHCR_CLR_MRDY_IE | CHCR_CLR_DRDY_IE |
187 CHCR_CLR_LC_IE | CHCR_CLR_CONT_RB_IE,
188 mite->mite_io_addr + MITE_CHCR(i));
190 mite->fifo_size = mite_fifo_size(mite, 0);
191 printk("mite: fifo size is %i.\n", mite->fifo_size);
197 int mite_setup(struct mite_struct *mite)
199 return mite_setup2(mite, 0);
202 void mite_cleanup(void)
204 struct mite_struct *mite, *next;
206 for (mite = mite_devices; mite; mite = next) {
207 pci_dev_put(mite->pcidev);
213 void mite_unsetup(struct mite_struct *mite)
215 //unsigned long offset, start, length;
220 if (mite->mite_io_addr) {
221 iounmap(mite->mite_io_addr);
222 mite->mite_io_addr = NULL;
224 if (mite->daq_io_addr) {
225 iounmap(mite->daq_io_addr);
226 mite->daq_io_addr = NULL;
228 if (mite->mite_phys_addr) {
229 comedi_pci_disable(mite->pcidev);
230 mite->mite_phys_addr = 0;
236 void mite_list_devices(void)
238 struct mite_struct *mite, *next;
240 printk("Available NI device IDs:");
242 for (mite = mite_devices; mite; mite = next) {
244 printk(" 0x%04x", mite_device_id(mite));
252 struct mite_channel *mite_request_channel_in_range(struct mite_struct *mite,
253 struct mite_dma_descriptor_ring *ring, unsigned min_channel,
254 unsigned max_channel)
258 struct mite_channel *channel = NULL;
260 // spin lock so mite_release_channel can be called safely from interrupts
261 comedi_spin_lock_irqsave(&mite->lock, flags);
262 for (i = min_channel; i <= max_channel; ++i) {
263 if (mite->channel_allocated[i] == 0) {
264 mite->channel_allocated[i] = 1;
265 channel = &mite->channels[i];
266 channel->ring = ring;
270 comedi_spin_unlock_irqrestore(&mite->lock, flags);
274 void mite_release_channel(struct mite_channel *mite_chan)
276 struct mite_struct *mite = mite_chan->mite;
279 // spin lock to prevent races with mite_request_channel
280 comedi_spin_lock_irqsave(&mite->lock, flags);
281 if (mite->channel_allocated[mite_chan->channel]) {
282 mite_dma_disarm(mite_chan);
283 mite_dma_reset(mite_chan);
284 /* disable all channel's interrupts (do it after disarm/reset so
285 MITE_CHCR reg isn't changed while dma is still active!) */
286 writel(CHCR_CLR_DMA_IE | CHCR_CLR_LINKP_IE |
287 CHCR_CLR_SAR_IE | CHCR_CLR_DONE_IE |
288 CHCR_CLR_MRDY_IE | CHCR_CLR_DRDY_IE |
289 CHCR_CLR_LC_IE | CHCR_CLR_CONT_RB_IE,
290 mite->mite_io_addr + MITE_CHCR(mite_chan->channel));
291 mite->channel_allocated[mite_chan->channel] = 0;
292 mite_chan->ring = NULL;
295 comedi_spin_unlock_irqrestore(&mite->lock, flags);
298 void mite_dma_arm(struct mite_channel *mite_chan)
300 struct mite_struct *mite = mite_chan->mite;
304 MDPRINTK("mite_dma_arm ch%i\n", channel);
305 /* memory barrier is intended to insure any twiddling with the buffer
306 is done before writing to the mite to arm dma transfer */
310 comedi_spin_lock_irqsave(&mite->lock, flags);
312 writel(chor, mite->mite_io_addr + MITE_CHOR(mite_chan->channel));
314 comedi_spin_unlock_irqrestore(&mite->lock, flags);
315 // mite_dma_tcr(mite, channel);
318 /**************************************/
320 int mite_buf_change(struct mite_dma_descriptor_ring *ring, comedi_async * async)
322 unsigned int n_links;
325 if (ring->descriptors) {
326 dma_free_coherent(ring->hw_dev,
327 ring->n_links * sizeof(struct mite_dma_descriptor),
328 ring->descriptors, ring->descriptors_dma_addr);
330 ring->descriptors = NULL;
331 ring->descriptors_dma_addr = 0;
334 if (async->prealloc_bufsz == 0) {
337 n_links = async->prealloc_bufsz >> PAGE_SHIFT;
339 MDPRINTK("ring->hw_dev=%p, n_links=0x%04x\n", ring->hw_dev, n_links);
342 dma_alloc_coherent(ring->hw_dev,
343 n_links * sizeof(struct mite_dma_descriptor),
344 &ring->descriptors_dma_addr, GFP_KERNEL);
345 if (!ring->descriptors) {
346 printk("mite: ring buffer allocation failed\n");
349 ring->n_links = n_links;
351 for (i = 0; i < n_links; i++) {
352 ring->descriptors[i].count = cpu_to_le32(PAGE_SIZE);
353 ring->descriptors[i].addr =
354 cpu_to_le32(async->buf_page_list[i].dma_addr);
355 ring->descriptors[i].next =
356 cpu_to_le32(ring->descriptors_dma_addr + (i +
357 1) * sizeof(struct mite_dma_descriptor));
359 ring->descriptors[n_links - 1].next =
360 cpu_to_le32(ring->descriptors_dma_addr);
361 /* barrier is meant to insure that all the writes to the dma descriptors
362 have completed before the dma controller is commanded to read them */
367 void mite_prep_dma(struct mite_channel *mite_chan,
368 unsigned int num_device_bits, unsigned int num_memory_bits)
370 unsigned int chor, chcr, mcr, dcr, lkcr;
371 struct mite_struct *mite = mite_chan->mite;
373 MDPRINTK("mite_prep_dma ch%i\n", mite_chan->channel);
375 /* reset DMA and FIFO */
376 chor = CHOR_DMARESET | CHOR_FRESET;
377 writel(chor, mite->mite_io_addr + MITE_CHOR(mite_chan->channel));
379 /* short link chaining mode */
380 chcr = CHCR_SET_DMA_IE | CHCR_LINKSHORT | CHCR_SET_DONE_IE |
383 * Link Complete Interrupt: interrupt every time a link
384 * in MITE_RING is completed. This can generate a lot of
385 * extra interrupts, but right now we update the values
386 * of buf_int_ptr and buf_int_count at each interrupt. A
387 * better method is to poll the MITE before each user
388 * "read()" to calculate the number of bytes available.
390 chcr |= CHCR_SET_LC_IE;
391 if (num_memory_bits == 32 && num_device_bits == 16) {
392 /* Doing a combined 32 and 16 bit byteswap gets the 16 bit samples into the fifo in the right order.
393 Tested doing 32 bit memory to 16 bit device transfers to the analog out of a pxi-6281,
394 which has mite version = 1, type = 4. This also works for dma reads from the counters
395 on e-series boards. */
396 chcr |= CHCR_BYTE_SWAP_DEVICE | CHCR_BYTE_SWAP_MEMORY;
398 if (mite_chan->dir == COMEDI_INPUT) {
399 chcr |= CHCR_DEV_TO_MEM;
401 writel(chcr, mite->mite_io_addr + MITE_CHCR(mite_chan->channel));
404 mcr = CR_RL(64) | CR_ASEQUP;
405 switch (num_memory_bits) {
417 ("mite: bug! invalid mem bit width for dma transfer\n");
420 writel(mcr, mite->mite_io_addr + MITE_MCR(mite_chan->channel));
423 dcr = CR_RL(64) | CR_ASEQUP;
424 dcr |= CR_PORTIO | CR_AMDEVICE | CR_REQSDRQ(mite_chan->channel);
425 switch (num_device_bits) {
437 ("mite: bug! invalid dev bit width for dma transfer\n");
440 writel(dcr, mite->mite_io_addr + MITE_DCR(mite_chan->channel));
443 writel(0, mite->mite_io_addr + MITE_DAR(mite_chan->channel));
445 /* the link is 32bits */
446 lkcr = CR_RL(64) | CR_ASEQUP | CR_PSIZE32;
447 writel(lkcr, mite->mite_io_addr + MITE_LKCR(mite_chan->channel));
449 /* starting address for link chaining */
450 writel(mite_chan->ring->descriptors_dma_addr,
451 mite->mite_io_addr + MITE_LKAR(mite_chan->channel));
453 MDPRINTK("exit mite_prep_dma\n");
456 u32 mite_device_bytes_transferred(struct mite_channel *mite_chan)
458 struct mite_struct *mite = mite_chan->mite;
459 return readl(mite->mite_io_addr + MITE_DAR(mite_chan->channel));
462 u32 mite_bytes_in_transit(struct mite_channel * mite_chan)
464 struct mite_struct *mite = mite_chan->mite;
465 return readl(mite->mite_io_addr +
466 MITE_FCR(mite_chan->channel)) & 0x000000FF;
469 // returns lower bound for number of bytes transferred from device to memory
470 u32 mite_bytes_written_to_memory_lb(struct mite_channel * mite_chan)
472 u32 device_byte_count;
474 device_byte_count = mite_device_bytes_transferred(mite_chan);
475 return device_byte_count - mite_bytes_in_transit(mite_chan);
478 // returns upper bound for number of bytes transferred from device to memory
479 u32 mite_bytes_written_to_memory_ub(struct mite_channel * mite_chan)
481 u32 in_transit_count;
483 in_transit_count = mite_bytes_in_transit(mite_chan);
484 return mite_device_bytes_transferred(mite_chan) - in_transit_count;
487 // returns lower bound for number of bytes read from memory for transfer to device
488 u32 mite_bytes_read_from_memory_lb(struct mite_channel * mite_chan)
490 u32 device_byte_count;
492 device_byte_count = mite_device_bytes_transferred(mite_chan);
493 return device_byte_count + mite_bytes_in_transit(mite_chan);
496 // returns upper bound for number of bytes read from memory for transfer to device
497 u32 mite_bytes_read_from_memory_ub(struct mite_channel * mite_chan)
499 u32 in_transit_count;
501 in_transit_count = mite_bytes_in_transit(mite_chan);
502 return mite_device_bytes_transferred(mite_chan) + in_transit_count;
505 unsigned mite_dma_tcr(struct mite_channel *mite_chan)
507 struct mite_struct *mite = mite_chan->mite;
511 lkar = readl(mite->mite_io_addr + MITE_LKAR(mite_chan->channel));
512 tcr = readl(mite->mite_io_addr + MITE_TCR(mite_chan->channel));
513 MDPRINTK("mite_dma_tcr ch%i, lkar=0x%08x tcr=%d\n", mite_chan->channel,
519 void mite_dma_disarm(struct mite_channel *mite_chan)
521 struct mite_struct *mite = mite_chan->mite;
526 writel(chor, mite->mite_io_addr + MITE_CHOR(mite_chan->channel));
529 int mite_sync_input_dma(struct mite_channel *mite_chan, comedi_async * async)
532 unsigned int nbytes, old_alloc_count;
533 const unsigned bytes_per_scan = cfc_bytes_per_scan(async->subdevice);
535 old_alloc_count = async->buf_write_alloc_count;
536 // write alloc as much as we can
537 comedi_buf_write_alloc(async, async->prealloc_bufsz);
539 nbytes = mite_bytes_written_to_memory_lb(mite_chan);
540 if ((int)(mite_bytes_written_to_memory_ub(mite_chan) -
541 old_alloc_count) > 0) {
542 rt_printk("mite: DMA overwrite of free area\n");
543 async->events |= COMEDI_CB_OVERFLOW;
547 count = nbytes - async->buf_write_count;
548 /* it's possible count will be negative due to
549 * conservative value returned by mite_bytes_written_to_memory_lb */
553 comedi_buf_write_free(async, count);
555 async->scan_progress += count;
556 if (async->scan_progress >= bytes_per_scan) {
557 async->scan_progress %= bytes_per_scan;
558 async->events |= COMEDI_CB_EOS;
560 async->events |= COMEDI_CB_BLOCK;
564 int mite_sync_output_dma(struct mite_channel *mite_chan, comedi_async * async)
567 u32 nbytes_ub, nbytes_lb;
568 unsigned int old_alloc_count;
570 async->cmd.stop_arg * cfc_bytes_per_scan(async->subdevice);
572 old_alloc_count = async->buf_read_alloc_count;
573 // read alloc as much as we can
574 comedi_buf_read_alloc(async, async->prealloc_bufsz);
575 nbytes_lb = mite_bytes_read_from_memory_lb(mite_chan);
576 if (async->cmd.stop_src == TRIG_COUNT &&
577 (int)(nbytes_lb - stop_count) > 0)
578 nbytes_lb = stop_count;
579 nbytes_ub = mite_bytes_read_from_memory_ub(mite_chan);
580 if (async->cmd.stop_src == TRIG_COUNT &&
581 (int)(nbytes_ub - stop_count) > 0)
582 nbytes_ub = stop_count;
583 if ((int)(nbytes_ub - old_alloc_count) > 0) {
584 rt_printk("mite: DMA underrun\n");
585 async->events |= COMEDI_CB_OVERFLOW;
588 count = nbytes_lb - async->buf_read_count;
593 comedi_buf_read_free(async, count);
594 async->events |= COMEDI_CB_BLOCK;
599 unsigned mite_get_status(struct mite_channel *mite_chan)
601 struct mite_struct *mite = mite_chan->mite;
605 comedi_spin_lock_irqsave(&mite->lock, flags);
606 status = readl(mite->mite_io_addr + MITE_CHSR(mite_chan->channel));
607 if (status & CHSR_DONE) {
610 mite->mite_io_addr + MITE_CHOR(mite_chan->channel));
613 comedi_spin_unlock_irqrestore(&mite->lock, flags);
617 int mite_done(struct mite_channel *mite_chan)
619 struct mite_struct *mite = mite_chan->mite;
623 mite_get_status(mite_chan);
624 comedi_spin_lock_irqsave(&mite->lock, flags);
625 done = mite_chan->done;
626 comedi_spin_unlock_irqrestore(&mite->lock, flags);
632 static void mite_decode(char **bit_str, unsigned int bits);
634 /* names of bits in mite registers */
636 static const char *const mite_CHOR_strings[] = {
637 "start", "cont", "stop", "abort",
638 "freset", "clrlc", "clrrb", "clrdone",
639 "clr_lpause", "set_lpause", "clr_send_tc",
640 "set_send_tc", "12", "13", "14",
641 "15", "16", "17", "18",
642 "19", "20", "21", "22",
643 "23", "24", "25", "26",
644 "27", "28", "29", "30",
648 static const char *const mite_CHCR_strings[] = {
649 "continue", "ringbuff", "2", "3",
651 "8", "9", "10", "11",
652 "12", "13", "bursten", "fifodis",
653 "clr_cont_rb_ie", "set_cont_rb_ie", "clr_lc_ie", "set_lc_ie",
654 "clr_drdy_ie", "set_drdy_ie", "clr_mrdy_ie", "set_mrdy_ie",
655 "clr_done_ie", "set_done_ie", "clr_sar_ie", "set_sar_ie",
656 "clr_linkp_ie", "set_linkp_ie", "clr_dma_ie", "set_dma_ie",
659 static const char *const mite_MCR_strings[] = {
660 "amdevice", "1", "2", "3",
661 "4", "5", "portio", "portvxi",
662 "psizebyte", "psizehalf (byte & half = word)", "aseqxp1", "11",
663 "12", "13", "blocken", "berhand",
664 "reqsintlim/reqs0", "reqs1", "reqs2", "rd32",
665 "rd512", "rl1", "rl2", "rl8",
666 "24", "25", "26", "27",
667 "28", "29", "30", "stopen",
670 static const char *const mite_DCR_strings[] = {
671 "amdevice", "1", "2", "3",
672 "4", "5", "portio", "portvxi",
673 "psizebyte", "psizehalf (byte & half = word)", "aseqxp1", "aseqxp2",
674 "aseqxp8", "13", "blocken", "berhand",
675 "reqsintlim", "reqs1", "reqs2", "rd32",
676 "rd512", "rl1", "rl2", "rl8",
677 "23", "24", "25", "27",
678 "28", "wsdevc", "wsdevs", "rwdevpack",
681 static const char *const mite_LKCR_strings[] = {
682 "amdevice", "1", "2", "3",
683 "4", "5", "portio", "portvxi",
684 "psizebyte", "psizehalf (byte & half = word)", "asequp", "aseqdown",
685 "12", "13", "14", "berhand",
686 "16", "17", "18", "rd32",
687 "rd512", "rl1", "rl2", "rl8",
688 "24", "25", "26", "27",
689 "28", "29", "30", "chngend",
692 static const char *const mite_CHSR_strings[] = {
693 "d.err0", "d.err1", "m.err0", "m.err1",
694 "l.err0", "l.err1", "drq0", "drq1",
695 "end", "xferr", "operr0", "operr1",
696 "stops", "habort", "sabort", "error",
697 "16", "conts_rb", "18", "linkc",
698 "20", "drdy", "22", "mrdy",
699 "24", "done", "26", "sars",
700 "28", "lpauses", "30", "int",
703 void mite_dump_regs(struct mite_channel *mite_chan)
705 unsigned long mite_io_addr =
706 (unsigned long)mite_chan->mite->mite_io_addr;
707 unsigned long addr = 0;
708 unsigned long temp = 0;
710 printk("mite_dump_regs ch%i\n", mite_chan->channel);
711 printk("mite address is =0x%08lx\n", mite_io_addr);
713 addr = mite_io_addr + MITE_CHOR(channel);
714 printk("mite status[CHOR]at 0x%08lx =0x%08lx\n", addr, temp =
716 mite_decode(mite_CHOR_strings, temp);
717 addr = mite_io_addr + MITE_CHCR(channel);
718 printk("mite status[CHCR]at 0x%08lx =0x%08lx\n", addr, temp =
720 mite_decode(mite_CHCR_strings, temp);
721 addr = mite_io_addr + MITE_TCR(channel);
722 printk("mite status[TCR] at 0x%08lx =0x%08x\n", addr, readl(addr));
723 addr = mite_io_addr + MITE_MCR(channel);
724 printk("mite status[MCR] at 0x%08lx =0x%08lx\n", addr, temp =
726 mite_decode(mite_MCR_strings, temp);
728 addr = mite_io_addr + MITE_MAR(channel);
729 printk("mite status[MAR] at 0x%08lx =0x%08x\n", addr, readl(addr));
730 addr = mite_io_addr + MITE_DCR(channel);
731 printk("mite status[DCR] at 0x%08lx =0x%08lx\n", addr, temp =
733 mite_decode(mite_DCR_strings, temp);
734 addr = mite_io_addr + MITE_DAR(channel);
735 printk("mite status[DAR] at 0x%08lx =0x%08x\n", addr, readl(addr));
736 addr = mite_io_addr + MITE_LKCR(channel);
737 printk("mite status[LKCR]at 0x%08lx =0x%08lx\n", addr, temp =
739 mite_decode(mite_LKCR_strings, temp);
740 addr = mite_io_addr + MITE_LKAR(channel);
741 printk("mite status[LKAR]at 0x%08lx =0x%08x\n", addr, readl(addr));
743 addr = mite_io_addr + MITE_CHSR(channel);
744 printk("mite status[CHSR]at 0x%08lx =0x%08lx\n", addr, temp =
746 mite_decode(mite_CHSR_strings, temp);
747 addr = mite_io_addr + MITE_FCR(channel);
748 printk("mite status[FCR] at 0x%08lx =0x%08x\n\n", addr, readl(addr));
751 static void mite_decode(char **bit_str, unsigned int bits)
755 for (i = 31; i >= 0; i--) {
756 if (bits & (1 << i)) {
757 printk(" %s", bit_str[i]);
765 int __init init_module(void)
773 void __exit cleanup_module(void)
778 EXPORT_SYMBOL(mite_dma_tcr);
779 EXPORT_SYMBOL(mite_dma_arm);
780 EXPORT_SYMBOL(mite_dma_disarm);
781 EXPORT_SYMBOL(mite_sync_input_dma);
782 EXPORT_SYMBOL(mite_sync_output_dma);
783 EXPORT_SYMBOL(mite_setup);
784 EXPORT_SYMBOL(mite_setup2);
785 EXPORT_SYMBOL(mite_unsetup);
787 EXPORT_SYMBOL(mite_kvmem_segment_load);
788 EXPORT_SYMBOL(mite_ll_from_kvmem);
789 EXPORT_SYMBOL(mite_setregs);
791 EXPORT_SYMBOL(mite_devices);
792 EXPORT_SYMBOL(mite_list_devices);
793 EXPORT_SYMBOL(mite_request_channel_in_range);
794 EXPORT_SYMBOL(mite_release_channel);
795 EXPORT_SYMBOL(mite_prep_dma);
796 EXPORT_SYMBOL(mite_buf_change);
797 EXPORT_SYMBOL(mite_bytes_written_to_memory_lb);
798 EXPORT_SYMBOL(mite_bytes_written_to_memory_ub);
799 EXPORT_SYMBOL(mite_bytes_read_from_memory_lb);
800 EXPORT_SYMBOL(mite_bytes_read_from_memory_ub);
801 EXPORT_SYMBOL(mite_bytes_in_transit);
802 EXPORT_SYMBOL(mite_get_status);
803 EXPORT_SYMBOL(mite_done);
805 EXPORT_SYMBOL(mite_decode);
806 EXPORT_SYMBOL(mite_dump_regs);