diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2013-11-11 02:49:45 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2013-11-11 02:49:45 -0500 |
commit | aac59e3efce3dca787b11e34726001603ce3d161 (patch) | |
tree | 855d3f967b102877a179e23382be3c2c7fc8d66c /arch/arm/mach-s3c64xx | |
parent | 21604cdcdcf9ea8c16b1656f78e2eff097244d66 (diff) | |
parent | 005ff5fb077ebf93882bd643932f932a9b402529 (diff) |
Merge tag 'soc-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc
Pull ARM SoC platform changes from Olof Johansson:
"New and updated SoC support. Among the things new for this release
are:
- More support for the AM33xx platforms from TI
- Tegra 124 support, and some updates to older tegra families as well
- imx cleanups and updates across the board
- A rename of Broadcom's Mobile platforms which were introduced as
ARCH_BCM, and turned out to be too broad a name. New name is
ARCH_BCM_MOBILE.
- A whole bunch of updates and fixes for integrator, making the
platform code more modern and switches over to DT-only booting.
- Support for two new Renesas shmobile chipsets. Next up for them is
more work on consolidation instead of introduction of new
non-multiplatform SoCs, we're all looking forward to that!
- Misc cleanups for older Samsung platforms, some Allwinner updates,
etc"
* tag 'soc-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc: (159 commits)
ARM: bcm281xx: Add ARCH_BCM_MOBILE to bcm config
ARM: bcm_defconfig: Run "make savedefconfig"
ARM: bcm281xx: Add ARCH Timers to config
rename ARCH_BCM to ARCH_BCM_MOBILE (mach-bcm)
ARM: vexpress: Enable platform-specific options in defconfig
ARM: vexpress: Make defconfig work again
ARM: sunxi: remove .init_time hooks
ARM: imx: enable suspend for imx6sl
ARM: imx: ensure dsm_request signal is not asserted when setting LPM
ARM: imx6q: call WB and RBC configuration from imx6q_pm_enter()
ARM: imx6q: move low-power code out of clock driver
ARM: imx: drop extern with function prototypes in common.h
ARM: imx: reset core along with enable/disable operation
ARM: imx: do not return from imx_cpu_die() call
ARM: imx_v6_v7_defconfig: Select CONFIG_PROVE_LOCKING
ARM: imx_v6_v7_defconfig: Enable LEDS_GPIO related options
ARM: mxs_defconfig: Turn off CONFIG_DEBUG_GPIO
ARM: imx: replace imx6q_restart() with mxc_restart()
ARM: mach-imx: mm-imx5: Retrieve iomuxc base address from dt
ARM: mach-imx: mm-imx5: Retrieve tzic base address from dt
...
Diffstat (limited to 'arch/arm/mach-s3c64xx')
-rw-r--r-- | arch/arm/mach-s3c64xx/Makefile | 2 | ||||
-rw-r--r-- | arch/arm/mach-s3c64xx/clock.c | 1007 | ||||
-rw-r--r-- | arch/arm/mach-s3c64xx/common.c | 21 | ||||
-rw-r--r-- | arch/arm/mach-s3c64xx/common.h | 12 | ||||
-rw-r--r-- | arch/arm/mach-s3c64xx/dma.c | 4 | ||||
-rw-r--r-- | arch/arm/mach-s3c64xx/include/mach/regs-clock.h | 132 | ||||
-rw-r--r-- | arch/arm/mach-s3c64xx/mach-anw6410.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-s3c64xx/mach-crag6410.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-s3c64xx/mach-hmt.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-s3c64xx/mach-mini6410.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-s3c64xx/mach-ncp.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-s3c64xx/mach-smartq.c | 11 | ||||
-rw-r--r-- | arch/arm/mach-s3c64xx/mach-smdk6400.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-s3c64xx/mach-smdk6410.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-s3c64xx/pm.c | 21 | ||||
-rw-r--r-- | arch/arm/mach-s3c64xx/s3c6400.c | 6 | ||||
-rw-r--r-- | arch/arm/mach-s3c64xx/s3c6410.c | 7 |
17 files changed, 38 insertions, 1199 deletions
diff --git a/arch/arm/mach-s3c64xx/Makefile b/arch/arm/mach-s3c64xx/Makefile index 31d0c9101272..645a8fe55f8d 100644 --- a/arch/arm/mach-s3c64xx/Makefile +++ b/arch/arm/mach-s3c64xx/Makefile | |||
@@ -12,7 +12,7 @@ obj- := | |||
12 | 12 | ||
13 | # Core | 13 | # Core |
14 | 14 | ||
15 | obj-y += common.o clock.o | 15 | obj-y += common.o |
16 | 16 | ||
17 | # Core support | 17 | # Core support |
18 | 18 | ||
diff --git a/arch/arm/mach-s3c64xx/clock.c b/arch/arm/mach-s3c64xx/clock.c deleted file mode 100644 index c1bcc4a6d3a8..000000000000 --- a/arch/arm/mach-s3c64xx/clock.c +++ /dev/null | |||
@@ -1,1007 +0,0 @@ | |||
1 | /* linux/arch/arm/plat-s3c64xx/clock.c | ||
2 | * | ||
3 | * Copyright 2008 Openmoko, Inc. | ||
4 | * Copyright 2008 Simtec Electronics | ||
5 | * Ben Dooks <ben@simtec.co.uk> | ||
6 | * http://armlinux.simtec.co.uk/ | ||
7 | * | ||
8 | * S3C64XX Base clock support | ||
9 | * | ||
10 | * This program is free software; you can redistribute it and/or modify | ||
11 | * it under the terms of the GNU General Public License version 2 as | ||
12 | * published by the Free Software Foundation. | ||
13 | */ | ||
14 | |||
15 | #include <linux/init.h> | ||
16 | #include <linux/module.h> | ||
17 | #include <linux/interrupt.h> | ||
18 | #include <linux/ioport.h> | ||
19 | #include <linux/clk.h> | ||
20 | #include <linux/err.h> | ||
21 | #include <linux/io.h> | ||
22 | |||
23 | #include <mach/hardware.h> | ||
24 | #include <mach/map.h> | ||
25 | |||
26 | #include <mach/regs-clock.h> | ||
27 | |||
28 | #include <plat/cpu.h> | ||
29 | #include <plat/devs.h> | ||
30 | #include <plat/cpu-freq.h> | ||
31 | #include <plat/clock.h> | ||
32 | #include <plat/clock-clksrc.h> | ||
33 | #include <plat/pll.h> | ||
34 | |||
35 | #include "regs-sys.h" | ||
36 | |||
37 | /* fin_apll, fin_mpll and fin_epll are all the same clock, which we call | ||
38 | * ext_xtal_mux for want of an actual name from the manual. | ||
39 | */ | ||
40 | |||
41 | static struct clk clk_ext_xtal_mux = { | ||
42 | .name = "ext_xtal", | ||
43 | }; | ||
44 | |||
45 | #define clk_fin_apll clk_ext_xtal_mux | ||
46 | #define clk_fin_mpll clk_ext_xtal_mux | ||
47 | #define clk_fin_epll clk_ext_xtal_mux | ||
48 | |||
49 | #define clk_fout_mpll clk_mpll | ||
50 | #define clk_fout_epll clk_epll | ||
51 | |||
52 | struct clk clk_h2 = { | ||
53 | .name = "hclk2", | ||
54 | .rate = 0, | ||
55 | }; | ||
56 | |||
57 | struct clk clk_27m = { | ||
58 | .name = "clk_27m", | ||
59 | .rate = 27000000, | ||
60 | }; | ||
61 | |||
62 | static int clk_48m_ctrl(struct clk *clk, int enable) | ||
63 | { | ||
64 | unsigned long flags; | ||
65 | u32 val; | ||
66 | |||
67 | /* can't rely on clock lock, this register has other usages */ | ||
68 | local_irq_save(flags); | ||
69 | |||
70 | val = __raw_readl(S3C64XX_OTHERS); | ||
71 | if (enable) | ||
72 | val |= S3C64XX_OTHERS_USBMASK; | ||
73 | else | ||
74 | val &= ~S3C64XX_OTHERS_USBMASK; | ||
75 | |||
76 | __raw_writel(val, S3C64XX_OTHERS); | ||
77 | local_irq_restore(flags); | ||
78 | |||
79 | return 0; | ||
80 | } | ||
81 | |||
82 | struct clk clk_48m = { | ||
83 | .name = "clk_48m", | ||
84 | .rate = 48000000, | ||
85 | .enable = clk_48m_ctrl, | ||
86 | }; | ||
87 | |||
88 | struct clk clk_xusbxti = { | ||
89 | .name = "xusbxti", | ||
90 | .rate = 48000000, | ||
91 | }; | ||
92 | |||
93 | static int inline s3c64xx_gate(void __iomem *reg, | ||
94 | struct clk *clk, | ||
95 | int enable) | ||
96 | { | ||
97 | unsigned int ctrlbit = clk->ctrlbit; | ||
98 | u32 con; | ||
99 | |||
100 | con = __raw_readl(reg); | ||
101 | |||
102 | if (enable) | ||
103 | con |= ctrlbit; | ||
104 | else | ||
105 | con &= ~ctrlbit; | ||
106 | |||
107 | __raw_writel(con, reg); | ||
108 | return 0; | ||
109 | } | ||
110 | |||
111 | static int s3c64xx_pclk_ctrl(struct clk *clk, int enable) | ||
112 | { | ||
113 | return s3c64xx_gate(S3C_PCLK_GATE, clk, enable); | ||
114 | } | ||
115 | |||
116 | static int s3c64xx_hclk_ctrl(struct clk *clk, int enable) | ||
117 | { | ||
118 | return s3c64xx_gate(S3C_HCLK_GATE, clk, enable); | ||
119 | } | ||
120 | |||
121 | int s3c64xx_sclk_ctrl(struct clk *clk, int enable) | ||
122 | { | ||
123 | return s3c64xx_gate(S3C_SCLK_GATE, clk, enable); | ||
124 | } | ||
125 | |||
126 | static struct clk init_clocks_off[] = { | ||
127 | { | ||
128 | .name = "nand", | ||
129 | .parent = &clk_h, | ||
130 | }, { | ||
131 | .name = "rtc", | ||
132 | .parent = &clk_p, | ||
133 | .enable = s3c64xx_pclk_ctrl, | ||
134 | .ctrlbit = S3C_CLKCON_PCLK_RTC, | ||
135 | }, { | ||
136 | .name = "adc", | ||
137 | .parent = &clk_p, | ||
138 | .enable = s3c64xx_pclk_ctrl, | ||
139 | .ctrlbit = S3C_CLKCON_PCLK_TSADC, | ||
140 | }, { | ||
141 | .name = "i2c", | ||
142 | .devname = "s3c2440-i2c.0", | ||
143 | .parent = &clk_p, | ||
144 | .enable = s3c64xx_pclk_ctrl, | ||
145 | .ctrlbit = S3C_CLKCON_PCLK_IIC, | ||
146 | }, { | ||
147 | .name = "i2c", | ||
148 | .devname = "s3c2440-i2c.1", | ||
149 | .parent = &clk_p, | ||
150 | .enable = s3c64xx_pclk_ctrl, | ||
151 | .ctrlbit = S3C6410_CLKCON_PCLK_I2C1, | ||
152 | }, { | ||
153 | .name = "keypad", | ||
154 | .parent = &clk_p, | ||
155 | .enable = s3c64xx_pclk_ctrl, | ||
156 | .ctrlbit = S3C_CLKCON_PCLK_KEYPAD, | ||
157 | }, { | ||
158 | .name = "spi", | ||
159 | .devname = "s3c6410-spi.0", | ||
160 | .parent = &clk_p, | ||
161 | .enable = s3c64xx_pclk_ctrl, | ||
162 | .ctrlbit = S3C_CLKCON_PCLK_SPI0, | ||
163 | }, { | ||
164 | .name = "spi", | ||
165 | .devname = "s3c6410-spi.1", | ||
166 | .parent = &clk_p, | ||
167 | .enable = s3c64xx_pclk_ctrl, | ||
168 | .ctrlbit = S3C_CLKCON_PCLK_SPI1, | ||
169 | }, { | ||
170 | .name = "48m", | ||
171 | .devname = "s3c-sdhci.0", | ||
172 | .parent = &clk_48m, | ||
173 | .enable = s3c64xx_sclk_ctrl, | ||
174 | .ctrlbit = S3C_CLKCON_SCLK_MMC0_48, | ||
175 | }, { | ||
176 | .name = "48m", | ||
177 | .devname = "s3c-sdhci.1", | ||
178 | .parent = &clk_48m, | ||
179 | .enable = s3c64xx_sclk_ctrl, | ||
180 | .ctrlbit = S3C_CLKCON_SCLK_MMC1_48, | ||
181 | }, { | ||
182 | .name = "48m", | ||
183 | .devname = "s3c-sdhci.2", | ||
184 | .parent = &clk_48m, | ||
185 | .enable = s3c64xx_sclk_ctrl, | ||
186 | .ctrlbit = S3C_CLKCON_SCLK_MMC2_48, | ||
187 | }, { | ||
188 | .name = "ac97", | ||
189 | .parent = &clk_p, | ||
190 | .ctrlbit = S3C_CLKCON_PCLK_AC97, | ||
191 | }, { | ||
192 | .name = "cfcon", | ||
193 | .parent = &clk_h, | ||
194 | .enable = s3c64xx_hclk_ctrl, | ||
195 | .ctrlbit = S3C_CLKCON_HCLK_IHOST, | ||
196 | }, { | ||
197 | .name = "dma0", | ||
198 | .parent = &clk_h, | ||
199 | .enable = s3c64xx_hclk_ctrl, | ||
200 | .ctrlbit = S3C_CLKCON_HCLK_DMA0, | ||
201 | }, { | ||
202 | .name = "dma1", | ||
203 | .parent = &clk_h, | ||
204 | .enable = s3c64xx_hclk_ctrl, | ||
205 | .ctrlbit = S3C_CLKCON_HCLK_DMA1, | ||
206 | }, { | ||
207 | .name = "3dse", | ||
208 | .parent = &clk_h, | ||
209 | .enable = s3c64xx_hclk_ctrl, | ||
210 | .ctrlbit = S3C_CLKCON_HCLK_3DSE, | ||
211 | }, { | ||
212 | .name = "hclk_secur", | ||
213 | .parent = &clk_h, | ||
214 | .enable = s3c64xx_hclk_ctrl, | ||
215 | .ctrlbit = S3C_CLKCON_HCLK_SECUR, | ||
216 | }, { | ||
217 | .name = "sdma1", | ||
218 | .parent = &clk_h, | ||
219 | .enable = s3c64xx_hclk_ctrl, | ||
220 | .ctrlbit = S3C_CLKCON_HCLK_SDMA1, | ||
221 | }, { | ||
222 | .name = "sdma0", | ||
223 | .parent = &clk_h, | ||
224 | .enable = s3c64xx_hclk_ctrl, | ||
225 | .ctrlbit = S3C_CLKCON_HCLK_SDMA0, | ||
226 | }, { | ||
227 | .name = "hclk_jpeg", | ||
228 | .parent = &clk_h, | ||
229 | .enable = s3c64xx_hclk_ctrl, | ||
230 | .ctrlbit = S3C_CLKCON_HCLK_JPEG, | ||
231 | }, { | ||
232 | .name = "camif", | ||
233 | .parent = &clk_h, | ||
234 | .enable = s3c64xx_hclk_ctrl, | ||
235 | .ctrlbit = S3C_CLKCON_HCLK_CAMIF, | ||
236 | }, { | ||
237 | .name = "hclk_scaler", | ||
238 | .parent = &clk_h, | ||
239 | .enable = s3c64xx_hclk_ctrl, | ||
240 | .ctrlbit = S3C_CLKCON_HCLK_SCALER, | ||
241 | }, { | ||
242 | .name = "2d", | ||
243 | .parent = &clk_h, | ||
244 | .enable = s3c64xx_hclk_ctrl, | ||
245 | .ctrlbit = S3C_CLKCON_HCLK_2D, | ||
246 | }, { | ||
247 | .name = "tv", | ||
248 | .parent = &clk_h, | ||
249 | .enable = s3c64xx_hclk_ctrl, | ||
250 | .ctrlbit = S3C_CLKCON_HCLK_TV, | ||
251 | }, { | ||
252 | .name = "post0", | ||
253 | .parent = &clk_h, | ||
254 | .enable = s3c64xx_hclk_ctrl, | ||
255 | .ctrlbit = S3C_CLKCON_HCLK_POST0, | ||
256 | }, { | ||
257 | .name = "rot", | ||
258 | .parent = &clk_h, | ||
259 | .enable = s3c64xx_hclk_ctrl, | ||
260 | .ctrlbit = S3C_CLKCON_HCLK_ROT, | ||
261 | }, { | ||
262 | .name = "hclk_mfc", | ||
263 | .parent = &clk_h, | ||
264 | .enable = s3c64xx_hclk_ctrl, | ||
265 | .ctrlbit = S3C_CLKCON_HCLK_MFC, | ||
266 | }, { | ||
267 | .name = "pclk_mfc", | ||
268 | .parent = &clk_p, | ||
269 | .enable = s3c64xx_pclk_ctrl, | ||
270 | .ctrlbit = S3C_CLKCON_PCLK_MFC, | ||
271 | }, { | ||
272 | .name = "dac27", | ||
273 | .enable = s3c64xx_sclk_ctrl, | ||
274 | .ctrlbit = S3C_CLKCON_SCLK_DAC27, | ||
275 | }, { | ||
276 | .name = "tv27", | ||
277 | .enable = s3c64xx_sclk_ctrl, | ||
278 | .ctrlbit = S3C_CLKCON_SCLK_TV27, | ||
279 | }, { | ||
280 | .name = "scaler27", | ||
281 | .enable = s3c64xx_sclk_ctrl, | ||
282 | .ctrlbit = S3C_CLKCON_SCLK_SCALER27, | ||
283 | }, { | ||
284 | .name = "sclk_scaler", | ||
285 | .enable = s3c64xx_sclk_ctrl, | ||
286 | .ctrlbit = S3C_CLKCON_SCLK_SCALER, | ||
287 | }, { | ||
288 | .name = "post0_27", | ||
289 | .enable = s3c64xx_sclk_ctrl, | ||
290 | .ctrlbit = S3C_CLKCON_SCLK_POST0_27, | ||
291 | }, { | ||
292 | .name = "secur", | ||
293 | .enable = s3c64xx_sclk_ctrl, | ||
294 | .ctrlbit = S3C_CLKCON_SCLK_SECUR, | ||
295 | }, { | ||
296 | .name = "sclk_mfc", | ||
297 | .enable = s3c64xx_sclk_ctrl, | ||
298 | .ctrlbit = S3C_CLKCON_SCLK_MFC, | ||
299 | }, { | ||
300 | .name = "sclk_jpeg", | ||
301 | .enable = s3c64xx_sclk_ctrl, | ||
302 | .ctrlbit = S3C_CLKCON_SCLK_JPEG, | ||
303 | }, | ||
304 | }; | ||
305 | |||
306 | static struct clk clk_48m_spi0 = { | ||
307 | .name = "spi_48m", | ||
308 | .devname = "s3c6410-spi.0", | ||
309 | .parent = &clk_48m, | ||
310 | .enable = s3c64xx_sclk_ctrl, | ||
311 | .ctrlbit = S3C_CLKCON_SCLK_SPI0_48, | ||
312 | }; | ||
313 | |||
314 | static struct clk clk_48m_spi1 = { | ||
315 | .name = "spi_48m", | ||
316 | .devname = "s3c6410-spi.1", | ||
317 | .parent = &clk_48m, | ||
318 | .enable = s3c64xx_sclk_ctrl, | ||
319 | .ctrlbit = S3C_CLKCON_SCLK_SPI1_48, | ||
320 | }; | ||
321 | |||
322 | static struct clk clk_i2s0 = { | ||
323 | .name = "iis", | ||
324 | .devname = "samsung-i2s.0", | ||
325 | .parent = &clk_p, | ||
326 | .enable = s3c64xx_pclk_ctrl, | ||
327 | .ctrlbit = S3C_CLKCON_PCLK_IIS0, | ||
328 | }; | ||
329 | |||
330 | static struct clk clk_i2s1 = { | ||
331 | .name = "iis", | ||
332 | .devname = "samsung-i2s.1", | ||
333 | .parent = &clk_p, | ||
334 | .enable = s3c64xx_pclk_ctrl, | ||
335 | .ctrlbit = S3C_CLKCON_PCLK_IIS1, | ||
336 | }; | ||
337 | |||
338 | #ifdef CONFIG_CPU_S3C6410 | ||
339 | static struct clk clk_i2s2 = { | ||
340 | .name = "iis", | ||
341 | .devname = "samsung-i2s.2", | ||
342 | .parent = &clk_p, | ||
343 | .enable = s3c64xx_pclk_ctrl, | ||
344 | .ctrlbit = S3C6410_CLKCON_PCLK_IIS2, | ||
345 | }; | ||
346 | #endif | ||
347 | |||
348 | static struct clk init_clocks[] = { | ||
349 | { | ||
350 | .name = "lcd", | ||
351 | .parent = &clk_h, | ||
352 | .enable = s3c64xx_hclk_ctrl, | ||
353 | .ctrlbit = S3C_CLKCON_HCLK_LCD, | ||
354 | }, { | ||
355 | .name = "gpio", | ||
356 | .parent = &clk_p, | ||
357 | .enable = s3c64xx_pclk_ctrl, | ||
358 | .ctrlbit = S3C_CLKCON_PCLK_GPIO, | ||
359 | }, { | ||
360 | .name = "usb-host", | ||
361 | .parent = &clk_h, | ||
362 | .enable = s3c64xx_hclk_ctrl, | ||
363 | .ctrlbit = S3C_CLKCON_HCLK_UHOST, | ||
364 | }, { | ||
365 | .name = "otg", | ||
366 | .parent = &clk_h, | ||
367 | .enable = s3c64xx_hclk_ctrl, | ||
368 | .ctrlbit = S3C_CLKCON_HCLK_USB, | ||
369 | }, { | ||
370 | .name = "timers", | ||
371 | .parent = &clk_p, | ||
372 | .enable = s3c64xx_pclk_ctrl, | ||
373 | .ctrlbit = S3C_CLKCON_PCLK_PWM, | ||
374 | }, { | ||
375 | .name = "uart", | ||
376 | .devname = "s3c6400-uart.0", | ||
377 | .parent = &clk_p, | ||
378 | .enable = s3c64xx_pclk_ctrl, | ||
379 | .ctrlbit = S3C_CLKCON_PCLK_UART0, | ||
380 | }, { | ||
381 | .name = "uart", | ||
382 | .devname = "s3c6400-uart.1", | ||
383 | .parent = &clk_p, | ||
384 | .enable = s3c64xx_pclk_ctrl, | ||
385 | .ctrlbit = S3C_CLKCON_PCLK_UART1, | ||
386 | }, { | ||
387 | .name = "uart", | ||
388 | .devname = "s3c6400-uart.2", | ||
389 | .parent = &clk_p, | ||
390 | .enable = s3c64xx_pclk_ctrl, | ||
391 | .ctrlbit = S3C_CLKCON_PCLK_UART2, | ||
392 | }, { | ||
393 | .name = "uart", | ||
394 | .devname = "s3c6400-uart.3", | ||
395 | .parent = &clk_p, | ||
396 | .enable = s3c64xx_pclk_ctrl, | ||
397 | .ctrlbit = S3C_CLKCON_PCLK_UART3, | ||
398 | }, { | ||
399 | .name = "watchdog", | ||
400 | .parent = &clk_p, | ||
401 | .ctrlbit = S3C_CLKCON_PCLK_WDT, | ||
402 | }, | ||
403 | }; | ||
404 | |||
405 | static struct clk clk_hsmmc0 = { | ||
406 | .name = "hsmmc", | ||
407 | .devname = "s3c-sdhci.0", | ||
408 | .parent = &clk_h, | ||
409 | .enable = s3c64xx_hclk_ctrl, | ||
410 | .ctrlbit = S3C_CLKCON_HCLK_HSMMC0, | ||
411 | }; | ||
412 | |||
413 | static struct clk clk_hsmmc1 = { | ||
414 | .name = "hsmmc", | ||
415 | .devname = "s3c-sdhci.1", | ||
416 | .parent = &clk_h, | ||
417 | .enable = s3c64xx_hclk_ctrl, | ||
418 | .ctrlbit = S3C_CLKCON_HCLK_HSMMC1, | ||
419 | }; | ||
420 | |||
421 | static struct clk clk_hsmmc2 = { | ||
422 | .name = "hsmmc", | ||
423 | .devname = "s3c-sdhci.2", | ||
424 | .parent = &clk_h, | ||
425 | .enable = s3c64xx_hclk_ctrl, | ||
426 | .ctrlbit = S3C_CLKCON_HCLK_HSMMC2, | ||
427 | }; | ||
428 | |||
429 | static struct clk clk_fout_apll = { | ||
430 | .name = "fout_apll", | ||
431 | }; | ||
432 | |||
433 | static struct clk *clk_src_apll_list[] = { | ||
434 | [0] = &clk_fin_apll, | ||
435 | [1] = &clk_fout_apll, | ||
436 | }; | ||
437 | |||
438 | static struct clksrc_sources clk_src_apll = { | ||
439 | .sources = clk_src_apll_list, | ||
440 | .nr_sources = ARRAY_SIZE(clk_src_apll_list), | ||
441 | }; | ||
442 | |||
443 | static struct clksrc_clk clk_mout_apll = { | ||
444 | .clk = { | ||
445 | .name = "mout_apll", | ||
446 | }, | ||
447 | .reg_src = { .reg = S3C_CLK_SRC, .shift = 0, .size = 1 }, | ||
448 | .sources = &clk_src_apll, | ||
449 | }; | ||
450 | |||
451 | static struct clk *clk_src_epll_list[] = { | ||
452 | [0] = &clk_fin_epll, | ||
453 | [1] = &clk_fout_epll, | ||
454 | }; | ||
455 | |||
456 | static struct clksrc_sources clk_src_epll = { | ||
457 | .sources = clk_src_epll_list, | ||
458 | .nr_sources = ARRAY_SIZE(clk_src_epll_list), | ||
459 | }; | ||
460 | |||
461 | static struct clksrc_clk clk_mout_epll = { | ||
462 | .clk = { | ||
463 | .name = "mout_epll", | ||
464 | }, | ||
465 | .reg_src = { .reg = S3C_CLK_SRC, .shift = 2, .size = 1 }, | ||
466 | .sources = &clk_src_epll, | ||
467 | }; | ||
468 | |||
469 | static struct clk *clk_src_mpll_list[] = { | ||
470 | [0] = &clk_fin_mpll, | ||
471 | [1] = &clk_fout_mpll, | ||
472 | }; | ||
473 | |||
474 | static struct clksrc_sources clk_src_mpll = { | ||
475 | .sources = clk_src_mpll_list, | ||
476 | .nr_sources = ARRAY_SIZE(clk_src_mpll_list), | ||
477 | }; | ||
478 | |||
479 | static struct clksrc_clk clk_mout_mpll = { | ||
480 | .clk = { | ||
481 | .name = "mout_mpll", | ||
482 | }, | ||
483 | .reg_src = { .reg = S3C_CLK_SRC, .shift = 1, .size = 1 }, | ||
484 | .sources = &clk_src_mpll, | ||
485 | }; | ||
486 | |||
487 | static unsigned int armclk_mask; | ||
488 | |||
489 | static unsigned long s3c64xx_clk_arm_get_rate(struct clk *clk) | ||
490 | { | ||
491 | unsigned long rate = clk_get_rate(clk->parent); | ||
492 | u32 clkdiv; | ||
493 | |||
494 | /* divisor mask starts at bit0, so no need to shift */ | ||
495 | clkdiv = __raw_readl(S3C_CLK_DIV0) & armclk_mask; | ||
496 | |||
497 | return rate / (clkdiv + 1); | ||
498 | } | ||
499 | |||
500 | static unsigned long s3c64xx_clk_arm_round_rate(struct clk *clk, | ||
501 | unsigned long rate) | ||
502 | { | ||
503 | unsigned long parent = clk_get_rate(clk->parent); | ||
504 | u32 div; | ||
505 | |||
506 | if (parent < rate) | ||
507 | return parent; | ||
508 | |||
509 | div = (parent / rate) - 1; | ||
510 | if (div > armclk_mask) | ||
511 | div = armclk_mask; | ||
512 | |||
513 | return parent / (div + 1); | ||
514 | } | ||
515 | |||
516 | static int s3c64xx_clk_arm_set_rate(struct clk *clk, unsigned long rate) | ||
517 | { | ||
518 | unsigned long parent = clk_get_rate(clk->parent); | ||
519 | u32 div; | ||
520 | u32 val; | ||
521 | |||
522 | if (rate < parent / (armclk_mask + 1)) | ||
523 | return -EINVAL; | ||
524 | |||
525 | rate = clk_round_rate(clk, rate); | ||
526 | div = clk_get_rate(clk->parent) / rate; | ||
527 | |||
528 | val = __raw_readl(S3C_CLK_DIV0); | ||
529 | val &= ~armclk_mask; | ||
530 | val |= (div - 1); | ||
531 | __raw_writel(val, S3C_CLK_DIV0); | ||
532 | |||
533 | return 0; | ||
534 | |||
535 | } | ||
536 | |||
537 | static struct clk clk_arm = { | ||
538 | .name = "armclk", | ||
539 | .parent = &clk_mout_apll.clk, | ||
540 | .ops = &(struct clk_ops) { | ||
541 | .get_rate = s3c64xx_clk_arm_get_rate, | ||
542 | .set_rate = s3c64xx_clk_arm_set_rate, | ||
543 | .round_rate = s3c64xx_clk_arm_round_rate, | ||
544 | }, | ||
545 | }; | ||
546 | |||
547 | static unsigned long s3c64xx_clk_doutmpll_get_rate(struct clk *clk) | ||
548 | { | ||
549 | unsigned long rate = clk_get_rate(clk->parent); | ||
550 | |||
551 | printk(KERN_DEBUG "%s: parent is %ld\n", __func__, rate); | ||
552 | |||
553 | if (__raw_readl(S3C_CLK_DIV0) & S3C6400_CLKDIV0_MPLL_MASK) | ||
554 | rate /= 2; | ||
555 | |||
556 | return rate; | ||
557 | } | ||
558 | |||
559 | static struct clk_ops clk_dout_ops = { | ||
560 | .get_rate = s3c64xx_clk_doutmpll_get_rate, | ||
561 | }; | ||
562 | |||
563 | static struct clk clk_dout_mpll = { | ||
564 | .name = "dout_mpll", | ||
565 | .parent = &clk_mout_mpll.clk, | ||
566 | .ops = &clk_dout_ops, | ||
567 | }; | ||
568 | |||
569 | static struct clk *clkset_spi_mmc_list[] = { | ||
570 | &clk_mout_epll.clk, | ||
571 | &clk_dout_mpll, | ||
572 | &clk_fin_epll, | ||
573 | &clk_27m, | ||
574 | }; | ||
575 | |||
576 | static struct clksrc_sources clkset_spi_mmc = { | ||
577 | .sources = clkset_spi_mmc_list, | ||
578 | .nr_sources = ARRAY_SIZE(clkset_spi_mmc_list), | ||
579 | }; | ||
580 | |||
581 | static struct clk *clkset_irda_list[] = { | ||
582 | &clk_mout_epll.clk, | ||
583 | &clk_dout_mpll, | ||
584 | NULL, | ||
585 | &clk_27m, | ||
586 | }; | ||
587 | |||
588 | static struct clksrc_sources clkset_irda = { | ||
589 | .sources = clkset_irda_list, | ||
590 | .nr_sources = ARRAY_SIZE(clkset_irda_list), | ||
591 | }; | ||
592 | |||
593 | static struct clk *clkset_uart_list[] = { | ||
594 | &clk_mout_epll.clk, | ||
595 | &clk_dout_mpll, | ||
596 | NULL, | ||
597 | NULL | ||
598 | }; | ||
599 | |||
600 | static struct clksrc_sources clkset_uart = { | ||
601 | .sources = clkset_uart_list, | ||
602 | .nr_sources = ARRAY_SIZE(clkset_uart_list), | ||
603 | }; | ||
604 | |||
605 | static struct clk *clkset_uhost_list[] = { | ||
606 | &clk_48m, | ||
607 | &clk_mout_epll.clk, | ||
608 | &clk_dout_mpll, | ||
609 | &clk_fin_epll, | ||
610 | }; | ||
611 | |||
612 | static struct clksrc_sources clkset_uhost = { | ||
613 | .sources = clkset_uhost_list, | ||
614 | .nr_sources = ARRAY_SIZE(clkset_uhost_list), | ||
615 | }; | ||
616 | |||
617 | /* The peripheral clocks are all controlled via clocksource followed | ||
618 | * by an optional divider and gate stage. We currently roll this into | ||
619 | * one clock which hides the intermediate clock from the mux. | ||
620 | * | ||
621 | * Note, the JPEG clock can only be an even divider... | ||
622 | * | ||
623 | * The scaler and LCD clocks depend on the S3C64XX version, and also | ||
624 | * have a common parent divisor so are not included here. | ||
625 | */ | ||
626 | |||
627 | /* clocks that feed other parts of the clock source tree */ | ||
628 | |||
629 | static struct clk clk_iis_cd0 = { | ||
630 | .name = "iis_cdclk0", | ||
631 | }; | ||
632 | |||
633 | static struct clk clk_iis_cd1 = { | ||
634 | .name = "iis_cdclk1", | ||
635 | }; | ||
636 | |||
637 | static struct clk clk_iisv4_cd = { | ||
638 | .name = "iis_cdclk_v4", | ||
639 | }; | ||
640 | |||
641 | static struct clk clk_pcm_cd = { | ||
642 | .name = "pcm_cdclk", | ||
643 | }; | ||
644 | |||
645 | static struct clk *clkset_audio0_list[] = { | ||
646 | [0] = &clk_mout_epll.clk, | ||
647 | [1] = &clk_dout_mpll, | ||
648 | [2] = &clk_fin_epll, | ||
649 | [3] = &clk_iis_cd0, | ||
650 | [4] = &clk_pcm_cd, | ||
651 | }; | ||
652 | |||
653 | static struct clksrc_sources clkset_audio0 = { | ||
654 | .sources = clkset_audio0_list, | ||
655 | .nr_sources = ARRAY_SIZE(clkset_audio0_list), | ||
656 | }; | ||
657 | |||
658 | static struct clk *clkset_audio1_list[] = { | ||
659 | [0] = &clk_mout_epll.clk, | ||
660 | [1] = &clk_dout_mpll, | ||
661 | [2] = &clk_fin_epll, | ||
662 | [3] = &clk_iis_cd1, | ||
663 | [4] = &clk_pcm_cd, | ||
664 | }; | ||
665 | |||
666 | static struct clksrc_sources clkset_audio1 = { | ||
667 | .sources = clkset_audio1_list, | ||
668 | .nr_sources = ARRAY_SIZE(clkset_audio1_list), | ||
669 | }; | ||
670 | |||
671 | #ifdef CONFIG_CPU_S3C6410 | ||
672 | static struct clk *clkset_audio2_list[] = { | ||
673 | [0] = &clk_mout_epll.clk, | ||
674 | [1] = &clk_dout_mpll, | ||
675 | [2] = &clk_fin_epll, | ||
676 | [3] = &clk_iisv4_cd, | ||
677 | [4] = &clk_pcm_cd, | ||
678 | }; | ||
679 | |||
680 | static struct clksrc_sources clkset_audio2 = { | ||
681 | .sources = clkset_audio2_list, | ||
682 | .nr_sources = ARRAY_SIZE(clkset_audio2_list), | ||
683 | }; | ||
684 | #endif | ||
685 | |||
686 | static struct clksrc_clk clksrcs[] = { | ||
687 | { | ||
688 | .clk = { | ||
689 | .name = "usb-bus-host", | ||
690 | .ctrlbit = S3C_CLKCON_SCLK_UHOST, | ||
691 | .enable = s3c64xx_sclk_ctrl, | ||
692 | }, | ||
693 | .reg_src = { .reg = S3C_CLK_SRC, .shift = 5, .size = 2 }, | ||
694 | .reg_div = { .reg = S3C_CLK_DIV1, .shift = 20, .size = 4 }, | ||
695 | .sources = &clkset_uhost, | ||
696 | }, { | ||
697 | .clk = { | ||
698 | .name = "irda-bus", | ||
699 | .ctrlbit = S3C_CLKCON_SCLK_IRDA, | ||
700 | .enable = s3c64xx_sclk_ctrl, | ||
701 | }, | ||
702 | .reg_src = { .reg = S3C_CLK_SRC, .shift = 24, .size = 2 }, | ||
703 | .reg_div = { .reg = S3C_CLK_DIV2, .shift = 20, .size = 4 }, | ||
704 | .sources = &clkset_irda, | ||
705 | }, { | ||
706 | .clk = { | ||
707 | .name = "camera", | ||
708 | .ctrlbit = S3C_CLKCON_SCLK_CAM, | ||
709 | .enable = s3c64xx_sclk_ctrl, | ||
710 | .parent = &clk_h2, | ||
711 | }, | ||
712 | .reg_div = { .reg = S3C_CLK_DIV0, .shift = 20, .size = 4 }, | ||
713 | }, | ||
714 | }; | ||
715 | |||
716 | /* Where does UCLK0 come from? */ | ||
717 | static struct clksrc_clk clk_sclk_uclk = { | ||
718 | .clk = { | ||
719 | .name = "uclk1", | ||
720 | .ctrlbit = S3C_CLKCON_SCLK_UART, | ||
721 | .enable = s3c64xx_sclk_ctrl, | ||
722 | }, | ||
723 | .reg_src = { .reg = S3C_CLK_SRC, .shift = 13, .size = 1 }, | ||
724 | .reg_div = { .reg = S3C_CLK_DIV2, .shift = 16, .size = 4 }, | ||
725 | .sources = &clkset_uart, | ||
726 | }; | ||
727 | |||
728 | static struct clksrc_clk clk_sclk_mmc0 = { | ||
729 | .clk = { | ||
730 | .name = "mmc_bus", | ||
731 | .devname = "s3c-sdhci.0", | ||
732 | .ctrlbit = S3C_CLKCON_SCLK_MMC0, | ||
733 | .enable = s3c64xx_sclk_ctrl, | ||
734 | }, | ||
735 | .reg_src = { .reg = S3C_CLK_SRC, .shift = 18, .size = 2 }, | ||
736 | .reg_div = { .reg = S3C_CLK_DIV1, .shift = 0, .size = 4 }, | ||
737 | .sources = &clkset_spi_mmc, | ||
738 | }; | ||
739 | |||
740 | static struct clksrc_clk clk_sclk_mmc1 = { | ||
741 | .clk = { | ||
742 | .name = "mmc_bus", | ||
743 | .devname = "s3c-sdhci.1", | ||
744 | .ctrlbit = S3C_CLKCON_SCLK_MMC1, | ||
745 | .enable = s3c64xx_sclk_ctrl, | ||
746 | }, | ||
747 | .reg_src = { .reg = S3C_CLK_SRC, .shift = 20, .size = 2 }, | ||
748 | .reg_div = { .reg = S3C_CLK_DIV1, .shift = 4, .size = 4 }, | ||
749 | .sources = &clkset_spi_mmc, | ||
750 | }; | ||
751 | |||
752 | static struct clksrc_clk clk_sclk_mmc2 = { | ||
753 | .clk = { | ||
754 | .name = "mmc_bus", | ||
755 | .devname = "s3c-sdhci.2", | ||
756 | .ctrlbit = S3C_CLKCON_SCLK_MMC2, | ||
757 | .enable = s3c64xx_sclk_ctrl, | ||
758 | }, | ||
759 | .reg_src = { .reg = S3C_CLK_SRC, .shift = 22, .size = 2 }, | ||
760 | .reg_div = { .reg = S3C_CLK_DIV1, .shift = 8, .size = 4 }, | ||
761 | .sources = &clkset_spi_mmc, | ||
762 | }; | ||
763 | |||
764 | static struct clksrc_clk clk_sclk_spi0 = { | ||
765 | .clk = { | ||
766 | .name = "spi-bus", | ||
767 | .devname = "s3c6410-spi.0", | ||
768 | .ctrlbit = S3C_CLKCON_SCLK_SPI0, | ||
769 | .enable = s3c64xx_sclk_ctrl, | ||
770 | }, | ||
771 | .reg_src = { .reg = S3C_CLK_SRC, .shift = 14, .size = 2 }, | ||
772 | .reg_div = { .reg = S3C_CLK_DIV2, .shift = 0, .size = 4 }, | ||
773 | .sources = &clkset_spi_mmc, | ||
774 | }; | ||
775 | |||
776 | static struct clksrc_clk clk_sclk_spi1 = { | ||
777 | .clk = { | ||
778 | .name = "spi-bus", | ||
779 | .devname = "s3c6410-spi.1", | ||
780 | .ctrlbit = S3C_CLKCON_SCLK_SPI1, | ||
781 | .enable = s3c64xx_sclk_ctrl, | ||
782 | }, | ||
783 | .reg_src = { .reg = S3C_CLK_SRC, .shift = 16, .size = 2 }, | ||
784 | .reg_div = { .reg = S3C_CLK_DIV2, .shift = 4, .size = 4 }, | ||
785 | .sources = &clkset_spi_mmc, | ||
786 | }; | ||
787 | |||
788 | static struct clksrc_clk clk_audio_bus0 = { | ||
789 | .clk = { | ||
790 | .name = "audio-bus", | ||
791 | .devname = "samsung-i2s.0", | ||
792 | .ctrlbit = S3C_CLKCON_SCLK_AUDIO0, | ||
793 | .enable = s3c64xx_sclk_ctrl, | ||
794 | }, | ||
795 | .reg_src = { .reg = S3C_CLK_SRC, .shift = 7, .size = 3 }, | ||
796 | .reg_div = { .reg = S3C_CLK_DIV2, .shift = 8, .size = 4 }, | ||
797 | .sources = &clkset_audio0, | ||
798 | }; | ||
799 | |||
800 | static struct clksrc_clk clk_audio_bus1 = { | ||
801 | .clk = { | ||
802 | .name = "audio-bus", | ||
803 | .devname = "samsung-i2s.1", | ||
804 | .ctrlbit = S3C_CLKCON_SCLK_AUDIO1, | ||
805 | .enable = s3c64xx_sclk_ctrl, | ||
806 | }, | ||
807 | .reg_src = { .reg = S3C_CLK_SRC, .shift = 10, .size = 3 }, | ||
808 | .reg_div = { .reg = S3C_CLK_DIV2, .shift = 12, .size = 4 }, | ||
809 | .sources = &clkset_audio1, | ||
810 | }; | ||
811 | |||
812 | #ifdef CONFIG_CPU_S3C6410 | ||
813 | static struct clksrc_clk clk_audio_bus2 = { | ||
814 | .clk = { | ||
815 | .name = "audio-bus", | ||
816 | .devname = "samsung-i2s.2", | ||
817 | .ctrlbit = S3C6410_CLKCON_SCLK_AUDIO2, | ||
818 | .enable = s3c64xx_sclk_ctrl, | ||
819 | }, | ||
820 | .reg_src = { .reg = S3C6410_CLK_SRC2, .shift = 0, .size = 3 }, | ||
821 | .reg_div = { .reg = S3C_CLK_DIV2, .shift = 24, .size = 4 }, | ||
822 | .sources = &clkset_audio2, | ||
823 | }; | ||
824 | #endif | ||
825 | /* Clock initialisation code */ | ||
826 | |||
827 | static struct clksrc_clk *init_parents[] = { | ||
828 | &clk_mout_apll, | ||
829 | &clk_mout_epll, | ||
830 | &clk_mout_mpll, | ||
831 | }; | ||
832 | |||
833 | static struct clksrc_clk *clksrc_cdev[] = { | ||
834 | &clk_sclk_uclk, | ||
835 | &clk_sclk_mmc0, | ||
836 | &clk_sclk_mmc1, | ||
837 | &clk_sclk_mmc2, | ||
838 | &clk_sclk_spi0, | ||
839 | &clk_sclk_spi1, | ||
840 | &clk_audio_bus0, | ||
841 | &clk_audio_bus1, | ||
842 | }; | ||
843 | |||
844 | static struct clk *clk_cdev[] = { | ||
845 | &clk_hsmmc0, | ||
846 | &clk_hsmmc1, | ||
847 | &clk_hsmmc2, | ||
848 | &clk_48m_spi0, | ||
849 | &clk_48m_spi1, | ||
850 | &clk_i2s0, | ||
851 | &clk_i2s1, | ||
852 | }; | ||
853 | |||
854 | static struct clk_lookup s3c64xx_clk_lookup[] = { | ||
855 | CLKDEV_INIT(NULL, "clk_uart_baud2", &clk_p), | ||
856 | CLKDEV_INIT(NULL, "clk_uart_baud3", &clk_sclk_uclk.clk), | ||
857 | CLKDEV_INIT("s3c-sdhci.0", "mmc_busclk.0", &clk_hsmmc0), | ||
858 | CLKDEV_INIT("s3c-sdhci.1", "mmc_busclk.0", &clk_hsmmc1), | ||
859 | CLKDEV_INIT("s3c-sdhci.2", "mmc_busclk.0", &clk_hsmmc2), | ||
860 | CLKDEV_INIT("s3c-sdhci.0", "mmc_busclk.2", &clk_sclk_mmc0.clk), | ||
861 | CLKDEV_INIT("s3c-sdhci.1", "mmc_busclk.2", &clk_sclk_mmc1.clk), | ||
862 | CLKDEV_INIT("s3c-sdhci.2", "mmc_busclk.2", &clk_sclk_mmc2.clk), | ||
863 | CLKDEV_INIT(NULL, "spi_busclk0", &clk_p), | ||
864 | CLKDEV_INIT("s3c6410-spi.0", "spi_busclk1", &clk_sclk_spi0.clk), | ||
865 | CLKDEV_INIT("s3c6410-spi.0", "spi_busclk2", &clk_48m_spi0), | ||
866 | CLKDEV_INIT("s3c6410-spi.1", "spi_busclk1", &clk_sclk_spi1.clk), | ||
867 | CLKDEV_INIT("s3c6410-spi.1", "spi_busclk2", &clk_48m_spi1), | ||
868 | CLKDEV_INIT("samsung-i2s.0", "i2s_opclk0", &clk_i2s0), | ||
869 | CLKDEV_INIT("samsung-i2s.0", "i2s_opclk1", &clk_audio_bus0.clk), | ||
870 | CLKDEV_INIT("samsung-i2s.1", "i2s_opclk0", &clk_i2s1), | ||
871 | CLKDEV_INIT("samsung-i2s.1", "i2s_opclk1", &clk_audio_bus1.clk), | ||
872 | #ifdef CONFIG_CPU_S3C6410 | ||
873 | CLKDEV_INIT("samsung-i2s.2", "i2s_opclk0", &clk_i2s2), | ||
874 | CLKDEV_INIT("samsung-i2s.2", "i2s_opclk1", &clk_audio_bus2.clk), | ||
875 | #endif | ||
876 | }; | ||
877 | |||
878 | #define GET_DIV(clk, field) ((((clk) & field##_MASK) >> field##_SHIFT) + 1) | ||
879 | |||
880 | void __init_or_cpufreq s3c64xx_setup_clocks(void) | ||
881 | { | ||
882 | struct clk *xtal_clk; | ||
883 | unsigned long xtal; | ||
884 | unsigned long fclk; | ||
885 | unsigned long hclk; | ||
886 | unsigned long hclk2; | ||
887 | unsigned long pclk; | ||
888 | unsigned long epll; | ||
889 | unsigned long apll; | ||
890 | unsigned long mpll; | ||
891 | unsigned int ptr; | ||
892 | u32 clkdiv0; | ||
893 | |||
894 | printk(KERN_DEBUG "%s: registering clocks\n", __func__); | ||
895 | |||
896 | clkdiv0 = __raw_readl(S3C_CLK_DIV0); | ||
897 | printk(KERN_DEBUG "%s: clkdiv0 = %08x\n", __func__, clkdiv0); | ||
898 | |||
899 | xtal_clk = clk_get(NULL, "xtal"); | ||
900 | BUG_ON(IS_ERR(xtal_clk)); | ||
901 | |||
902 | xtal = clk_get_rate(xtal_clk); | ||
903 | clk_put(xtal_clk); | ||
904 | |||
905 | printk(KERN_DEBUG "%s: xtal is %ld\n", __func__, xtal); | ||
906 | |||
907 | /* For now assume the mux always selects the crystal */ | ||
908 | clk_ext_xtal_mux.parent = xtal_clk; | ||
909 | |||
910 | epll = s3c_get_pll6553x(xtal, __raw_readl(S3C_EPLL_CON0), | ||
911 | __raw_readl(S3C_EPLL_CON1)); | ||
912 | mpll = s3c6400_get_pll(xtal, __raw_readl(S3C_MPLL_CON)); | ||
913 | apll = s3c6400_get_pll(xtal, __raw_readl(S3C_APLL_CON)); | ||
914 | |||
915 | fclk = mpll; | ||
916 | |||
917 | printk(KERN_INFO "S3C64XX: PLL settings, A=%ld, M=%ld, E=%ld\n", | ||
918 | apll, mpll, epll); | ||
919 | |||
920 | if(__raw_readl(S3C64XX_OTHERS) & S3C64XX_OTHERS_SYNCMUXSEL) | ||
921 | /* Synchronous mode */ | ||
922 | hclk2 = apll / GET_DIV(clkdiv0, S3C6400_CLKDIV0_HCLK2); | ||
923 | else | ||
924 | /* Asynchronous mode */ | ||
925 | hclk2 = mpll / GET_DIV(clkdiv0, S3C6400_CLKDIV0_HCLK2); | ||
926 | |||
927 | hclk = hclk2 / GET_DIV(clkdiv0, S3C6400_CLKDIV0_HCLK); | ||
928 | pclk = hclk2 / GET_DIV(clkdiv0, S3C6400_CLKDIV0_PCLK); | ||
929 | |||
930 | printk(KERN_INFO "S3C64XX: HCLK2=%ld, HCLK=%ld, PCLK=%ld\n", | ||
931 | hclk2, hclk, pclk); | ||
932 | |||
933 | clk_fout_mpll.rate = mpll; | ||
934 | clk_fout_epll.rate = epll; | ||
935 | clk_fout_apll.rate = apll; | ||
936 | |||
937 | clk_h2.rate = hclk2; | ||
938 | clk_h.rate = hclk; | ||
939 | clk_p.rate = pclk; | ||
940 | clk_f.rate = fclk; | ||
941 | |||
942 | for (ptr = 0; ptr < ARRAY_SIZE(init_parents); ptr++) | ||
943 | s3c_set_clksrc(init_parents[ptr], true); | ||
944 | |||
945 | for (ptr = 0; ptr < ARRAY_SIZE(clksrcs); ptr++) | ||
946 | s3c_set_clksrc(&clksrcs[ptr], true); | ||
947 | } | ||
948 | |||
949 | static struct clk *clks1[] __initdata = { | ||
950 | &clk_ext_xtal_mux, | ||
951 | &clk_iis_cd0, | ||
952 | &clk_iis_cd1, | ||
953 | &clk_iisv4_cd, | ||
954 | &clk_pcm_cd, | ||
955 | &clk_mout_epll.clk, | ||
956 | &clk_mout_mpll.clk, | ||
957 | &clk_dout_mpll, | ||
958 | &clk_arm, | ||
959 | }; | ||
960 | |||
961 | static struct clk *clks[] __initdata = { | ||
962 | &clk_ext, | ||
963 | &clk_epll, | ||
964 | &clk_27m, | ||
965 | &clk_48m, | ||
966 | &clk_h2, | ||
967 | &clk_xusbxti, | ||
968 | }; | ||
969 | |||
970 | /** | ||
971 | * s3c64xx_register_clocks - register clocks for s3c6400 and s3c6410 | ||
972 | * @xtal: The rate for the clock crystal feeding the PLLs. | ||
973 | * @armclk_divlimit: Divisor mask for ARMCLK. | ||
974 | * | ||
975 | * Register the clocks for the S3C6400 and S3C6410 SoC range, such | ||
976 | * as ARMCLK as well as the necessary parent clocks. | ||
977 | * | ||
978 | * This call does not setup the clocks, which is left to the | ||
979 | * s3c64xx_setup_clocks() call which may be needed by the cpufreq | ||
980 | * or resume code to re-set the clocks if the bootloader has changed | ||
981 | * them. | ||
982 | */ | ||
983 | void __init s3c64xx_register_clocks(unsigned long xtal, | ||
984 | unsigned armclk_divlimit) | ||
985 | { | ||
986 | unsigned int cnt; | ||
987 | |||
988 | armclk_mask = armclk_divlimit; | ||
989 | |||
990 | s3c24xx_register_baseclocks(xtal); | ||
991 | s3c24xx_register_clocks(clks, ARRAY_SIZE(clks)); | ||
992 | |||
993 | s3c_register_clocks(init_clocks, ARRAY_SIZE(init_clocks)); | ||
994 | |||
995 | s3c_register_clocks(init_clocks_off, ARRAY_SIZE(init_clocks_off)); | ||
996 | s3c_disable_clocks(init_clocks_off, ARRAY_SIZE(init_clocks_off)); | ||
997 | |||
998 | s3c24xx_register_clocks(clk_cdev, ARRAY_SIZE(clk_cdev)); | ||
999 | for (cnt = 0; cnt < ARRAY_SIZE(clk_cdev); cnt++) | ||
1000 | s3c_disable_clocks(clk_cdev[cnt], 1); | ||
1001 | |||
1002 | s3c24xx_register_clocks(clks1, ARRAY_SIZE(clks1)); | ||
1003 | s3c_register_clksrc(clksrcs, ARRAY_SIZE(clksrcs)); | ||
1004 | for (cnt = 0; cnt < ARRAY_SIZE(clksrc_cdev); cnt++) | ||
1005 | s3c_register_clksrc(clksrc_cdev[cnt], 1); | ||
1006 | clkdev_add_table(s3c64xx_clk_lookup, ARRAY_SIZE(s3c64xx_clk_lookup)); | ||
1007 | } | ||
diff --git a/arch/arm/mach-s3c64xx/common.c b/arch/arm/mach-s3c64xx/common.c index 73d79cf5e141..7d3cb58f1856 100644 --- a/arch/arm/mach-s3c64xx/common.c +++ b/arch/arm/mach-s3c64xx/common.c | |||
@@ -17,6 +17,7 @@ | |||
17 | #include <linux/kernel.h> | 17 | #include <linux/kernel.h> |
18 | #include <linux/init.h> | 18 | #include <linux/init.h> |
19 | #include <linux/module.h> | 19 | #include <linux/module.h> |
20 | #include <linux/clk-provider.h> | ||
20 | #include <linux/interrupt.h> | 21 | #include <linux/interrupt.h> |
21 | #include <linux/ioport.h> | 22 | #include <linux/ioport.h> |
22 | #include <linux/serial_core.h> | 23 | #include <linux/serial_core.h> |
@@ -38,7 +39,6 @@ | |||
38 | #include <mach/regs-gpio.h> | 39 | #include <mach/regs-gpio.h> |
39 | 40 | ||
40 | #include <plat/cpu.h> | 41 | #include <plat/cpu.h> |
41 | #include <plat/clock.h> | ||
42 | #include <plat/devs.h> | 42 | #include <plat/devs.h> |
43 | #include <plat/pm.h> | 43 | #include <plat/pm.h> |
44 | #include <plat/gpio-cfg.h> | 44 | #include <plat/gpio-cfg.h> |
@@ -50,6 +50,19 @@ | |||
50 | 50 | ||
51 | #include "common.h" | 51 | #include "common.h" |
52 | 52 | ||
53 | /* External clock frequency */ | ||
54 | static unsigned long xtal_f = 12000000, xusbxti_f = 48000000; | ||
55 | |||
56 | void __init s3c64xx_set_xtal_freq(unsigned long freq) | ||
57 | { | ||
58 | xtal_f = freq; | ||
59 | } | ||
60 | |||
61 | void __init s3c64xx_set_xusbxti_freq(unsigned long freq) | ||
62 | { | ||
63 | xusbxti_f = freq; | ||
64 | } | ||
65 | |||
53 | /* uart registration process */ | 66 | /* uart registration process */ |
54 | 67 | ||
55 | static void __init s3c64xx_init_uarts(struct s3c2410_uartcfg *cfg, int no) | 68 | static void __init s3c64xx_init_uarts(struct s3c2410_uartcfg *cfg, int no) |
@@ -67,7 +80,6 @@ static struct cpu_table cpu_ids[] __initdata = { | |||
67 | .idcode = S3C6400_CPU_ID, | 80 | .idcode = S3C6400_CPU_ID, |
68 | .idmask = S3C64XX_CPU_MASK, | 81 | .idmask = S3C64XX_CPU_MASK, |
69 | .map_io = s3c6400_map_io, | 82 | .map_io = s3c6400_map_io, |
70 | .init_clocks = s3c6400_init_clocks, | ||
71 | .init_uarts = s3c64xx_init_uarts, | 83 | .init_uarts = s3c64xx_init_uarts, |
72 | .init = s3c6400_init, | 84 | .init = s3c6400_init, |
73 | .name = name_s3c6400, | 85 | .name = name_s3c6400, |
@@ -75,7 +87,6 @@ static struct cpu_table cpu_ids[] __initdata = { | |||
75 | .idcode = S3C6410_CPU_ID, | 87 | .idcode = S3C6410_CPU_ID, |
76 | .idmask = S3C64XX_CPU_MASK, | 88 | .idmask = S3C64XX_CPU_MASK, |
77 | .map_io = s3c6410_map_io, | 89 | .map_io = s3c6410_map_io, |
78 | .init_clocks = s3c6410_init_clocks, | ||
79 | .init_uarts = s3c64xx_init_uarts, | 90 | .init_uarts = s3c64xx_init_uarts, |
80 | .init = s3c6410_init, | 91 | .init = s3c6410_init, |
81 | .name = name_s3c6410, | 92 | .name = name_s3c6410, |
@@ -213,8 +224,10 @@ void __init s3c64xx_init_irq(u32 vic0_valid, u32 vic1_valid) | |||
213 | { | 224 | { |
214 | /* | 225 | /* |
215 | * FIXME: there is no better place to put this at the moment | 226 | * FIXME: there is no better place to put this at the moment |
216 | * (samsung_wdt_reset_init needs clocks) | 227 | * (s3c64xx_clk_init needs ioremap and must happen before init_time |
228 | * samsung_wdt_reset_init needs clocks) | ||
217 | */ | 229 | */ |
230 | s3c64xx_clk_init(NULL, xtal_f, xusbxti_f, soc_is_s3c6400(), S3C_VA_SYS); | ||
218 | samsung_wdt_reset_init(S3C_VA_WATCHDOG); | 231 | samsung_wdt_reset_init(S3C_VA_WATCHDOG); |
219 | 232 | ||
220 | printk(KERN_DEBUG "%s: initialising interrupts\n", __func__); | 233 | printk(KERN_DEBUG "%s: initialising interrupts\n", __func__); |
diff --git a/arch/arm/mach-s3c64xx/common.h b/arch/arm/mach-s3c64xx/common.h index e8f990b37665..bd3bd562011e 100644 --- a/arch/arm/mach-s3c64xx/common.h +++ b/arch/arm/mach-s3c64xx/common.h | |||
@@ -22,21 +22,21 @@ | |||
22 | void s3c64xx_init_irq(u32 vic0, u32 vic1); | 22 | void s3c64xx_init_irq(u32 vic0, u32 vic1); |
23 | void s3c64xx_init_io(struct map_desc *mach_desc, int size); | 23 | void s3c64xx_init_io(struct map_desc *mach_desc, int size); |
24 | 24 | ||
25 | void s3c64xx_register_clocks(unsigned long xtal, unsigned armclk_limit); | ||
26 | void s3c64xx_setup_clocks(void); | ||
27 | |||
28 | void s3c64xx_restart(enum reboot_mode mode, const char *cmd); | 25 | void s3c64xx_restart(enum reboot_mode mode, const char *cmd); |
29 | void s3c64xx_init_late(void); | 26 | void s3c64xx_init_late(void); |
30 | 27 | ||
28 | void s3c64xx_clk_init(struct device_node *np, unsigned long xtal_f, | ||
29 | unsigned long xusbxti_f, bool is_s3c6400, void __iomem *reg_base); | ||
30 | void s3c64xx_set_xtal_freq(unsigned long freq); | ||
31 | void s3c64xx_set_xusbxti_freq(unsigned long freq); | ||
32 | |||
31 | #ifdef CONFIG_CPU_S3C6400 | 33 | #ifdef CONFIG_CPU_S3C6400 |
32 | 34 | ||
33 | extern int s3c6400_init(void); | 35 | extern int s3c6400_init(void); |
34 | extern void s3c6400_init_irq(void); | 36 | extern void s3c6400_init_irq(void); |
35 | extern void s3c6400_map_io(void); | 37 | extern void s3c6400_map_io(void); |
36 | extern void s3c6400_init_clocks(int xtal); | ||
37 | 38 | ||
38 | #else | 39 | #else |
39 | #define s3c6400_init_clocks NULL | ||
40 | #define s3c6400_map_io NULL | 40 | #define s3c6400_map_io NULL |
41 | #define s3c6400_init NULL | 41 | #define s3c6400_init NULL |
42 | #endif | 42 | #endif |
@@ -46,10 +46,8 @@ extern void s3c6400_init_clocks(int xtal); | |||
46 | extern int s3c6410_init(void); | 46 | extern int s3c6410_init(void); |
47 | extern void s3c6410_init_irq(void); | 47 | extern void s3c6410_init_irq(void); |
48 | extern void s3c6410_map_io(void); | 48 | extern void s3c6410_map_io(void); |
49 | extern void s3c6410_init_clocks(int xtal); | ||
50 | 49 | ||
51 | #else | 50 | #else |
52 | #define s3c6410_init_clocks NULL | ||
53 | #define s3c6410_map_io NULL | 51 | #define s3c6410_map_io NULL |
54 | #define s3c6410_init NULL | 52 | #define s3c6410_init NULL |
55 | #endif | 53 | #endif |
diff --git a/arch/arm/mach-s3c64xx/dma.c b/arch/arm/mach-s3c64xx/dma.c index 759846c28d12..c511dfaae148 100644 --- a/arch/arm/mach-s3c64xx/dma.c +++ b/arch/arm/mach-s3c64xx/dma.c | |||
@@ -677,7 +677,7 @@ static int s3c64xx_dma_init1(int chno, enum dma_ch chbase, | |||
677 | goto err_map; | 677 | goto err_map; |
678 | } | 678 | } |
679 | 679 | ||
680 | clk_enable(dmac->clk); | 680 | clk_prepare_enable(dmac->clk); |
681 | 681 | ||
682 | dmac->regs = regs; | 682 | dmac->regs = regs; |
683 | dmac->chanbase = chbase; | 683 | dmac->chanbase = chbase; |
@@ -711,7 +711,7 @@ static int s3c64xx_dma_init1(int chno, enum dma_ch chbase, | |||
711 | return 0; | 711 | return 0; |
712 | 712 | ||
713 | err_clk: | 713 | err_clk: |
714 | clk_disable(dmac->clk); | 714 | clk_disable_unprepare(dmac->clk); |
715 | clk_put(dmac->clk); | 715 | clk_put(dmac->clk); |
716 | err_map: | 716 | err_map: |
717 | iounmap(regs); | 717 | iounmap(regs); |
diff --git a/arch/arm/mach-s3c64xx/include/mach/regs-clock.h b/arch/arm/mach-s3c64xx/include/mach/regs-clock.h index 05332b998ec0..4f44aac77092 100644 --- a/arch/arm/mach-s3c64xx/include/mach/regs-clock.h +++ b/arch/arm/mach-s3c64xx/include/mach/regs-clock.h | |||
@@ -15,145 +15,21 @@ | |||
15 | #ifndef __PLAT_REGS_CLOCK_H | 15 | #ifndef __PLAT_REGS_CLOCK_H |
16 | #define __PLAT_REGS_CLOCK_H __FILE__ | 16 | #define __PLAT_REGS_CLOCK_H __FILE__ |
17 | 17 | ||
18 | /* | ||
19 | * FIXME: Remove remaining definitions | ||
20 | */ | ||
21 | |||
18 | #define S3C_CLKREG(x) (S3C_VA_SYS + (x)) | 22 | #define S3C_CLKREG(x) (S3C_VA_SYS + (x)) |
19 | 23 | ||
20 | #define S3C_APLL_LOCK S3C_CLKREG(0x00) | ||
21 | #define S3C_MPLL_LOCK S3C_CLKREG(0x04) | ||
22 | #define S3C_EPLL_LOCK S3C_CLKREG(0x08) | ||
23 | #define S3C_APLL_CON S3C_CLKREG(0x0C) | ||
24 | #define S3C_MPLL_CON S3C_CLKREG(0x10) | ||
25 | #define S3C_EPLL_CON0 S3C_CLKREG(0x14) | ||
26 | #define S3C_EPLL_CON1 S3C_CLKREG(0x18) | ||
27 | #define S3C_CLK_SRC S3C_CLKREG(0x1C) | ||
28 | #define S3C_CLK_DIV0 S3C_CLKREG(0x20) | ||
29 | #define S3C_CLK_DIV1 S3C_CLKREG(0x24) | ||
30 | #define S3C_CLK_DIV2 S3C_CLKREG(0x28) | ||
31 | #define S3C_CLK_OUT S3C_CLKREG(0x2C) | ||
32 | #define S3C_HCLK_GATE S3C_CLKREG(0x30) | ||
33 | #define S3C_PCLK_GATE S3C_CLKREG(0x34) | 24 | #define S3C_PCLK_GATE S3C_CLKREG(0x34) |
34 | #define S3C_SCLK_GATE S3C_CLKREG(0x38) | ||
35 | #define S3C_MEM0_GATE S3C_CLKREG(0x3C) | ||
36 | #define S3C6410_CLK_SRC2 S3C_CLKREG(0x10C) | 25 | #define S3C6410_CLK_SRC2 S3C_CLKREG(0x10C) |
37 | #define S3C_MEM_SYS_CFG S3C_CLKREG(0x120) | 26 | #define S3C_MEM_SYS_CFG S3C_CLKREG(0x120) |
38 | 27 | ||
39 | /* CLKDIV0 */ | ||
40 | #define S3C6400_CLKDIV0_PCLK_MASK (0xf << 12) | ||
41 | #define S3C6400_CLKDIV0_PCLK_SHIFT (12) | ||
42 | #define S3C6400_CLKDIV0_HCLK2_MASK (0x7 << 9) | ||
43 | #define S3C6400_CLKDIV0_HCLK2_SHIFT (9) | ||
44 | #define S3C6400_CLKDIV0_HCLK_MASK (0x1 << 8) | ||
45 | #define S3C6400_CLKDIV0_HCLK_SHIFT (8) | ||
46 | #define S3C6400_CLKDIV0_MPLL_MASK (0x1 << 4) | ||
47 | #define S3C6400_CLKDIV0_MPLL_SHIFT (4) | ||
48 | |||
49 | #define S3C6400_CLKDIV0_ARM_MASK (0x7 << 0) | ||
50 | #define S3C6410_CLKDIV0_ARM_MASK (0xf << 0) | ||
51 | #define S3C6400_CLKDIV0_ARM_SHIFT (0) | ||
52 | |||
53 | /* HCLK GATE Registers */ | ||
54 | #define S3C_CLKCON_HCLK_3DSE (1<<31) | ||
55 | #define S3C_CLKCON_HCLK_UHOST (1<<29) | ||
56 | #define S3C_CLKCON_HCLK_SECUR (1<<28) | ||
57 | #define S3C_CLKCON_HCLK_SDMA1 (1<<27) | ||
58 | #define S3C_CLKCON_HCLK_SDMA0 (1<<26) | ||
59 | #define S3C_CLKCON_HCLK_IROM (1<<25) | ||
60 | #define S3C_CLKCON_HCLK_DDR1 (1<<24) | ||
61 | #define S3C_CLKCON_HCLK_DDR0 (1<<23) | ||
62 | #define S3C_CLKCON_HCLK_MEM1 (1<<22) | ||
63 | #define S3C_CLKCON_HCLK_MEM0 (1<<21) | ||
64 | #define S3C_CLKCON_HCLK_USB (1<<20) | ||
65 | #define S3C_CLKCON_HCLK_HSMMC2 (1<<19) | ||
66 | #define S3C_CLKCON_HCLK_HSMMC1 (1<<18) | ||
67 | #define S3C_CLKCON_HCLK_HSMMC0 (1<<17) | ||
68 | #define S3C_CLKCON_HCLK_MDP (1<<16) | ||
69 | #define S3C_CLKCON_HCLK_DHOST (1<<15) | ||
70 | #define S3C_CLKCON_HCLK_IHOST (1<<14) | ||
71 | #define S3C_CLKCON_HCLK_DMA1 (1<<13) | ||
72 | #define S3C_CLKCON_HCLK_DMA0 (1<<12) | ||
73 | #define S3C_CLKCON_HCLK_JPEG (1<<11) | ||
74 | #define S3C_CLKCON_HCLK_CAMIF (1<<10) | ||
75 | #define S3C_CLKCON_HCLK_SCALER (1<<9) | ||
76 | #define S3C_CLKCON_HCLK_2D (1<<8) | ||
77 | #define S3C_CLKCON_HCLK_TV (1<<7) | ||
78 | #define S3C_CLKCON_HCLK_POST0 (1<<5) | ||
79 | #define S3C_CLKCON_HCLK_ROT (1<<4) | ||
80 | #define S3C_CLKCON_HCLK_LCD (1<<3) | ||
81 | #define S3C_CLKCON_HCLK_TZIC (1<<2) | ||
82 | #define S3C_CLKCON_HCLK_INTC (1<<1) | ||
83 | #define S3C_CLKCON_HCLK_MFC (1<<0) | ||
84 | |||
85 | /* PCLK GATE Registers */ | 28 | /* PCLK GATE Registers */ |
86 | #define S3C6410_CLKCON_PCLK_I2C1 (1<<27) | ||
87 | #define S3C6410_CLKCON_PCLK_IIS2 (1<<26) | ||
88 | #define S3C_CLKCON_PCLK_SKEY (1<<24) | ||
89 | #define S3C_CLKCON_PCLK_CHIPID (1<<23) | ||
90 | #define S3C_CLKCON_PCLK_SPI1 (1<<22) | ||
91 | #define S3C_CLKCON_PCLK_SPI0 (1<<21) | ||
92 | #define S3C_CLKCON_PCLK_HSIRX (1<<20) | ||
93 | #define S3C_CLKCON_PCLK_HSITX (1<<19) | ||
94 | #define S3C_CLKCON_PCLK_GPIO (1<<18) | ||
95 | #define S3C_CLKCON_PCLK_IIC (1<<17) | ||
96 | #define S3C_CLKCON_PCLK_IIS1 (1<<16) | ||
97 | #define S3C_CLKCON_PCLK_IIS0 (1<<15) | ||
98 | #define S3C_CLKCON_PCLK_AC97 (1<<14) | ||
99 | #define S3C_CLKCON_PCLK_TZPC (1<<13) | ||
100 | #define S3C_CLKCON_PCLK_TSADC (1<<12) | ||
101 | #define S3C_CLKCON_PCLK_KEYPAD (1<<11) | ||
102 | #define S3C_CLKCON_PCLK_IRDA (1<<10) | ||
103 | #define S3C_CLKCON_PCLK_PCM1 (1<<9) | ||
104 | #define S3C_CLKCON_PCLK_PCM0 (1<<8) | ||
105 | #define S3C_CLKCON_PCLK_PWM (1<<7) | ||
106 | #define S3C_CLKCON_PCLK_RTC (1<<6) | ||
107 | #define S3C_CLKCON_PCLK_WDT (1<<5) | ||
108 | #define S3C_CLKCON_PCLK_UART3 (1<<4) | 29 | #define S3C_CLKCON_PCLK_UART3 (1<<4) |
109 | #define S3C_CLKCON_PCLK_UART2 (1<<3) | 30 | #define S3C_CLKCON_PCLK_UART2 (1<<3) |
110 | #define S3C_CLKCON_PCLK_UART1 (1<<2) | 31 | #define S3C_CLKCON_PCLK_UART1 (1<<2) |
111 | #define S3C_CLKCON_PCLK_UART0 (1<<1) | 32 | #define S3C_CLKCON_PCLK_UART0 (1<<1) |
112 | #define S3C_CLKCON_PCLK_MFC (1<<0) | ||
113 | |||
114 | /* SCLK GATE Registers */ | ||
115 | #define S3C_CLKCON_SCLK_UHOST (1<<30) | ||
116 | #define S3C_CLKCON_SCLK_MMC2_48 (1<<29) | ||
117 | #define S3C_CLKCON_SCLK_MMC1_48 (1<<28) | ||
118 | #define S3C_CLKCON_SCLK_MMC0_48 (1<<27) | ||
119 | #define S3C_CLKCON_SCLK_MMC2 (1<<26) | ||
120 | #define S3C_CLKCON_SCLK_MMC1 (1<<25) | ||
121 | #define S3C_CLKCON_SCLK_MMC0 (1<<24) | ||
122 | #define S3C_CLKCON_SCLK_SPI1_48 (1<<23) | ||
123 | #define S3C_CLKCON_SCLK_SPI0_48 (1<<22) | ||
124 | #define S3C_CLKCON_SCLK_SPI1 (1<<21) | ||
125 | #define S3C_CLKCON_SCLK_SPI0 (1<<20) | ||
126 | #define S3C_CLKCON_SCLK_DAC27 (1<<19) | ||
127 | #define S3C_CLKCON_SCLK_TV27 (1<<18) | ||
128 | #define S3C_CLKCON_SCLK_SCALER27 (1<<17) | ||
129 | #define S3C_CLKCON_SCLK_SCALER (1<<16) | ||
130 | #define S3C_CLKCON_SCLK_LCD27 (1<<15) | ||
131 | #define S3C_CLKCON_SCLK_LCD (1<<14) | ||
132 | #define S3C6400_CLKCON_SCLK_POST1_27 (1<<13) | ||
133 | #define S3C6410_CLKCON_FIMC (1<<13) | ||
134 | #define S3C_CLKCON_SCLK_POST0_27 (1<<12) | ||
135 | #define S3C6400_CLKCON_SCLK_POST1 (1<<11) | ||
136 | #define S3C6410_CLKCON_SCLK_AUDIO2 (1<<11) | ||
137 | #define S3C_CLKCON_SCLK_POST0 (1<<10) | ||
138 | #define S3C_CLKCON_SCLK_AUDIO1 (1<<9) | ||
139 | #define S3C_CLKCON_SCLK_AUDIO0 (1<<8) | ||
140 | #define S3C_CLKCON_SCLK_SECUR (1<<7) | ||
141 | #define S3C_CLKCON_SCLK_IRDA (1<<6) | ||
142 | #define S3C_CLKCON_SCLK_UART (1<<5) | ||
143 | #define S3C_CLKCON_SCLK_ONENAND (1<<4) | ||
144 | #define S3C_CLKCON_SCLK_MFC (1<<3) | ||
145 | #define S3C_CLKCON_SCLK_CAM (1<<2) | ||
146 | #define S3C_CLKCON_SCLK_JPEG (1<<1) | ||
147 | |||
148 | /* CLKSRC */ | ||
149 | |||
150 | #define S3C6400_CLKSRC_APLL_MOUT (1 << 0) | ||
151 | #define S3C6400_CLKSRC_MPLL_MOUT (1 << 1) | ||
152 | #define S3C6400_CLKSRC_EPLL_MOUT (1 << 2) | ||
153 | #define S3C6400_CLKSRC_APLL_MOUT_SHIFT (0) | ||
154 | #define S3C6400_CLKSRC_MPLL_MOUT_SHIFT (1) | ||
155 | #define S3C6400_CLKSRC_EPLL_MOUT_SHIFT (2) | ||
156 | #define S3C6400_CLKSRC_MFC (1 << 4) | ||
157 | 33 | ||
158 | /* MEM_SYS_CFG */ | 34 | /* MEM_SYS_CFG */ |
159 | #define MEM_SYS_CFG_INDEP_CF 0x4000 | 35 | #define MEM_SYS_CFG_INDEP_CF 0x4000 |
diff --git a/arch/arm/mach-s3c64xx/mach-anw6410.c b/arch/arm/mach-s3c64xx/mach-anw6410.c index 35e3f54574ef..d266dd5f7060 100644 --- a/arch/arm/mach-s3c64xx/mach-anw6410.c +++ b/arch/arm/mach-s3c64xx/mach-anw6410.c | |||
@@ -207,7 +207,7 @@ static struct platform_device *anw6410_devices[] __initdata = { | |||
207 | static void __init anw6410_map_io(void) | 207 | static void __init anw6410_map_io(void) |
208 | { | 208 | { |
209 | s3c64xx_init_io(anw6410_iodesc, ARRAY_SIZE(anw6410_iodesc)); | 209 | s3c64xx_init_io(anw6410_iodesc, ARRAY_SIZE(anw6410_iodesc)); |
210 | s3c24xx_init_clocks(12000000); | 210 | s3c64xx_set_xtal_freq(12000000); |
211 | s3c24xx_init_uarts(anw6410_uartcfgs, ARRAY_SIZE(anw6410_uartcfgs)); | 211 | s3c24xx_init_uarts(anw6410_uartcfgs, ARRAY_SIZE(anw6410_uartcfgs)); |
212 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | 212 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); |
213 | 213 | ||
diff --git a/arch/arm/mach-s3c64xx/mach-crag6410.c b/arch/arm/mach-s3c64xx/mach-crag6410.c index eb8e5a1aca42..1a911df9e451 100644 --- a/arch/arm/mach-s3c64xx/mach-crag6410.c +++ b/arch/arm/mach-s3c64xx/mach-crag6410.c | |||
@@ -743,7 +743,7 @@ static struct s3c2410_platform_i2c i2c1_pdata = { | |||
743 | static void __init crag6410_map_io(void) | 743 | static void __init crag6410_map_io(void) |
744 | { | 744 | { |
745 | s3c64xx_init_io(NULL, 0); | 745 | s3c64xx_init_io(NULL, 0); |
746 | s3c24xx_init_clocks(12000000); | 746 | s3c64xx_set_xtal_freq(12000000); |
747 | s3c24xx_init_uarts(crag6410_uartcfgs, ARRAY_SIZE(crag6410_uartcfgs)); | 747 | s3c24xx_init_uarts(crag6410_uartcfgs, ARRAY_SIZE(crag6410_uartcfgs)); |
748 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | 748 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); |
749 | 749 | ||
diff --git a/arch/arm/mach-s3c64xx/mach-hmt.c b/arch/arm/mach-s3c64xx/mach-hmt.c index f39569e0f2e6..e8064044ef79 100644 --- a/arch/arm/mach-s3c64xx/mach-hmt.c +++ b/arch/arm/mach-s3c64xx/mach-hmt.c | |||
@@ -247,7 +247,7 @@ static struct platform_device *hmt_devices[] __initdata = { | |||
247 | static void __init hmt_map_io(void) | 247 | static void __init hmt_map_io(void) |
248 | { | 248 | { |
249 | s3c64xx_init_io(hmt_iodesc, ARRAY_SIZE(hmt_iodesc)); | 249 | s3c64xx_init_io(hmt_iodesc, ARRAY_SIZE(hmt_iodesc)); |
250 | s3c24xx_init_clocks(12000000); | 250 | s3c64xx_set_xtal_freq(12000000); |
251 | s3c24xx_init_uarts(hmt_uartcfgs, ARRAY_SIZE(hmt_uartcfgs)); | 251 | s3c24xx_init_uarts(hmt_uartcfgs, ARRAY_SIZE(hmt_uartcfgs)); |
252 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | 252 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); |
253 | } | 253 | } |
diff --git a/arch/arm/mach-s3c64xx/mach-mini6410.c b/arch/arm/mach-s3c64xx/mach-mini6410.c index fc043e3ecdf8..58d46a3d7b78 100644 --- a/arch/arm/mach-s3c64xx/mach-mini6410.c +++ b/arch/arm/mach-s3c64xx/mach-mini6410.c | |||
@@ -231,7 +231,7 @@ static void __init mini6410_map_io(void) | |||
231 | u32 tmp; | 231 | u32 tmp; |
232 | 232 | ||
233 | s3c64xx_init_io(NULL, 0); | 233 | s3c64xx_init_io(NULL, 0); |
234 | s3c24xx_init_clocks(12000000); | 234 | s3c64xx_set_xtal_freq(12000000); |
235 | s3c24xx_init_uarts(mini6410_uartcfgs, ARRAY_SIZE(mini6410_uartcfgs)); | 235 | s3c24xx_init_uarts(mini6410_uartcfgs, ARRAY_SIZE(mini6410_uartcfgs)); |
236 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | 236 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); |
237 | 237 | ||
diff --git a/arch/arm/mach-s3c64xx/mach-ncp.c b/arch/arm/mach-s3c64xx/mach-ncp.c index 7e2c3908f1f8..2067b0bf55b4 100644 --- a/arch/arm/mach-s3c64xx/mach-ncp.c +++ b/arch/arm/mach-s3c64xx/mach-ncp.c | |||
@@ -86,7 +86,7 @@ static struct map_desc ncp_iodesc[] __initdata = {}; | |||
86 | static void __init ncp_map_io(void) | 86 | static void __init ncp_map_io(void) |
87 | { | 87 | { |
88 | s3c64xx_init_io(ncp_iodesc, ARRAY_SIZE(ncp_iodesc)); | 88 | s3c64xx_init_io(ncp_iodesc, ARRAY_SIZE(ncp_iodesc)); |
89 | s3c24xx_init_clocks(12000000); | 89 | s3c64xx_set_xtal_freq(12000000); |
90 | s3c24xx_init_uarts(ncp_uartcfgs, ARRAY_SIZE(ncp_uartcfgs)); | 90 | s3c24xx_init_uarts(ncp_uartcfgs, ARRAY_SIZE(ncp_uartcfgs)); |
91 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | 91 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); |
92 | } | 92 | } |
diff --git a/arch/arm/mach-s3c64xx/mach-smartq.c b/arch/arm/mach-s3c64xx/mach-smartq.c index 86d980b448fd..0f47237be3b2 100644 --- a/arch/arm/mach-s3c64xx/mach-smartq.c +++ b/arch/arm/mach-s3c64xx/mach-smartq.c | |||
@@ -337,13 +337,6 @@ err: | |||
337 | return ret; | 337 | return ret; |
338 | } | 338 | } |
339 | 339 | ||
340 | static int __init smartq_usb_otg_init(void) | ||
341 | { | ||
342 | clk_xusbxti.rate = 12000000; | ||
343 | |||
344 | return 0; | ||
345 | } | ||
346 | |||
347 | static int __init smartq_wifi_init(void) | 340 | static int __init smartq_wifi_init(void) |
348 | { | 341 | { |
349 | int ret; | 342 | int ret; |
@@ -377,7 +370,8 @@ static struct map_desc smartq_iodesc[] __initdata = {}; | |||
377 | void __init smartq_map_io(void) | 370 | void __init smartq_map_io(void) |
378 | { | 371 | { |
379 | s3c64xx_init_io(smartq_iodesc, ARRAY_SIZE(smartq_iodesc)); | 372 | s3c64xx_init_io(smartq_iodesc, ARRAY_SIZE(smartq_iodesc)); |
380 | s3c24xx_init_clocks(12000000); | 373 | s3c64xx_set_xtal_freq(12000000); |
374 | s3c64xx_set_xusbxti_freq(12000000); | ||
381 | s3c24xx_init_uarts(smartq_uartcfgs, ARRAY_SIZE(smartq_uartcfgs)); | 375 | s3c24xx_init_uarts(smartq_uartcfgs, ARRAY_SIZE(smartq_uartcfgs)); |
382 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | 376 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); |
383 | 377 | ||
@@ -399,7 +393,6 @@ void __init smartq_machine_init(void) | |||
399 | WARN_ON(smartq_lcd_setup_gpio()); | 393 | WARN_ON(smartq_lcd_setup_gpio()); |
400 | WARN_ON(smartq_power_off_init()); | 394 | WARN_ON(smartq_power_off_init()); |
401 | WARN_ON(smartq_usb_host_init()); | 395 | WARN_ON(smartq_usb_host_init()); |
402 | WARN_ON(smartq_usb_otg_init()); | ||
403 | WARN_ON(smartq_wifi_init()); | 396 | WARN_ON(smartq_wifi_init()); |
404 | 397 | ||
405 | platform_add_devices(smartq_devices, ARRAY_SIZE(smartq_devices)); | 398 | platform_add_devices(smartq_devices, ARRAY_SIZE(smartq_devices)); |
diff --git a/arch/arm/mach-s3c64xx/mach-smdk6400.c b/arch/arm/mach-s3c64xx/mach-smdk6400.c index d70c0843aea2..27381cfcabbe 100644 --- a/arch/arm/mach-s3c64xx/mach-smdk6400.c +++ b/arch/arm/mach-s3c64xx/mach-smdk6400.c | |||
@@ -65,7 +65,7 @@ static struct map_desc smdk6400_iodesc[] = {}; | |||
65 | static void __init smdk6400_map_io(void) | 65 | static void __init smdk6400_map_io(void) |
66 | { | 66 | { |
67 | s3c64xx_init_io(smdk6400_iodesc, ARRAY_SIZE(smdk6400_iodesc)); | 67 | s3c64xx_init_io(smdk6400_iodesc, ARRAY_SIZE(smdk6400_iodesc)); |
68 | s3c24xx_init_clocks(12000000); | 68 | s3c64xx_set_xtal_freq(12000000); |
69 | s3c24xx_init_uarts(smdk6400_uartcfgs, ARRAY_SIZE(smdk6400_uartcfgs)); | 69 | s3c24xx_init_uarts(smdk6400_uartcfgs, ARRAY_SIZE(smdk6400_uartcfgs)); |
70 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | 70 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); |
71 | } | 71 | } |
diff --git a/arch/arm/mach-s3c64xx/mach-smdk6410.c b/arch/arm/mach-s3c64xx/mach-smdk6410.c index d90b450c5645..2a7b32ca5c96 100644 --- a/arch/arm/mach-s3c64xx/mach-smdk6410.c +++ b/arch/arm/mach-s3c64xx/mach-smdk6410.c | |||
@@ -634,7 +634,7 @@ static void __init smdk6410_map_io(void) | |||
634 | u32 tmp; | 634 | u32 tmp; |
635 | 635 | ||
636 | s3c64xx_init_io(smdk6410_iodesc, ARRAY_SIZE(smdk6410_iodesc)); | 636 | s3c64xx_init_io(smdk6410_iodesc, ARRAY_SIZE(smdk6410_iodesc)); |
637 | s3c24xx_init_clocks(12000000); | 637 | s3c64xx_set_xtal_freq(12000000); |
638 | s3c24xx_init_uarts(smdk6410_uartcfgs, ARRAY_SIZE(smdk6410_uartcfgs)); | 638 | s3c24xx_init_uarts(smdk6410_uartcfgs, ARRAY_SIZE(smdk6410_uartcfgs)); |
639 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | 639 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); |
640 | 640 | ||
diff --git a/arch/arm/mach-s3c64xx/pm.c b/arch/arm/mach-s3c64xx/pm.c index 6a1f91fea678..8cdb824a3b43 100644 --- a/arch/arm/mach-s3c64xx/pm.c +++ b/arch/arm/mach-s3c64xx/pm.c | |||
@@ -194,29 +194,8 @@ void s3c_pm_debug_smdkled(u32 set, u32 clear) | |||
194 | #endif | 194 | #endif |
195 | 195 | ||
196 | static struct sleep_save core_save[] = { | 196 | static struct sleep_save core_save[] = { |
197 | SAVE_ITEM(S3C_APLL_LOCK), | ||
198 | SAVE_ITEM(S3C_MPLL_LOCK), | ||
199 | SAVE_ITEM(S3C_EPLL_LOCK), | ||
200 | SAVE_ITEM(S3C_CLK_SRC), | ||
201 | SAVE_ITEM(S3C_CLK_DIV0), | ||
202 | SAVE_ITEM(S3C_CLK_DIV1), | ||
203 | SAVE_ITEM(S3C_CLK_DIV2), | ||
204 | SAVE_ITEM(S3C_CLK_OUT), | ||
205 | SAVE_ITEM(S3C_HCLK_GATE), | ||
206 | SAVE_ITEM(S3C_PCLK_GATE), | ||
207 | SAVE_ITEM(S3C_SCLK_GATE), | ||
208 | SAVE_ITEM(S3C_MEM0_GATE), | ||
209 | |||
210 | SAVE_ITEM(S3C_EPLL_CON1), | ||
211 | SAVE_ITEM(S3C_EPLL_CON0), | ||
212 | |||
213 | SAVE_ITEM(S3C64XX_MEM0DRVCON), | 197 | SAVE_ITEM(S3C64XX_MEM0DRVCON), |
214 | SAVE_ITEM(S3C64XX_MEM1DRVCON), | 198 | SAVE_ITEM(S3C64XX_MEM1DRVCON), |
215 | |||
216 | #ifndef CONFIG_CPU_FREQ | ||
217 | SAVE_ITEM(S3C_APLL_CON), | ||
218 | SAVE_ITEM(S3C_MPLL_CON), | ||
219 | #endif | ||
220 | }; | 199 | }; |
221 | 200 | ||
222 | static struct sleep_save misc_save[] = { | 201 | static struct sleep_save misc_save[] = { |
diff --git a/arch/arm/mach-s3c64xx/s3c6400.c b/arch/arm/mach-s3c64xx/s3c6400.c index 4869714c6f1b..331fe8e58145 100644 --- a/arch/arm/mach-s3c64xx/s3c6400.c +++ b/arch/arm/mach-s3c64xx/s3c6400.c | |||
@@ -58,12 +58,6 @@ void __init s3c6400_map_io(void) | |||
58 | s3c64xx_onenand1_setname("s3c6400-onenand"); | 58 | s3c64xx_onenand1_setname("s3c6400-onenand"); |
59 | } | 59 | } |
60 | 60 | ||
61 | void __init s3c6400_init_clocks(int xtal) | ||
62 | { | ||
63 | s3c64xx_register_clocks(xtal, S3C6400_CLKDIV0_ARM_MASK); | ||
64 | s3c64xx_setup_clocks(); | ||
65 | } | ||
66 | |||
67 | void __init s3c6400_init_irq(void) | 61 | void __init s3c6400_init_irq(void) |
68 | { | 62 | { |
69 | /* VIC0 does not have IRQS 5..7, | 63 | /* VIC0 does not have IRQS 5..7, |
diff --git a/arch/arm/mach-s3c64xx/s3c6410.c b/arch/arm/mach-s3c64xx/s3c6410.c index 31c29fdf1800..7e6fa125584a 100644 --- a/arch/arm/mach-s3c64xx/s3c6410.c +++ b/arch/arm/mach-s3c64xx/s3c6410.c | |||
@@ -62,13 +62,6 @@ void __init s3c6410_map_io(void) | |||
62 | s3c_cfcon_setname("s3c64xx-pata"); | 62 | s3c_cfcon_setname("s3c64xx-pata"); |
63 | } | 63 | } |
64 | 64 | ||
65 | void __init s3c6410_init_clocks(int xtal) | ||
66 | { | ||
67 | printk(KERN_DEBUG "%s: initialising clocks\n", __func__); | ||
68 | s3c64xx_register_clocks(xtal, S3C6410_CLKDIV0_ARM_MASK); | ||
69 | s3c64xx_setup_clocks(); | ||
70 | } | ||
71 | |||
72 | void __init s3c6410_init_irq(void) | 65 | void __init s3c6410_init_irq(void) |
73 | { | 66 | { |
74 | /* VIC0 is missing IRQ7, VIC1 is fully populated. */ | 67 | /* VIC0 is missing IRQ7, VIC1 is fully populated. */ |