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/interconnect/qcom,qcm2290.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: Qualcomm QCM2290 Network-On-Chip interconnect
862306a36Sopenharmony_ci
962306a36Sopenharmony_cimaintainers:
1062306a36Sopenharmony_ci  - Shawn Guo <shawn.guo@linaro.org>
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_cidescription: |
1362306a36Sopenharmony_ci  The Qualcomm QCM2290 interconnect providers support adjusting the
1462306a36Sopenharmony_ci  bandwidth requirements between the various NoC fabrics.
1562306a36Sopenharmony_ci
1662306a36Sopenharmony_ciproperties:
1762306a36Sopenharmony_ci  reg:
1862306a36Sopenharmony_ci    maxItems: 1
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_ci  compatible:
2162306a36Sopenharmony_ci    enum:
2262306a36Sopenharmony_ci      - qcom,qcm2290-bimc
2362306a36Sopenharmony_ci      - qcom,qcm2290-cnoc
2462306a36Sopenharmony_ci      - qcom,qcm2290-snoc
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_ci  '#interconnect-cells':
2762306a36Sopenharmony_ci    const: 1
2862306a36Sopenharmony_ci
2962306a36Sopenharmony_ci  clock-names:
3062306a36Sopenharmony_ci    items:
3162306a36Sopenharmony_ci      - const: bus
3262306a36Sopenharmony_ci      - const: bus_a
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_ci  clocks:
3562306a36Sopenharmony_ci    items:
3662306a36Sopenharmony_ci      - description: Bus Clock
3762306a36Sopenharmony_ci      - description: Bus A Clock
3862306a36Sopenharmony_ci
3962306a36Sopenharmony_ci# Child node's properties
4062306a36Sopenharmony_cipatternProperties:
4162306a36Sopenharmony_ci  '^interconnect-[a-z0-9]+$':
4262306a36Sopenharmony_ci    type: object
4362306a36Sopenharmony_ci    description:
4462306a36Sopenharmony_ci      The interconnect providers do not have a separate QoS register space,
4562306a36Sopenharmony_ci      but share parent's space.
4662306a36Sopenharmony_ci
4762306a36Sopenharmony_ci    properties:
4862306a36Sopenharmony_ci      compatible:
4962306a36Sopenharmony_ci        enum:
5062306a36Sopenharmony_ci          - qcom,qcm2290-qup-virt
5162306a36Sopenharmony_ci          - qcom,qcm2290-mmrt-virt
5262306a36Sopenharmony_ci          - qcom,qcm2290-mmnrt-virt
5362306a36Sopenharmony_ci
5462306a36Sopenharmony_ci      '#interconnect-cells':
5562306a36Sopenharmony_ci        const: 1
5662306a36Sopenharmony_ci
5762306a36Sopenharmony_ci      clock-names:
5862306a36Sopenharmony_ci        items:
5962306a36Sopenharmony_ci          - const: bus
6062306a36Sopenharmony_ci          - const: bus_a
6162306a36Sopenharmony_ci
6262306a36Sopenharmony_ci      clocks:
6362306a36Sopenharmony_ci        items:
6462306a36Sopenharmony_ci          - description: Bus Clock
6562306a36Sopenharmony_ci          - description: Bus A Clock
6662306a36Sopenharmony_ci
6762306a36Sopenharmony_ci    required:
6862306a36Sopenharmony_ci      - compatible
6962306a36Sopenharmony_ci      - '#interconnect-cells'
7062306a36Sopenharmony_ci      - clock-names
7162306a36Sopenharmony_ci      - clocks
7262306a36Sopenharmony_ci
7362306a36Sopenharmony_ci    additionalProperties: false
7462306a36Sopenharmony_ci
7562306a36Sopenharmony_cirequired:
7662306a36Sopenharmony_ci  - compatible
7762306a36Sopenharmony_ci  - reg
7862306a36Sopenharmony_ci  - '#interconnect-cells'
7962306a36Sopenharmony_ci  - clock-names
8062306a36Sopenharmony_ci  - clocks
8162306a36Sopenharmony_ci
8262306a36Sopenharmony_ciadditionalProperties: false
8362306a36Sopenharmony_ci
8462306a36Sopenharmony_ciexamples:
8562306a36Sopenharmony_ci  - |
8662306a36Sopenharmony_ci    #include <dt-bindings/clock/qcom,rpmcc.h>
8762306a36Sopenharmony_ci
8862306a36Sopenharmony_ci    snoc: interconnect@1880000 {
8962306a36Sopenharmony_ci        compatible = "qcom,qcm2290-snoc";
9062306a36Sopenharmony_ci        reg = <0x01880000 0x60200>;
9162306a36Sopenharmony_ci        #interconnect-cells = <1>;
9262306a36Sopenharmony_ci        clock-names = "bus", "bus_a";
9362306a36Sopenharmony_ci        clocks = <&rpmcc RPM_SMD_SNOC_CLK>,
9462306a36Sopenharmony_ci                 <&rpmcc RPM_SMD_SNOC_A_CLK>;
9562306a36Sopenharmony_ci
9662306a36Sopenharmony_ci        qup_virt: interconnect-qup {
9762306a36Sopenharmony_ci            compatible = "qcom,qcm2290-qup-virt";
9862306a36Sopenharmony_ci            #interconnect-cells = <1>;
9962306a36Sopenharmony_ci            clock-names = "bus", "bus_a";
10062306a36Sopenharmony_ci            clocks = <&rpmcc RPM_SMD_QUP_CLK>,
10162306a36Sopenharmony_ci                     <&rpmcc RPM_SMD_QUP_A_CLK>;
10262306a36Sopenharmony_ci        };
10362306a36Sopenharmony_ci
10462306a36Sopenharmony_ci        mmnrt_virt: interconnect-mmnrt {
10562306a36Sopenharmony_ci            compatible = "qcom,qcm2290-mmnrt-virt";
10662306a36Sopenharmony_ci            #interconnect-cells = <1>;
10762306a36Sopenharmony_ci            clock-names = "bus", "bus_a";
10862306a36Sopenharmony_ci            clocks = <&rpmcc RPM_SMD_MMNRT_CLK>,
10962306a36Sopenharmony_ci                     <&rpmcc RPM_SMD_MMNRT_A_CLK>;
11062306a36Sopenharmony_ci        };
11162306a36Sopenharmony_ci
11262306a36Sopenharmony_ci        mmrt_virt: interconnect-mmrt {
11362306a36Sopenharmony_ci            compatible = "qcom,qcm2290-mmrt-virt";
11462306a36Sopenharmony_ci            #interconnect-cells = <1>;
11562306a36Sopenharmony_ci            clock-names = "bus", "bus_a";
11662306a36Sopenharmony_ci            clocks = <&rpmcc RPM_SMD_MMRT_CLK>,
11762306a36Sopenharmony_ci                     <&rpmcc RPM_SMD_MMRT_A_CLK>;
11862306a36Sopenharmony_ci        };
11962306a36Sopenharmony_ci    };
12062306a36Sopenharmony_ci
12162306a36Sopenharmony_ci    cnoc: interconnect@1900000 {
12262306a36Sopenharmony_ci        compatible = "qcom,qcm2290-cnoc";
12362306a36Sopenharmony_ci        reg = <0x01900000 0x8200>;
12462306a36Sopenharmony_ci        #interconnect-cells = <1>;
12562306a36Sopenharmony_ci        clock-names = "bus", "bus_a";
12662306a36Sopenharmony_ci        clocks = <&rpmcc RPM_SMD_CNOC_CLK>,
12762306a36Sopenharmony_ci                 <&rpmcc RPM_SMD_CNOC_A_CLK>;
12862306a36Sopenharmony_ci    };
12962306a36Sopenharmony_ci
13062306a36Sopenharmony_ci    bimc: interconnect@4480000 {
13162306a36Sopenharmony_ci        compatible = "qcom,qcm2290-bimc";
13262306a36Sopenharmony_ci        reg = <0x04480000 0x80000>;
13362306a36Sopenharmony_ci        #interconnect-cells = <1>;
13462306a36Sopenharmony_ci        clock-names = "bus", "bus_a";
13562306a36Sopenharmony_ci        clocks = <&rpmcc RPM_SMD_BIMC_CLK>,
13662306a36Sopenharmony_ci                 <&rpmcc RPM_SMD_BIMC_A_CLK>;
13762306a36Sopenharmony_ci    };
138