Blame view

arch/arm/mach-s3c2443/dma.c 3.57 KB
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
  /* linux/arch/arm/mach-s3c2443/dma.c
   *
   * Copyright (c) 2007 Simtec Electronics
   *	Ben Dooks <ben@simtec.co.uk>
   *
   * S3C2443 DMA selection
   *
   * http://armlinux.simtec.co.uk/
   *
   * This program is free software; you can redistribute it and/or modify
   * it under the terms of the GNU General Public License version 2 as
   * published by the Free Software Foundation.
  */
  
  #include <linux/kernel.h>
  #include <linux/init.h>
4a858cfc9   Kay Sievers   arm: convert sysd...
17
  #include <linux/device.h>
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
18
  #include <linux/serial_core.h>
fced80c73   Russell King   [ARM] Convert asm...
19
  #include <linux/io.h>
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
20

a09e64fbc   Russell King   [ARM] Move includ...
21
  #include <mach/dma.h>
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
22

992426bfe   Ben Dooks   ARM: SAMSUNG: Rem...
23
  #include <plat/dma-s3c24xx.h>
a2b7ba9ca   Ben Dooks   [ARM] S3C24XX: Mo...
24
  #include <plat/cpu.h>
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
25

a2b7ba9ca   Ben Dooks   [ARM] S3C24XX: Mo...
26
  #include <plat/regs-serial.h>
a09e64fbc   Russell King   [ARM] Move includ...
27
  #include <mach/regs-gpio.h>
f74c95c20   Ben Dooks   [ARM] S3C: Move r...
28
  #include <plat/regs-ac97.h>
44dc94045   Ben Dooks   [ARM] S3C24XX: DM...
29
  #include <plat/regs-dma.h>
a09e64fbc   Russell King   [ARM] Move includ...
30
31
32
  #include <mach/regs-mem.h>
  #include <mach/regs-lcd.h>
  #include <mach/regs-sdi.h>
8150bc886   Ben Dooks   S3C24XX: Move and...
33
  #include <plat/regs-iis.h>
136227087   Ben Dooks   [ARM] S3C: Move p...
34
  #include <plat/regs-spi.h>
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
  
  #define MAP(x) { \
  		[0]	= (x) | DMA_CH_VALID,	\
  		[1]	= (x) | DMA_CH_VALID,	\
  		[2]	= (x) | DMA_CH_VALID,	\
  		[3]	= (x) | DMA_CH_VALID,	\
  		[4]	= (x) | DMA_CH_VALID,	\
  		[5]     = (x) | DMA_CH_VALID,	\
  	}
  
  static struct s3c24xx_dma_map __initdata s3c2443_dma_mappings[] = {
  	[DMACH_XD0] = {
  		.name		= "xdreq0",
  		.channels	= MAP(S3C2443_DMAREQSEL_XDREQ0),
  	},
  	[DMACH_XD1] = {
  		.name		= "xdreq1",
  		.channels	= MAP(S3C2443_DMAREQSEL_XDREQ1),
  	},
  	[DMACH_SDI] = {
  		.name		= "sdi",
  		.channels	= MAP(S3C2443_DMAREQSEL_SDI),
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
57
58
59
60
  	},
  	[DMACH_SPI0] = {
  		.name		= "spi0",
  		.channels	= MAP(S3C2443_DMAREQSEL_SPI0TX),
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
61
62
63
64
  	},
  	[DMACH_SPI1] = {
  		.name		= "spi1",
  		.channels	= MAP(S3C2443_DMAREQSEL_SPI1TX),
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
65
66
67
68
  	},
  	[DMACH_UART0] = {
  		.name		= "uart0",
  		.channels	= MAP(S3C2443_DMAREQSEL_UART0_0),
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
69
70
71
72
  	},
  	[DMACH_UART1] = {
  		.name		= "uart1",
  		.channels	= MAP(S3C2443_DMAREQSEL_UART1_0),
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
73
74
75
76
  	},
        	[DMACH_UART2] = {
  		.name		= "uart2",
  		.channels	= MAP(S3C2443_DMAREQSEL_UART2_0),
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
77
78
79
80
  	},
        	[DMACH_UART3] = {
  		.name		= "uart3",
  		.channels	= MAP(S3C2443_DMAREQSEL_UART3_0),
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
81
82
83
84
  	},
  	[DMACH_UART0_SRC2] = {
  		.name		= "uart0",
  		.channels	= MAP(S3C2443_DMAREQSEL_UART0_1),
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
85
86
87
88
  	},
  	[DMACH_UART1_SRC2] = {
  		.name		= "uart1",
  		.channels	= MAP(S3C2443_DMAREQSEL_UART1_1),
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
89
90
91
92
  	},
        	[DMACH_UART2_SRC2] = {
  		.name		= "uart2",
  		.channels	= MAP(S3C2443_DMAREQSEL_UART2_1),
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
93
94
95
96
  	},
        	[DMACH_UART3_SRC2] = {
  		.name		= "uart3",
  		.channels	= MAP(S3C2443_DMAREQSEL_UART3_1),
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
97
98
99
100
101
102
103
104
  	},
  	[DMACH_TIMER] = {
  		.name		= "timer",
  		.channels	= MAP(S3C2443_DMAREQSEL_TIMER),
  	},
  	[DMACH_I2S_IN] = {
  		.name		= "i2s-sdi",
  		.channels	= MAP(S3C2443_DMAREQSEL_I2SRX),
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
105
106
107
108
  	},
  	[DMACH_I2S_OUT] = {
  		.name		= "i2s-sdo",
  		.channels	= MAP(S3C2443_DMAREQSEL_I2STX),
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
109
110
111
112
  	},
  	[DMACH_PCM_IN] = {
  		.name		= "pcm-in",
  		.channels	= MAP(S3C2443_DMAREQSEL_PCMIN),
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
113
114
115
116
  	},
  	[DMACH_PCM_OUT] = {
  		.name		= "pcm-out",
  		.channels	= MAP(S3C2443_DMAREQSEL_PCMOUT),
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
117
118
119
120
  	},
  	[DMACH_MIC_IN] = {
  		.name		= "mic-in",
  		.channels	= MAP(S3C2443_DMAREQSEL_MICIN),
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
  	},
  };
  
  static void s3c2443_dma_select(struct s3c2410_dma_chan *chan,
  			       struct s3c24xx_dma_map *map)
  {
  	writel(map->channels[0] | S3C2443_DMAREQSEL_HW,
  	       chan->regs + S3C2443_DMA_DMAREQSEL);
  }
  
  static struct s3c24xx_dma_selection __initdata s3c2443_dma_sel = {
  	.select		= s3c2443_dma_select,
  	.dcon_mask	= 0,
  	.map		= s3c2443_dma_mappings,
  	.map_size	= ARRAY_SIZE(s3c2443_dma_mappings),
  };
4a858cfc9   Kay Sievers   arm: convert sysd...
137
  static int __init s3c2443_dma_add(struct device *dev)
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
138
139
140
141
  {
  	s3c24xx_dma_init(6, IRQ_S3C2443_DMA0, 0x100);
  	return s3c24xx_dma_init_map(&s3c2443_dma_sel);
  }
4a858cfc9   Kay Sievers   arm: convert sysd...
142
143
144
145
  static struct subsys_interface s3c2443_dma_interface = {
  	.name		= "s3c2443_dma",
  	.subsys		= &s3c2443_subsys,
  	.add_dev	= s3c2443_dma_add,
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
146
147
148
149
  };
  
  static int __init s3c2443_dma_init(void)
  {
4a858cfc9   Kay Sievers   arm: convert sysd...
150
  	return subsys_interface_register(&s3c2443_dma_interface);
f8271e575   Ben Dooks   [ARM] 4221/1: S3C...
151
152
153
  }
  
  arch_initcall(s3c2443_dma_init);