diff options
Diffstat (limited to 'arch/arm/mach-spear3xx')
-rw-r--r-- | arch/arm/mach-spear3xx/clock.c | 66 |
1 files changed, 58 insertions, 8 deletions
diff --git a/arch/arm/mach-spear3xx/clock.c b/arch/arm/mach-spear3xx/clock.c index 18febf92f20a..7ea8749ddf28 100644 --- a/arch/arm/mach-spear3xx/clock.c +++ b/arch/arm/mach-spear3xx/clock.c | |||
@@ -39,10 +39,25 @@ static struct clk rtc_clk = { | |||
39 | }; | 39 | }; |
40 | 40 | ||
41 | /* clock derived from 24 MHz osc clk */ | 41 | /* clock derived from 24 MHz osc clk */ |
42 | /* pll masks structure */ | ||
43 | static struct pll_clk_masks pll1_masks = { | ||
44 | .mode_mask = PLL_MODE_MASK, | ||
45 | .mode_shift = PLL_MODE_SHIFT, | ||
46 | .norm_fdbk_m_mask = PLL_NORM_FDBK_M_MASK, | ||
47 | .norm_fdbk_m_shift = PLL_NORM_FDBK_M_SHIFT, | ||
48 | .dith_fdbk_m_mask = PLL_DITH_FDBK_M_MASK, | ||
49 | .dith_fdbk_m_shift = PLL_DITH_FDBK_M_SHIFT, | ||
50 | .div_p_mask = PLL_DIV_P_MASK, | ||
51 | .div_p_shift = PLL_DIV_P_SHIFT, | ||
52 | .div_n_mask = PLL_DIV_N_MASK, | ||
53 | .div_n_shift = PLL_DIV_N_SHIFT, | ||
54 | }; | ||
55 | |||
42 | /* pll1 configuration structure */ | 56 | /* pll1 configuration structure */ |
43 | static struct pll_clk_config pll1_config = { | 57 | static struct pll_clk_config pll1_config = { |
44 | .mode_reg = PLL1_CTR, | 58 | .mode_reg = PLL1_CTR, |
45 | .cfg_reg = PLL1_FRQ, | 59 | .cfg_reg = PLL1_FRQ, |
60 | .masks = &pll1_masks, | ||
46 | }; | 61 | }; |
47 | 62 | ||
48 | /* PLL1 clock */ | 63 | /* PLL1 clock */ |
@@ -50,7 +65,7 @@ static struct clk pll1_clk = { | |||
50 | .pclk = &osc_24m_clk, | 65 | .pclk = &osc_24m_clk, |
51 | .en_reg = PLL1_CTR, | 66 | .en_reg = PLL1_CTR, |
52 | .en_reg_bit = PLL_ENABLE, | 67 | .en_reg_bit = PLL_ENABLE, |
53 | .recalc = &pll1_clk_recalc, | 68 | .recalc = &pll_clk_recalc, |
54 | .private_data = &pll1_config, | 69 | .private_data = &pll1_config, |
55 | }; | 70 | }; |
56 | 71 | ||
@@ -76,11 +91,16 @@ static struct clk cpu_clk = { | |||
76 | .recalc = &follow_parent, | 91 | .recalc = &follow_parent, |
77 | }; | 92 | }; |
78 | 93 | ||
94 | /* ahb masks structure */ | ||
95 | static struct bus_clk_masks ahb_masks = { | ||
96 | .mask = PLL_HCLK_RATIO_MASK, | ||
97 | .shift = PLL_HCLK_RATIO_SHIFT, | ||
98 | }; | ||
99 | |||
79 | /* ahb configuration structure */ | 100 | /* ahb configuration structure */ |
80 | static struct bus_clk_config ahb_config = { | 101 | static struct bus_clk_config ahb_config = { |
81 | .reg = CORE_CLK_CFG, | 102 | .reg = CORE_CLK_CFG, |
82 | .mask = PLL_HCLK_RATIO_MASK, | 103 | .masks = &ahb_masks, |
83 | .shift = PLL_HCLK_RATIO_SHIFT, | ||
84 | }; | 104 | }; |
85 | 105 | ||
86 | /* ahb clock */ | 106 | /* ahb clock */ |
@@ -91,9 +111,22 @@ static struct clk ahb_clk = { | |||
91 | .private_data = &ahb_config, | 111 | .private_data = &ahb_config, |
92 | }; | 112 | }; |
93 | 113 | ||
114 | /* auxiliary synthesizers masks */ | ||
115 | static struct aux_clk_masks aux_masks = { | ||
116 | .eq_sel_mask = AUX_EQ_SEL_MASK, | ||
117 | .eq_sel_shift = AUX_EQ_SEL_SHIFT, | ||
118 | .eq1_mask = AUX_EQ1_SEL, | ||
119 | .eq2_mask = AUX_EQ2_SEL, | ||
120 | .xscale_sel_mask = AUX_XSCALE_MASK, | ||
121 | .xscale_sel_shift = AUX_XSCALE_SHIFT, | ||
122 | .yscale_sel_mask = AUX_YSCALE_MASK, | ||
123 | .yscale_sel_shift = AUX_YSCALE_SHIFT, | ||
124 | }; | ||
125 | |||
94 | /* uart configurations */ | 126 | /* uart configurations */ |
95 | static struct aux_clk_config uart_config = { | 127 | static struct aux_clk_config uart_config = { |
96 | .synth_reg = UART_CLK_SYNT, | 128 | .synth_reg = UART_CLK_SYNT, |
129 | .masks = &aux_masks, | ||
97 | }; | 130 | }; |
98 | 131 | ||
99 | /* uart parents */ | 132 | /* uart parents */ |
@@ -130,6 +163,7 @@ static struct clk uart_clk = { | |||
130 | /* firda configurations */ | 163 | /* firda configurations */ |
131 | static struct aux_clk_config firda_config = { | 164 | static struct aux_clk_config firda_config = { |
132 | .synth_reg = FIRDA_CLK_SYNT, | 165 | .synth_reg = FIRDA_CLK_SYNT, |
166 | .masks = &aux_masks, | ||
133 | }; | 167 | }; |
134 | 168 | ||
135 | /* firda parents */ | 169 | /* firda parents */ |
@@ -184,9 +218,18 @@ static struct pclk_sel gpt_pclk_sel = { | |||
184 | .pclk_sel_mask = GPT_CLK_MASK, | 218 | .pclk_sel_mask = GPT_CLK_MASK, |
185 | }; | 219 | }; |
186 | 220 | ||
221 | /* gpt synthesizer masks */ | ||
222 | static struct gpt_clk_masks gpt_masks = { | ||
223 | .mscale_sel_mask = GPT_MSCALE_MASK, | ||
224 | .mscale_sel_shift = GPT_MSCALE_SHIFT, | ||
225 | .nscale_sel_mask = GPT_NSCALE_MASK, | ||
226 | .nscale_sel_shift = GPT_NSCALE_SHIFT, | ||
227 | }; | ||
228 | |||
187 | /* gpt0 configurations */ | 229 | /* gpt0 configurations */ |
188 | static struct aux_clk_config gpt0_config = { | 230 | static struct gpt_clk_config gpt0_config = { |
189 | .synth_reg = PRSC1_CLK_CFG, | 231 | .synth_reg = PRSC1_CLK_CFG, |
232 | .masks = &gpt_masks, | ||
190 | }; | 233 | }; |
191 | 234 | ||
192 | /* gpt0 timer clock */ | 235 | /* gpt0 timer clock */ |
@@ -199,8 +242,9 @@ static struct clk gpt0_clk = { | |||
199 | }; | 242 | }; |
200 | 243 | ||
201 | /* gpt1 configurations */ | 244 | /* gpt1 configurations */ |
202 | static struct aux_clk_config gpt1_config = { | 245 | static struct gpt_clk_config gpt1_config = { |
203 | .synth_reg = PRSC2_CLK_CFG, | 246 | .synth_reg = PRSC2_CLK_CFG, |
247 | .masks = &gpt_masks, | ||
204 | }; | 248 | }; |
205 | 249 | ||
206 | /* gpt1 timer clock */ | 250 | /* gpt1 timer clock */ |
@@ -214,8 +258,9 @@ static struct clk gpt1_clk = { | |||
214 | }; | 258 | }; |
215 | 259 | ||
216 | /* gpt2 configurations */ | 260 | /* gpt2 configurations */ |
217 | static struct aux_clk_config gpt2_config = { | 261 | static struct gpt_clk_config gpt2_config = { |
218 | .synth_reg = PRSC3_CLK_CFG, | 262 | .synth_reg = PRSC3_CLK_CFG, |
263 | .masks = &gpt_masks, | ||
219 | }; | 264 | }; |
220 | 265 | ||
221 | /* gpt2 timer clock */ | 266 | /* gpt2 timer clock */ |
@@ -253,11 +298,16 @@ static struct clk clcd_clk = { | |||
253 | }; | 298 | }; |
254 | 299 | ||
255 | /* clock derived from ahb clk */ | 300 | /* clock derived from ahb clk */ |
301 | /* apb masks structure */ | ||
302 | static struct bus_clk_masks apb_masks = { | ||
303 | .mask = HCLK_PCLK_RATIO_MASK, | ||
304 | .shift = HCLK_PCLK_RATIO_SHIFT, | ||
305 | }; | ||
306 | |||
256 | /* apb configuration structure */ | 307 | /* apb configuration structure */ |
257 | static struct bus_clk_config apb_config = { | 308 | static struct bus_clk_config apb_config = { |
258 | .reg = CORE_CLK_CFG, | 309 | .reg = CORE_CLK_CFG, |
259 | .mask = HCLK_PCLK_RATIO_MASK, | 310 | .masks = &apb_masks, |
260 | .shift = HCLK_PCLK_RATIO_SHIFT, | ||
261 | }; | 311 | }; |
262 | 312 | ||
263 | /* apb clock */ | 313 | /* apb clock */ |