18c2ecf20Sopenharmony_ci# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
28c2ecf20Sopenharmony_ci# Copyright 2019 Unisoc Inc.
38c2ecf20Sopenharmony_ci%YAML 1.2
48c2ecf20Sopenharmony_ci---
58c2ecf20Sopenharmony_ci$id: "http://devicetree.org/schemas/clock/sprd,sc9863a-clk.yaml#"
68c2ecf20Sopenharmony_ci$schema: "http://devicetree.org/meta-schemas/core.yaml#"
78c2ecf20Sopenharmony_ci
88c2ecf20Sopenharmony_cititle: SC9863A Clock Control Unit Device Tree Bindings
98c2ecf20Sopenharmony_ci
108c2ecf20Sopenharmony_cimaintainers:
118c2ecf20Sopenharmony_ci  - Orson Zhai <orsonzhai@gmail.com>
128c2ecf20Sopenharmony_ci  - Baolin Wang <baolin.wang7@gmail.com>
138c2ecf20Sopenharmony_ci  - Chunyan Zhang <zhang.lyra@gmail.com>
148c2ecf20Sopenharmony_ci
158c2ecf20Sopenharmony_ciproperties:
168c2ecf20Sopenharmony_ci  "#clock-cells":
178c2ecf20Sopenharmony_ci    const: 1
188c2ecf20Sopenharmony_ci
198c2ecf20Sopenharmony_ci  compatible:
208c2ecf20Sopenharmony_ci    enum:
218c2ecf20Sopenharmony_ci      - sprd,sc9863a-ap-clk
228c2ecf20Sopenharmony_ci      - sprd,sc9863a-aon-clk
238c2ecf20Sopenharmony_ci      - sprd,sc9863a-apahb-gate
248c2ecf20Sopenharmony_ci      - sprd,sc9863a-pmu-gate
258c2ecf20Sopenharmony_ci      - sprd,sc9863a-aonapb-gate
268c2ecf20Sopenharmony_ci      - sprd,sc9863a-pll
278c2ecf20Sopenharmony_ci      - sprd,sc9863a-mpll
288c2ecf20Sopenharmony_ci      - sprd,sc9863a-rpll
298c2ecf20Sopenharmony_ci      - sprd,sc9863a-dpll
308c2ecf20Sopenharmony_ci      - sprd,sc9863a-mm-gate
318c2ecf20Sopenharmony_ci      - sprd,sc9863a-mm-clk
328c2ecf20Sopenharmony_ci      - sprd,sc9863a-apapb-gate
338c2ecf20Sopenharmony_ci
348c2ecf20Sopenharmony_ci  clocks:
358c2ecf20Sopenharmony_ci    minItems: 1
368c2ecf20Sopenharmony_ci    maxItems: 4
378c2ecf20Sopenharmony_ci    description: |
388c2ecf20Sopenharmony_ci      The input parent clock(s) phandle for this clock, only list fixed
398c2ecf20Sopenharmony_ci      clocks which are declared in devicetree.
408c2ecf20Sopenharmony_ci
418c2ecf20Sopenharmony_ci  clock-names:
428c2ecf20Sopenharmony_ci    minItems: 1
438c2ecf20Sopenharmony_ci    maxItems: 4
448c2ecf20Sopenharmony_ci    items:
458c2ecf20Sopenharmony_ci      - const: ext-26m
468c2ecf20Sopenharmony_ci      - const: ext-32k
478c2ecf20Sopenharmony_ci      - const: ext-4m
488c2ecf20Sopenharmony_ci      - const: rco-100m
498c2ecf20Sopenharmony_ci
508c2ecf20Sopenharmony_ci  reg:
518c2ecf20Sopenharmony_ci    maxItems: 1
528c2ecf20Sopenharmony_ci
538c2ecf20Sopenharmony_cirequired:
548c2ecf20Sopenharmony_ci  - compatible
558c2ecf20Sopenharmony_ci  - '#clock-cells'
568c2ecf20Sopenharmony_ci
578c2ecf20Sopenharmony_ciif:
588c2ecf20Sopenharmony_ci  properties:
598c2ecf20Sopenharmony_ci    compatible:
608c2ecf20Sopenharmony_ci      enum:
618c2ecf20Sopenharmony_ci        - sprd,sc9863a-ap-clk
628c2ecf20Sopenharmony_ci        - sprd,sc9863a-aon-clk
638c2ecf20Sopenharmony_cithen:
648c2ecf20Sopenharmony_ci  required:
658c2ecf20Sopenharmony_ci    - reg
668c2ecf20Sopenharmony_ci
678c2ecf20Sopenharmony_cielse:
688c2ecf20Sopenharmony_ci  description: |
698c2ecf20Sopenharmony_ci    Other SC9863a clock nodes should be the child of a syscon node in
708c2ecf20Sopenharmony_ci    which compatible string shoule be:
718c2ecf20Sopenharmony_ci            "sprd,sc9863a-glbregs", "syscon", "simple-mfd"
728c2ecf20Sopenharmony_ci
738c2ecf20Sopenharmony_ci    The 'reg' property for the clock node is also required if there is a sub
748c2ecf20Sopenharmony_ci    range of registers for the clocks.
758c2ecf20Sopenharmony_ci
768c2ecf20Sopenharmony_ciadditionalProperties: false
778c2ecf20Sopenharmony_ci
788c2ecf20Sopenharmony_ciexamples:
798c2ecf20Sopenharmony_ci  - |
808c2ecf20Sopenharmony_ci    ap_clk: clock-controller@21500000 {
818c2ecf20Sopenharmony_ci      compatible = "sprd,sc9863a-ap-clk";
828c2ecf20Sopenharmony_ci      reg = <0x21500000 0x1000>;
838c2ecf20Sopenharmony_ci      clocks = <&ext_26m>, <&ext_32k>;
848c2ecf20Sopenharmony_ci      clock-names = "ext-26m", "ext-32k";
858c2ecf20Sopenharmony_ci      #clock-cells = <1>;
868c2ecf20Sopenharmony_ci    };
878c2ecf20Sopenharmony_ci
888c2ecf20Sopenharmony_ci  - |
898c2ecf20Sopenharmony_ci    syscon@20e00000 {
908c2ecf20Sopenharmony_ci      compatible = "sprd,sc9863a-glbregs", "syscon", "simple-mfd";
918c2ecf20Sopenharmony_ci      reg = <0x20e00000 0x4000>;
928c2ecf20Sopenharmony_ci      #address-cells = <1>;
938c2ecf20Sopenharmony_ci      #size-cells = <1>;
948c2ecf20Sopenharmony_ci      ranges = <0 0x20e00000 0x4000>;
958c2ecf20Sopenharmony_ci
968c2ecf20Sopenharmony_ci      apahb_gate: apahb-gate@0 {
978c2ecf20Sopenharmony_ci        compatible = "sprd,sc9863a-apahb-gate";
988c2ecf20Sopenharmony_ci        reg = <0x0 0x1020>;
998c2ecf20Sopenharmony_ci        #clock-cells = <1>;
1008c2ecf20Sopenharmony_ci      };
1018c2ecf20Sopenharmony_ci    };
1028c2ecf20Sopenharmony_ci
1038c2ecf20Sopenharmony_ci...
104