Blame view

drivers/clk/spear/spear6xx_clock.c 12.1 KB
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
1
2
3
4
  /*
   * SPEAr6xx 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
   *
   * 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.
   */
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
11
12
13
  #include <linux/clkdev.h>
  #include <linux/io.h>
  #include <linux/spinlock_types.h>
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
14
15
16
  #include "clk.h"
  
  static DEFINE_SPINLOCK(_lock);
d9909ebe6   Arnd Bergmann   ARM: spear: make ...
17
18
19
20
21
  #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 ...
22
23
24
  	/* PLL_CLK_CFG register masks */
  	#define MCTR_CLK_SHIFT		28
  	#define MCTR_CLK_MASK		3
d9909ebe6   Arnd Bergmann   ARM: spear: make ...
25
  #define CORE_CLK_CFG			(misc_base + 0x024)
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
26
27
28
29
30
  	/* CORE CLK CFG register masks */
  	#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 ...
31
  #define PERIP_CLK_CFG			(misc_base + 0x028)
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
32
33
34
35
36
37
38
39
40
41
42
43
  	/* PERIP_CLK_CFG register masks */
  	#define CLCD_CLK_SHIFT		2
  	#define CLCD_CLK_MASK		2
  	#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		10
  	#define GPT2_CLK_SHIFT		11
  	#define GPT3_CLK_SHIFT		12
  	#define GPT_CLK_MASK		1
d9909ebe6   Arnd Bergmann   ARM: spear: make ...
44
  #define PERIP1_CLK_ENB			(misc_base + 0x02C)
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
  	/* PERIP1_CLK_ENB register masks */
  	#define UART0_CLK_ENB		3
  	#define UART1_CLK_ENB		4
  	#define SSP0_CLK_ENB		5
  	#define SSP1_CLK_ENB		6
  	#define I2C_CLK_ENB		7
  	#define JPEG_CLK_ENB		8
  	#define FSMC_CLK_ENB		9
  	#define FIRDA_CLK_ENB		10
  	#define GPT2_CLK_ENB		11
  	#define GPT3_CLK_ENB		12
  	#define GPIO2_CLK_ENB		13
  	#define SSP2_CLK_ENB		14
  	#define ADC_CLK_ENB		15
  	#define GPT1_CLK_ENB		11
  	#define RTC_CLK_ENB		17
  	#define GPIO1_CLK_ENB		18
  	#define DMA_CLK_ENB		19
  	#define SMI_CLK_ENB		21
  	#define CLCD_CLK_ENB		22
  	#define GMAC_CLK_ENB		23
  	#define USBD_CLK_ENB		24
  	#define USBH0_CLK_ENB		25
  	#define USBH1_CLK_ENB		26
d9909ebe6   Arnd Bergmann   ARM: spear: make ...
69
70
71
  #define PRSC0_CLK_CFG			(misc_base + 0x044)
  #define PRSC1_CLK_CFG			(misc_base + 0x048)
  #define PRSC2_CLK_CFG			(misc_base + 0x04C)
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
72

d9909ebe6   Arnd Bergmann   ARM: spear: make ...
73
74
75
  #define CLCD_CLK_SYNT			(misc_base + 0x05C)
  #define FIRDA_CLK_SYNT			(misc_base + 0x060)
  #define UART_CLK_SYNT			(misc_base + 0x064)
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
76
77
78
79
80
81
82
83
84
85
86
  
  /* vco rate configuration table, in ascending order of rates */
  static struct pll_rate_tbl pll_rtbl[] = {
  	{.mode = 0, .m = 0x53, .n = 0x0F, .p = 0x1}, /* vco 332 & pll 166 MHz */
  	{.mode = 0, .m = 0x85, .n = 0x0F, .p = 0x1}, /* vco 532 & pll 266 MHz */
  	{.mode = 0, .m = 0xA6, .n = 0x0F, .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...
87
  	{.xscale = 2, .yscale = 27, .eq = 0}, /* 12.296 MHz */
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
88
89
90
91
  	{.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 */
  };
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
92
93
94
95
96
97
  static const char *clcd_parents[] = { "pll3_clk", "clcd_syn_gclk", };
  static const char *firda_parents[] = { "pll3_clk", "firda_syn_gclk", };
  static const char *uart_parents[] = { "pll3_clk", "uart_syn_gclk", };
  static const char *gpt0_1_parents[] = { "pll3_clk", "gpt0_1_syn_clk", };
  static const char *gpt2_parents[] = { "pll3_clk", "gpt2_syn_clk", };
  static const char *gpt3_parents[] = { "pll3_clk", "gpt3_syn_clk", };
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
98
99
100
101
102
103
104
105
106
107
  static const char *ddr_parents[] = { "ahb_clk", "ahbmult2_clk", "none",
  	"pll2_clk", };
  
  /* 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 */
  };
d9909ebe6   Arnd Bergmann   ARM: spear: make ...
108
  void __init spear6xx_clk_init(void __iomem *misc_base)
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
109
110
  {
  	struct clk *clk, *clk1;
afb4bdc9d   Stephen Boyd   clk: spear: Remov...
111
  	clk = clk_register_fixed_rate(NULL, "osc_32k_clk", NULL, 0, 32000);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
112
  	clk_register_clkdev(clk, "osc_32k_clk", NULL);
afb4bdc9d   Stephen Boyd   clk: spear: Remov...
113
  	clk = clk_register_fixed_rate(NULL, "osc_30m_clk", NULL, 0, 30000000);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
114
115
116
117
118
119
120
121
  	clk_register_clkdev(clk, "osc_30m_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, "rtc-spear");
  
  	/* clock derived from 30 MHz osc clk */
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
122
  	clk = clk_register_fixed_rate(NULL, "pll3_clk", "osc_24m_clk", 0,
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
123
  			48000000);
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
124
  	clk_register_clkdev(clk, "pll3_clk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
125
126
127
128
129
130
  
  	clk = clk_register_vco_pll("vco1_clk", "pll1_clk", NULL, "osc_30m_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);
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
131
132
133
  	clk = clk_register_vco_pll("vco2_clk", "pll2_clk", NULL, "osc_30m_clk",
  			0, PLL2_CTR, PLL2_FRQ, pll_rtbl, ARRAY_SIZE(pll_rtbl),
  			&_lock, &clk1, NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
134
135
136
137
138
139
140
141
  	clk_register_clkdev(clk, "vco2_clk", NULL);
  	clk_register_clkdev(clk1, "pll2_clk", NULL);
  
  	clk = clk_register_fixed_factor(NULL, "wdt_clk", "osc_30m_clk", 0, 1,
  			1);
  	clk_register_clkdev(clk, NULL, "wdt");
  
  	/* clock derived from pll1 clk */
124997924   Vipul Kumar Samar   CLK: SPEAr: Set C...
142
143
  	clk = clk_register_fixed_factor(NULL, "cpu_clk", "pll1_clk",
  			CLK_SET_RATE_PARENT, 1, 1);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
144
145
146
147
148
149
  	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);
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
150
151
152
153
154
  	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 ...
155

a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
156
  	clk = clk_register_mux(NULL, "uart_mclk", uart_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
157
158
159
  			ARRAY_SIZE(uart_parents), CLK_SET_RATE_NO_REPARENT,
  			PERIP_CLK_CFG, UART_CLK_SHIFT, UART_CLK_MASK, 0,
  			&_lock);
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
160
  	clk_register_clkdev(clk, "uart_mclk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
161

a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
162
163
  	clk = clk_register_gate(NULL, "uart0", "uart_mclk", 0, PERIP1_CLK_ENB,
  			UART0_CLK_ENB, 0, &_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
164
  	clk_register_clkdev(clk, NULL, "d0000000.serial");
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
165
166
  	clk = clk_register_gate(NULL, "uart1", "uart_mclk", 0, PERIP1_CLK_ENB,
  			UART1_CLK_ENB, 0, &_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
167
  	clk_register_clkdev(clk, NULL, "d0080000.serial");
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
168
169
170
171
172
  	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 ...
173

a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
174
  	clk = clk_register_mux(NULL, "firda_mclk", firda_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
175
176
177
  			ARRAY_SIZE(firda_parents), CLK_SET_RATE_NO_REPARENT,
  			PERIP_CLK_CFG, FIRDA_CLK_SHIFT, FIRDA_CLK_MASK, 0,
  			&_lock);
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
178
  	clk_register_clkdev(clk, "firda_mclk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
179

a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
180
  	clk = clk_register_gate(NULL, "firda_clk", "firda_mclk", 0,
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
181
182
  			PERIP1_CLK_ENB, FIRDA_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "firda");
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
183
184
185
186
187
  	clk = clk_register_aux("clcd_syn_clk", "clcd_syn_gclk", "pll1_clk",
  			0, CLCD_CLK_SYNT, NULL, aux_rtbl, ARRAY_SIZE(aux_rtbl),
  			&_lock, &clk1);
  	clk_register_clkdev(clk, "clcd_syn_clk", NULL);
  	clk_register_clkdev(clk1, "clcd_syn_gclk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
188

a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
189
  	clk = clk_register_mux(NULL, "clcd_mclk", clcd_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
190
191
192
  			ARRAY_SIZE(clcd_parents), CLK_SET_RATE_NO_REPARENT,
  			PERIP_CLK_CFG, CLCD_CLK_SHIFT, CLCD_CLK_MASK, 0,
  			&_lock);
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
193
  	clk_register_clkdev(clk, "clcd_mclk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
194

a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
195
  	clk = clk_register_gate(NULL, "clcd_clk", "clcd_mclk", 0,
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
196
197
198
199
  			PERIP1_CLK_ENB, CLCD_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "clcd");
  
  	/* gpt clocks */
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
200
  	clk = clk_register_gpt("gpt0_1_syn_clk", "pll1_clk", 0, PRSC0_CLK_CFG,
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
201
  			gpt_rtbl, ARRAY_SIZE(gpt_rtbl), &_lock);
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
202
  	clk_register_clkdev(clk, "gpt0_1_syn_clk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
203

a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
204
  	clk = clk_register_mux(NULL, "gpt0_mclk", gpt0_1_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
205
206
  			ARRAY_SIZE(gpt0_1_parents), CLK_SET_RATE_NO_REPARENT,
  			PERIP_CLK_CFG, GPT0_CLK_SHIFT, GPT_CLK_MASK, 0, &_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
207
  	clk_register_clkdev(clk, NULL, "gpt0");
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
208
  	clk = clk_register_mux(NULL, "gpt1_mclk", gpt0_1_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
209
210
  			ARRAY_SIZE(gpt0_1_parents), CLK_SET_RATE_NO_REPARENT,
  			PERIP_CLK_CFG, GPT1_CLK_SHIFT, GPT_CLK_MASK, 0, &_lock);
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
211
  	clk_register_clkdev(clk, "gpt1_mclk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
212

a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
213
  	clk = clk_register_gate(NULL, "gpt1_clk", "gpt1_mclk", 0,
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
214
215
  			PERIP1_CLK_ENB, GPT1_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "gpt1");
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
216
  	clk = clk_register_gpt("gpt2_syn_clk", "pll1_clk", 0, PRSC1_CLK_CFG,
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
217
  			gpt_rtbl, ARRAY_SIZE(gpt_rtbl), &_lock);
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
218
  	clk_register_clkdev(clk, "gpt2_syn_clk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
219

a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
220
  	clk = clk_register_mux(NULL, "gpt2_mclk", gpt2_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
221
222
  			ARRAY_SIZE(gpt2_parents), CLK_SET_RATE_NO_REPARENT,
  			PERIP_CLK_CFG, GPT2_CLK_SHIFT, GPT_CLK_MASK, 0, &_lock);
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
223
  	clk_register_clkdev(clk, "gpt2_mclk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
224

a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
225
  	clk = clk_register_gate(NULL, "gpt2_clk", "gpt2_mclk", 0,
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
226
227
  			PERIP1_CLK_ENB, GPT2_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "gpt2");
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
228
  	clk = clk_register_gpt("gpt3_syn_clk", "pll1_clk", 0, PRSC2_CLK_CFG,
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
229
  			gpt_rtbl, ARRAY_SIZE(gpt_rtbl), &_lock);
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
230
  	clk_register_clkdev(clk, "gpt3_syn_clk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
231

a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
232
  	clk = clk_register_mux(NULL, "gpt3_mclk", gpt3_parents,
819c1de34   James Hogan   clk: add CLK_SET_...
233
234
  			ARRAY_SIZE(gpt3_parents), CLK_SET_RATE_NO_REPARENT,
  			PERIP_CLK_CFG, GPT3_CLK_SHIFT, GPT_CLK_MASK, 0, &_lock);
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
235
  	clk_register_clkdev(clk, "gpt3_mclk", NULL);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
236

a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
237
  	clk = clk_register_gate(NULL, "gpt3_clk", "gpt3_mclk", 0,
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
238
239
240
241
  			PERIP1_CLK_ENB, GPT3_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "gpt3");
  
  	/* clock derived from pll3 clk */
a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
242
  	clk = clk_register_gate(NULL, "usbh0_clk", "pll3_clk", 0,
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
243
  			PERIP1_CLK_ENB, USBH0_CLK_ENB, 0, &_lock);
df2449aba   Rajeev Kumar   CLK: SPEAr: Fix d...
244
245
  	clk_register_clkdev(clk, NULL, "e1800000.ehci");
  	clk_register_clkdev(clk, NULL, "e1900000.ohci");
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
246

a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
247
  	clk = clk_register_gate(NULL, "usbh1_clk", "pll3_clk", 0,
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
248
  			PERIP1_CLK_ENB, USBH1_CLK_ENB, 0, &_lock);
df2449aba   Rajeev Kumar   CLK: SPEAr: Fix d...
249
250
  	clk_register_clkdev(clk, NULL, "e2000000.ehci");
  	clk_register_clkdev(clk, NULL, "e2100000.ohci");
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
251

a8f4bf0eb   Vipul Kumar Samar   Clk:spear6xx:Fix:...
252
253
  	clk = clk_register_gate(NULL, "usbd_clk", "pll3_clk", 0, PERIP1_CLK_ENB,
  			USBD_CLK_ENB, 0, &_lock);
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
254
255
256
257
258
259
260
261
  	clk_register_clkdev(clk, NULL, "designware_udc");
  
  	/* 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_...
262
263
  			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 ...
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
  	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, "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, "fsmc_clk", "ahb_clk", 0, PERIP1_CLK_ENB,
  			FSMC_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "d1800000.flash");
  
  	clk = clk_register_gate(NULL, "gmac_clk", "ahb_clk", 0, PERIP1_CLK_ENB,
  			GMAC_CLK_ENB, 0, &_lock);
3a35fc3a1   Stefan Roese   clk: SPEAr600: Fi...
281
  	clk_register_clkdev(clk, NULL, "e0800000.ethernet");
5df33a62c   Viresh Kumar   SPEAr: Switch to ...
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
  
  	clk = clk_register_gate(NULL, "i2c_clk", "ahb_clk", 0, PERIP1_CLK_ENB,
  			I2C_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "d0200000.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);
  	clk_register_clkdev(clk, NULL, "adc");
  
  	clk = clk_register_fixed_factor(NULL, "gpio0_clk", "apb_clk", 0, 1, 1);
  	clk_register_clkdev(clk, NULL, "f0100000.gpio");
  
  	clk = clk_register_gate(NULL, "gpio1_clk", "apb_clk", 0, PERIP1_CLK_ENB,
  			GPIO1_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "fc980000.gpio");
  
  	clk = clk_register_gate(NULL, "gpio2_clk", "apb_clk", 0, PERIP1_CLK_ENB,
  			GPIO2_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "d8100000.gpio");
  
  	clk = clk_register_gate(NULL, "ssp0_clk", "apb_clk", 0, PERIP1_CLK_ENB,
  			SSP0_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "ssp-pl022.0");
  
  	clk = clk_register_gate(NULL, "ssp1_clk", "apb_clk", 0, PERIP1_CLK_ENB,
  			SSP1_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "ssp-pl022.1");
  
  	clk = clk_register_gate(NULL, "ssp2_clk", "apb_clk", 0, PERIP1_CLK_ENB,
  			SSP2_CLK_ENB, 0, &_lock);
  	clk_register_clkdev(clk, NULL, "ssp-pl022.2");
  }