diff options
author | Thomas Abraham <thomas.ab@samsung.com> | 2010-05-16 20:38:34 -0400 |
---|---|---|
committer | Ben Dooks <ben-linux@fluff.org> | 2010-05-16 21:37:35 -0400 |
commit | af76a201c63fd7566bab8892f3b8c82e66a264d0 (patch) | |
tree | e4671770bcd22cea086661fa17b0bbea25975d58 /arch/arm | |
parent | 374e0bf5f9e3b6055a943a838605e411b50c2838 (diff) |
ARM: S5PV210: Remove usage of clk_h200 clock and add clk_hclk_msys clock
The clk_h200 represents the HCLK for the MSYS domain. This clock
is of type 'struct clk' but on V210, it is more suitable to be of
type 'struct clksrc_clk' (since it is a divided version of the
armclk). The replacement clock is renamed as clk_hclk_msys to
indicate that it represents the HCLK for MSYS domain.
This patch modifies the following.
1. Removes the usage of the clk_h200 clock.
2. Adds the new clock 'clk_hclk_msys'.
3. Adds clk_hclk_msys to the list of sysclks to be registered.
4. Modifies the hclk_msys clock rate calculation procedure to
be based on the new clk_hclk_msys clock.
Signed-off-by: Thomas Abraham <thomas.ab@samsung.com>
Signed-off-by: Kukjin Kim <kgene.kim@samsung.com>
Signed-off-by: Ben Dooks <ben-linux@fluff.org>
Diffstat (limited to 'arch/arm')
-rw-r--r-- | arch/arm/mach-s5pv210/clock.c | 28 |
1 files changed, 14 insertions, 14 deletions
diff --git a/arch/arm/mach-s5pv210/clock.c b/arch/arm/mach-s5pv210/clock.c index f57fa1ee6ff0..d5acd261795c 100644 --- a/arch/arm/mach-s5pv210/clock.c +++ b/arch/arm/mach-s5pv210/clock.c | |||
@@ -78,6 +78,15 @@ static struct clksrc_clk clk_armclk = { | |||
78 | .reg_div = { .reg = S5P_CLK_DIV0, .shift = 0, .size = 3 }, | 78 | .reg_div = { .reg = S5P_CLK_DIV0, .shift = 0, .size = 3 }, |
79 | }; | 79 | }; |
80 | 80 | ||
81 | static struct clksrc_clk clk_hclk_msys = { | ||
82 | .clk = { | ||
83 | .name = "hclk_msys", | ||
84 | .id = -1, | ||
85 | .parent = &clk_armclk.clk, | ||
86 | }, | ||
87 | .reg_div = { .reg = S5P_CLK_DIV0, .shift = 8, .size = 3 }, | ||
88 | }; | ||
89 | |||
81 | static int s5pv210_clk_ip0_ctrl(struct clk *clk, int enable) | 90 | static int s5pv210_clk_ip0_ctrl(struct clk *clk, int enable) |
82 | { | 91 | { |
83 | return s5p_gatectrl(S5P_CLKGATE_IP0, clk, enable); | 92 | return s5p_gatectrl(S5P_CLKGATE_IP0, clk, enable); |
@@ -98,11 +107,6 @@ static int s5pv210_clk_ip3_ctrl(struct clk *clk, int enable) | |||
98 | return s5p_gatectrl(S5P_CLKGATE_IP3, clk, enable); | 107 | return s5p_gatectrl(S5P_CLKGATE_IP3, clk, enable); |
99 | } | 108 | } |
100 | 109 | ||
101 | static struct clk clk_h200 = { | ||
102 | .name = "hclk200", | ||
103 | .id = -1, | ||
104 | }; | ||
105 | |||
106 | static struct clk clk_h100 = { | 110 | static struct clk clk_h100 = { |
107 | .name = "hclk100", | 111 | .name = "hclk100", |
108 | .id = -1, | 112 | .id = -1, |
@@ -134,7 +138,6 @@ static struct clk clk_p66 = { | |||
134 | }; | 138 | }; |
135 | 139 | ||
136 | static struct clk *sys_clks[] = { | 140 | static struct clk *sys_clks[] = { |
137 | &clk_h200, | ||
138 | &clk_h100, | 141 | &clk_h100, |
139 | &clk_h166, | 142 | &clk_h166, |
140 | &clk_h133, | 143 | &clk_h133, |
@@ -349,6 +352,7 @@ static struct clksrc_clk *sysclks[] = { | |||
349 | &clk_mout_epll, | 352 | &clk_mout_epll, |
350 | &clk_mout_mpll, | 353 | &clk_mout_mpll, |
351 | &clk_armclk, | 354 | &clk_armclk, |
355 | &clk_hclk_msys, | ||
352 | }; | 356 | }; |
353 | 357 | ||
354 | #define GET_DIV(clk, field) ((((clk) & field##_MASK) >> field##_SHIFT) + 1) | 358 | #define GET_DIV(clk, field) ((((clk) & field##_MASK) >> field##_SHIFT) + 1) |
@@ -358,7 +362,7 @@ void __init_or_cpufreq s5pv210_setup_clocks(void) | |||
358 | struct clk *xtal_clk; | 362 | struct clk *xtal_clk; |
359 | unsigned long xtal; | 363 | unsigned long xtal; |
360 | unsigned long armclk; | 364 | unsigned long armclk; |
361 | unsigned long hclk200; | 365 | unsigned long hclk_msys; |
362 | unsigned long hclk166; | 366 | unsigned long hclk166; |
363 | unsigned long hclk133; | 367 | unsigned long hclk133; |
364 | unsigned long pclk100; | 368 | unsigned long pclk100; |
@@ -398,10 +402,7 @@ void __init_or_cpufreq s5pv210_setup_clocks(void) | |||
398 | apll, mpll, epll); | 402 | apll, mpll, epll); |
399 | 403 | ||
400 | armclk = clk_get_rate(&clk_armclk.clk); | 404 | armclk = clk_get_rate(&clk_armclk.clk); |
401 | if (__raw_readl(S5P_CLK_SRC0) & S5P_CLKSRC0_MUX200_MASK) | 405 | hclk_msys = clk_get_rate(&clk_hclk_msys.clk); |
402 | hclk200 = mpll / GET_DIV(clkdiv0, S5P_CLKDIV0_HCLK200); | ||
403 | else | ||
404 | hclk200 = armclk / GET_DIV(clkdiv0, S5P_CLKDIV0_HCLK200); | ||
405 | 406 | ||
406 | if (__raw_readl(S5P_CLK_SRC0) & S5P_CLKSRC0_MUX166_MASK) { | 407 | if (__raw_readl(S5P_CLK_SRC0) & S5P_CLKSRC0_MUX166_MASK) { |
407 | hclk166 = apll / GET_DIV(clkdiv0, S5P_CLKDIV0_A2M); | 408 | hclk166 = apll / GET_DIV(clkdiv0, S5P_CLKDIV0_A2M); |
@@ -415,13 +416,13 @@ void __init_or_cpufreq s5pv210_setup_clocks(void) | |||
415 | } else | 416 | } else |
416 | hclk133 = mpll / GET_DIV(clkdiv0, S5P_CLKDIV0_HCLK133); | 417 | hclk133 = mpll / GET_DIV(clkdiv0, S5P_CLKDIV0_HCLK133); |
417 | 418 | ||
418 | pclk100 = hclk200 / GET_DIV(clkdiv0, S5P_CLKDIV0_PCLK100); | 419 | pclk100 = hclk_msys / GET_DIV(clkdiv0, S5P_CLKDIV0_PCLK100); |
419 | pclk83 = hclk166 / GET_DIV(clkdiv0, S5P_CLKDIV0_PCLK83); | 420 | pclk83 = hclk166 / GET_DIV(clkdiv0, S5P_CLKDIV0_PCLK83); |
420 | pclk66 = hclk133 / GET_DIV(clkdiv0, S5P_CLKDIV0_PCLK66); | 421 | pclk66 = hclk133 / GET_DIV(clkdiv0, S5P_CLKDIV0_PCLK66); |
421 | 422 | ||
422 | printk(KERN_INFO "S5PV210: ARMCLK=%ld, HCLKM=%ld, HCLKD=%ld, \ | 423 | printk(KERN_INFO "S5PV210: ARMCLK=%ld, HCLKM=%ld, HCLKD=%ld, \ |
423 | HCLKP=%ld, PCLKM=%ld, PCLKD=%ld, PCLKP=%ld\n", | 424 | HCLKP=%ld, PCLKM=%ld, PCLKD=%ld, PCLKP=%ld\n", |
424 | armclk, hclk200, hclk166, hclk133, pclk100, pclk83, pclk66); | 425 | armclk, hclk_msys, hclk166, hclk133, pclk100, pclk83, pclk66); |
425 | 426 | ||
426 | clk_f.rate = armclk; | 427 | clk_f.rate = armclk; |
427 | clk_h.rate = hclk133; | 428 | clk_h.rate = hclk133; |
@@ -430,7 +431,6 @@ void __init_or_cpufreq s5pv210_setup_clocks(void) | |||
430 | clk_p83.rate = pclk83; | 431 | clk_p83.rate = pclk83; |
431 | clk_h133.rate = hclk133; | 432 | clk_h133.rate = hclk133; |
432 | clk_h166.rate = hclk166; | 433 | clk_h166.rate = hclk166; |
433 | clk_h200.rate = hclk200; | ||
434 | 434 | ||
435 | for (ptr = 0; ptr < ARRAY_SIZE(clksrcs); ptr++) | 435 | for (ptr = 0; ptr < ARRAY_SIZE(clksrcs); ptr++) |
436 | s3c_set_clksrc(&clksrcs[ptr], true); | 436 | s3c_set_clksrc(&clksrcs[ptr], true); |