Blame view

drivers/clk/spear/spear3xx_clock.c 23.1 KB
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
1
2
3
4
  /*
   * SPEAr3xx machines clock framework source file
   *
   * Copyright (C) 2012 ST Microelectronics
da89947b4   Viresh Kumar   Update Viresh Kum...
5
   * Viresh Kumar <vireshk@kernel.org>
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
6
7
8
9
10
11
12
13
14
15
16
17
   *
   * This file is licensed under the terms of the GNU General Public
   * License version 2. This program is licensed "as is" without any
   * warranty of any kind, whether express or implied.
   */
  
  #include <linux/clk.h>
  #include <linux/clkdev.h>
  #include <linux/err.h>
  #include <linux/io.h>
  #include <linux/of_platform.h>
  #include <linux/spinlock_types.h>
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
18
19
20
  #include "clk.h"
  
  static DEFINE_SPINLOCK(_lock);
d9909ebe6   Arnd Bergmann   ARM: spear: make ...
21
22
23
24
25
  #define PLL1_CTR			(misc_base + 0x008)
  #define PLL1_FRQ			(misc_base + 0x00C)
  #define PLL2_CTR			(misc_base + 0x014)
  #define PLL2_FRQ			(misc_base + 0x018)
  #define PLL_CLK_CFG			(misc_base + 0x020)
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
26
27
28
  	/* PLL_CLK_CFG register masks */
  	#define MCTR_CLK_SHIFT		28
  	#define MCTR_CLK_MASK		3
d9909ebe6   Arnd Bergmann   ARM: spear: make ...
29
  #define CORE_CLK_CFG			(misc_base + 0x024)
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
30
31
32
33
34
35
36
37
  	/* CORE CLK CFG register masks */
  	#define GEN_SYNTH2_3_CLK_SHIFT	18
  	#define GEN_SYNTH2_3_CLK_MASK	1
  
  	#define HCLK_RATIO_SHIFT	10
  	#define HCLK_RATIO_MASK		2
  	#define PCLK_RATIO_SHIFT	8
  	#define PCLK_RATIO_MASK		2
d9909ebe6   Arnd Bergmann   ARM: spear: make ...
38
  #define PERIP_CLK_CFG			(misc_base + 0x028)
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
39
40
41
42
43
44
45
46
47
  	/* PERIP_CLK_CFG register masks */
  	#define UART_CLK_SHIFT		4
  	#define UART_CLK_MASK		1
  	#define FIRDA_CLK_SHIFT		5
  	#define FIRDA_CLK_MASK		2
  	#define GPT0_CLK_SHIFT		8
  	#define GPT1_CLK_SHIFT		11
  	#define GPT2_CLK_SHIFT		12
  	#define GPT_CLK_MASK		1
d9909ebe6   Arnd Bergmann   ARM: spear: make ...
48
  #define PERIP1_CLK_ENB			(misc_base + 0x02C)
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
  	/* PERIP1_CLK_ENB register masks */
  	#define UART_CLK_ENB		3
  	#define SSP_CLK_ENB		5
  	#define I2C_CLK_ENB		7
  	#define JPEG_CLK_ENB		8
  	#define FIRDA_CLK_ENB		10
  	#define GPT1_CLK_ENB		11
  	#define GPT2_CLK_ENB		12
  	#define ADC_CLK_ENB		15
  	#define RTC_CLK_ENB		17
  	#define GPIO_CLK_ENB		18
  	#define DMA_CLK_ENB		19
  	#define SMI_CLK_ENB		21
  	#define GMAC_CLK_ENB		23
  	#define USBD_CLK_ENB		24
  	#define USBH_CLK_ENB		25
  	#define C3_CLK_ENB		31
d9909ebe6   Arnd Bergmann   ARM: spear: make ...
66
  #define RAS_CLK_ENB			(misc_base + 0x034)
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
67
68
69
70
71
72
73
74
75
76
77
  	#define RAS_AHB_CLK_ENB		0
  	#define RAS_PLL1_CLK_ENB	1
  	#define RAS_APB_CLK_ENB		2
  	#define RAS_32K_CLK_ENB		3
  	#define RAS_24M_CLK_ENB		4
  	#define RAS_48M_CLK_ENB		5
  	#define RAS_PLL2_CLK_ENB	7
  	#define RAS_SYNT0_CLK_ENB	8
  	#define RAS_SYNT1_CLK_ENB	9
  	#define RAS_SYNT2_CLK_ENB	10
  	#define RAS_SYNT3_CLK_ENB	11
d9909ebe6   Arnd Bergmann   ARM: spear: make ...
78
79
80
81
  #define PRSC0_CLK_CFG			(misc_base + 0x044)
  #define PRSC1_CLK_CFG			(misc_base + 0x048)
  #define PRSC2_CLK_CFG			(misc_base + 0x04C)
  #define AMEM_CLK_CFG			(misc_base + 0x050)
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
82
  	#define AMEM_CLK_ENB		0
d9909ebe6   Arnd Bergmann   ARM: spear: make ...
83
84
85
86
87
88
89
90
  #define CLCD_CLK_SYNT			(misc_base + 0x05C)
  #define FIRDA_CLK_SYNT			(misc_base + 0x060)
  #define UART_CLK_SYNT			(misc_base + 0x064)
  #define GMAC_CLK_SYNT			(misc_base + 0x068)
  #define GEN0_CLK_SYNT			(misc_base + 0x06C)
  #define GEN1_CLK_SYNT			(misc_base + 0x070)
  #define GEN2_CLK_SYNT			(misc_base + 0x074)
  #define GEN3_CLK_SYNT			(misc_base + 0x078)
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
91
92
93
94
95
96
97
98
99
100
101
  
  /* pll rate configuration table, in ascending order of rates */
  static struct pll_rate_tbl pll_rtbl[] = {
  	{.mode = 0, .m = 0x53, .n = 0x0C, .p = 0x1}, /* vco 332 & pll 166 MHz */
  	{.mode = 0, .m = 0x85, .n = 0x0C, .p = 0x1}, /* vco 532 & pll 266 MHz */
  	{.mode = 0, .m = 0xA6, .n = 0x0C, .p = 0x1}, /* vco 664 & pll 332 MHz */
  };
  
  /* aux rate configuration table, in ascending order of rates */
  static struct aux_rate_tbl aux_rtbl[] = {
  	/* For PLL1 = 332 MHz */
ef0fd0a20   Deepak Sikri   CLK: SPEAr: Updat...
102
103
104
105
106
107
  	{.xscale = 1, .yscale = 81, .eq = 0}, /* 2.049 MHz */
  	{.xscale = 1, .yscale = 59, .eq = 0}, /* 2.822 MHz */
  	{.xscale = 2, .yscale = 81, .eq = 0}, /* 4.098 MHz */
  	{.xscale = 3, .yscale = 89, .eq = 0}, /* 5.644 MHz */
  	{.xscale = 4, .yscale = 81, .eq = 0}, /* 8.197 MHz */
  	{.xscale = 4, .yscale = 59, .eq = 0}, /* 11.254 MHz */
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
  	{.xscale = 2, .yscale = 27, .eq = 0}, /* 12.296 MHz */
  	{.xscale = 2, .yscale = 8, .eq = 0}, /* 41.5 MHz */
  	{.xscale = 2, .yscale = 4, .eq = 0}, /* 83 MHz */
  	{.xscale = 1, .yscale = 2, .eq = 1}, /* 166 MHz */
  };
  
  /* gpt rate configuration table, in ascending order of rates */
  static struct gpt_rate_tbl gpt_rtbl[] = {
  	/* For pll1 = 332 MHz */
  	{.mscale = 4, .nscale = 0}, /* 41.5 MHz */
  	{.mscale = 2, .nscale = 0}, /* 55.3 MHz */
  	{.mscale = 1, .nscale = 0}, /* 83 MHz */
  };
  
  /* clock parents */
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
123
124
  static const char *uart0_parents[] = { "pll3_clk", "uart_syn_gclk", };
  static const char *firda_parents[] = { "pll3_clk", "firda_syn_gclk",
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
125
  };
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
126
127
128
  static const char *gpt0_parents[] = { "pll3_clk", "gpt0_syn_clk", };
  static const char *gpt1_parents[] = { "pll3_clk", "gpt1_syn_clk", };
  static const char *gpt2_parents[] = { "pll3_clk", "gpt2_syn_clk", };
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
129
130
131
132
133
134
135
136
  static const char *gen2_3_parents[] = { "pll1_clk", "pll2_clk", };
  static const char *ddr_parents[] = { "ahb_clk", "ahbmult2_clk", "none",
  	"pll2_clk", };
  
  #ifdef CONFIG_MACH_SPEAR300
  static void __init spear300_clk_init(void)
  {
  	struct clk *clk;
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
137
  	clk = clk_register_fixed_factor(NULL, "clcd_clk", "ras_pll3_clk", 0,
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
  			1, 1);
  	clk_register_clkdev(clk, NULL, "60000000.clcd");
  
  	clk = clk_register_fixed_factor(NULL, "fsmc_clk", "ras_ahb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, NULL, "94000000.flash");
  
  	clk = clk_register_fixed_factor(NULL, "sdhci_clk", "ras_ahb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, NULL, "70000000.sdhci");
  
  	clk = clk_register_fixed_factor(NULL, "gpio1_clk", "ras_apb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, NULL, "a9000000.gpio");
  
  	clk = clk_register_fixed_factor(NULL, "kbd_clk", "ras_apb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, NULL, "a0000000.kbd");
  }
90d4971d3   Axel Lin   clk: spear: Add s...
157
158
  #else
  static inline void spear300_clk_init(void) { }
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
  #endif
  
  /* array of all spear 310 clock lookups */
  #ifdef CONFIG_MACH_SPEAR310
  static void __init spear310_clk_init(void)
  {
  	struct clk *clk;
  
  	clk = clk_register_fixed_factor(NULL, "emi_clk", "ras_ahb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, "emi", NULL);
  
  	clk = clk_register_fixed_factor(NULL, "fsmc_clk", "ras_ahb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, NULL, "44000000.flash");
  
  	clk = clk_register_fixed_factor(NULL, "tdm_clk", "ras_ahb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, NULL, "tdm");
  
  	clk = clk_register_fixed_factor(NULL, "uart1_clk", "ras_apb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, NULL, "b2000000.serial");
  
  	clk = clk_register_fixed_factor(NULL, "uart2_clk", "ras_apb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, NULL, "b2080000.serial");
  
  	clk = clk_register_fixed_factor(NULL, "uart3_clk", "ras_apb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, NULL, "b2100000.serial");
  
  	clk = clk_register_fixed_factor(NULL, "uart4_clk", "ras_apb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, NULL, "b2180000.serial");
  
  	clk = clk_register_fixed_factor(NULL, "uart5_clk", "ras_apb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, NULL, "b2200000.serial");
  }
90d4971d3   Axel Lin   clk: spear: Add s...
199
200
  #else
  static inline void spear310_clk_init(void) { }
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
201
202
203
204
  #endif
  
  /* array of all spear 320 clock lookups */
  #ifdef CONFIG_MACH_SPEAR320
d9909ebe6   Arnd Bergmann   ARM: spear: make ...
205

15ebb0524   Thomas Gleixner   clk: spear3xx: Us...
206
  #define SPEAR320_CONTROL_REG		(soc_config_base + 0x0010)
d9909ebe6   Arnd Bergmann   ARM: spear: make ...
207
208
209
210
211
212
213
214
215
  #define SPEAR320_EXT_CTRL_REG		(soc_config_base + 0x0018)
  
  	#define SPEAR320_UARTX_PCLK_MASK		0x1
  	#define SPEAR320_UART2_PCLK_SHIFT		8
  	#define SPEAR320_UART3_PCLK_SHIFT		9
  	#define SPEAR320_UART4_PCLK_SHIFT		10
  	#define SPEAR320_UART5_PCLK_SHIFT		11
  	#define SPEAR320_UART6_PCLK_SHIFT		12
  	#define SPEAR320_RS485_PCLK_SHIFT		13
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
  	#define SMII_PCLK_SHIFT				18
  	#define SMII_PCLK_MASK				2
  	#define SMII_PCLK_VAL_PAD			0x0
  	#define SMII_PCLK_VAL_PLL2			0x1
  	#define SMII_PCLK_VAL_SYNTH0			0x2
  	#define SDHCI_PCLK_SHIFT			15
  	#define SDHCI_PCLK_MASK				1
  	#define SDHCI_PCLK_VAL_48M			0x0
  	#define SDHCI_PCLK_VAL_SYNTH3			0x1
  	#define I2S_REF_PCLK_SHIFT			8
  	#define I2S_REF_PCLK_MASK			1
  	#define I2S_REF_PCLK_SYNTH_VAL			0x1
  	#define I2S_REF_PCLK_PLL2_VAL			0x0
  	#define UART1_PCLK_SHIFT			6
  	#define UART1_PCLK_MASK				1
  	#define SPEAR320_UARTX_PCLK_VAL_SYNTH1		0x0
  	#define SPEAR320_UARTX_PCLK_VAL_APB		0x1
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
233
234
  static const char *i2s_ref_parents[] = { "ras_pll2_clk", "ras_syn2_gclk", };
  static const char *sdhci_parents[] = { "ras_pll3_clk", "ras_syn3_gclk", };
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
235
  static const char *smii0_parents[] = { "smii_125m_pad", "ras_pll2_clk",
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
236
237
  	"ras_syn0_gclk", };
  static const char *uartx_parents[] = { "ras_syn1_gclk", "ras_apb_clk", };
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
238

449437778   Thomas Gleixner   clk: spear3xx: Se...
239
240
  static void __init spear320_clk_init(void __iomem *soc_config_base,
  				     struct clk *ras_apb_clk)
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
241
242
243
244
  {
  	struct clk *clk;
  
  	clk = clk_register_fixed_rate(NULL, "smii_125m_pad_clk", NULL,
afb4bdc9d   Stephen Boyd   clk: spear: Remov...
245
  			0, 125000000);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
246
  	clk_register_clkdev(clk, "smii_125m_pad", NULL);
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
247
  	clk = clk_register_fixed_factor(NULL, "clcd_clk", "ras_pll3_clk", 0,
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
  			1, 1);
  	clk_register_clkdev(clk, NULL, "90000000.clcd");
  
  	clk = clk_register_fixed_factor(NULL, "emi_clk", "ras_ahb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, "emi", NULL);
  
  	clk = clk_register_fixed_factor(NULL, "fsmc_clk", "ras_ahb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, NULL, "4c000000.flash");
  
  	clk = clk_register_fixed_factor(NULL, "i2c1_clk", "ras_ahb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, NULL, "a7000000.i2c");
  
  	clk = clk_register_fixed_factor(NULL, "pwm_clk", "ras_ahb_clk", 0, 1,
  			1);
df2449aba   Rajeev Kumar   CLK: SPEAr: Fix d...
265
  	clk_register_clkdev(clk, NULL, "a8000000.pwm");
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
  
  	clk = clk_register_fixed_factor(NULL, "ssp1_clk", "ras_ahb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, NULL, "a5000000.spi");
  
  	clk = clk_register_fixed_factor(NULL, "ssp2_clk", "ras_ahb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, NULL, "a6000000.spi");
  
  	clk = clk_register_fixed_factor(NULL, "can0_clk", "ras_apb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, NULL, "c_can_platform.0");
  
  	clk = clk_register_fixed_factor(NULL, "can1_clk", "ras_apb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, NULL, "c_can_platform.1");
  
  	clk = clk_register_fixed_factor(NULL, "i2s_clk", "ras_apb_clk", 0, 1,
  			1);
df2449aba   Rajeev Kumar   CLK: SPEAr: Fix d...
285
  	clk_register_clkdev(clk, NULL, "a9400000.i2s");
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
286
287
  
  	clk = clk_register_mux(NULL, "i2s_ref_clk", i2s_ref_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
288
289
  			ARRAY_SIZE(i2s_ref_parents),
  			CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
290
291
  			SPEAR320_CONTROL_REG, I2S_REF_PCLK_SHIFT,
  			I2S_REF_PCLK_MASK, 0, &_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
292
  	clk_register_clkdev(clk, "i2s_ref_clk", NULL);
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
293
294
  	clk = clk_register_fixed_factor(NULL, "i2s_sclk", "i2s_ref_clk",
  			CLK_SET_RATE_PARENT, 1,
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
295
296
  			4);
  	clk_register_clkdev(clk, "i2s_sclk", NULL);
cd4b519aa   Vipul Kumar Samar   CLK: SPEAr: Add m...
297
298
299
300
301
302
303
  	clk = clk_register_fixed_factor(NULL, "macb1_clk", "ras_apb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, "hclk", "aa000000.eth");
  
  	clk = clk_register_fixed_factor(NULL, "macb2_clk", "ras_apb_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, "hclk", "ab000000.eth");
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
304
  	clk = clk_register_mux(NULL, "rs485_clk", uartx_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
305
306
  			ARRAY_SIZE(uartx_parents),
  			CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
307
308
  			SPEAR320_EXT_CTRL_REG, SPEAR320_RS485_PCLK_SHIFT,
  			SPEAR320_UARTX_PCLK_MASK, 0, &_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
309
310
311
  	clk_register_clkdev(clk, NULL, "a9300000.serial");
  
  	clk = clk_register_mux(NULL, "sdhci_clk", sdhci_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
312
313
  			ARRAY_SIZE(sdhci_parents),
  			CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
314
315
  			SPEAR320_CONTROL_REG, SDHCI_PCLK_SHIFT, SDHCI_PCLK_MASK,
  			0, &_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
316
317
318
  	clk_register_clkdev(clk, NULL, "70000000.sdhci");
  
  	clk = clk_register_mux(NULL, "smii_pclk", smii0_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
319
320
321
  			ARRAY_SIZE(smii0_parents), CLK_SET_RATE_NO_REPARENT,
  			SPEAR320_CONTROL_REG, SMII_PCLK_SHIFT, SMII_PCLK_MASK,
  			0, &_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
322
323
324
325
326
327
  	clk_register_clkdev(clk, NULL, "smii_pclk");
  
  	clk = clk_register_fixed_factor(NULL, "smii_clk", "smii_pclk", 0, 1, 1);
  	clk_register_clkdev(clk, NULL, "smii");
  
  	clk = clk_register_mux(NULL, "uart1_clk", uartx_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
328
329
  			ARRAY_SIZE(uartx_parents),
  			CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
330
331
  			SPEAR320_CONTROL_REG, UART1_PCLK_SHIFT, UART1_PCLK_MASK,
  			0, &_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
332
  	clk_register_clkdev(clk, NULL, "a3000000.serial");
449437778   Thomas Gleixner   clk: spear3xx: Se...
333
334
  	/* Enforce ras_apb_clk */
  	clk_set_parent(clk, ras_apb_clk);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
335
336
  
  	clk = clk_register_mux(NULL, "uart2_clk", uartx_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
337
338
  			ARRAY_SIZE(uartx_parents),
  			CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
339
340
  			SPEAR320_EXT_CTRL_REG, SPEAR320_UART2_PCLK_SHIFT,
  			SPEAR320_UARTX_PCLK_MASK, 0, &_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
341
  	clk_register_clkdev(clk, NULL, "a4000000.serial");
449437778   Thomas Gleixner   clk: spear3xx: Se...
342
343
  	/* Enforce ras_apb_clk */
  	clk_set_parent(clk, ras_apb_clk);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
344
345
  
  	clk = clk_register_mux(NULL, "uart3_clk", uartx_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
346
347
  			ARRAY_SIZE(uartx_parents),
  			CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
348
349
  			SPEAR320_EXT_CTRL_REG, SPEAR320_UART3_PCLK_SHIFT,
  			SPEAR320_UARTX_PCLK_MASK, 0, &_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
350
351
352
  	clk_register_clkdev(clk, NULL, "a9100000.serial");
  
  	clk = clk_register_mux(NULL, "uart4_clk", uartx_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
353
354
  			ARRAY_SIZE(uartx_parents),
  			CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
355
356
  			SPEAR320_EXT_CTRL_REG, SPEAR320_UART4_PCLK_SHIFT,
  			SPEAR320_UARTX_PCLK_MASK, 0, &_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
357
358
359
  	clk_register_clkdev(clk, NULL, "a9200000.serial");
  
  	clk = clk_register_mux(NULL, "uart5_clk", uartx_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
360
361
  			ARRAY_SIZE(uartx_parents),
  			CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
362
363
  			SPEAR320_EXT_CTRL_REG, SPEAR320_UART5_PCLK_SHIFT,
  			SPEAR320_UARTX_PCLK_MASK, 0, &_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
364
365
366
  	clk_register_clkdev(clk, NULL, "60000000.serial");
  
  	clk = clk_register_mux(NULL, "uart6_clk", uartx_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
367
368
  			ARRAY_SIZE(uartx_parents),
  			CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
369
370
  			SPEAR320_EXT_CTRL_REG, SPEAR320_UART6_PCLK_SHIFT,
  			SPEAR320_UARTX_PCLK_MASK, 0, &_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
371
372
  	clk_register_clkdev(clk, NULL, "60100000.serial");
  }
90d4971d3   Axel Lin   clk: spear: Add s...
373
  #else
449437778   Thomas Gleixner   clk: spear3xx: Se...
374
  static inline void spear320_clk_init(void __iomem *sb, struct clk *rc) { }
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
375
  #endif
d9909ebe6   Arnd Bergmann   ARM: spear: make ...
376
  void __init spear3xx_clk_init(void __iomem *misc_base, void __iomem *soc_config_base)
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
377
  {
449437778   Thomas Gleixner   clk: spear3xx: Se...
378
  	struct clk *clk, *clk1, *ras_apb_clk;
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
379

afb4bdc9d   Stephen Boyd   clk: spear: Remov...
380
  	clk = clk_register_fixed_rate(NULL, "osc_32k_clk", NULL, 0, 32000);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
381
  	clk_register_clkdev(clk, "osc_32k_clk", NULL);
afb4bdc9d   Stephen Boyd   clk: spear: Remov...
382
  	clk = clk_register_fixed_rate(NULL, "osc_24m_clk", NULL, 0, 24000000);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
383
384
385
386
387
388
389
390
  	clk_register_clkdev(clk, "osc_24m_clk", NULL);
  
  	/* clock derived from 32 KHz osc clk */
  	clk = clk_register_gate(NULL, "rtc-spear", "osc_32k_clk", 0,
  			PERIP1_CLK_ENB, RTC_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "fc900000.rtc");
  
  	/* clock derived from 24 MHz osc clk */
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
391
  	clk = clk_register_fixed_rate(NULL, "pll3_clk", "osc_24m_clk", 0,
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
392
  			48000000);
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
393
  	clk_register_clkdev(clk, "pll3_clk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
  
  	clk = clk_register_fixed_factor(NULL, "wdt_clk", "osc_24m_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, NULL, "fc880000.wdt");
  
  	clk = clk_register_vco_pll("vco1_clk", "pll1_clk", NULL,
  			"osc_24m_clk", 0, PLL1_CTR, PLL1_FRQ, pll_rtbl,
  			ARRAY_SIZE(pll_rtbl), &_lock, &clk1, NULL);
  	clk_register_clkdev(clk, "vco1_clk", NULL);
  	clk_register_clkdev(clk1, "pll1_clk", NULL);
  
  	clk = clk_register_vco_pll("vco2_clk", "pll2_clk", NULL,
  			"osc_24m_clk", 0, PLL2_CTR, PLL2_FRQ, pll_rtbl,
  			ARRAY_SIZE(pll_rtbl), &_lock, &clk1, NULL);
  	clk_register_clkdev(clk, "vco2_clk", NULL);
  	clk_register_clkdev(clk1, "pll2_clk", NULL);
  
  	/* clock derived from pll1 clk */
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
412
413
  	clk = clk_register_fixed_factor(NULL, "cpu_clk", "pll1_clk",
  			CLK_SET_RATE_PARENT, 1, 1);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
414
415
416
417
418
419
  	clk_register_clkdev(clk, "cpu_clk", NULL);
  
  	clk = clk_register_divider(NULL, "ahb_clk", "pll1_clk",
  			CLK_SET_RATE_PARENT, CORE_CLK_CFG, HCLK_RATIO_SHIFT,
  			HCLK_RATIO_MASK, 0, &_lock);
  	clk_register_clkdev(clk, "ahb_clk", NULL);
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
420
421
422
423
424
  	clk = clk_register_aux("uart_syn_clk", "uart_syn_gclk", "pll1_clk", 0,
  			UART_CLK_SYNT, NULL, aux_rtbl, ARRAY_SIZE(aux_rtbl),
  			&_lock, &clk1);
  	clk_register_clkdev(clk, "uart_syn_clk", NULL);
  	clk_register_clkdev(clk1, "uart_syn_gclk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
425

5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
426
  	clk = clk_register_mux(NULL, "uart0_mclk", uart0_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
427
428
  			ARRAY_SIZE(uart0_parents),
  			CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
429
430
  			PERIP_CLK_CFG, UART_CLK_SHIFT, UART_CLK_MASK, 0,
  			&_lock);
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
431
  	clk_register_clkdev(clk, "uart0_mclk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
432

124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
433
434
435
  	clk = clk_register_gate(NULL, "uart0", "uart0_mclk",
  			CLK_SET_RATE_PARENT, PERIP1_CLK_ENB, UART_CLK_ENB, 0,
  			&_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
436
  	clk_register_clkdev(clk, NULL, "d0000000.serial");
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
437
438
439
440
441
  	clk = clk_register_aux("firda_syn_clk", "firda_syn_gclk", "pll1_clk", 0,
  			FIRDA_CLK_SYNT, NULL, aux_rtbl, ARRAY_SIZE(aux_rtbl),
  			&_lock, &clk1);
  	clk_register_clkdev(clk, "firda_syn_clk", NULL);
  	clk_register_clkdev(clk1, "firda_syn_gclk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
442

5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
443
  	clk = clk_register_mux(NULL, "firda_mclk", firda_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
444
445
  			ARRAY_SIZE(firda_parents),
  			CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
446
447
  			PERIP_CLK_CFG, FIRDA_CLK_SHIFT, FIRDA_CLK_MASK, 0,
  			&_lock);
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
448
  	clk_register_clkdev(clk, "firda_mclk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
449

124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
450
451
452
  	clk = clk_register_gate(NULL, "firda_clk", "firda_mclk",
  			CLK_SET_RATE_PARENT, PERIP1_CLK_ENB, FIRDA_CLK_ENB, 0,
  			&_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
453
454
455
  	clk_register_clkdev(clk, NULL, "firda");
  
  	/* gpt clocks */
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
456
457
  	clk_register_gpt("gpt0_syn_clk", "pll1_clk", 0, PRSC0_CLK_CFG, gpt_rtbl,
  			ARRAY_SIZE(gpt_rtbl), &_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
458
  	clk = clk_register_mux(NULL, "gpt0_clk", gpt0_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
459
460
  			ARRAY_SIZE(gpt0_parents),
  			CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
461
  			PERIP_CLK_CFG, GPT0_CLK_SHIFT, GPT_CLK_MASK, 0, &_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
462
  	clk_register_clkdev(clk, NULL, "gpt0");
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
463
464
465
  	clk_register_gpt("gpt1_syn_clk", "pll1_clk", 0, PRSC1_CLK_CFG, gpt_rtbl,
  			ARRAY_SIZE(gpt_rtbl), &_lock);
  	clk = clk_register_mux(NULL, "gpt1_mclk", gpt1_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
466
467
  			ARRAY_SIZE(gpt1_parents),
  			CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
468
  			PERIP_CLK_CFG, GPT1_CLK_SHIFT, GPT_CLK_MASK, 0, &_lock);
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
469
  	clk_register_clkdev(clk, "gpt1_mclk", NULL);
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
470
471
472
  	clk = clk_register_gate(NULL, "gpt1_clk", "gpt1_mclk",
  			CLK_SET_RATE_PARENT, PERIP1_CLK_ENB, GPT1_CLK_ENB, 0,
  			&_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
473
  	clk_register_clkdev(clk, NULL, "gpt1");
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
474
475
476
  	clk_register_gpt("gpt2_syn_clk", "pll1_clk", 0, PRSC2_CLK_CFG, gpt_rtbl,
  			ARRAY_SIZE(gpt_rtbl), &_lock);
  	clk = clk_register_mux(NULL, "gpt2_mclk", gpt2_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
477
478
  			ARRAY_SIZE(gpt2_parents),
  			CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
479
  			PERIP_CLK_CFG, GPT2_CLK_SHIFT, GPT_CLK_MASK, 0, &_lock);
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
480
  	clk_register_clkdev(clk, "gpt2_mclk", NULL);
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
481
482
483
  	clk = clk_register_gate(NULL, "gpt2_clk", "gpt2_mclk",
  			CLK_SET_RATE_PARENT, PERIP1_CLK_ENB, GPT2_CLK_ENB, 0,
  			&_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
484
485
486
  	clk_register_clkdev(clk, NULL, "gpt2");
  
  	/* general synths clocks */
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
487
488
489
490
491
492
493
494
495
496
497
498
499
  	clk = clk_register_aux("gen0_syn_clk", "gen0_syn_gclk", "pll1_clk",
  			0, GEN0_CLK_SYNT, NULL, aux_rtbl, ARRAY_SIZE(aux_rtbl),
  			&_lock, &clk1);
  	clk_register_clkdev(clk, "gen0_syn_clk", NULL);
  	clk_register_clkdev(clk1, "gen0_syn_gclk", NULL);
  
  	clk = clk_register_aux("gen1_syn_clk", "gen1_syn_gclk", "pll1_clk",
  			0, GEN1_CLK_SYNT, NULL, aux_rtbl, ARRAY_SIZE(aux_rtbl),
  			&_lock, &clk1);
  	clk_register_clkdev(clk, "gen1_syn_clk", NULL);
  	clk_register_clkdev(clk1, "gen1_syn_gclk", NULL);
  
  	clk = clk_register_mux(NULL, "gen2_3_par_clk", gen2_3_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
500
501
502
  			ARRAY_SIZE(gen2_3_parents), CLK_SET_RATE_NO_REPARENT,
  			CORE_CLK_CFG, GEN_SYNTH2_3_CLK_SHIFT,
  			GEN_SYNTH2_3_CLK_MASK, 0, &_lock);
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
503
  	clk_register_clkdev(clk, "gen2_3_par_clk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
504

5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
505
506
  	clk = clk_register_aux("gen2_syn_clk", "gen2_syn_gclk",
  			"gen2_3_par_clk", 0, GEN2_CLK_SYNT, NULL, aux_rtbl,
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
507
  			ARRAY_SIZE(aux_rtbl), &_lock, &clk1);
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
508
509
  	clk_register_clkdev(clk, "gen2_syn_clk", NULL);
  	clk_register_clkdev(clk1, "gen2_syn_gclk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
510

5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
511
512
  	clk = clk_register_aux("gen3_syn_clk", "gen3_syn_gclk",
  			"gen2_3_par_clk", 0, GEN3_CLK_SYNT, NULL, aux_rtbl,
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
513
  			ARRAY_SIZE(aux_rtbl), &_lock, &clk1);
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
514
515
  	clk_register_clkdev(clk, "gen3_syn_clk", NULL);
  	clk_register_clkdev(clk1, "gen3_syn_gclk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
516
517
  
  	/* clock derived from pll3 clk */
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
518
519
  	clk = clk_register_gate(NULL, "usbh_clk", "pll3_clk", 0, PERIP1_CLK_ENB,
  			USBH_CLK_ENB, 0, &_lock);
df2449aba   Rajeev Kumar   CLK: SPEAr: Fix d...
520
521
522
  	clk_register_clkdev(clk, NULL, "e1800000.ehci");
  	clk_register_clkdev(clk, NULL, "e1900000.ohci");
  	clk_register_clkdev(clk, NULL, "e2100000.ohci");
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
523
524
525
526
527
528
529
530
  
  	clk = clk_register_fixed_factor(NULL, "usbh.0_clk", "usbh_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, "usbh.0_clk", NULL);
  
  	clk = clk_register_fixed_factor(NULL, "usbh.1_clk", "usbh_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, "usbh.1_clk", NULL);
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
531
532
  	clk = clk_register_gate(NULL, "usbd_clk", "pll3_clk", 0, PERIP1_CLK_ENB,
  			USBD_CLK_ENB, 0, &_lock);
df2449aba   Rajeev Kumar   CLK: SPEAr: Fix d...
533
  	clk_register_clkdev(clk, NULL, "e1100000.usbd");
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
534
535
536
537
538
539
540
  
  	/* clock derived from ahb clk */
  	clk = clk_register_fixed_factor(NULL, "ahbmult2_clk", "ahb_clk", 0, 2,
  			1);
  	clk_register_clkdev(clk, "ahbmult2_clk", NULL);
  
  	clk = clk_register_mux(NULL, "ddr_clk", ddr_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
541
542
  			ARRAY_SIZE(ddr_parents), CLK_SET_RATE_NO_REPARENT,
  			PLL_CLK_CFG, MCTR_CLK_SHIFT, MCTR_CLK_MASK, 0, &_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
  	clk_register_clkdev(clk, "ddr_clk", NULL);
  
  	clk = clk_register_divider(NULL, "apb_clk", "ahb_clk",
  			CLK_SET_RATE_PARENT, CORE_CLK_CFG, PCLK_RATIO_SHIFT,
  			PCLK_RATIO_MASK, 0, &_lock);
  	clk_register_clkdev(clk, "apb_clk", NULL);
  
  	clk = clk_register_gate(NULL, "amem_clk", "ahb_clk", 0, AMEM_CLK_CFG,
  			AMEM_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, "amem_clk", NULL);
  
  	clk = clk_register_gate(NULL, "c3_clk", "ahb_clk", 0, PERIP1_CLK_ENB,
  			C3_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "c3_clk");
  
  	clk = clk_register_gate(NULL, "dma_clk", "ahb_clk", 0, PERIP1_CLK_ENB,
  			DMA_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "fc400000.dma");
  
  	clk = clk_register_gate(NULL, "gmac_clk", "ahb_clk", 0, PERIP1_CLK_ENB,
  			GMAC_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "e0800000.eth");
  
  	clk = clk_register_gate(NULL, "i2c0_clk", "ahb_clk", 0, PERIP1_CLK_ENB,
  			I2C_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "d0180000.i2c");
  
  	clk = clk_register_gate(NULL, "jpeg_clk", "ahb_clk", 0, PERIP1_CLK_ENB,
  			JPEG_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "jpeg");
  
  	clk = clk_register_gate(NULL, "smi_clk", "ahb_clk", 0, PERIP1_CLK_ENB,
  			SMI_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "fc000000.flash");
  
  	/* clock derived from apb clk */
  	clk = clk_register_gate(NULL, "adc_clk", "apb_clk", 0, PERIP1_CLK_ENB,
  			ADC_CLK_ENB, 0, &_lock);
df2449aba   Rajeev Kumar   CLK: SPEAr: Fix d...
581
  	clk_register_clkdev(clk, NULL, "d0080000.adc");
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
  
  	clk = clk_register_gate(NULL, "gpio0_clk", "apb_clk", 0, PERIP1_CLK_ENB,
  			GPIO_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "fc980000.gpio");
  
  	clk = clk_register_gate(NULL, "ssp0_clk", "apb_clk", 0, PERIP1_CLK_ENB,
  			SSP_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "d0100000.spi");
  
  	/* RAS clk enable */
  	clk = clk_register_gate(NULL, "ras_ahb_clk", "ahb_clk", 0, RAS_CLK_ENB,
  			RAS_AHB_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, "ras_ahb_clk", NULL);
  
  	clk = clk_register_gate(NULL, "ras_apb_clk", "apb_clk", 0, RAS_CLK_ENB,
  			RAS_APB_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, "ras_apb_clk", NULL);
449437778   Thomas Gleixner   clk: spear3xx: Se...
599
  	ras_apb_clk = clk;
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
  
  	clk = clk_register_gate(NULL, "ras_32k_clk", "osc_32k_clk", 0,
  			RAS_CLK_ENB, RAS_32K_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, "ras_32k_clk", NULL);
  
  	clk = clk_register_gate(NULL, "ras_24m_clk", "osc_24m_clk", 0,
  			RAS_CLK_ENB, RAS_24M_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, "ras_24m_clk", NULL);
  
  	clk = clk_register_gate(NULL, "ras_pll1_clk", "pll1_clk", 0,
  			RAS_CLK_ENB, RAS_PLL1_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, "ras_pll1_clk", NULL);
  
  	clk = clk_register_gate(NULL, "ras_pll2_clk", "pll2_clk", 0,
  			RAS_CLK_ENB, RAS_PLL2_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, "ras_pll2_clk", NULL);
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
616
  	clk = clk_register_gate(NULL, "ras_pll3_clk", "pll3_clk", 0,
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
617
  			RAS_CLK_ENB, RAS_48M_CLK_ENB, 0, &_lock);
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
618
  	clk_register_clkdev(clk, "ras_pll3_clk", NULL);
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
619
620
621
  	clk = clk_register_gate(NULL, "ras_syn0_gclk", "gen0_syn_gclk",
  			CLK_SET_RATE_PARENT, RAS_CLK_ENB, RAS_SYNT0_CLK_ENB, 0,
  			&_lock);
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
622
  	clk_register_clkdev(clk, "ras_syn0_gclk", NULL);
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
623
624
625
  	clk = clk_register_gate(NULL, "ras_syn1_gclk", "gen1_syn_gclk",
  			CLK_SET_RATE_PARENT, RAS_CLK_ENB, RAS_SYNT1_CLK_ENB, 0,
  			&_lock);
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
626
  	clk_register_clkdev(clk, "ras_syn1_gclk", NULL);
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
627
628
629
  	clk = clk_register_gate(NULL, "ras_syn2_gclk", "gen2_syn_gclk",
  			CLK_SET_RATE_PARENT, RAS_CLK_ENB, RAS_SYNT2_CLK_ENB, 0,
  			&_lock);
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
630
  	clk_register_clkdev(clk, "ras_syn2_gclk", NULL);
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
631
632
633
  	clk = clk_register_gate(NULL, "ras_syn3_gclk", "gen3_syn_gclk",
  			CLK_SET_RATE_PARENT, RAS_CLK_ENB, RAS_SYNT3_CLK_ENB, 0,
  			&_lock);
5cfc545f5   Vipul Kumar Samar   Clk:spear3xx:Fix:...
634
  	clk_register_clkdev(clk, "ras_syn3_gclk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
635
636
637
638
639
640
  
  	if (of_machine_is_compatible("st,spear300"))
  		spear300_clk_init();
  	else if (of_machine_is_compatible("st,spear310"))
  		spear310_clk_init();
  	else if (of_machine_is_compatible("st,spear320"))
449437778   Thomas Gleixner   clk: spear3xx: Se...
641
  		spear320_clk_init(soc_config_base, ras_apb_clk);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
642
  }