1 * Samsung Exynos5433 CMU (Clock Management Units)
3 The Exynos5433 clock controller generates and supplies clock to various
4 controllers within the Exynos5433 SoC.
8 - compatible: should be one of the following.
9 - "samsung,exynos5433-cmu-top" - clock controller compatible for CMU_TOP
10 which generates clocks for IMEM/FSYS/G3D/GSCL/HEVC/MSCL/G2D/MFC/PERIC/PERIS
11 domains and bus clocks.
12 - "samsung,exynos5433-cmu-cpif" - clock controller compatible for CMU_CPIF
13 which generates clocks for LLI (Low Latency Interface) IP.
14 - "samsung,exynos5433-cmu-mif" - clock controller compatible for CMU_MIF
15 which generates clocks for DRAM Memory Controller domain.
16 - "samsung,exynos5433-cmu-peric" - clock controller compatible for CMU_PERIC
17 which generates clocks for UART/I2C/SPI/I2S/PCM/SPDIF/PWM/SLIMBUS IPs.
18 - "samsung,exynos5433-cmu-peris" - clock controller compatible for CMU_PERIS
19 which generates clocks for PMU/TMU/MCT/WDT/RTC/SECKEY/TZPC IPs.
20 - "samsung,exynos5433-cmu-fsys" - clock controller compatible for CMU_FSYS
21 which generates clocks for USB/UFS/SDMMC/TSI/PDMA IPs.
22 - "samsung,exynos5433-cmu-g2d" - clock controller compatible for CMU_G2D
23 which generates clocks for G2D/MDMA IPs.
24 - "samsung,exynos5433-cmu-disp" - clock controller compatible for CMU_DISP
25 which generates clocks for Display (DECON/HDMI/DSIM/MIXER) IPs.
26 - "samsung,exynos5433-cmu-aud" - clock controller compatible for CMU_AUD
27 which generates clocks for Cortex-A5/BUS/AUDIO clocks.
28 - "samsung,exynos5433-cmu-bus0", "samsung,exynos5433-cmu-bus1"
29 and "samsung,exynos5433-cmu-bus2" - clock controller compatible for CMU_BUS
30 which generates global data buses clock and global peripheral buses clock.
31 - "samsung,exynos5433-cmu-g3d" - clock controller compatible for CMU_G3D
32 which generates clocks for 3D Graphics Engine IP.
33 - "samsung,exynos5433-cmu-gscl" - clock controller compatible for CMU_GSCL
34 which generates clocks for GSCALER IPs.
35 - "samsung,exynos5433-cmu-apollo"- clock controller compatible for CMU_APOLLO
36 which generates clocks for Cortex-A53 Quad-core processor.
37 - "samsung,exynos5433-cmu-atlas" - clock controller compatible for CMU_ATLAS
38 which generates clocks for Cortex-A57 Quad-core processor, CoreSight and
40 - "samsung,exynos5433-cmu-mscl" - clock controller compatible for CMU_MSCL
41 which generates clocks for M2M (Memory to Memory) scaler and JPEG IPs.
42 - "samsung,exynos5433-cmu-mfc" - clock controller compatible for CMU_MFC
43 which generates clocks for MFC(Multi-Format Codec) IP.
44 - "samsung,exynos5433-cmu-hevc" - clock controller compatible for CMU_HEVC
45 which generates clocks for HEVC(High Efficiency Video Codec) decoder IP.
46 - "samsung,exynos5433-cmu-isp" - clock controller compatible for CMU_ISP
47 which generates clocks for FIMC-ISP/DRC/SCLC/DIS/3DNR IPs.
48 - "samsung,exynos5433-cmu-cam0" - clock controller compatible for CMU_CAM0
49 which generates clocks for MIPI_CSIS{0|1}/FIMC_LITE_{A|B|D}/FIMC_3AA{0|1}
51 - "samsung,exynos5433-cmu-cam1" - clock controller compatible for CMU_CAM1
52 which generates clocks for Cortex-A5/MIPI_CSIS2/FIMC-LITE_C/FIMC-FD IPs.
54 - reg: physical base address of the controller and length of memory mapped
57 - #clock-cells: should be 1.
59 - clocks: list of the clock controller input clock identifiers,
60 from common clock bindings. Please refer the next section
61 to find the input clocks for a given controller.
63 - clock-names: list of the clock controller input clock names,
64 as described in clock-bindings.txt.
66 Input clocks for top clock controller:
72 Input clocks for cpif clock controller:
75 Input clocks for mif clock controller:
79 Input clocks for fsys clock controller:
91 Input clocks for g2d clock controller:
96 Input clocks for disp clock controller:
101 - sclk_decon_tv_eclk_disp
102 - sclk_decon_vclk_disp
103 - sclk_decon_eclk_disp
104 - sclk_decon_tv_vclk_disp
107 Input clocks for audio clock controller:
111 Input clocks for bus0 clock controller:
114 Input clocks for bus1 clock controller:
117 Input clocks for bus2 clock controller:
121 Input clocks for g3d clock controller:
125 Input clocks for gscl clock controller:
130 Input clocks for apollo clock controller:
132 - sclk_bus_pll_apollo
134 Input clocks for atlas clock controller:
138 Input clocks for mscl clock controller:
143 Input clocks for mfc clock controller:
147 Input clocks for hevc clock controller:
151 Input clocks for isp clock controller:
156 Input clocks for cam0 clock controller:
162 Input clocks for cam1 clock controller:
172 - power-domains: a phandle to respective power domain node as described by
173 generic PM domain bindings (see power/power_domain.txt for more
176 Each clock is assigned an identifier and client nodes can use this identifier
177 to specify the clock which they consume.
179 All available clocks are defined as preprocessor macros in
180 dt-bindings/clock/exynos5433.h header and can be used in device
183 Example 1: Examples of 'oscclk' source clock node are listed below.
186 compatible = "fixed-clock";
187 clock-output-names = "oscclk";
191 Example 2: Examples of clock controller nodes are listed below.
193 cmu_top: clock-controller@10030000 {
194 compatible = "samsung,exynos5433-cmu-top";
195 reg = <0x10030000 0x0c04>;
198 clock-names = "oscclk",
203 <&cmu_cpif CLK_SCLK_MPHY_PLL>,
204 <&cmu_mif CLK_SCLK_MFC_PLL>,
205 <&cmu_mif CLK_SCLK_BUS_PLL>;
208 cmu_cpif: clock-controller@10fc0000 {
209 compatible = "samsung,exynos5433-cmu-cpif";
210 reg = <0x10fc0000 0x0c04>;
213 clock-names = "oscclk";
217 cmu_mif: clock-controller@105b0000 {
218 compatible = "samsung,exynos5433-cmu-mif";
219 reg = <0x105b0000 0x100c>;
222 clock-names = "oscclk",
225 <&cmu_cpif CLK_SCLK_MPHY_PLL>;
228 cmu_peric: clock-controller@14c80000 {
229 compatible = "samsung,exynos5433-cmu-peric";
230 reg = <0x14c80000 0x0b08>;
234 cmu_peris: clock-controller@10040000 {
235 compatible = "samsung,exynos5433-cmu-peris";
236 reg = <0x10040000 0x0b20>;
240 cmu_fsys: clock-controller@156e0000 {
241 compatible = "samsung,exynos5433-cmu-fsys";
242 reg = <0x156e0000 0x0b04>;
245 clock-names = "oscclk",
248 "sclk_pcie_100_fsys",
249 "sclk_ufsunipro_fsys",
253 "sclk_usbhost30_fsys",
254 "sclk_usbdrd30_fsys";
256 <&cmu_cpif CLK_SCLK_UFS_MPHY>,
257 <&cmu_top CLK_ACLK_FSYS_200>,
258 <&cmu_top CLK_SCLK_PCIE_100_FSYS>,
259 <&cmu_top CLK_SCLK_UFSUNIPRO_FSYS>,
260 <&cmu_top CLK_SCLK_MMC2_FSYS>,
261 <&cmu_top CLK_SCLK_MMC1_FSYS>,
262 <&cmu_top CLK_SCLK_MMC0_FSYS>,
263 <&cmu_top CLK_SCLK_USBHOST30_FSYS>,
264 <&cmu_top CLK_SCLK_USBDRD30_FSYS>;
267 cmu_g2d: clock-controller@12460000 {
268 compatible = "samsung,exynos5433-cmu-g2d";
269 reg = <0x12460000 0x0b08>;
272 clock-names = "oscclk",
276 <&cmu_top CLK_ACLK_G2D_266>,
277 <&cmu_top CLK_ACLK_G2D_400>;
278 power-domains = <&pd_g2d>;
281 cmu_disp: clock-controller@13b90000 {
282 compatible = "samsung,exynos5433-cmu-disp";
283 reg = <0x13b90000 0x0c04>;
286 clock-names = "oscclk",
290 "sclk_decon_tv_eclk_disp",
291 "sclk_decon_vclk_disp",
292 "sclk_decon_eclk_disp",
293 "sclk_decon_tv_vclk_disp",
296 <&cmu_mif CLK_SCLK_DSIM1_DISP>,
297 <&cmu_mif CLK_SCLK_DSIM0_DISP>,
298 <&cmu_mif CLK_SCLK_DSD_DISP>,
299 <&cmu_mif CLK_SCLK_DECON_TV_ECLK_DISP>,
300 <&cmu_mif CLK_SCLK_DECON_VCLK_DISP>,
301 <&cmu_mif CLK_SCLK_DECON_ECLK_DISP>,
302 <&cmu_mif CLK_SCLK_DECON_TV_VCLK_DISP>,
303 <&cmu_mif CLK_ACLK_DISP_333>;
304 power-domains = <&pd_disp>;
307 cmu_aud: clock-controller@114c0000 {
308 compatible = "samsung,exynos5433-cmu-aud";
309 reg = <0x114c0000 0x0b04>;
312 clock-names = "oscclk", "fout_aud_pll";
313 clocks = <&xxti>, <&cmu_top CLK_FOUT_AUD_PLL>;
314 power-domains = <&pd_aud>;
317 cmu_bus0: clock-controller@13600000 {
318 compatible = "samsung,exynos5433-cmu-bus0";
319 reg = <0x13600000 0x0b04>;
322 clock-names = "aclk_bus0_400";
323 clocks = <&cmu_top CLK_ACLK_BUS0_400>;
326 cmu_bus1: clock-controller@14800000 {
327 compatible = "samsung,exynos5433-cmu-bus1";
328 reg = <0x14800000 0x0b04>;
331 clock-names = "aclk_bus1_400";
332 clocks = <&cmu_top CLK_ACLK_BUS1_400>;
335 cmu_bus2: clock-controller@13400000 {
336 compatible = "samsung,exynos5433-cmu-bus2";
337 reg = <0x13400000 0x0b04>;
340 clock-names = "oscclk", "aclk_bus2_400";
341 clocks = <&xxti>, <&cmu_mif CLK_ACLK_BUS2_400>;
344 cmu_g3d: clock-controller@14aa0000 {
345 compatible = "samsung,exynos5433-cmu-g3d";
346 reg = <0x14aa0000 0x1000>;
349 clock-names = "oscclk", "aclk_g3d_400";
350 clocks = <&xxti>, <&cmu_top CLK_ACLK_G3D_400>;
351 power-domains = <&pd_g3d>;
354 cmu_gscl: clock-controller@13cf0000 {
355 compatible = "samsung,exynos5433-cmu-gscl";
356 reg = <0x13cf0000 0x0b10>;
359 clock-names = "oscclk",
363 <&cmu_top CLK_ACLK_GSCL_111>,
364 <&cmu_top CLK_ACLK_GSCL_333>;
365 power-domains = <&pd_gscl>;
368 cmu_apollo: clock-controller@11900000 {
369 compatible = "samsung,exynos5433-cmu-apollo";
370 reg = <0x11900000 0x1088>;
373 clock-names = "oscclk", "sclk_bus_pll_apollo";
374 clocks = <&xxti>, <&cmu_mif CLK_SCLK_BUS_PLL_APOLLO>;
377 cmu_atlas: clock-controller@11800000 {
378 compatible = "samsung,exynos5433-cmu-atlas";
379 reg = <0x11800000 0x1088>;
382 clock-names = "oscclk", "sclk_bus_pll_atlas";
383 clocks = <&xxti>, <&cmu_mif CLK_SCLK_BUS_PLL_ATLAS>;
386 cmu_mscl: clock-controller@105d0000 {
387 compatible = "samsung,exynos5433-cmu-mscl";
388 reg = <0x105d0000 0x0b10>;
391 clock-names = "oscclk",
395 <&cmu_top CLK_SCLK_JPEG_MSCL>,
396 <&cmu_top CLK_ACLK_MSCL_400>;
397 power-domains = <&pd_mscl>;
400 cmu_mfc: clock-controller@15280000 {
401 compatible = "samsung,exynos5433-cmu-mfc";
402 reg = <0x15280000 0x0b08>;
405 clock-names = "oscclk", "aclk_mfc_400";
406 clocks = <&xxti>, <&cmu_top CLK_ACLK_MFC_400>;
407 power-domains = <&pd_mfc>;
410 cmu_hevc: clock-controller@14f80000 {
411 compatible = "samsung,exynos5433-cmu-hevc";
412 reg = <0x14f80000 0x0b08>;
415 clock-names = "oscclk", "aclk_hevc_400";
416 clocks = <&xxti>, <&cmu_top CLK_ACLK_HEVC_400>;
417 power-domains = <&pd_hevc>;
420 cmu_isp: clock-controller@146d0000 {
421 compatible = "samsung,exynos5433-cmu-isp";
422 reg = <0x146d0000 0x0b0c>;
425 clock-names = "oscclk",
429 <&cmu_top CLK_ACLK_ISP_DIS_400>,
430 <&cmu_top CLK_ACLK_ISP_400>;
431 power-domains = <&pd_isp>;
434 cmu_cam0: clock-controller@120d0000 {
435 compatible = "samsung,exynos5433-cmu-cam0";
436 reg = <0x120d0000 0x0b0c>;
439 clock-names = "oscclk",
444 <&cmu_top CLK_ACLK_CAM0_333>,
445 <&cmu_top CLK_ACLK_CAM0_400>,
446 <&cmu_top CLK_ACLK_CAM0_552>;
447 power-domains = <&pd_cam0>;
450 cmu_cam1: clock-controller@145d0000 {
451 compatible = "samsung,exynos5433-cmu-cam1";
452 reg = <0x145d0000 0x0b08>;
455 clock-names = "oscclk",
456 "sclk_isp_uart_cam1",
457 "sclk_isp_spi1_cam1",
458 "sclk_isp_spi0_cam1",
463 <&cmu_top CLK_SCLK_ISP_UART_CAM1>,
464 <&cmu_top CLK_SCLK_ISP_SPI1_CAM1>,
465 <&cmu_top CLK_SCLK_ISP_SPI0_CAM1>,
466 <&cmu_top CLK_ACLK_CAM1_333>,
467 <&cmu_top CLK_ACLK_CAM1_400>,
468 <&cmu_top CLK_ACLK_CAM1_552>;
469 power-domains = <&pd_cam1>;
472 Example 3: UART controller node that consumes the clock generated by the clock
475 serial_0: serial@14c10000 {
476 compatible = "samsung,exynos5433-uart";
477 reg = <0x14C10000 0x100>;
478 interrupts = <0 421 0>;
479 clocks = <&cmu_peric CLK_PCLK_UART0>,
480 <&cmu_peric CLK_SCLK_UART0>;
481 clock-names = "uart", "clk_uart_baud0";
482 pinctrl-names = "default";
483 pinctrl-0 = <&uart0_bus>;