diff options
author | Nobuhiro Iwamatsu <iwamatsu.nobuhiro@renesas.com> | 2009-03-10 04:26:49 -0400 |
---|---|---|
committer | Paul Mundt <lethal@linux-sh.org> | 2009-03-10 04:26:49 -0400 |
commit | 71b973a42c5456824c8712e00659d9616d395919 (patch) | |
tree | 1367c85de45159c66752a93fc062a6f67f616607 | |
parent | ae68df5635a191c7edb75f5c1c1406353cb24a9f (diff) |
sh: dma-sh updates for multi IRQ and new SH-4A CPUs.
This adds DMA support for newer SH-4A CPUs, particularly SH7763/64/80/85.
This also enables multi IRQ support for platforms that have multiple
vectors bound to the same IRQ source.
Signed-off-by: Nobuhiro Iwamatsu <iwamatsu.nobuhiro@renesas.com>
Signed-off-by: Yoshihiro Shimoda <shimoda.yoshihiro@renesas.com>
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
-rw-r--r-- | arch/sh/drivers/dma/Kconfig | 8 | ||||
-rw-r--r-- | arch/sh/drivers/dma/dma-sh.c | 172 | ||||
-rw-r--r-- | arch/sh/drivers/dma/dma-sh.h | 75 | ||||
-rw-r--r-- | arch/sh/include/asm/dma-sh.h | 117 | ||||
-rw-r--r-- | arch/sh/include/asm/dma.h | 4 | ||||
-rw-r--r-- | arch/sh/include/cpu-sh3/cpu/dma.h | 17 | ||||
-rw-r--r-- | arch/sh/include/cpu-sh4/cpu/dma-sh4a.h | 94 | ||||
-rw-r--r-- | arch/sh/include/cpu-sh4/cpu/dma-sh7780.h | 39 | ||||
-rw-r--r-- | arch/sh/include/cpu-sh4/cpu/dma.h | 30 |
9 files changed, 352 insertions, 204 deletions
diff --git a/arch/sh/drivers/dma/Kconfig b/arch/sh/drivers/dma/Kconfig index 01936368b8b0..57d95fce0464 100644 --- a/arch/sh/drivers/dma/Kconfig +++ b/arch/sh/drivers/dma/Kconfig | |||
@@ -12,10 +12,10 @@ config SH_DMA | |||
12 | config NR_ONCHIP_DMA_CHANNELS | 12 | config NR_ONCHIP_DMA_CHANNELS |
13 | int | 13 | int |
14 | depends on SH_DMA | 14 | depends on SH_DMA |
15 | default "6" if CPU_SUBTYPE_SH7720 || CPU_SUBTYPE_SH7721 | 15 | default "4" if CPU_SUBTYPE_SH7750 || CPU_SUBTYPE_SH7751 || CPU_SUBTYPE_SH7750S |
16 | default "8" if CPU_SUBTYPE_SH7750R || CPU_SUBTYPE_SH7751R | 16 | default "8" if CPU_SUBTYPE_SH7750R || CPU_SUBTYPE_SH7751R || CPU_SUBTYPE_SH7760 |
17 | default "12" if CPU_SUBTYPE_SH7780 | 17 | default "12" if CPU_SUBTYPE_SH7723 || CPU_SUBTYPE_SH7780 || CPU_SUBTYPE_SH7785 |
18 | default "4" | 18 | default "6" |
19 | help | 19 | help |
20 | This allows you to specify the number of channels that the on-chip | 20 | This allows you to specify the number of channels that the on-chip |
21 | DMAC supports. This will be 4 for SH7750/SH7751 and 8 for the | 21 | DMAC supports. This will be 4 for SH7750/SH7751 and 8 for the |
diff --git a/arch/sh/drivers/dma/dma-sh.c b/arch/sh/drivers/dma/dma-sh.c index 50887a592dd0..ab7b18dcbaba 100644 --- a/arch/sh/drivers/dma/dma-sh.c +++ b/arch/sh/drivers/dma/dma-sh.c | |||
@@ -17,28 +17,23 @@ | |||
17 | #include <mach-dreamcast/mach/dma.h> | 17 | #include <mach-dreamcast/mach/dma.h> |
18 | #include <asm/dma.h> | 18 | #include <asm/dma.h> |
19 | #include <asm/io.h> | 19 | #include <asm/io.h> |
20 | #include "dma-sh.h" | 20 | #include <asm/dma-sh.h> |
21 | 21 | ||
22 | static int dmte_irq_map[] = { | 22 | #if defined(CONFIG_CPU_SUBTYPE_SH7763) || \ |
23 | DMTE0_IRQ, | 23 | defined(CONFIG_CPU_SUBTYPE_SH7764) || \ |
24 | DMTE1_IRQ, | 24 | defined(CONFIG_CPU_SUBTYPE_SH7780) || \ |
25 | DMTE2_IRQ, | 25 | defined(CONFIG_CPU_SUBTYPE_SH7785) |
26 | DMTE3_IRQ, | 26 | #define DMAC_IRQ_MULTI 1 |
27 | #if defined(CONFIG_CPU_SUBTYPE_SH7720) || \ | ||
28 | defined(CONFIG_CPU_SUBTYPE_SH7721) || \ | ||
29 | defined(CONFIG_CPU_SUBTYPE_SH7751R) || \ | ||
30 | defined(CONFIG_CPU_SUBTYPE_SH7760) || \ | ||
31 | defined(CONFIG_CPU_SUBTYPE_SH7709) || \ | ||
32 | defined(CONFIG_CPU_SUBTYPE_SH7780) | ||
33 | DMTE4_IRQ, | ||
34 | DMTE5_IRQ, | ||
35 | #endif | 27 | #endif |
36 | #if defined(CONFIG_CPU_SUBTYPE_SH7751R) || \ | 28 | |
37 | defined(CONFIG_CPU_SUBTYPE_SH7760) || \ | 29 | #if defined(DMAE1_IRQ) |
38 | defined(CONFIG_CPU_SUBTYPE_SH7780) | 30 | #define NR_DMAE 2 |
39 | DMTE6_IRQ, | 31 | #else |
40 | DMTE7_IRQ, | 32 | #define NR_DMAE 1 |
41 | #endif | 33 | #endif |
34 | |||
35 | static const char *dmae_name[] = { | ||
36 | "DMAC Address Error0", "DMAC Address Error1" | ||
42 | }; | 37 | }; |
43 | 38 | ||
44 | static inline unsigned int get_dmte_irq(unsigned int chan) | 39 | static inline unsigned int get_dmte_irq(unsigned int chan) |
@@ -46,7 +41,14 @@ static inline unsigned int get_dmte_irq(unsigned int chan) | |||
46 | unsigned int irq = 0; | 41 | unsigned int irq = 0; |
47 | if (chan < ARRAY_SIZE(dmte_irq_map)) | 42 | if (chan < ARRAY_SIZE(dmte_irq_map)) |
48 | irq = dmte_irq_map[chan]; | 43 | irq = dmte_irq_map[chan]; |
44 | |||
45 | #if defined(DMAC_IRQ_MULTI) | ||
46 | if (irq > DMTE6_IRQ) | ||
47 | return DMTE6_IRQ; | ||
48 | return DMTE0_IRQ; | ||
49 | #else | ||
49 | return irq; | 50 | return irq; |
51 | #endif | ||
50 | } | 52 | } |
51 | 53 | ||
52 | /* | 54 | /* |
@@ -59,7 +61,7 @@ static inline unsigned int get_dmte_irq(unsigned int chan) | |||
59 | */ | 61 | */ |
60 | static inline unsigned int calc_xmit_shift(struct dma_channel *chan) | 62 | static inline unsigned int calc_xmit_shift(struct dma_channel *chan) |
61 | { | 63 | { |
62 | u32 chcr = ctrl_inl(CHCR[chan->chan]); | 64 | u32 chcr = ctrl_inl(dma_base_addr[chan->chan] + CHCR); |
63 | 65 | ||
64 | return ts_shift[(chcr & CHCR_TS_MASK)>>CHCR_TS_SHIFT]; | 66 | return ts_shift[(chcr & CHCR_TS_MASK)>>CHCR_TS_SHIFT]; |
65 | } | 67 | } |
@@ -75,13 +77,13 @@ static irqreturn_t dma_tei(int irq, void *dev_id) | |||
75 | struct dma_channel *chan = dev_id; | 77 | struct dma_channel *chan = dev_id; |
76 | u32 chcr; | 78 | u32 chcr; |
77 | 79 | ||
78 | chcr = ctrl_inl(CHCR[chan->chan]); | 80 | chcr = ctrl_inl(dma_base_addr[chan->chan] + CHCR); |
79 | 81 | ||
80 | if (!(chcr & CHCR_TE)) | 82 | if (!(chcr & CHCR_TE)) |
81 | return IRQ_NONE; | 83 | return IRQ_NONE; |
82 | 84 | ||
83 | chcr &= ~(CHCR_IE | CHCR_DE); | 85 | chcr &= ~(CHCR_IE | CHCR_DE); |
84 | ctrl_outl(chcr, CHCR[chan->chan]); | 86 | ctrl_outl(chcr, (dma_base_addr[chan->chan] + CHCR)); |
85 | 87 | ||
86 | wake_up(&chan->wait_queue); | 88 | wake_up(&chan->wait_queue); |
87 | 89 | ||
@@ -94,7 +96,12 @@ static int sh_dmac_request_dma(struct dma_channel *chan) | |||
94 | return 0; | 96 | return 0; |
95 | 97 | ||
96 | return request_irq(get_dmte_irq(chan->chan), dma_tei, | 98 | return request_irq(get_dmte_irq(chan->chan), dma_tei, |
97 | IRQF_DISABLED, chan->dev_id, chan); | 99 | #if defined(DMAC_IRQ_MULTI) |
100 | IRQF_SHARED, | ||
101 | #else | ||
102 | IRQF_DISABLED, | ||
103 | #endif | ||
104 | chan->dev_id, chan); | ||
98 | } | 105 | } |
99 | 106 | ||
100 | static void sh_dmac_free_dma(struct dma_channel *chan) | 107 | static void sh_dmac_free_dma(struct dma_channel *chan) |
@@ -115,7 +122,7 @@ sh_dmac_configure_channel(struct dma_channel *chan, unsigned long chcr) | |||
115 | chan->flags &= ~DMA_TEI_CAPABLE; | 122 | chan->flags &= ~DMA_TEI_CAPABLE; |
116 | } | 123 | } |
117 | 124 | ||
118 | ctrl_outl(chcr, CHCR[chan->chan]); | 125 | ctrl_outl(chcr, (dma_base_addr[chan->chan] + CHCR)); |
119 | 126 | ||
120 | chan->flags |= DMA_CONFIGURED; | 127 | chan->flags |= DMA_CONFIGURED; |
121 | return 0; | 128 | return 0; |
@@ -126,13 +133,13 @@ static void sh_dmac_enable_dma(struct dma_channel *chan) | |||
126 | int irq; | 133 | int irq; |
127 | u32 chcr; | 134 | u32 chcr; |
128 | 135 | ||
129 | chcr = ctrl_inl(CHCR[chan->chan]); | 136 | chcr = ctrl_inl(dma_base_addr[chan->chan] + CHCR); |
130 | chcr |= CHCR_DE; | 137 | chcr |= CHCR_DE; |
131 | 138 | ||
132 | if (chan->flags & DMA_TEI_CAPABLE) | 139 | if (chan->flags & DMA_TEI_CAPABLE) |
133 | chcr |= CHCR_IE; | 140 | chcr |= CHCR_IE; |
134 | 141 | ||
135 | ctrl_outl(chcr, CHCR[chan->chan]); | 142 | ctrl_outl(chcr, (dma_base_addr[chan->chan] + CHCR)); |
136 | 143 | ||
137 | if (chan->flags & DMA_TEI_CAPABLE) { | 144 | if (chan->flags & DMA_TEI_CAPABLE) { |
138 | irq = get_dmte_irq(chan->chan); | 145 | irq = get_dmte_irq(chan->chan); |
@@ -150,9 +157,9 @@ static void sh_dmac_disable_dma(struct dma_channel *chan) | |||
150 | disable_irq(irq); | 157 | disable_irq(irq); |
151 | } | 158 | } |
152 | 159 | ||
153 | chcr = ctrl_inl(CHCR[chan->chan]); | 160 | chcr = ctrl_inl(dma_base_addr[chan->chan] + CHCR); |
154 | chcr &= ~(CHCR_DE | CHCR_TE | CHCR_IE); | 161 | chcr &= ~(CHCR_DE | CHCR_TE | CHCR_IE); |
155 | ctrl_outl(chcr, CHCR[chan->chan]); | 162 | ctrl_outl(chcr, (dma_base_addr[chan->chan] + CHCR)); |
156 | } | 163 | } |
157 | 164 | ||
158 | static int sh_dmac_xfer_dma(struct dma_channel *chan) | 165 | static int sh_dmac_xfer_dma(struct dma_channel *chan) |
@@ -183,12 +190,13 @@ static int sh_dmac_xfer_dma(struct dma_channel *chan) | |||
183 | */ | 190 | */ |
184 | if (chan->sar || (mach_is_dreamcast() && | 191 | if (chan->sar || (mach_is_dreamcast() && |
185 | chan->chan == PVR2_CASCADE_CHAN)) | 192 | chan->chan == PVR2_CASCADE_CHAN)) |
186 | ctrl_outl(chan->sar, SAR[chan->chan]); | 193 | ctrl_outl(chan->sar, (dma_base_addr[chan->chan]+SAR)); |
187 | if (chan->dar || (mach_is_dreamcast() && | 194 | if (chan->dar || (mach_is_dreamcast() && |
188 | chan->chan == PVR2_CASCADE_CHAN)) | 195 | chan->chan == PVR2_CASCADE_CHAN)) |
189 | ctrl_outl(chan->dar, DAR[chan->chan]); | 196 | ctrl_outl(chan->dar, (dma_base_addr[chan->chan] + DAR)); |
190 | 197 | ||
191 | ctrl_outl(chan->count >> calc_xmit_shift(chan), DMATCR[chan->chan]); | 198 | ctrl_outl(chan->count >> calc_xmit_shift(chan), |
199 | (dma_base_addr[chan->chan] + TCR)); | ||
192 | 200 | ||
193 | sh_dmac_enable_dma(chan); | 201 | sh_dmac_enable_dma(chan); |
194 | 202 | ||
@@ -197,36 +205,26 @@ static int sh_dmac_xfer_dma(struct dma_channel *chan) | |||
197 | 205 | ||
198 | static int sh_dmac_get_dma_residue(struct dma_channel *chan) | 206 | static int sh_dmac_get_dma_residue(struct dma_channel *chan) |
199 | { | 207 | { |
200 | if (!(ctrl_inl(CHCR[chan->chan]) & CHCR_DE)) | 208 | if (!(ctrl_inl(dma_base_addr[chan->chan] + CHCR) & CHCR_DE)) |
201 | return 0; | 209 | return 0; |
202 | 210 | ||
203 | return ctrl_inl(DMATCR[chan->chan]) << calc_xmit_shift(chan); | 211 | return ctrl_inl(dma_base_addr[chan->chan] + TCR) |
212 | << calc_xmit_shift(chan); | ||
204 | } | 213 | } |
205 | 214 | ||
206 | #if defined(CONFIG_CPU_SUBTYPE_SH7720) || \ | 215 | static inline int dmaor_reset(int no) |
207 | defined(CONFIG_CPU_SUBTYPE_SH7721) || \ | ||
208 | defined(CONFIG_CPU_SUBTYPE_SH7780) || \ | ||
209 | defined(CONFIG_CPU_SUBTYPE_SH7709) | ||
210 | #define dmaor_read_reg() ctrl_inw(DMAOR) | ||
211 | #define dmaor_write_reg(data) ctrl_outw(data, DMAOR) | ||
212 | #else | ||
213 | #define dmaor_read_reg() ctrl_inl(DMAOR) | ||
214 | #define dmaor_write_reg(data) ctrl_outl(data, DMAOR) | ||
215 | #endif | ||
216 | |||
217 | static inline int dmaor_reset(void) | ||
218 | { | 216 | { |
219 | unsigned long dmaor = dmaor_read_reg(); | 217 | unsigned long dmaor = dmaor_read_reg(no); |
220 | 218 | ||
221 | /* Try to clear the error flags first, incase they are set */ | 219 | /* Try to clear the error flags first, incase they are set */ |
222 | dmaor &= ~(DMAOR_NMIF | DMAOR_AE); | 220 | dmaor &= ~(DMAOR_NMIF | DMAOR_AE); |
223 | dmaor_write_reg(dmaor); | 221 | dmaor_write_reg(no, dmaor); |
224 | 222 | ||
225 | dmaor |= DMAOR_INIT; | 223 | dmaor |= DMAOR_INIT; |
226 | dmaor_write_reg(dmaor); | 224 | dmaor_write_reg(no, dmaor); |
227 | 225 | ||
228 | /* See if we got an error again */ | 226 | /* See if we got an error again */ |
229 | if ((dmaor_read_reg() & (DMAOR_AE | DMAOR_NMIF))) { | 227 | if ((dmaor_read_reg(no) & (DMAOR_AE | DMAOR_NMIF))) { |
230 | printk(KERN_ERR "dma-sh: Can't initialize DMAOR.\n"); | 228 | printk(KERN_ERR "dma-sh: Can't initialize DMAOR.\n"); |
231 | return -EINVAL; | 229 | return -EINVAL; |
232 | } | 230 | } |
@@ -237,10 +235,33 @@ static inline int dmaor_reset(void) | |||
237 | #if defined(CONFIG_CPU_SH4) | 235 | #if defined(CONFIG_CPU_SH4) |
238 | static irqreturn_t dma_err(int irq, void *dummy) | 236 | static irqreturn_t dma_err(int irq, void *dummy) |
239 | { | 237 | { |
240 | dmaor_reset(); | 238 | #if defined(DMAC_IRQ_MULTI) |
239 | int cnt = 0; | ||
240 | switch (irq) { | ||
241 | #if defined(DMTE6_IRQ) && defined(DMAE1_IRQ) | ||
242 | case DMTE6_IRQ: | ||
243 | cnt++; | ||
244 | #endif | ||
245 | case DMTE0_IRQ: | ||
246 | if (dmaor_read_reg(cnt) & (DMAOR_NMIF | DMAOR_AE)) { | ||
247 | disable_irq(irq); | ||
248 | /* DMA multi and error IRQ */ | ||
249 | return IRQ_HANDLED; | ||
250 | } | ||
251 | default: | ||
252 | return IRQ_NONE; | ||
253 | } | ||
254 | #else | ||
255 | dmaor_reset(0); | ||
256 | #if defined(CONFIG_CPU_SUBTYPE_SH7723) || \ | ||
257 | defined(CONFIG_CPU_SUBTYPE_SH7780) || \ | ||
258 | defined(CONFIG_CPU_SUBTYPE_SH7785) | ||
259 | dmaor_reset(1); | ||
260 | #endif | ||
241 | disable_irq(irq); | 261 | disable_irq(irq); |
242 | 262 | ||
243 | return IRQ_HANDLED; | 263 | return IRQ_HANDLED; |
264 | #endif | ||
244 | } | 265 | } |
245 | #endif | 266 | #endif |
246 | 267 | ||
@@ -259,24 +280,57 @@ static struct dma_info sh_dmac_info = { | |||
259 | .flags = DMAC_CHANNELS_TEI_CAPABLE, | 280 | .flags = DMAC_CHANNELS_TEI_CAPABLE, |
260 | }; | 281 | }; |
261 | 282 | ||
283 | static unsigned int get_dma_error_irq(int n) | ||
284 | { | ||
285 | #if defined(DMAC_IRQ_MULTI) | ||
286 | return (n == 0) ? get_dmte_irq(0) : get_dmte_irq(6); | ||
287 | #else | ||
288 | return (n == 0) ? DMAE0_IRQ : | ||
289 | #if defined(DMAE1_IRQ) | ||
290 | DMAE1_IRQ; | ||
291 | #else | ||
292 | -1; | ||
293 | #endif | ||
294 | #endif | ||
295 | } | ||
296 | |||
262 | static int __init sh_dmac_init(void) | 297 | static int __init sh_dmac_init(void) |
263 | { | 298 | { |
264 | struct dma_info *info = &sh_dmac_info; | 299 | struct dma_info *info = &sh_dmac_info; |
265 | int i; | 300 | int i; |
266 | 301 | ||
267 | #ifdef CONFIG_CPU_SH4 | 302 | #ifdef CONFIG_CPU_SH4 |
268 | i = request_irq(DMAE_IRQ, dma_err, IRQF_DISABLED, "DMAC Address Error", 0); | 303 | int n; |
269 | if (unlikely(i < 0)) | 304 | |
270 | return i; | 305 | for (n = 0; n < NR_DMAE; n++) { |
306 | i = request_irq(get_dma_error_irq(n), dma_err, | ||
307 | #if defined(DMAC_IRQ_MULTI) | ||
308 | IRQF_SHARED, | ||
309 | #else | ||
310 | IRQF_DISABLED, | ||
271 | #endif | 311 | #endif |
312 | dmae_name[n], (void *)dmae_name[n]); | ||
313 | if (unlikely(i < 0)) { | ||
314 | printk(KERN_ERR "%s request_irq fail\n", dmae_name[n]); | ||
315 | return i; | ||
316 | } | ||
317 | } | ||
318 | #endif /* CONFIG_CPU_SH4 */ | ||
272 | 319 | ||
273 | /* | 320 | /* |
274 | * Initialize DMAOR, and clean up any error flags that may have | 321 | * Initialize DMAOR, and clean up any error flags that may have |
275 | * been set. | 322 | * been set. |
276 | */ | 323 | */ |
277 | i = dmaor_reset(); | 324 | i = dmaor_reset(0); |
325 | if (unlikely(i != 0)) | ||
326 | return i; | ||
327 | #if defined(CONFIG_CPU_SUBTYPE_SH7723) || \ | ||
328 | defined(CONFIG_CPU_SUBTYPE_SH7780) || \ | ||
329 | defined(CONFIG_CPU_SUBTYPE_SH7785) | ||
330 | i = dmaor_reset(1); | ||
278 | if (unlikely(i != 0)) | 331 | if (unlikely(i != 0)) |
279 | return i; | 332 | return i; |
333 | #endif | ||
280 | 334 | ||
281 | return register_dmac(info); | 335 | return register_dmac(info); |
282 | } | 336 | } |
@@ -284,8 +338,12 @@ static int __init sh_dmac_init(void) | |||
284 | static void __exit sh_dmac_exit(void) | 338 | static void __exit sh_dmac_exit(void) |
285 | { | 339 | { |
286 | #ifdef CONFIG_CPU_SH4 | 340 | #ifdef CONFIG_CPU_SH4 |
287 | free_irq(DMAE_IRQ, 0); | 341 | int n; |
288 | #endif | 342 | |
343 | for (n = 0; n < NR_DMAE; n++) { | ||
344 | free_irq(get_dma_error_irq(n), (void *)dmae_name[n]); | ||
345 | } | ||
346 | #endif /* CONFIG_CPU_SH4 */ | ||
289 | unregister_dmac(&sh_dmac_info); | 347 | unregister_dmac(&sh_dmac_info); |
290 | } | 348 | } |
291 | 349 | ||
diff --git a/arch/sh/drivers/dma/dma-sh.h b/arch/sh/drivers/dma/dma-sh.h deleted file mode 100644 index 05fecd5428e4..000000000000 --- a/arch/sh/drivers/dma/dma-sh.h +++ /dev/null | |||
@@ -1,75 +0,0 @@ | |||
1 | /* | ||
2 | * arch/sh/drivers/dma/dma-sh.h | ||
3 | * | ||
4 | * Copyright (C) 2000 Takashi YOSHII | ||
5 | * Copyright (C) 2003 Paul Mundt | ||
6 | * | ||
7 | * This file is subject to the terms and conditions of the GNU General Public | ||
8 | * License. See the file "COPYING" in the main directory of this archive | ||
9 | * for more details. | ||
10 | */ | ||
11 | #ifndef __DMA_SH_H | ||
12 | #define __DMA_SH_H | ||
13 | |||
14 | #include <cpu/dma.h> | ||
15 | |||
16 | /* Definitions for the SuperH DMAC */ | ||
17 | #define REQ_L 0x00000000 | ||
18 | #define REQ_E 0x00080000 | ||
19 | #define RACK_H 0x00000000 | ||
20 | #define RACK_L 0x00040000 | ||
21 | #define ACK_R 0x00000000 | ||
22 | #define ACK_W 0x00020000 | ||
23 | #define ACK_H 0x00000000 | ||
24 | #define ACK_L 0x00010000 | ||
25 | #define DM_INC 0x00004000 | ||
26 | #define DM_DEC 0x00008000 | ||
27 | #define SM_INC 0x00001000 | ||
28 | #define SM_DEC 0x00002000 | ||
29 | #define RS_IN 0x00000200 | ||
30 | #define RS_OUT 0x00000300 | ||
31 | #define TS_BLK 0x00000040 | ||
32 | #define TM_BUR 0x00000020 | ||
33 | #define CHCR_DE 0x00000001 | ||
34 | #define CHCR_TE 0x00000002 | ||
35 | #define CHCR_IE 0x00000004 | ||
36 | |||
37 | /* DMAOR definitions */ | ||
38 | #define DMAOR_AE 0x00000004 | ||
39 | #define DMAOR_NMIF 0x00000002 | ||
40 | #define DMAOR_DME 0x00000001 | ||
41 | |||
42 | /* | ||
43 | * Define the default configuration for dual address memory-memory transfer. | ||
44 | * The 0x400 value represents auto-request, external->external. | ||
45 | */ | ||
46 | #define RS_DUAL (DM_INC | SM_INC | 0x400 | TS_32) | ||
47 | |||
48 | #define MAX_DMAC_CHANNELS (CONFIG_NR_ONCHIP_DMA_CHANNELS) | ||
49 | |||
50 | /* | ||
51 | * Subtypes that have fewer channels than this simply need to change | ||
52 | * CONFIG_NR_ONCHIP_DMA_CHANNELS. Likewise, subtypes with a larger number | ||
53 | * of channels should expand on this. | ||
54 | * | ||
55 | * For most subtypes we can easily figure these values out with some | ||
56 | * basic calculation, unfortunately on other subtypes these are more | ||
57 | * scattered, so we just leave it unrolled for simplicity. | ||
58 | */ | ||
59 | #define SAR ((unsigned long[]){SH_DMAC_BASE + 0x00, SH_DMAC_BASE + 0x10, \ | ||
60 | SH_DMAC_BASE + 0x20, SH_DMAC_BASE + 0x30, \ | ||
61 | SH_DMAC_BASE + 0x50, SH_DMAC_BASE + 0x60}) | ||
62 | #define DAR ((unsigned long[]){SH_DMAC_BASE + 0x04, SH_DMAC_BASE + 0x14, \ | ||
63 | SH_DMAC_BASE + 0x24, SH_DMAC_BASE + 0x34, \ | ||
64 | SH_DMAC_BASE + 0x54, SH_DMAC_BASE + 0x64}) | ||
65 | #define DMATCR ((unsigned long[]){SH_DMAC_BASE + 0x08, SH_DMAC_BASE + 0x18, \ | ||
66 | SH_DMAC_BASE + 0x28, SH_DMAC_BASE + 0x38, \ | ||
67 | SH_DMAC_BASE + 0x58, SH_DMAC_BASE + 0x68}) | ||
68 | #define CHCR ((unsigned long[]){SH_DMAC_BASE + 0x0c, SH_DMAC_BASE + 0x1c, \ | ||
69 | SH_DMAC_BASE + 0x2c, SH_DMAC_BASE + 0x3c, \ | ||
70 | SH_DMAC_BASE + 0x5c, SH_DMAC_BASE + 0x6c}) | ||
71 | |||
72 | #define DMAOR (SH_DMAC_BASE + 0x40) | ||
73 | |||
74 | #endif /* __DMA_SH_H */ | ||
75 | |||
diff --git a/arch/sh/include/asm/dma-sh.h b/arch/sh/include/asm/dma-sh.h new file mode 100644 index 000000000000..e873ecaa5065 --- /dev/null +++ b/arch/sh/include/asm/dma-sh.h | |||
@@ -0,0 +1,117 @@ | |||
1 | /* | ||
2 | * arch/sh/include/asm/dma-sh.h | ||
3 | * | ||
4 | * Copyright (C) 2000 Takashi YOSHII | ||
5 | * Copyright (C) 2003 Paul Mundt | ||
6 | * | ||
7 | * This file is subject to the terms and conditions of the GNU General Public | ||
8 | * License. See the file "COPYING" in the main directory of this archive | ||
9 | * for more details. | ||
10 | */ | ||
11 | #ifndef __DMA_SH_H | ||
12 | #define __DMA_SH_H | ||
13 | |||
14 | #include <cpu/dma.h> | ||
15 | |||
16 | /* DMAOR contorl: The DMAOR access size is different by CPU.*/ | ||
17 | #if defined(CONFIG_CPU_SUBTYPE_SH7723) || \ | ||
18 | defined(CONFIG_CPU_SUBTYPE_SH7780) || \ | ||
19 | defined(CONFIG_CPU_SUBTYPE_SH7785) | ||
20 | #define dmaor_read_reg(n) \ | ||
21 | (n ? ctrl_inw(SH_DMAC_BASE1 + DMAOR) \ | ||
22 | : ctrl_inw(SH_DMAC_BASE0 + DMAOR)) | ||
23 | #define dmaor_write_reg(n, data) \ | ||
24 | (n ? ctrl_outw(data, SH_DMAC_BASE1 + DMAOR) \ | ||
25 | : ctrl_outw(data, SH_DMAC_BASE0 + DMAOR)) | ||
26 | #else /* Other CPU */ | ||
27 | #define dmaor_read_reg(n) ctrl_inw(SH_DMAC_BASE0 + DMAOR) | ||
28 | #define dmaor_write_reg(n, data) ctrl_outw(data, SH_DMAC_BASE0 + DMAOR) | ||
29 | #endif | ||
30 | |||
31 | static int dmte_irq_map[] __maybe_unused = { | ||
32 | #if (CONFIG_NR_ONCHIP_DMA_CHANNELS >= 4) | ||
33 | DMTE0_IRQ, | ||
34 | DMTE0_IRQ + 1, | ||
35 | DMTE0_IRQ + 2, | ||
36 | DMTE0_IRQ + 3, | ||
37 | #endif | ||
38 | #if (CONFIG_NR_ONCHIP_DMA_CHANNELS >= 6) | ||
39 | DMTE4_IRQ, | ||
40 | DMTE4_IRQ + 1, | ||
41 | #endif | ||
42 | #if (CONFIG_NR_ONCHIP_DMA_CHANNELS >= 8) | ||
43 | DMTE6_IRQ, | ||
44 | DMTE6_IRQ + 1, | ||
45 | #endif | ||
46 | #if (CONFIG_NR_ONCHIP_DMA_CHANNELS >= 12) | ||
47 | DMTE8_IRQ, | ||
48 | DMTE9_IRQ, | ||
49 | DMTE10_IRQ, | ||
50 | DMTE11_IRQ, | ||
51 | #endif | ||
52 | }; | ||
53 | |||
54 | /* Definitions for the SuperH DMAC */ | ||
55 | #define REQ_L 0x00000000 | ||
56 | #define REQ_E 0x00080000 | ||
57 | #define RACK_H 0x00000000 | ||
58 | #define RACK_L 0x00040000 | ||
59 | #define ACK_R 0x00000000 | ||
60 | #define ACK_W 0x00020000 | ||
61 | #define ACK_H 0x00000000 | ||
62 | #define ACK_L 0x00010000 | ||
63 | #define DM_INC 0x00004000 | ||
64 | #define DM_DEC 0x00008000 | ||
65 | #define SM_INC 0x00001000 | ||
66 | #define SM_DEC 0x00002000 | ||
67 | #define RS_IN 0x00000200 | ||
68 | #define RS_OUT 0x00000300 | ||
69 | #define TS_BLK 0x00000040 | ||
70 | #define TM_BUR 0x00000020 | ||
71 | #define CHCR_DE 0x00000001 | ||
72 | #define CHCR_TE 0x00000002 | ||
73 | #define CHCR_IE 0x00000004 | ||
74 | |||
75 | /* DMAOR definitions */ | ||
76 | #define DMAOR_AE 0x00000004 | ||
77 | #define DMAOR_NMIF 0x00000002 | ||
78 | #define DMAOR_DME 0x00000001 | ||
79 | |||
80 | /* | ||
81 | * Define the default configuration for dual address memory-memory transfer. | ||
82 | * The 0x400 value represents auto-request, external->external. | ||
83 | */ | ||
84 | #define RS_DUAL (DM_INC | SM_INC | 0x400 | TS_32) | ||
85 | |||
86 | /* DMA base address */ | ||
87 | static u32 dma_base_addr[] __maybe_unused = { | ||
88 | #if (CONFIG_NR_ONCHIP_DMA_CHANNELS >= 4) | ||
89 | SH_DMAC_BASE0 + 0x00, /* channel 0 */ | ||
90 | SH_DMAC_BASE0 + 0x10, | ||
91 | SH_DMAC_BASE0 + 0x20, | ||
92 | SH_DMAC_BASE0 + 0x30, | ||
93 | #endif | ||
94 | #if (CONFIG_NR_ONCHIP_DMA_CHANNELS >= 6) | ||
95 | SH_DMAC_BASE0 + 0x50, | ||
96 | SH_DMAC_BASE0 + 0x60, | ||
97 | #endif | ||
98 | #if (CONFIG_NR_ONCHIP_DMA_CHANNELS >= 8) | ||
99 | SH_DMAC_BASE1 + 0x00, | ||
100 | SH_DMAC_BASE1 + 0x10, | ||
101 | #endif | ||
102 | #if (CONFIG_NR_ONCHIP_DMA_CHANNELS >= 12) | ||
103 | SH_DMAC_BASE1 + 0x20, | ||
104 | SH_DMAC_BASE1 + 0x30, | ||
105 | SH_DMAC_BASE1 + 0x50, | ||
106 | SH_DMAC_BASE1 + 0x60, /* channel 11 */ | ||
107 | #endif | ||
108 | }; | ||
109 | |||
110 | /* DMA register */ | ||
111 | #define SAR 0x00 | ||
112 | #define DAR 0x04 | ||
113 | #define TCR 0x08 | ||
114 | #define CHCR 0x0C | ||
115 | #define DMAOR 0x40 | ||
116 | |||
117 | #endif /* __DMA_SH_H */ | ||
diff --git a/arch/sh/include/asm/dma.h b/arch/sh/include/asm/dma.h index beca7128e2ab..6bd178473878 100644 --- a/arch/sh/include/asm/dma.h +++ b/arch/sh/include/asm/dma.h | |||
@@ -25,9 +25,9 @@ | |||
25 | #define MAX_DMA_ADDRESS (PAGE_OFFSET+0x10000000) | 25 | #define MAX_DMA_ADDRESS (PAGE_OFFSET+0x10000000) |
26 | 26 | ||
27 | #ifdef CONFIG_NR_DMA_CHANNELS | 27 | #ifdef CONFIG_NR_DMA_CHANNELS |
28 | # define MAX_DMA_CHANNELS (CONFIG_NR_DMA_CHANNELS) | 28 | # define MAX_DMA_CHANNELS (CONFIG_NR_DMA_CHANNELS) |
29 | #else | 29 | #else |
30 | # define MAX_DMA_CHANNELS (CONFIG_NR_ONCHIP_DMA_CHANNELS) | 30 | # define MAX_DMA_CHANNELS (CONFIG_NR_ONCHIP_DMA_CHANNELS) |
31 | #endif | 31 | #endif |
32 | 32 | ||
33 | /* | 33 | /* |
diff --git a/arch/sh/include/cpu-sh3/cpu/dma.h b/arch/sh/include/cpu-sh3/cpu/dma.h index 6813c3220a1d..0ea15f3f2363 100644 --- a/arch/sh/include/cpu-sh3/cpu/dma.h +++ b/arch/sh/include/cpu-sh3/cpu/dma.h | |||
@@ -1,22 +1,17 @@ | |||
1 | #ifndef __ASM_CPU_SH3_DMA_H | 1 | #ifndef __ASM_CPU_SH3_DMA_H |
2 | #define __ASM_CPU_SH3_DMA_H | 2 | #define __ASM_CPU_SH3_DMA_H |
3 | 3 | ||
4 | |||
5 | #if defined(CONFIG_CPU_SUBTYPE_SH7720) || \ | 4 | #if defined(CONFIG_CPU_SUBTYPE_SH7720) || \ |
6 | defined(CONFIG_CPU_SUBTYPE_SH7721) | 5 | defined(CONFIG_CPU_SUBTYPE_SH7721) || \ |
7 | #define SH_DMAC_BASE 0xa4010020 | 6 | defined(CONFIG_CPU_SUBTYPE_SH7710) || \ |
8 | #else | 7 | defined(CONFIG_CPU_SUBTYPE_SH7712) |
9 | #define SH_DMAC_BASE 0xa4000020 | 8 | #define SH_DMAC_BASE0 0xa4010020 |
9 | #else /* SH7705/06/07/09 */ | ||
10 | #define SH_DMAC_BASE0 0xa4000020 | ||
10 | #endif | 11 | #endif |
11 | 12 | ||
12 | #if defined(CONFIG_CPU_SUBTYPE_SH7720) || defined(CONFIG_CPU_SUBTYPE_SH7709) | ||
13 | #define DMTE0_IRQ 48 | 13 | #define DMTE0_IRQ 48 |
14 | #define DMTE1_IRQ 49 | ||
15 | #define DMTE2_IRQ 50 | ||
16 | #define DMTE3_IRQ 51 | ||
17 | #define DMTE4_IRQ 76 | 14 | #define DMTE4_IRQ 76 |
18 | #define DMTE5_IRQ 77 | ||
19 | #endif | ||
20 | 15 | ||
21 | /* Definitions for the SuperH DMAC */ | 16 | /* Definitions for the SuperH DMAC */ |
22 | #define TM_BURST 0x00000020 | 17 | #define TM_BURST 0x00000020 |
diff --git a/arch/sh/include/cpu-sh4/cpu/dma-sh4a.h b/arch/sh/include/cpu-sh4/cpu/dma-sh4a.h new file mode 100644 index 000000000000..0ed5178fed69 --- /dev/null +++ b/arch/sh/include/cpu-sh4/cpu/dma-sh4a.h | |||
@@ -0,0 +1,94 @@ | |||
1 | #ifndef __ASM_SH_CPU_SH4_DMA_SH7780_H | ||
2 | #define __ASM_SH_CPU_SH4_DMA_SH7780_H | ||
3 | |||
4 | #if defined(CONFIG_CPU_SUBTYPE_SH7343) || \ | ||
5 | defined(CONFIG_CPU_SUBTYPE_SH7722) || \ | ||
6 | defined(CONFIG_CPU_SUBTYPE_SH7730) | ||
7 | #define DMTE0_IRQ 48 | ||
8 | #define DMTE4_IRQ 76 | ||
9 | #define DMAE0_IRQ 78 /* DMA Error IRQ*/ | ||
10 | #define SH_DMAC_BASE0 0xFE008020 | ||
11 | #define SH_DMARS_BASE 0xFE009000 | ||
12 | #elif defined(CONFIG_CPU_SUBTYPE_SH7763) || \ | ||
13 | defined(CONFIG_CPU_SUBTYPE_SH7764) | ||
14 | #define DMTE0_IRQ 34 | ||
15 | #define DMTE4_IRQ 44 | ||
16 | #define DMAE0_IRQ 38 | ||
17 | #define SH_DMAC_BASE0 0xFF608020 | ||
18 | #define SH_DMARS_BASE 0xFF609000 | ||
19 | #elif defined(CONFIG_CPU_SUBTYPE_SH7723) | ||
20 | #define DMTE0_IRQ 48 /* DMAC0A*/ | ||
21 | #define DMTE4_IRQ 40 /* DMAC0B */ | ||
22 | #define DMTE6_IRQ 42 | ||
23 | #define DMTE8_IRQ 76 /* DMAC1A */ | ||
24 | #define DMTE9_IRQ 77 | ||
25 | #define DMTE10_IRQ 72 /* DMAC1B */ | ||
26 | #define DMTE11_IRQ 73 | ||
27 | #define DMAE0_IRQ 78 /* DMA Error IRQ*/ | ||
28 | #define DMAE1_IRQ 74 /* DMA Error IRQ*/ | ||
29 | #define SH_DMAC_BASE0 0xFE008020 | ||
30 | #define SH_DMAC_BASE1 0xFDC08020 | ||
31 | #define SH_DMARS_BASE 0xFDC09000 | ||
32 | #elif defined(CONFIG_CPU_SUBTYPE_SH7780) | ||
33 | #define DMTE0_IRQ 34 | ||
34 | #define DMTE4_IRQ 44 | ||
35 | #define DMTE6_IRQ 46 | ||
36 | #define DMTE8_IRQ 92 | ||
37 | #define DMTE9_IRQ 93 | ||
38 | #define DMTE10_IRQ 94 | ||
39 | #define DMTE11_IRQ 95 | ||
40 | #define DMAE0_IRQ 38 /* DMA Error IRQ */ | ||
41 | #define SH_DMAC_BASE0 0xFC808020 | ||
42 | #define SH_DMAC_BASE1 0xFC818020 | ||
43 | #define SH_DMARS_BASE 0xFC809000 | ||
44 | #else /* SH7785 */ | ||
45 | #define DMTE0_IRQ 33 | ||
46 | #define DMTE4_IRQ 37 | ||
47 | #define DMTE6_IRQ 52 | ||
48 | #define DMTE8_IRQ 54 | ||
49 | #define DMTE9_IRQ 55 | ||
50 | #define DMTE10_IRQ 56 | ||
51 | #define DMTE11_IRQ 57 | ||
52 | #define DMAE0_IRQ 39 /* DMA Error IRQ0 */ | ||
53 | #define DMAE1_IRQ 58 /* DMA Error IRQ1 */ | ||
54 | #define SH_DMAC_BASE0 0xFC808020 | ||
55 | #define SH_DMAC_BASE1 0xFCC08020 | ||
56 | #define SH_DMARS_BASE 0xFC809000 | ||
57 | #endif | ||
58 | |||
59 | #define REQ_HE 0x000000C0 | ||
60 | #define REQ_H 0x00000080 | ||
61 | #define REQ_LE 0x00000040 | ||
62 | #define TM_BURST 0x0000020 | ||
63 | #define TS_8 0x00000000 | ||
64 | #define TS_16 0x00000008 | ||
65 | #define TS_32 0x00000010 | ||
66 | #define TS_16BLK 0x00000018 | ||
67 | #define TS_32BLK 0x00100000 | ||
68 | |||
69 | /* | ||
70 | * The SuperH DMAC supports a number of transmit sizes, we list them here, | ||
71 | * with their respective values as they appear in the CHCR registers. | ||
72 | * | ||
73 | * Defaults to a 64-bit transfer size. | ||
74 | */ | ||
75 | enum { | ||
76 | XMIT_SZ_8BIT, | ||
77 | XMIT_SZ_16BIT, | ||
78 | XMIT_SZ_32BIT, | ||
79 | XMIT_SZ_128BIT, | ||
80 | XMIT_SZ_256BIT, | ||
81 | }; | ||
82 | |||
83 | /* | ||
84 | * The DMA count is defined as the number of bytes to transfer. | ||
85 | */ | ||
86 | static unsigned int ts_shift[] __maybe_unused = { | ||
87 | [XMIT_SZ_8BIT] = 0, | ||
88 | [XMIT_SZ_16BIT] = 1, | ||
89 | [XMIT_SZ_32BIT] = 2, | ||
90 | [XMIT_SZ_128BIT] = 4, | ||
91 | [XMIT_SZ_256BIT] = 5, | ||
92 | }; | ||
93 | |||
94 | #endif /* __ASM_SH_CPU_SH4_DMA_SH7780_H */ | ||
diff --git a/arch/sh/include/cpu-sh4/cpu/dma-sh7780.h b/arch/sh/include/cpu-sh4/cpu/dma-sh7780.h deleted file mode 100644 index 71b426a6e482..000000000000 --- a/arch/sh/include/cpu-sh4/cpu/dma-sh7780.h +++ /dev/null | |||
@@ -1,39 +0,0 @@ | |||
1 | #ifndef __ASM_SH_CPU_SH4_DMA_SH7780_H | ||
2 | #define __ASM_SH_CPU_SH4_DMA_SH7780_H | ||
3 | |||
4 | #define REQ_HE 0x000000C0 | ||
5 | #define REQ_H 0x00000080 | ||
6 | #define REQ_LE 0x00000040 | ||
7 | #define TM_BURST 0x0000020 | ||
8 | #define TS_8 0x00000000 | ||
9 | #define TS_16 0x00000008 | ||
10 | #define TS_32 0x00000010 | ||
11 | #define TS_16BLK 0x00000018 | ||
12 | #define TS_32BLK 0x00100000 | ||
13 | |||
14 | /* | ||
15 | * The SuperH DMAC supports a number of transmit sizes, we list them here, | ||
16 | * with their respective values as they appear in the CHCR registers. | ||
17 | * | ||
18 | * Defaults to a 64-bit transfer size. | ||
19 | */ | ||
20 | enum { | ||
21 | XMIT_SZ_8BIT, | ||
22 | XMIT_SZ_16BIT, | ||
23 | XMIT_SZ_32BIT, | ||
24 | XMIT_SZ_128BIT, | ||
25 | XMIT_SZ_256BIT, | ||
26 | }; | ||
27 | |||
28 | /* | ||
29 | * The DMA count is defined as the number of bytes to transfer. | ||
30 | */ | ||
31 | static unsigned int ts_shift[] __maybe_unused = { | ||
32 | [XMIT_SZ_8BIT] = 0, | ||
33 | [XMIT_SZ_16BIT] = 1, | ||
34 | [XMIT_SZ_32BIT] = 2, | ||
35 | [XMIT_SZ_128BIT] = 4, | ||
36 | [XMIT_SZ_256BIT] = 5, | ||
37 | }; | ||
38 | |||
39 | #endif /* __ASM_SH_CPU_SH4_DMA_SH7780_H */ | ||
diff --git a/arch/sh/include/cpu-sh4/cpu/dma.h b/arch/sh/include/cpu-sh4/cpu/dma.h index 235b7cd1fc9a..bcb30246e85c 100644 --- a/arch/sh/include/cpu-sh4/cpu/dma.h +++ b/arch/sh/include/cpu-sh4/cpu/dma.h | |||
@@ -1,31 +1,29 @@ | |||
1 | #ifndef __ASM_CPU_SH4_DMA_H | 1 | #ifndef __ASM_CPU_SH4_DMA_H |
2 | #define __ASM_CPU_SH4_DMA_H | 2 | #define __ASM_CPU_SH4_DMA_H |
3 | 3 | ||
4 | #define DMAOR_INIT ( 0x8000 | DMAOR_DME ) | ||
5 | |||
6 | /* SH7751/7760/7780 DMA IRQ sources */ | 4 | /* SH7751/7760/7780 DMA IRQ sources */ |
7 | #define DMTE0_IRQ 34 | ||
8 | #define DMTE1_IRQ 35 | ||
9 | #define DMTE2_IRQ 36 | ||
10 | #define DMTE3_IRQ 37 | ||
11 | #define DMTE4_IRQ 44 | ||
12 | #define DMTE5_IRQ 45 | ||
13 | #define DMTE6_IRQ 46 | ||
14 | #define DMTE7_IRQ 47 | ||
15 | #define DMAE_IRQ 38 | ||
16 | 5 | ||
17 | #ifdef CONFIG_CPU_SH4A | 6 | #ifdef CONFIG_CPU_SH4A |
18 | #define SH_DMAC_BASE 0xfc808020 | ||
19 | 7 | ||
8 | #define DMAOR_INIT (DMAOR_DME) | ||
20 | #define CHCR_TS_MASK 0x18 | 9 | #define CHCR_TS_MASK 0x18 |
21 | #define CHCR_TS_SHIFT 3 | 10 | #define CHCR_TS_SHIFT 3 |
22 | 11 | ||
23 | #include <cpu/dma-sh7780.h> | 12 | #include <cpu/dma-sh4a.h> |
24 | #else | 13 | #else /* CONFIG_CPU_SH4A */ |
25 | #define SH_DMAC_BASE 0xffa00000 | 14 | /* |
15 | * SH7750/SH7751/SH7760 | ||
16 | */ | ||
17 | #define DMTE0_IRQ 34 | ||
18 | #define DMTE4_IRQ 44 | ||
19 | #define DMTE6_IRQ 46 | ||
20 | #define DMAE0_IRQ 38 | ||
26 | 21 | ||
22 | #define DMAOR_INIT (0x8000|DMAOR_DME) | ||
23 | #define SH_DMAC_BASE0 0xffa00000 | ||
24 | #define SH_DMAC_BASE1 0xffa00070 | ||
27 | /* Definitions for the SuperH DMAC */ | 25 | /* Definitions for the SuperH DMAC */ |
28 | #define TM_BURST 0x0000080 | 26 | #define TM_BURST 0x00000080 |
29 | #define TS_8 0x00000010 | 27 | #define TS_8 0x00000010 |
30 | #define TS_16 0x00000020 | 28 | #define TS_16 0x00000020 |
31 | #define TS_32 0x00000030 | 29 | #define TS_32 0x00000030 |