162306a36Sopenharmony_ci# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause)
262306a36Sopenharmony_ci%YAML 1.2
362306a36Sopenharmony_ci---
462306a36Sopenharmony_ci$id: http://devicetree.org/schemas/soc/starfive/starfive,jh7110-syscon.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: StarFive JH7110 SoC system controller
862306a36Sopenharmony_ci
962306a36Sopenharmony_cimaintainers:
1062306a36Sopenharmony_ci  - William Qiu <william.qiu@starfivetech.com>
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_cidescription:
1362306a36Sopenharmony_ci  The StarFive JH7110 SoC system controller provides register information such
1462306a36Sopenharmony_ci  as offset, mask and shift to configure related modules such as MMC and PCIe.
1562306a36Sopenharmony_ci
1662306a36Sopenharmony_ciproperties:
1762306a36Sopenharmony_ci  compatible:
1862306a36Sopenharmony_ci    oneOf:
1962306a36Sopenharmony_ci      - items:
2062306a36Sopenharmony_ci          - const: starfive,jh7110-sys-syscon
2162306a36Sopenharmony_ci          - const: syscon
2262306a36Sopenharmony_ci          - const: simple-mfd
2362306a36Sopenharmony_ci      - items:
2462306a36Sopenharmony_ci          - enum:
2562306a36Sopenharmony_ci              - starfive,jh7110-aon-syscon
2662306a36Sopenharmony_ci              - starfive,jh7110-stg-syscon
2762306a36Sopenharmony_ci          - const: syscon
2862306a36Sopenharmony_ci
2962306a36Sopenharmony_ci  reg:
3062306a36Sopenharmony_ci    maxItems: 1
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_ci  clock-controller:
3362306a36Sopenharmony_ci    $ref: /schemas/clock/starfive,jh7110-pll.yaml#
3462306a36Sopenharmony_ci    type: object
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_ci  "#power-domain-cells":
3762306a36Sopenharmony_ci    const: 1
3862306a36Sopenharmony_ci
3962306a36Sopenharmony_cirequired:
4062306a36Sopenharmony_ci  - compatible
4162306a36Sopenharmony_ci  - reg
4262306a36Sopenharmony_ci
4362306a36Sopenharmony_ciallOf:
4462306a36Sopenharmony_ci  - if:
4562306a36Sopenharmony_ci      properties:
4662306a36Sopenharmony_ci        compatible:
4762306a36Sopenharmony_ci          contains:
4862306a36Sopenharmony_ci            const: starfive,jh7110-sys-syscon
4962306a36Sopenharmony_ci    then:
5062306a36Sopenharmony_ci      required:
5162306a36Sopenharmony_ci        - clock-controller
5262306a36Sopenharmony_ci    else:
5362306a36Sopenharmony_ci      properties:
5462306a36Sopenharmony_ci        clock-controller: false
5562306a36Sopenharmony_ci  - if:
5662306a36Sopenharmony_ci      properties:
5762306a36Sopenharmony_ci        compatible:
5862306a36Sopenharmony_ci          contains:
5962306a36Sopenharmony_ci            const: starfive,jh7110-aon-syscon
6062306a36Sopenharmony_ci    then:
6162306a36Sopenharmony_ci      required:
6262306a36Sopenharmony_ci        - "#power-domain-cells"
6362306a36Sopenharmony_ci    else:
6462306a36Sopenharmony_ci      properties:
6562306a36Sopenharmony_ci        "#power-domain-cells": false
6662306a36Sopenharmony_ci
6762306a36Sopenharmony_ciadditionalProperties: false
6862306a36Sopenharmony_ci
6962306a36Sopenharmony_ciexamples:
7062306a36Sopenharmony_ci  - |
7162306a36Sopenharmony_ci    syscon@10240000 {
7262306a36Sopenharmony_ci        compatible = "starfive,jh7110-stg-syscon", "syscon";
7362306a36Sopenharmony_ci        reg = <0x10240000 0x1000>;
7462306a36Sopenharmony_ci    };
7562306a36Sopenharmony_ci
7662306a36Sopenharmony_ci    syscon@13030000 {
7762306a36Sopenharmony_ci        compatible = "starfive,jh7110-sys-syscon", "syscon", "simple-mfd";
7862306a36Sopenharmony_ci        reg = <0x13030000 0x1000>;
7962306a36Sopenharmony_ci
8062306a36Sopenharmony_ci        clock-controller {
8162306a36Sopenharmony_ci            compatible = "starfive,jh7110-pll";
8262306a36Sopenharmony_ci            clocks = <&osc>;
8362306a36Sopenharmony_ci            #clock-cells = <1>;
8462306a36Sopenharmony_ci        };
8562306a36Sopenharmony_ci    };
8662306a36Sopenharmony_ci
8762306a36Sopenharmony_ci    syscon@17010000 {
8862306a36Sopenharmony_ci        compatible = "starfive,jh7110-aon-syscon", "syscon";
8962306a36Sopenharmony_ci        reg = <0x17010000 0x1000>;
9062306a36Sopenharmony_ci        #power-domain-cells = <1>;
9162306a36Sopenharmony_ci    };
9262306a36Sopenharmony_ci
9362306a36Sopenharmony_ci...
94