diff options
author | Sylwester Nawrocki <s.nawrocki@samsung.com> | 2013-04-08 02:24:47 -0400 |
---|---|---|
committer | Kukjin Kim <kgene.kim@samsung.com> | 2013-04-08 10:43:54 -0400 |
commit | cdbf618ab8a326cb3bdc65e8adb74bac9c347e64 (patch) | |
tree | 36eb7164c6746ec817b77927d27d0851c73ebbac | |
parent | 6cec90826e9a3e505c9df91a62de59078f521dd3 (diff) |
clk: exynos4: export clocks required for fimc-is
This patch adds clock indexes for ACLK_DIV0, ACLK_DIV1,
ACLK_400_MCUISP, ACLK_MCUISP_DIV0, ACLK_MCUISP_DIV1,
DIVACLK_400_MCUISP and DIVACLK_200 so these clocks are
available to the consumers (Exynos4x12 FIMC-IS subsystem).
While at it, indentation of the mux clocks table is
corrected.
Signed-off-by: Sylwester Nawrocki <s.nawrocki@samsung.com>
Signed-off-by: Kyungmin Park <kyungmin.park@samsung.com>
Acked-by: Mike Turquette <mturquette@linaro.org>
Signed-off-by: Kukjin Kim <kgene.kim@samsung.com>
-rw-r--r-- | Documentation/devicetree/bindings/clock/exynos4-clock.txt | 42 | ||||
-rw-r--r-- | drivers/clk/samsung/clk-exynos4.c | 20 |
2 files changed, 41 insertions, 21 deletions
diff --git a/Documentation/devicetree/bindings/clock/exynos4-clock.txt b/Documentation/devicetree/bindings/clock/exynos4-clock.txt index 662007e059dc..ea5e26f16aec 100644 --- a/Documentation/devicetree/bindings/clock/exynos4-clock.txt +++ b/Documentation/devicetree/bindings/clock/exynos4-clock.txt | |||
@@ -236,22 +236,36 @@ Exynos4 SoC and this is specified where applicable. | |||
236 | spi1_isp_sclk 381 Exynos4x12 | 236 | spi1_isp_sclk 381 Exynos4x12 |
237 | uart_isp_sclk 382 Exynos4x12 | 237 | uart_isp_sclk 382 Exynos4x12 |
238 | 238 | ||
239 | [Mux Clocks] | 239 | [Mux Clocks] |
240 | 240 | ||
241 | Clock ID SoC (if specific) | 241 | Clock ID SoC (if specific) |
242 | ----------------------------------------------- | 242 | ----------------------------------------------- |
243 | |||
244 | mout_fimc0 384 | ||
245 | mout_fimc1 385 | ||
246 | mout_fimc2 386 | ||
247 | mout_fimc3 387 | ||
248 | mout_cam0 388 | ||
249 | mout_cam1 389 | ||
250 | mout_csis0 390 | ||
251 | mout_csis1 391 | ||
252 | mout_g3d0 392 | ||
253 | mout_g3d1 393 | ||
254 | mout_g3d 394 | ||
255 | aclk400_mcuisp 395 Exynos4x12 | ||
256 | |||
257 | [Div Clocks] | ||
258 | |||
259 | Clock ID SoC (if specific) | ||
260 | ----------------------------------------------- | ||
261 | |||
262 | div_isp0 450 Exynos4x12 | ||
263 | div_isp1 451 Exynos4x12 | ||
264 | div_mcuisp0 452 Exynos4x12 | ||
265 | div_mcuisp1 453 Exynos4x12 | ||
266 | div_aclk200 454 Exynos4x12 | ||
267 | div_aclk400_mcuisp 455 Exynos4x12 | ||
243 | 268 | ||
244 | mout_fimc0 384 | ||
245 | mout_fimc1 385 | ||
246 | mout_fimc2 386 | ||
247 | mout_fimc3 387 | ||
248 | mout_cam0 388 | ||
249 | mout_cam1 389 | ||
250 | mout_csis0 390 | ||
251 | mout_csis1 391 | ||
252 | mout_g3d0 392 | ||
253 | mout_g3d1 393 | ||
254 | mout_g3d 394 | ||
255 | 269 | ||
256 | Example 1: An example of a clock controller node is listed below. | 270 | Example 1: An example of a clock controller node is listed below. |
257 | 271 | ||
diff --git a/drivers/clk/samsung/clk-exynos4.c b/drivers/clk/samsung/clk-exynos4.c index 17674da1c5f8..71046694d9dd 100644 --- a/drivers/clk/samsung/clk-exynos4.c +++ b/drivers/clk/samsung/clk-exynos4.c | |||
@@ -175,6 +175,11 @@ enum exynos4_clks { | |||
175 | /* mux clocks */ | 175 | /* mux clocks */ |
176 | mout_fimc0 = 384, mout_fimc1, mout_fimc2, mout_fimc3, mout_cam0, | 176 | mout_fimc0 = 384, mout_fimc1, mout_fimc2, mout_fimc3, mout_cam0, |
177 | mout_cam1, mout_csis0, mout_csis1, mout_g3d0, mout_g3d1, mout_g3d, | 177 | mout_cam1, mout_csis0, mout_csis1, mout_g3d0, mout_g3d1, mout_g3d, |
178 | aclk400_mcuisp, | ||
179 | |||
180 | /* div clocks */ | ||
181 | div_isp0 = 450, div_isp1, div_mcuisp0, div_mcuisp1, div_aclk200, | ||
182 | div_aclk400_mcuisp, | ||
178 | 183 | ||
179 | nr_clks, | 184 | nr_clks, |
180 | }; | 185 | }; |
@@ -429,7 +434,7 @@ struct samsung_mux_clock exynos4x12_mux_clks[] __initdata = { | |||
429 | MUX(none, "mout_user_aclk266_gps", mout_user_aclk266_gps_p4x12, | 434 | MUX(none, "mout_user_aclk266_gps", mout_user_aclk266_gps_p4x12, |
430 | SRC_TOP1, 16, 1), | 435 | SRC_TOP1, 16, 1), |
431 | MUX(aclk200, "aclk200", mout_user_aclk200_p4x12, SRC_TOP1, 20, 1), | 436 | MUX(aclk200, "aclk200", mout_user_aclk200_p4x12, SRC_TOP1, 20, 1), |
432 | MUX(none, "aclk400_mcuisp", mout_user_aclk400_mcuisp_p4x12, | 437 | MUX(aclk400_mcuisp, "aclk400_mcuisp", mout_user_aclk400_mcuisp_p4x12, |
433 | SRC_TOP1, 24, 1), | 438 | SRC_TOP1, 24, 1), |
434 | MUX(none, "mout_aclk200", aclk_p4412, SRC_TOP0, 12, 1), | 439 | MUX(none, "mout_aclk200", aclk_p4412, SRC_TOP0, 12, 1), |
435 | MUX(none, "mout_aclk100", aclk_p4412, SRC_TOP0, 16, 1), | 440 | MUX(none, "mout_aclk100", aclk_p4412, SRC_TOP0, 16, 1), |
@@ -563,20 +568,21 @@ struct samsung_div_clock exynos4x12_div_clks[] __initdata = { | |||
563 | DIV(none, "div_mdnie_pwm_pre0", "div_mdnie_pwm0", DIV_LCD0, 12, 4), | 568 | DIV(none, "div_mdnie_pwm_pre0", "div_mdnie_pwm0", DIV_LCD0, 12, 4), |
564 | DIV(none, "div_mipihsi", "mout_mipihsi", DIV_FSYS0, 20, 4), | 569 | DIV(none, "div_mipihsi", "mout_mipihsi", DIV_FSYS0, 20, 4), |
565 | DIV(none, "div_jpeg", "mout_jpeg", E4X12_DIV_CAM1, 0, 4), | 570 | DIV(none, "div_jpeg", "mout_jpeg", E4X12_DIV_CAM1, 0, 4), |
566 | DIV(none, "div_aclk200", "mout_aclk200", DIV_TOP, 0, 3), | 571 | DIV(div_aclk200, "div_aclk200", "mout_aclk200", DIV_TOP, 0, 3), |
567 | DIV(none, "div_aclk266_gps", "mout_aclk266_gps", DIV_TOP, 20, 3), | 572 | DIV(none, "div_aclk266_gps", "mout_aclk266_gps", DIV_TOP, 20, 3), |
568 | DIV(none, "div_aclk400_mcuisp", "mout_aclk400_mcuisp", DIV_TOP, 24, 3), | 573 | DIV(div_aclk400_mcuisp, "div_aclk400_mcuisp", "mout_aclk400_mcuisp", |
574 | DIV_TOP, 24, 3), | ||
569 | DIV(none, "div_pwm_isp", "mout_pwm_isp", E4X12_DIV_ISP, 0, 4), | 575 | DIV(none, "div_pwm_isp", "mout_pwm_isp", E4X12_DIV_ISP, 0, 4), |
570 | DIV(none, "div_spi0_isp", "mout_spi0_isp", E4X12_DIV_ISP, 4, 4), | 576 | DIV(none, "div_spi0_isp", "mout_spi0_isp", E4X12_DIV_ISP, 4, 4), |
571 | DIV(none, "div_spi0_isp_pre", "div_spi0_isp", E4X12_DIV_ISP, 8, 8), | 577 | DIV(none, "div_spi0_isp_pre", "div_spi0_isp", E4X12_DIV_ISP, 8, 8), |
572 | DIV(none, "div_spi1_isp", "mout_spi1_isp", E4X12_DIV_ISP, 16, 4), | 578 | DIV(none, "div_spi1_isp", "mout_spi1_isp", E4X12_DIV_ISP, 16, 4), |
573 | DIV(none, "div_spi1_isp_pre", "div_spi1_isp", E4X12_DIV_ISP, 20, 8), | 579 | DIV(none, "div_spi1_isp_pre", "div_spi1_isp", E4X12_DIV_ISP, 20, 8), |
574 | DIV(none, "div_uart_isp", "mout_uart_isp", E4X12_DIV_ISP, 28, 4), | 580 | DIV(none, "div_uart_isp", "mout_uart_isp", E4X12_DIV_ISP, 28, 4), |
575 | DIV(none, "div_isp0", "aclk200", E4X12_DIV_ISP0, 0, 3), | 581 | DIV(div_isp0, "div_isp0", "aclk200", E4X12_DIV_ISP0, 0, 3), |
576 | DIV(none, "div_isp1", "aclk200", E4X12_DIV_ISP0, 4, 3), | 582 | DIV(div_isp1, "div_isp1", "aclk200", E4X12_DIV_ISP0, 4, 3), |
577 | DIV(none, "div_mpwm", "div_isp1", E4X12_DIV_ISP1, 0, 3), | 583 | DIV(none, "div_mpwm", "div_isp1", E4X12_DIV_ISP1, 0, 3), |
578 | DIV(none, "div_mcuisp0", "aclk400_mcuisp", E4X12_DIV_ISP1, 4, 3), | 584 | DIV(div_mcuisp0, "div_mcuisp0", "aclk400_mcuisp", E4X12_DIV_ISP1, 4, 3), |
579 | DIV(none, "div_mcuisp1", "div_mcuisp0", E4X12_DIV_ISP1, 8, 3), | 585 | DIV(div_mcuisp1, "div_mcuisp1", "div_mcuisp0", E4X12_DIV_ISP1, 8, 3), |
580 | }; | 586 | }; |
581 | 587 | ||
582 | /* list of gate clocks supported in all exynos4 soc's */ | 588 | /* list of gate clocks supported in all exynos4 soc's */ |