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/remoteproc/qcom,wcnss-pil.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: Qualcomm WCNSS Peripheral Image Loader
862306a36Sopenharmony_ci
962306a36Sopenharmony_cimaintainers:
1062306a36Sopenharmony_ci  - Bjorn Andersson <andersson@kernel.org>
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_cidescription:
1362306a36Sopenharmony_ci  This document defines the binding for a component that loads and boots
1462306a36Sopenharmony_ci  firmware on the Qualcomm WCNSS core.
1562306a36Sopenharmony_ci
1662306a36Sopenharmony_ciproperties:
1762306a36Sopenharmony_ci  compatible:
1862306a36Sopenharmony_ci    description:
1962306a36Sopenharmony_ci      Append "qcom,pronto" if the device is actually pronto, and not riva
2062306a36Sopenharmony_ci    oneOf:
2162306a36Sopenharmony_ci      - items:
2262306a36Sopenharmony_ci          - enum:
2362306a36Sopenharmony_ci              - qcom,pronto-v1-pil
2462306a36Sopenharmony_ci              - qcom,pronto-v2-pil
2562306a36Sopenharmony_ci              - qcom,pronto-v3-pil
2662306a36Sopenharmony_ci          - const: qcom,pronto
2762306a36Sopenharmony_ci      - const: qcom,riva-pil
2862306a36Sopenharmony_ci
2962306a36Sopenharmony_ci  reg:
3062306a36Sopenharmony_ci    maxItems: 3
3162306a36Sopenharmony_ci    description:
3262306a36Sopenharmony_ci      The base address and size of the CCU, DXE and PMU register blocks
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_ci  reg-names:
3562306a36Sopenharmony_ci    items:
3662306a36Sopenharmony_ci      - const: ccu
3762306a36Sopenharmony_ci      - const: dxe
3862306a36Sopenharmony_ci      - const: pmu
3962306a36Sopenharmony_ci
4062306a36Sopenharmony_ci  interrupts:
4162306a36Sopenharmony_ci    minItems: 2
4262306a36Sopenharmony_ci    maxItems: 5
4362306a36Sopenharmony_ci
4462306a36Sopenharmony_ci  interrupt-names:
4562306a36Sopenharmony_ci    minItems: 2
4662306a36Sopenharmony_ci    items:
4762306a36Sopenharmony_ci      - const: wdog
4862306a36Sopenharmony_ci      - const: fatal
4962306a36Sopenharmony_ci      - const: ready
5062306a36Sopenharmony_ci      - const: handover
5162306a36Sopenharmony_ci      - const: stop-ack
5262306a36Sopenharmony_ci
5362306a36Sopenharmony_ci  firmware-name:
5462306a36Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/string
5562306a36Sopenharmony_ci    description:
5662306a36Sopenharmony_ci      Relative firmware image path for the WCNSS core. Defaults to
5762306a36Sopenharmony_ci      "wcnss.mdt".
5862306a36Sopenharmony_ci
5962306a36Sopenharmony_ci  vddpx-supply:
6062306a36Sopenharmony_ci    description:
6162306a36Sopenharmony_ci      PX regulator to be held on behalf of the booting of the WCNSS core
6262306a36Sopenharmony_ci
6362306a36Sopenharmony_ci  vddmx-supply:
6462306a36Sopenharmony_ci    description:
6562306a36Sopenharmony_ci      MX regulator to be held on behalf of the booting of the WCNSS core.
6662306a36Sopenharmony_ci
6762306a36Sopenharmony_ci  vddcx-supply:
6862306a36Sopenharmony_ci    description:
6962306a36Sopenharmony_ci      CX regulator to be held on behalf of the booting of the WCNSS core.
7062306a36Sopenharmony_ci
7162306a36Sopenharmony_ci  power-domains:
7262306a36Sopenharmony_ci    maxItems: 2
7362306a36Sopenharmony_ci
7462306a36Sopenharmony_ci  power-domain-names:
7562306a36Sopenharmony_ci    items:
7662306a36Sopenharmony_ci      - const: cx
7762306a36Sopenharmony_ci      - const: mx
7862306a36Sopenharmony_ci
7962306a36Sopenharmony_ci  qcom,smem-states:
8062306a36Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/phandle-array
8162306a36Sopenharmony_ci    description:
8262306a36Sopenharmony_ci      States used by the AP to signal the WCNSS core that it should shutdown
8362306a36Sopenharmony_ci    items:
8462306a36Sopenharmony_ci      - description: Stop the modem
8562306a36Sopenharmony_ci
8662306a36Sopenharmony_ci  qcom,smem-state-names:
8762306a36Sopenharmony_ci    description: The names of the state bits used for SMP2P output
8862306a36Sopenharmony_ci    items:
8962306a36Sopenharmony_ci      - const: stop
9062306a36Sopenharmony_ci
9162306a36Sopenharmony_ci  memory-region:
9262306a36Sopenharmony_ci    maxItems: 1
9362306a36Sopenharmony_ci    description: reserved-memory for the WCNSS core
9462306a36Sopenharmony_ci
9562306a36Sopenharmony_ci  smd-edge:
9662306a36Sopenharmony_ci    $ref: /schemas/remoteproc/qcom,smd-edge.yaml#
9762306a36Sopenharmony_ci    description:
9862306a36Sopenharmony_ci      Qualcomm Shared Memory subnode which represents communication edge,
9962306a36Sopenharmony_ci      channels and devices related to the ADSP.
10062306a36Sopenharmony_ci
10162306a36Sopenharmony_ci  iris:
10262306a36Sopenharmony_ci    type: object
10362306a36Sopenharmony_ci    description:
10462306a36Sopenharmony_ci      The iris subnode of the WCNSS PIL is used to describe the attached RF module
10562306a36Sopenharmony_ci      and its resource dependencies.
10662306a36Sopenharmony_ci
10762306a36Sopenharmony_ci    properties:
10862306a36Sopenharmony_ci      compatible:
10962306a36Sopenharmony_ci        enum:
11062306a36Sopenharmony_ci          - qcom,wcn3620
11162306a36Sopenharmony_ci          - qcom,wcn3660
11262306a36Sopenharmony_ci          - qcom,wcn3660b
11362306a36Sopenharmony_ci          - qcom,wcn3680
11462306a36Sopenharmony_ci
11562306a36Sopenharmony_ci      clocks:
11662306a36Sopenharmony_ci        minItems: 1
11762306a36Sopenharmony_ci        items:
11862306a36Sopenharmony_ci          - description: XO clock
11962306a36Sopenharmony_ci          - description: RF clock
12062306a36Sopenharmony_ci
12162306a36Sopenharmony_ci      clock-names:
12262306a36Sopenharmony_ci        minItems: 1
12362306a36Sopenharmony_ci        items:
12462306a36Sopenharmony_ci          - const: xo
12562306a36Sopenharmony_ci          - const: rf
12662306a36Sopenharmony_ci
12762306a36Sopenharmony_ci      vddxo-supply:
12862306a36Sopenharmony_ci        description:
12962306a36Sopenharmony_ci          Reference to the regulator to be held on behalf of the booting WCNSS
13062306a36Sopenharmony_ci          core
13162306a36Sopenharmony_ci
13262306a36Sopenharmony_ci      vddrfa-supply:
13362306a36Sopenharmony_ci        description:
13462306a36Sopenharmony_ci          Reference to the regulator to be held on behalf of the booting WCNSS
13562306a36Sopenharmony_ci          core
13662306a36Sopenharmony_ci
13762306a36Sopenharmony_ci      vddpa-supply:
13862306a36Sopenharmony_ci        description:
13962306a36Sopenharmony_ci          Reference to the regulator to be held on behalf of the booting WCNSS
14062306a36Sopenharmony_ci          core
14162306a36Sopenharmony_ci
14262306a36Sopenharmony_ci      vdddig-supply:
14362306a36Sopenharmony_ci        description:
14462306a36Sopenharmony_ci          Reference to the regulator to be held on behalf of the booting WCNSS
14562306a36Sopenharmony_ci          core
14662306a36Sopenharmony_ci
14762306a36Sopenharmony_ci    required:
14862306a36Sopenharmony_ci      - compatible
14962306a36Sopenharmony_ci      - clocks
15062306a36Sopenharmony_ci      - clock-names
15162306a36Sopenharmony_ci      - vddxo-supply
15262306a36Sopenharmony_ci      - vddrfa-supply
15362306a36Sopenharmony_ci      - vddpa-supply
15462306a36Sopenharmony_ci      - vdddig-supply
15562306a36Sopenharmony_ci
15662306a36Sopenharmony_ci    additionalProperties: false
15762306a36Sopenharmony_ci
15862306a36Sopenharmony_cirequired:
15962306a36Sopenharmony_ci  - compatible
16062306a36Sopenharmony_ci  - reg
16162306a36Sopenharmony_ci  - reg-names
16262306a36Sopenharmony_ci  - interrupts
16362306a36Sopenharmony_ci  - interrupt-names
16462306a36Sopenharmony_ci  - iris
16562306a36Sopenharmony_ci  - vddpx-supply
16662306a36Sopenharmony_ci  - memory-region
16762306a36Sopenharmony_ci  - smd-edge
16862306a36Sopenharmony_ci
16962306a36Sopenharmony_ciadditionalProperties: false
17062306a36Sopenharmony_ci
17162306a36Sopenharmony_ciallOf:
17262306a36Sopenharmony_ci  - if:
17362306a36Sopenharmony_ci      properties:
17462306a36Sopenharmony_ci        compatible:
17562306a36Sopenharmony_ci          contains:
17662306a36Sopenharmony_ci            const: qcom,riva-pil
17762306a36Sopenharmony_ci    then:
17862306a36Sopenharmony_ci      required:
17962306a36Sopenharmony_ci        - vddcx-supply
18062306a36Sopenharmony_ci        - vddmx-supply
18162306a36Sopenharmony_ci
18262306a36Sopenharmony_ci  - if:
18362306a36Sopenharmony_ci      properties:
18462306a36Sopenharmony_ci        compatible:
18562306a36Sopenharmony_ci          contains:
18662306a36Sopenharmony_ci            enum:
18762306a36Sopenharmony_ci              - qcom,pronto-v1-pil
18862306a36Sopenharmony_ci              - qcom,pronto-v2-pil
18962306a36Sopenharmony_ci    then:
19062306a36Sopenharmony_ci      properties:
19162306a36Sopenharmony_ci        vddmx-supply:
19262306a36Sopenharmony_ci          deprecated: true
19362306a36Sopenharmony_ci          description: Deprecated for qcom,pronto-v1/2-pil
19462306a36Sopenharmony_ci
19562306a36Sopenharmony_ci        vddcx-supply:
19662306a36Sopenharmony_ci          deprecated: true
19762306a36Sopenharmony_ci          description: Deprecated for qcom,pronto-v1/2-pil
19862306a36Sopenharmony_ci
19962306a36Sopenharmony_ci      oneOf:
20062306a36Sopenharmony_ci        - required:
20162306a36Sopenharmony_ci            - power-domains
20262306a36Sopenharmony_ci            - power-domain-names
20362306a36Sopenharmony_ci        - required:
20462306a36Sopenharmony_ci            - vddmx-supply
20562306a36Sopenharmony_ci            - vddcx-supply
20662306a36Sopenharmony_ci
20762306a36Sopenharmony_ci  - if:
20862306a36Sopenharmony_ci      properties:
20962306a36Sopenharmony_ci        compatible:
21062306a36Sopenharmony_ci          contains:
21162306a36Sopenharmony_ci            enum:
21262306a36Sopenharmony_ci              - qcom,pronto-v3-pil
21362306a36Sopenharmony_ci    then:
21462306a36Sopenharmony_ci      properties:
21562306a36Sopenharmony_ci        vddmx-supply: false
21662306a36Sopenharmony_ci        vddcx-supply: false
21762306a36Sopenharmony_ci
21862306a36Sopenharmony_ci      required:
21962306a36Sopenharmony_ci        - power-domains
22062306a36Sopenharmony_ci        - power-domain-names
22162306a36Sopenharmony_ci
22262306a36Sopenharmony_ciexamples:
22362306a36Sopenharmony_ci  - |
22462306a36Sopenharmony_ci    #include <dt-bindings/interrupt-controller/arm-gic.h>
22562306a36Sopenharmony_ci    #include <dt-bindings/clock/qcom,rpmcc.h>
22662306a36Sopenharmony_ci    #include <dt-bindings/power/qcom-rpmpd.h>
22762306a36Sopenharmony_ci    pronto@a21b000 {
22862306a36Sopenharmony_ci        compatible = "qcom,pronto-v2-pil", "qcom,pronto";
22962306a36Sopenharmony_ci        reg = <0x0a204000 0x2000>, <0x0a202000 0x1000>, <0x0a21b000 0x3000>;
23062306a36Sopenharmony_ci        reg-names = "ccu", "dxe", "pmu";
23162306a36Sopenharmony_ci
23262306a36Sopenharmony_ci        interrupts-extended = <&intc GIC_SPI 149 IRQ_TYPE_EDGE_RISING>,
23362306a36Sopenharmony_ci                              <&wcnss_smp2p_in 0 IRQ_TYPE_EDGE_RISING>,
23462306a36Sopenharmony_ci                              <&wcnss_smp2p_in 1 IRQ_TYPE_EDGE_RISING>,
23562306a36Sopenharmony_ci                              <&wcnss_smp2p_in 2 IRQ_TYPE_EDGE_RISING>,
23662306a36Sopenharmony_ci                              <&wcnss_smp2p_in 3 IRQ_TYPE_EDGE_RISING>;
23762306a36Sopenharmony_ci        interrupt-names = "wdog", "fatal", "ready", "handover", "stop-ack";
23862306a36Sopenharmony_ci
23962306a36Sopenharmony_ci        power-domains = <&rpmpd MSM8916_VDDCX>, <&rpmpd MSM8916_VDDMX>;
24062306a36Sopenharmony_ci        power-domain-names = "cx", "mx";
24162306a36Sopenharmony_ci
24262306a36Sopenharmony_ci        vddpx-supply = <&pm8916_l7>;
24362306a36Sopenharmony_ci
24462306a36Sopenharmony_ci        qcom,smem-states = <&wcnss_smp2p_out 0>;
24562306a36Sopenharmony_ci        qcom,smem-state-names = "stop";
24662306a36Sopenharmony_ci
24762306a36Sopenharmony_ci        memory-region = <&wcnss_region>;
24862306a36Sopenharmony_ci
24962306a36Sopenharmony_ci        pinctrl-names = "default";
25062306a36Sopenharmony_ci        pinctrl-0 = <&wcnss_pin_a>;
25162306a36Sopenharmony_ci
25262306a36Sopenharmony_ci        iris {
25362306a36Sopenharmony_ci            compatible = "qcom,wcn3620";
25462306a36Sopenharmony_ci            vddxo-supply = <&pm8916_l7>;
25562306a36Sopenharmony_ci            vddrfa-supply = <&pm8916_s3>;
25662306a36Sopenharmony_ci            vddpa-supply = <&pm8916_l9>;
25762306a36Sopenharmony_ci            vdddig-supply = <&pm8916_l5>;
25862306a36Sopenharmony_ci
25962306a36Sopenharmony_ci            clocks = <&rpmcc RPM_SMD_RF_CLK2>;
26062306a36Sopenharmony_ci            clock-names = "xo";
26162306a36Sopenharmony_ci        };
26262306a36Sopenharmony_ci
26362306a36Sopenharmony_ci        smd-edge {
26462306a36Sopenharmony_ci            interrupts = <GIC_SPI 142 IRQ_TYPE_EDGE_RISING>;
26562306a36Sopenharmony_ci
26662306a36Sopenharmony_ci            qcom,ipc = <&apcs 8 17>;
26762306a36Sopenharmony_ci            qcom,smd-edge = <6>;
26862306a36Sopenharmony_ci            qcom,remote-pid = <4>;
26962306a36Sopenharmony_ci
27062306a36Sopenharmony_ci            label = "pronto";
27162306a36Sopenharmony_ci
27262306a36Sopenharmony_ci            wcnss_ctrl: wcnss {
27362306a36Sopenharmony_ci                compatible = "qcom,wcnss";
27462306a36Sopenharmony_ci                qcom,smd-channels = "WCNSS_CTRL";
27562306a36Sopenharmony_ci
27662306a36Sopenharmony_ci                qcom,mmio = <&pronto>;
27762306a36Sopenharmony_ci
27862306a36Sopenharmony_ci                bluetooth {
27962306a36Sopenharmony_ci                    compatible = "qcom,wcnss-bt";
28062306a36Sopenharmony_ci                };
28162306a36Sopenharmony_ci
28262306a36Sopenharmony_ci                wifi {
28362306a36Sopenharmony_ci                    compatible = "qcom,wcnss-wlan";
28462306a36Sopenharmony_ci
28562306a36Sopenharmony_ci                    interrupts = <GIC_SPI 145 IRQ_TYPE_LEVEL_HIGH>,
28662306a36Sopenharmony_ci                                 <GIC_SPI 146 IRQ_TYPE_LEVEL_HIGH>;
28762306a36Sopenharmony_ci                    interrupt-names = "tx", "rx";
28862306a36Sopenharmony_ci
28962306a36Sopenharmony_ci                    qcom,smem-states = <&apps_smsm 10>, <&apps_smsm 9>;
29062306a36Sopenharmony_ci                    qcom,smem-state-names = "tx-enable", "tx-rings-empty";
29162306a36Sopenharmony_ci                };
29262306a36Sopenharmony_ci            };
29362306a36Sopenharmony_ci        };
29462306a36Sopenharmony_ci    };
295