Blame view

arch/arm/mach-s3c2440/dma.c 4.73 KB
a21765a70   Ben Dooks   [ARM] 4157/2: S3C...
1
  /* linux/arch/arm/mach-s3c2440/dma.c
98c418a00   Ben Dooks   [ARM] 3798/1: S3C...
2
   *
c16f7bd8d   Ben Dooks   [ARM] 4040/1: S3C...
3
   * Copyright (c) 2006 Simtec Electronics
98c418a00   Ben Dooks   [ARM] 3798/1: S3C...
4
5
6
7
8
9
10
11
12
13
14
15
16
   *	Ben Dooks <ben@simtec.co.uk>
   *
   * S3C2440 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>
b6d1f542e   Ben Dooks   [ARM] 4049/1: S3C...
18
  #include <linux/serial_core.h>
98c418a00   Ben Dooks   [ARM] 3798/1: S3C...
19

44dc94045   Ben Dooks   [ARM] S3C24XX: DM...
20
  #include <mach/map.h>
a09e64fbc   Russell King   [ARM] Move includ...
21
  #include <mach/dma.h>
98c418a00   Ben Dooks   [ARM] 3798/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>
98c418a00   Ben Dooks   [ARM] 3798/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>
98c418a00   Ben Dooks   [ARM] 3798/1: S3C...
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
  
  static struct s3c24xx_dma_map __initdata s3c2440_dma_mappings[] = {
  	[DMACH_XD0] = {
  		.name		= "xdreq0",
  		.channels[0]	= S3C2410_DCON_CH0_XDREQ0 | DMA_CH_VALID,
  	},
  	[DMACH_XD1] = {
  		.name		= "xdreq1",
  		.channels[1]	= S3C2410_DCON_CH1_XDREQ1 | DMA_CH_VALID,
  	},
  	[DMACH_SDI] = {
  		.name		= "sdi",
  		.channels[0]	= S3C2410_DCON_CH0_SDI | DMA_CH_VALID,
  		.channels[1]	= S3C2440_DCON_CH1_SDI | DMA_CH_VALID,
  		.channels[2]	= S3C2410_DCON_CH2_SDI | DMA_CH_VALID,
  		.channels[3]	= S3C2410_DCON_CH3_SDI | DMA_CH_VALID,
98c418a00   Ben Dooks   [ARM] 3798/1: S3C...
51
52
53
54
  	},
  	[DMACH_SPI0] = {
  		.name		= "spi0",
  		.channels[1]	= S3C2410_DCON_CH1_SPI | DMA_CH_VALID,
98c418a00   Ben Dooks   [ARM] 3798/1: S3C...
55
56
57
58
  	},
  	[DMACH_SPI1] = {
  		.name		= "spi1",
  		.channels[3]	= S3C2410_DCON_CH3_SPI | DMA_CH_VALID,
98c418a00   Ben Dooks   [ARM] 3798/1: S3C...
59
60
61
62
  	},
  	[DMACH_UART0] = {
  		.name		= "uart0",
  		.channels[0]	= S3C2410_DCON_CH0_UART0 | DMA_CH_VALID,
98c418a00   Ben Dooks   [ARM] 3798/1: S3C...
63
64
65
66
  	},
  	[DMACH_UART1] = {
  		.name		= "uart1",
  		.channels[1]	= S3C2410_DCON_CH1_UART1 | DMA_CH_VALID,
98c418a00   Ben Dooks   [ARM] 3798/1: S3C...
67
68
69
70
  	},
        	[DMACH_UART2] = {
  		.name		= "uart2",
  		.channels[3]	= S3C2410_DCON_CH3_UART2 | DMA_CH_VALID,
98c418a00   Ben Dooks   [ARM] 3798/1: S3C...
71
72
73
74
75
76
77
78
79
80
81
  	},
  	[DMACH_TIMER] = {
  		.name		= "timer",
  		.channels[0]	= S3C2410_DCON_CH0_TIMER | DMA_CH_VALID,
  		.channels[2]	= S3C2410_DCON_CH2_TIMER | DMA_CH_VALID,
  		.channels[3]	= S3C2410_DCON_CH3_TIMER | DMA_CH_VALID,
  	},
  	[DMACH_I2S_IN] = {
  		.name		= "i2s-sdi",
  		.channels[1]	= S3C2410_DCON_CH1_I2SSDI | DMA_CH_VALID,
  		.channels[2]	= S3C2410_DCON_CH2_I2SSDI | DMA_CH_VALID,
98c418a00   Ben Dooks   [ARM] 3798/1: S3C...
82
83
84
85
86
  	},
  	[DMACH_I2S_OUT] = {
  		.name		= "i2s-sdo",
  		.channels[0]	= S3C2440_DCON_CH0_I2SSDO | DMA_CH_VALID,
  		.channels[2]	= S3C2410_DCON_CH2_I2SSDO | DMA_CH_VALID,
98c418a00   Ben Dooks   [ARM] 3798/1: S3C...
87
88
89
90
91
  	},
  	[DMACH_PCM_IN] = {
  		.name		= "pcm-in",
  		.channels[0]	= S3C2440_DCON_CH0_PCMIN | DMA_CH_VALID,
  		.channels[2]	= S3C2440_DCON_CH2_PCMIN | DMA_CH_VALID,
98c418a00   Ben Dooks   [ARM] 3798/1: S3C...
92
93
94
95
96
  	},
  	[DMACH_PCM_OUT] = {
  		.name		= "pcm-out",
  		.channels[1]	= S3C2440_DCON_CH1_PCMOUT | DMA_CH_VALID,
  		.channels[3]	= S3C2440_DCON_CH3_PCMOUT | DMA_CH_VALID,
98c418a00   Ben Dooks   [ARM] 3798/1: S3C...
97
98
99
100
101
  	},
  	[DMACH_MIC_IN] = {
  		.name		= "mic-in",
  		.channels[2]	= S3C2440_DCON_CH2_MICIN | DMA_CH_VALID,
  		.channels[3]	= S3C2440_DCON_CH3_MICIN | DMA_CH_VALID,
98c418a00   Ben Dooks   [ARM] 3798/1: S3C...
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
  	},
  	[DMACH_USB_EP1] = {
  		.name		= "usb-ep1",
  		.channels[0]	= S3C2410_DCON_CH0_USBEP1 | DMA_CH_VALID,
  	},
  	[DMACH_USB_EP2] = {
  		.name		= "usb-ep2",
  		.channels[1]	= S3C2410_DCON_CH1_USBEP2 | DMA_CH_VALID,
  	},
  	[DMACH_USB_EP3] = {
  		.name		= "usb-ep3",
  		.channels[2]	= S3C2410_DCON_CH2_USBEP3 | DMA_CH_VALID,
  	},
  	[DMACH_USB_EP4] = {
  		.name		= "usb-ep4",
  		.channels[3]	= S3C2410_DCON_CH3_USBEP4 | DMA_CH_VALID,
  	},
  };
  
  static void s3c2440_dma_select(struct s3c2410_dma_chan *chan,
  			       struct s3c24xx_dma_map *map)
  {
  	chan->dcon = map->channels[chan->number] & ~DMA_CH_VALID;
  }
  
  static struct s3c24xx_dma_selection __initdata s3c2440_dma_sel = {
  	.select		= s3c2440_dma_select,
  	.dcon_mask	= 7 << 24,
  	.map		= s3c2440_dma_mappings,
  	.map_size	= ARRAY_SIZE(s3c2440_dma_mappings),
  };
bd65c82b9   Ben Dooks   [ARM] 4179/1: S3C...
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
  static struct s3c24xx_dma_order __initdata s3c2440_dma_order = {
  	.channels	= {
  		[DMACH_SDI]	= {
  			.list	= {
  				[0]	= 3 | DMA_CH_VALID,
  				[1]	= 2 | DMA_CH_VALID,
  				[2]	= 1 | DMA_CH_VALID,
  				[3]	= 0 | DMA_CH_VALID,
  			},
  		},
  		[DMACH_I2S_IN]	= {
  			.list	= {
  				[0]	= 1 | DMA_CH_VALID,
  				[1]	= 2 | DMA_CH_VALID,
  			},
  		},
  		[DMACH_I2S_OUT]	= {
  			.list	= {
  				[0]	= 2 | DMA_CH_VALID,
  				[1]	= 1 | DMA_CH_VALID,
  			},
  		},
  		[DMACH_PCM_IN] = {
  			.list	= {
  				[0]	= 2 | DMA_CH_VALID,
  				[1]	= 1 | DMA_CH_VALID,
  			},
  		},
  		[DMACH_PCM_OUT] = {
  			.list	= {
  				[0]	= 1 | DMA_CH_VALID,
  				[1]	= 3 | DMA_CH_VALID,
  			},
  		},
  		[DMACH_MIC_IN] = {
  			.list	= {
  				[0]	= 3 | DMA_CH_VALID,
  				[1]	= 2 | DMA_CH_VALID,
  			},
  		},
  	},
  };
4a858cfc9   Kay Sievers   arm: convert sysd...
175
  static int __init s3c2440_dma_add(struct device *dev)
98c418a00   Ben Dooks   [ARM] 3798/1: S3C...
176
  {
48adbcf33   Ben Dooks   [ARM] 4220/1: S3C...
177
  	s3c2410_dma_init();
bd65c82b9   Ben Dooks   [ARM] 4179/1: S3C...
178
  	s3c24xx_dma_order_set(&s3c2440_dma_order);
98c418a00   Ben Dooks   [ARM] 3798/1: S3C...
179
180
  	return s3c24xx_dma_init_map(&s3c2440_dma_sel);
  }
4a858cfc9   Kay Sievers   arm: convert sysd...
181
182
183
184
  static struct subsys_interface s3c2440_dma_interface = {
  	.name		= "s3c2440_dma",
  	.subsys		= &s3c2440_subsys,
  	.add_dev	= s3c2440_dma_add,
98c418a00   Ben Dooks   [ARM] 3798/1: S3C...
185
186
187
188
  };
  
  static int __init s3c2440_dma_init(void)
  {
4a858cfc9   Kay Sievers   arm: convert sysd...
189
  	return subsys_interface_register(&s3c2440_dma_interface);
98c418a00   Ben Dooks   [ARM] 3798/1: S3C...
190
191
192
  }
  
  arch_initcall(s3c2440_dma_init);