4 #include <linux/list.h>
5 #include <linux/spinlock.h>
6 #include <linux/workqueue.h>
7 #include <linux/linkage.h>
8 #include <asm/atomic.h>
11 /* DMA-Interrupt reasons. */
12 #define BCM43xx_DMAIRQ_FATALMASK ((1 << 10) | (1 << 11) | (1 << 12) \
13 | (1 << 14) | (1 << 15))
14 #define BCM43xx_DMAIRQ_NONFATALMASK (1 << 13)
15 #define BCM43xx_DMAIRQ_RX_DONE (1 << 16)
17 /* DMA controller register offsets. (relative to BCM43xx_DMA#_BASE) */
18 #define BCM43xx_DMA_TX_CONTROL 0x00
19 #define BCM43xx_DMA_TX_DESC_RING 0x04
20 #define BCM43xx_DMA_TX_DESC_INDEX 0x08
21 #define BCM43xx_DMA_TX_STATUS 0x0c
22 #define BCM43xx_DMA_RX_CONTROL 0x10
23 #define BCM43xx_DMA_RX_DESC_RING 0x14
24 #define BCM43xx_DMA_RX_DESC_INDEX 0x18
25 #define BCM43xx_DMA_RX_STATUS 0x1c
27 /* DMA controller channel control word values. */
28 #define BCM43xx_DMA_TXCTRL_ENABLE (1 << 0)
29 #define BCM43xx_DMA_TXCTRL_SUSPEND (1 << 1)
30 #define BCM43xx_DMA_TXCTRL_LOOPBACK (1 << 2)
31 #define BCM43xx_DMA_TXCTRL_FLUSH (1 << 4)
32 #define BCM43xx_DMA_RXCTRL_ENABLE (1 << 0)
33 #define BCM43xx_DMA_RXCTRL_FRAMEOFF_MASK 0x000000fe
34 #define BCM43xx_DMA_RXCTRL_FRAMEOFF_SHIFT 1
35 #define BCM43xx_DMA_RXCTRL_PIO (1 << 8)
36 /* DMA controller channel status word values. */
37 #define BCM43xx_DMA_TXSTAT_DPTR_MASK 0x00000fff
38 #define BCM43xx_DMA_TXSTAT_STAT_MASK 0x0000f000
39 #define BCM43xx_DMA_TXSTAT_STAT_DISABLED 0x00000000
40 #define BCM43xx_DMA_TXSTAT_STAT_ACTIVE 0x00001000
41 #define BCM43xx_DMA_TXSTAT_STAT_IDLEWAIT 0x00002000
42 #define BCM43xx_DMA_TXSTAT_STAT_STOPPED 0x00003000
43 #define BCM43xx_DMA_TXSTAT_STAT_SUSP 0x00004000
44 #define BCM43xx_DMA_TXSTAT_ERROR_MASK 0x000f0000
45 #define BCM43xx_DMA_TXSTAT_FLUSHED (1 << 20)
46 #define BCM43xx_DMA_RXSTAT_DPTR_MASK 0x00000fff
47 #define BCM43xx_DMA_RXSTAT_STAT_MASK 0x0000f000
48 #define BCM43xx_DMA_RXSTAT_STAT_DISABLED 0x00000000
49 #define BCM43xx_DMA_RXSTAT_STAT_ACTIVE 0x00001000
50 #define BCM43xx_DMA_RXSTAT_STAT_IDLEWAIT 0x00002000
51 #define BCM43xx_DMA_RXSTAT_STAT_RESERVED 0x00003000
52 #define BCM43xx_DMA_RXSTAT_STAT_ERRORS 0x00004000
53 #define BCM43xx_DMA_RXSTAT_ERROR_MASK 0x000f0000
55 /* DMA descriptor control field values. */
56 #define BCM43xx_DMADTOR_BYTECNT_MASK 0x00001fff
57 #define BCM43xx_DMADTOR_DTABLEEND (1 << 28) /* End of descriptor table */
58 #define BCM43xx_DMADTOR_COMPIRQ (1 << 29) /* IRQ on completion request */
59 #define BCM43xx_DMADTOR_FRAMEEND (1 << 30)
60 #define BCM43xx_DMADTOR_FRAMESTART (1 << 31)
62 /* Misc DMA constants */
63 #define BCM43xx_DMA_RINGMEMSIZE PAGE_SIZE
64 #define BCM43xx_DMA_BUSADDRMAX 0x3FFFFFFF
65 #define BCM43xx_DMA_DMABUSADDROFFSET (1 << 30)
66 #define BCM43xx_DMA1_RX_FRAMEOFFSET 30
67 #define BCM43xx_DMA4_RX_FRAMEOFFSET 0
69 /* DMA engine tuning knobs */
70 #define BCM43xx_TXRING_SLOTS 512
71 #define BCM43xx_RXRING_SLOTS 64
72 #define BCM43xx_DMA1_RXBUFFERSIZE (2304 + 100)
73 #define BCM43xx_DMA4_RXBUFFERSIZE 16
74 /* Suspend the tx queue, if less than this percent slots are free. */
75 #define BCM43xx_TXSUSPEND_PERCENT 20
76 /* Resume the tx queue, if more than this percent slots are free. */
77 #define BCM43xx_TXRESUME_PERCENT 50
81 #ifdef CONFIG_BCM43XX_DMA
85 struct bcm43xx_private;
86 struct bcm43xx_xmitstatus;
89 struct bcm43xx_dmadesc {
92 } __attribute__((__packed__));
94 /* Macros to access the bcm43xx_dmadesc struct */
95 #define get_desc_ctl(desc) le32_to_cpu((desc)->_control)
96 #define set_desc_ctl(desc, ctl) do { (desc)->_control = cpu_to_le32(ctl); } while (0)
97 #define get_desc_addr(desc) le32_to_cpu((desc)->_address)
98 #define set_desc_addr(desc, addr) do { (desc)->_address = cpu_to_le32(addr); } while (0)
100 struct bcm43xx_dmadesc_meta {
101 /* The kernel DMA-able buffer. */
103 /* DMA base bus-address of the descriptor buffer. */
107 struct bcm43xx_dmaring {
108 struct bcm43xx_private *bcm;
109 /* Kernel virtual base address of the ring memory. */
110 struct bcm43xx_dmadesc *vbase;
111 /* DMA memory offset */
112 dma_addr_t memoffset;
113 /* (Unadjusted) DMA base bus-address of the ring memory. */
115 /* Meta data about all descriptors. */
116 struct bcm43xx_dmadesc_meta *meta;
117 /* Number of descriptor slots in the ring. */
119 /* Number of used descriptor slots. */
121 /* Currently used slot in the ring. */
123 /* Marks to suspend/resume the queue. */
126 /* Frameoffset in octets. */
128 /* Descriptor buffer size. */
130 /* The MMIO base register of the DMA controller, this
134 u8 tx:1, /* TRUE, if this is a TX ring. */
135 suspended:1; /* TRUE, if transfers are suspended on this ring. */
136 #ifdef CONFIG_BCM43XX_DEBUG
137 /* Maximum number of used slots. */
139 #endif /* CONFIG_BCM43XX_DEBUG*/
144 u32 bcm43xx_dma_read(struct bcm43xx_dmaring *ring,
147 return bcm43xx_read32(ring->bcm, ring->mmio_base + offset);
151 void bcm43xx_dma_write(struct bcm43xx_dmaring *ring,
152 u16 offset, u32 value)
154 bcm43xx_write32(ring->bcm, ring->mmio_base + offset, value);
158 int bcm43xx_dma_init(struct bcm43xx_private *bcm);
159 void bcm43xx_dma_free(struct bcm43xx_private *bcm);
161 int bcm43xx_dmacontroller_rx_reset(struct bcm43xx_private *bcm,
162 u16 dmacontroller_mmio_base);
163 int bcm43xx_dmacontroller_tx_reset(struct bcm43xx_private *bcm,
164 u16 dmacontroller_mmio_base);
166 void bcm43xx_dma_tx_suspend(struct bcm43xx_dmaring *ring);
167 void bcm43xx_dma_tx_resume(struct bcm43xx_dmaring *ring);
169 void bcm43xx_dma_handle_xmitstatus(struct bcm43xx_private *bcm,
170 struct bcm43xx_xmitstatus *status);
172 int bcm43xx_dma_tx(struct bcm43xx_private *bcm,
173 struct ieee80211_txb *txb);
174 void bcm43xx_dma_rx(struct bcm43xx_dmaring *ring);
177 #else /* CONFIG_BCM43XX_DMA */
181 int bcm43xx_dma_init(struct bcm43xx_private *bcm)
186 void bcm43xx_dma_free(struct bcm43xx_private *bcm)
190 int bcm43xx_dmacontroller_rx_reset(struct bcm43xx_private *bcm,
191 u16 dmacontroller_mmio_base)
196 int bcm43xx_dmacontroller_tx_reset(struct bcm43xx_private *bcm,
197 u16 dmacontroller_mmio_base)
202 int bcm43xx_dma_tx(struct bcm43xx_private *bcm,
203 struct ieee80211_txb *txb)
208 void bcm43xx_dma_handle_xmitstatus(struct bcm43xx_private *bcm,
209 struct bcm43xx_xmitstatus *status)
213 void bcm43xx_dma_rx(struct bcm43xx_dmaring *ring)
217 void bcm43xx_dma_tx_suspend(struct bcm43xx_dmaring *ring)
221 void bcm43xx_dma_tx_resume(struct bcm43xx_dmaring *ring)
225 #endif /* CONFIG_BCM43XX_DMA */
226 #endif /* BCM43xx_DMA_H_ */