| SAMSUNG Exynos SoC series PMU Registers |
| |
| Properties: |
| - compatible : should contain two values. First value must be one from following list: |
| - "samsung,exynos3250-pmu" - for Exynos3250 SoC, |
| - "samsung,exynos4210-pmu" - for Exynos4210 SoC, |
| - "samsung,exynos4412-pmu" - for Exynos4412 SoC, |
| - "samsung,exynos5250-pmu" - for Exynos5250 SoC, |
| - "samsung,exynos5260-pmu" - for Exynos5260 SoC. |
| - "samsung,exynos5410-pmu" - for Exynos5410 SoC, |
| - "samsung,exynos5420-pmu" - for Exynos5420 SoC. |
| - "samsung,exynos5433-pmu" - for Exynos5433 SoC. |
| - "samsung,exynos7-pmu" - for Exynos7 SoC. |
| second value must be always "syscon". |
| |
| - reg : offset and length of the register set. |
| |
| - #clock-cells : must be <1>, since PMU requires once cell as clock specifier. |
| The single specifier cell is used as index to list of clocks |
| provided by PMU, which is currently: |
| 0 : SoC clock output (CLKOUT pin) |
| |
| - clock-names : list of clock names for particular CLKOUT mux inputs in |
| following format: |
| "clkoutN", where N is a decimal number corresponding to |
| CLKOUT mux control bits value for given input, e.g. |
| "clkout0", "clkout7", "clkout15". |
| |
| - clocks : list of phandles and specifiers to all input clocks listed in |
| clock-names property. |
| |
| Optional properties: |
| |
| Some PMUs are capable of behaving as an interrupt controller (mostly |
| to wake up a suspended PMU). In which case, they can have the |
| following properties: |
| |
| - interrupt-controller: indicate that said PMU is an interrupt controller |
| |
| - #interrupt-cells: must be identical to the that of the parent interrupt |
| controller. |
| |
| - interrupt-parent: a phandle indicating which interrupt controller |
| this PMU signals interrupts to. |
| |
| |
| Optional nodes: |
| |
| - nodes defining the restart and poweroff syscon children |
| |
| |
| Example : |
| pmu_system_controller: system-controller@10040000 { |
| compatible = "samsung,exynos5250-pmu", "syscon"; |
| reg = <0x10040000 0x5000>; |
| interrupt-controller; |
| #interrupt-cells = <3>; |
| interrupt-parent = <&gic>; |
| #clock-cells = <1>; |
| clock-names = "clkout0", "clkout1", "clkout2", "clkout3", |
| "clkout4", "clkout8", "clkout9"; |
| clocks = <&clock CLK_OUT_DMC>, <&clock CLK_OUT_TOP>, |
| <&clock CLK_OUT_LEFTBUS>, <&clock CLK_OUT_RIGHTBUS>, |
| <&clock CLK_OUT_CPU>, <&clock CLK_XXTI>, |
| <&clock CLK_XUSBXTI>; |
| }; |
| |
| Example of clock consumer : |
| |
| usb3503: usb3503@8 { |
| /* ... */ |
| clock-names = "refclk"; |
| clocks = <&pmu_system_controller 0>; |
| /* ... */ |
| }; |