imx23_apbdmavar.h revision 1.1.6.3 1 1.1.6.2 tls /* $Id: imx23_apbdmavar.h,v 1.1.6.3 2017/12/03 11:35:53 jdolecek Exp $ */
2 1.1.6.2 tls
3 1.1.6.2 tls /*
4 1.1.6.2 tls * Copyright (c) 2013 The NetBSD Foundation, Inc.
5 1.1.6.2 tls * All rights reserved.
6 1.1.6.2 tls *
7 1.1.6.2 tls * This code is derived from software contributed to The NetBSD Foundation
8 1.1.6.2 tls * by Petri Laakso.
9 1.1.6.2 tls *
10 1.1.6.2 tls * Redistribution and use in source and binary forms, with or without
11 1.1.6.2 tls * modification, are permitted provided that the following conditions
12 1.1.6.2 tls * are met:
13 1.1.6.2 tls * 1. Redistributions of source code must retain the above copyright
14 1.1.6.2 tls * notice, this list of conditions and the following disclaimer.
15 1.1.6.2 tls * 2. Redistributions in binary form must reproduce the above copyright
16 1.1.6.2 tls * notice, this list of conditions and the following disclaimer in the
17 1.1.6.2 tls * documentation and/or other materials provided with the distribution.
18 1.1.6.2 tls *
19 1.1.6.2 tls * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 1.1.6.2 tls * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 1.1.6.2 tls * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 1.1.6.2 tls * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 1.1.6.2 tls * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 1.1.6.2 tls * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 1.1.6.2 tls * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 1.1.6.2 tls * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 1.1.6.2 tls * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 1.1.6.2 tls * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 1.1.6.2 tls * POSSIBILITY OF SUCH DAMAGE.
30 1.1.6.2 tls */
31 1.1.6.2 tls
32 1.1.6.2 tls #ifndef _ARM_IMX_IMX23_APBDMAVAR_H_
33 1.1.6.2 tls #define _ARM_IMX_IMX23_APBDMAVAR_H_
34 1.1.6.2 tls
35 1.1.6.2 tls #include <sys/cdefs.h>
36 1.1.6.2 tls #include <sys/types.h>
37 1.1.6.2 tls #include <sys/bus.h>
38 1.1.6.2 tls #include <sys/device.h>
39 1.1.6.2 tls #include <sys/mutex.h>
40 1.1.6.2 tls
41 1.1.6.2 tls /* DMA command control register bits. */
42 1.1.6.2 tls #define APBDMA_CMD_XFER_COUNT __BITS(31, 16)
43 1.1.6.2 tls #define APBDMA_CMD_CMDPIOWORDS __BITS(15, 12)
44 1.1.6.2 tls #define APBDMA_CMD_RESERVED __BITS(11, 9)
45 1.1.6.2 tls #define APBDMA_CMD_HALTONTERMINATE __BIT(8)
46 1.1.6.2 tls #define APBDMA_CMD_WAIT4ENDCMD __BIT(7)
47 1.1.6.2 tls #define APBDMA_CMD_SEMAPHORE __BIT(6)
48 1.1.6.2 tls #define APBDMA_CMD_NANDWAIT4READY __BIT(5)
49 1.1.6.2 tls #define APBDMA_CMD_NANDLOCK __BIT(4)
50 1.1.6.2 tls #define APBDMA_CMD_IRQONCMPLT __BIT(3)
51 1.1.6.2 tls #define APBDMA_CMD_CHAIN __BIT(2)
52 1.1.6.2 tls #define APBDMA_CMD_COMMAND __BITS(1, 0)
53 1.1.6.2 tls
54 1.1.6.2 tls /* DMA command types. */
55 1.1.6.2 tls #define APBDMA_CMD_NO_DMA_XFER 0
56 1.1.6.2 tls #define APBDMA_CMD_DMA_WRITE 1
57 1.1.6.2 tls #define APBDMA_CMD_DMA_READ 2
58 1.1.6.2 tls #define APBDMA_CMD_DMA_SENSE 3
59 1.1.6.2 tls
60 1.1.6.2 tls /* Flags. */
61 1.1.6.3 jdolecek #define F_APBH_DMA __BIT(0)
62 1.1.6.3 jdolecek #define F_APBX_DMA __BIT(1)
63 1.1.6.2 tls
64 1.1.6.2 tls /* Number of channels. */
65 1.1.6.2 tls #define AHBH_DMA_CHANNELS 8
66 1.1.6.2 tls #define AHBX_DMA_CHANNELS 16
67 1.1.6.2 tls
68 1.1.6.2 tls /* APBH DMA channel assignments. */
69 1.1.6.2 tls #define APBH_DMA_CHANNEL_RES0 0 /* Reserved. */
70 1.1.6.2 tls #define APBH_DMA_CHANNEL_SSP1 1 /* SSP1. */
71 1.1.6.2 tls #define APBH_DMA_CHANNEL_SSP2 2 /* SSP2. */
72 1.1.6.2 tls #define APBH_DMA_CHANNEL_RES1 3 /* Reserved. */
73 1.1.6.2 tls #define APBH_DMA_CHANNEL_NAND_DEVICE0 4 /* NAND_DEVICE0. */
74 1.1.6.2 tls #define APBH_DMA_CHANNEL_NAND_DEVICE1 5 /* NAND_DEVICE1. */
75 1.1.6.2 tls #define APBH_DMA_CHANNEL_NAND_DEVICE2 6 /* NAND_DEVICE2. */
76 1.1.6.2 tls #define APBH_DMA_CHANNEL_NAND_DEVICE3 7 /* NAND_DEVICE3. */
77 1.1.6.2 tls
78 1.1.6.2 tls /* APBX DMA channel assignments. */
79 1.1.6.2 tls #define APBX_DMA_CHANNEL_AUDIO_ADC 0 /* Audio ADCs. */
80 1.1.6.2 tls #define APBX_DMA_CHANNEL_AUDIO_DAC 1 /* Audio DACs. */
81 1.1.6.2 tls #define APBX_DMA_CHANNEL_SPDIF_TX 2 /* SPDIF TX. */
82 1.1.6.2 tls #define APBX_DMA_CHANNEL_I2C 3 /* I2C. */
83 1.1.6.2 tls #define APBX_DMA_CHANNEL_SAIF1 4 /* SAIF1. */
84 1.1.6.2 tls #define APBX_DMA_CHANNEL_RES0 5 /* Reserved. */
85 1.1.6.2 tls #define APBX_DMA_CHANNEL_UART1_RX 6 /* UART1 RX, IrDA RX. */
86 1.1.6.2 tls #define APBX_DMA_CHANNEL_UART1_TX 7 /* UART1 TX, IrDA TX. */
87 1.1.6.2 tls #define APBX_DMA_CHANNEL_UART2_RX 8 /* UART2 RX. */
88 1.1.6.2 tls #define APBX_DMA_CHANNEL_UART2_TX 9 /* UART2 TX. */
89 1.1.6.2 tls #define APBX_DMA_CHANNEL_SAIF2 10 /* SAIF2. */
90 1.1.6.2 tls #define APBX_DMA_CHANNEL_RES1 11 /* Reserved. */
91 1.1.6.2 tls #define APBX_DMA_CHANNEL_RES2 12 /* Reserved. */
92 1.1.6.2 tls #define APBX_DMA_CHANNEL_RES3 13 /* Reserved. */
93 1.1.6.2 tls #define APBX_DMA_CHANNEL_RES4 14 /* Reserved. */
94 1.1.6.2 tls #define APBX_DMA_CHANNEL_RES5 15 /* Reserved. */
95 1.1.6.2 tls
96 1.1.6.2 tls /* Return codes for apbdma_intr_status() */
97 1.1.6.2 tls #define DMA_IRQ_CMDCMPLT 0
98 1.1.6.2 tls #define DMA_IRQ_TERM 1
99 1.1.6.2 tls #define DMA_IRQ_BUS_ERROR 2
100 1.1.6.2 tls
101 1.1.6.2 tls #define PIO_WORDS_MAX 15
102 1.1.6.2 tls
103 1.1.6.2 tls /*
104 1.1.6.2 tls * How many PIO words apbdma_command structure has.
105 1.1.6.2 tls *
106 1.1.6.2 tls * XXX: If you change this value, make sure drivers are prepared for that.
107 1.1.6.2 tls * That means you have to allocate enough DMA memory for command chains.
108 1.1.6.2 tls */
109 1.1.6.2 tls #define PIO_WORDS 3
110 1.1.6.2 tls
111 1.1.6.2 tls typedef struct apbdma_softc {
112 1.1.6.2 tls device_t sc_dev;
113 1.1.6.2 tls bus_dma_tag_t sc_dmat;
114 1.1.6.2 tls bus_space_handle_t sc_ioh;
115 1.1.6.2 tls bus_space_tag_t sc_iot;
116 1.1.6.2 tls kmutex_t sc_lock;
117 1.1.6.2 tls u_int flags;
118 1.1.6.2 tls } *apbdma_softc_t;
119 1.1.6.2 tls
120 1.1.6.2 tls typedef struct apbdma_command {
121 1.1.6.2 tls void *next; /* Physical address. */
122 1.1.6.2 tls uint32_t control;
123 1.1.6.2 tls void *buffer; /* Physical address. */
124 1.1.6.2 tls uint32_t pio_words[PIO_WORDS];
125 1.1.6.2 tls } *apbdma_command_t;
126 1.1.6.2 tls
127 1.1.6.2 tls void apbdma_cmd_chain(apbdma_command_t, apbdma_command_t, void *, bus_dmamap_t);
128 1.1.6.2 tls void apbdma_cmd_buf(apbdma_command_t, bus_addr_t, bus_dmamap_t);
129 1.1.6.2 tls void apbdma_chan_init(struct apbdma_softc *, unsigned int);
130 1.1.6.2 tls void apbdma_chan_set_chain(struct apbdma_softc *, unsigned int, bus_dmamap_t);
131 1.1.6.2 tls void apbdma_run(struct apbdma_softc *, unsigned int);
132 1.1.6.2 tls void apbdma_ack_intr(struct apbdma_softc *, unsigned int);
133 1.1.6.2 tls void apbdma_ack_error_intr(struct apbdma_softc *, unsigned int);
134 1.1.6.2 tls unsigned int apbdma_intr_status(struct apbdma_softc *, unsigned int);
135 1.1.6.2 tls void apbdma_chan_reset(struct apbdma_softc *, unsigned int);
136 1.1.6.3 jdolecek void apbdma_wait(struct apbdma_softc *, unsigned int);
137 1.1.6.2 tls
138 1.1.6.2 tls #endif /* !_ARM_IMX_IMX23_APBDMAVAR_H_ */
139