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/phy/qcom,msm8996-qmp-pcie-phy.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: Qualcomm QMP PHY controller (MSM8996 PCIe)
862306a36Sopenharmony_ci
962306a36Sopenharmony_cimaintainers:
1062306a36Sopenharmony_ci  - Vinod Koul <vkoul@kernel.org>
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_cidescription:
1362306a36Sopenharmony_ci  QMP PHY controller supports physical layer functionality for a number of
1462306a36Sopenharmony_ci  controllers on Qualcomm chipsets, such as, PCIe, UFS, and USB.
1562306a36Sopenharmony_ci
1662306a36Sopenharmony_ciproperties:
1762306a36Sopenharmony_ci  compatible:
1862306a36Sopenharmony_ci    const: qcom,msm8996-qmp-pcie-phy
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_ci  reg:
2162306a36Sopenharmony_ci    items:
2262306a36Sopenharmony_ci      - description: serdes
2362306a36Sopenharmony_ci
2462306a36Sopenharmony_ci  "#address-cells":
2562306a36Sopenharmony_ci    enum: [ 1, 2 ]
2662306a36Sopenharmony_ci
2762306a36Sopenharmony_ci  "#size-cells":
2862306a36Sopenharmony_ci    enum: [ 1, 2 ]
2962306a36Sopenharmony_ci
3062306a36Sopenharmony_ci  ranges: true
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_ci  clocks:
3362306a36Sopenharmony_ci    maxItems: 3
3462306a36Sopenharmony_ci
3562306a36Sopenharmony_ci  clock-names:
3662306a36Sopenharmony_ci    items:
3762306a36Sopenharmony_ci      - const: aux
3862306a36Sopenharmony_ci      - const: cfg_ahb
3962306a36Sopenharmony_ci      - const: ref
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_ci  resets:
4262306a36Sopenharmony_ci    maxItems: 3
4362306a36Sopenharmony_ci
4462306a36Sopenharmony_ci  reset-names:
4562306a36Sopenharmony_ci    items:
4662306a36Sopenharmony_ci      - const: phy
4762306a36Sopenharmony_ci      - const: common
4862306a36Sopenharmony_ci      - const: cfg
4962306a36Sopenharmony_ci
5062306a36Sopenharmony_ci  vdda-phy-supply: true
5162306a36Sopenharmony_ci
5262306a36Sopenharmony_ci  vdda-pll-supply: true
5362306a36Sopenharmony_ci
5462306a36Sopenharmony_ci  vddp-ref-clk-supply: true
5562306a36Sopenharmony_ci
5662306a36Sopenharmony_cipatternProperties:
5762306a36Sopenharmony_ci  "^phy@[0-9a-f]+$":
5862306a36Sopenharmony_ci    type: object
5962306a36Sopenharmony_ci    description: one child node per PHY provided by this block
6062306a36Sopenharmony_ci    properties:
6162306a36Sopenharmony_ci      reg:
6262306a36Sopenharmony_ci        items:
6362306a36Sopenharmony_ci          - description: TX
6462306a36Sopenharmony_ci          - description: RX
6562306a36Sopenharmony_ci          - description: PCS
6662306a36Sopenharmony_ci
6762306a36Sopenharmony_ci      clocks:
6862306a36Sopenharmony_ci        items:
6962306a36Sopenharmony_ci          - description: PIPE clock
7062306a36Sopenharmony_ci
7162306a36Sopenharmony_ci      clock-names:
7262306a36Sopenharmony_ci        deprecated: true
7362306a36Sopenharmony_ci        items:
7462306a36Sopenharmony_ci          - enum:
7562306a36Sopenharmony_ci              - pipe0
7662306a36Sopenharmony_ci              - pipe1
7762306a36Sopenharmony_ci              - pipe2
7862306a36Sopenharmony_ci
7962306a36Sopenharmony_ci      resets:
8062306a36Sopenharmony_ci        items:
8162306a36Sopenharmony_ci          - description: PHY reset
8262306a36Sopenharmony_ci
8362306a36Sopenharmony_ci      reset-names:
8462306a36Sopenharmony_ci        deprecated: true
8562306a36Sopenharmony_ci        items:
8662306a36Sopenharmony_ci          - enum:
8762306a36Sopenharmony_ci              - lane0
8862306a36Sopenharmony_ci              - lane1
8962306a36Sopenharmony_ci              - lane2
9062306a36Sopenharmony_ci
9162306a36Sopenharmony_ci      "#clock-cells":
9262306a36Sopenharmony_ci        const: 0
9362306a36Sopenharmony_ci
9462306a36Sopenharmony_ci      clock-output-names:
9562306a36Sopenharmony_ci        maxItems: 1
9662306a36Sopenharmony_ci
9762306a36Sopenharmony_ci      "#phy-cells":
9862306a36Sopenharmony_ci        const: 0
9962306a36Sopenharmony_ci
10062306a36Sopenharmony_ci    required:
10162306a36Sopenharmony_ci      - reg
10262306a36Sopenharmony_ci      - clocks
10362306a36Sopenharmony_ci      - resets
10462306a36Sopenharmony_ci      - "#clock-cells"
10562306a36Sopenharmony_ci      - clock-output-names
10662306a36Sopenharmony_ci      - "#phy-cells"
10762306a36Sopenharmony_ci
10862306a36Sopenharmony_ci    additionalProperties: false
10962306a36Sopenharmony_ci
11062306a36Sopenharmony_cirequired:
11162306a36Sopenharmony_ci  - compatible
11262306a36Sopenharmony_ci  - reg
11362306a36Sopenharmony_ci  - "#address-cells"
11462306a36Sopenharmony_ci  - "#size-cells"
11562306a36Sopenharmony_ci  - ranges
11662306a36Sopenharmony_ci  - clocks
11762306a36Sopenharmony_ci  - clock-names
11862306a36Sopenharmony_ci  - resets
11962306a36Sopenharmony_ci  - reset-names
12062306a36Sopenharmony_ci  - vdda-phy-supply
12162306a36Sopenharmony_ci  - vdda-pll-supply
12262306a36Sopenharmony_ci
12362306a36Sopenharmony_ciadditionalProperties: false
12462306a36Sopenharmony_ci
12562306a36Sopenharmony_ciexamples:
12662306a36Sopenharmony_ci  - |
12762306a36Sopenharmony_ci    #include <dt-bindings/clock/qcom,gcc-msm8996.h>
12862306a36Sopenharmony_ci    pcie_phy: phy-wrapper@34000 {
12962306a36Sopenharmony_ci        compatible = "qcom,msm8996-qmp-pcie-phy";
13062306a36Sopenharmony_ci        reg = <0x34000 0x488>;
13162306a36Sopenharmony_ci        #address-cells = <1>;
13262306a36Sopenharmony_ci        #size-cells = <1>;
13362306a36Sopenharmony_ci        ranges = <0x0 0x34000 0x4000>;
13462306a36Sopenharmony_ci
13562306a36Sopenharmony_ci        clocks = <&gcc GCC_PCIE_PHY_AUX_CLK>,
13662306a36Sopenharmony_ci                 <&gcc GCC_PCIE_PHY_CFG_AHB_CLK>,
13762306a36Sopenharmony_ci                 <&gcc GCC_PCIE_CLKREF_CLK>;
13862306a36Sopenharmony_ci        clock-names = "aux", "cfg_ahb", "ref";
13962306a36Sopenharmony_ci
14062306a36Sopenharmony_ci        resets = <&gcc GCC_PCIE_PHY_BCR>,
14162306a36Sopenharmony_ci                 <&gcc GCC_PCIE_PHY_COM_BCR>,
14262306a36Sopenharmony_ci                 <&gcc GCC_PCIE_PHY_COM_NOCSR_BCR>;
14362306a36Sopenharmony_ci        reset-names = "phy", "common", "cfg";
14462306a36Sopenharmony_ci
14562306a36Sopenharmony_ci        vdda-phy-supply = <&vreg_l28a_0p925>;
14662306a36Sopenharmony_ci        vdda-pll-supply = <&vreg_l12a_1p8>;
14762306a36Sopenharmony_ci
14862306a36Sopenharmony_ci        pciephy_0: phy@1000 {
14962306a36Sopenharmony_ci            reg = <0x1000 0x130>,
15062306a36Sopenharmony_ci                  <0x1200 0x200>,
15162306a36Sopenharmony_ci                  <0x1400 0x1dc>;
15262306a36Sopenharmony_ci
15362306a36Sopenharmony_ci            clocks = <&gcc GCC_PCIE_0_PIPE_CLK>;
15462306a36Sopenharmony_ci            resets = <&gcc GCC_PCIE_0_PHY_BCR>;
15562306a36Sopenharmony_ci
15662306a36Sopenharmony_ci            #clock-cells = <0>;
15762306a36Sopenharmony_ci            clock-output-names = "pcie_0_pipe_clk_src";
15862306a36Sopenharmony_ci
15962306a36Sopenharmony_ci            #phy-cells = <0>;
16062306a36Sopenharmony_ci        };
16162306a36Sopenharmony_ci
16262306a36Sopenharmony_ci        pciephy_1: phy@2000 {
16362306a36Sopenharmony_ci            reg = <0x2000 0x130>,
16462306a36Sopenharmony_ci                  <0x2200 0x200>,
16562306a36Sopenharmony_ci                  <0x2400 0x1dc>;
16662306a36Sopenharmony_ci
16762306a36Sopenharmony_ci            clocks = <&gcc GCC_PCIE_1_PIPE_CLK>;
16862306a36Sopenharmony_ci            resets = <&gcc GCC_PCIE_1_PHY_BCR>;
16962306a36Sopenharmony_ci
17062306a36Sopenharmony_ci            #clock-cells = <0>;
17162306a36Sopenharmony_ci            clock-output-names = "pcie_1_pipe_clk_src";
17262306a36Sopenharmony_ci
17362306a36Sopenharmony_ci            #phy-cells = <0>;
17462306a36Sopenharmony_ci        };
17562306a36Sopenharmony_ci
17662306a36Sopenharmony_ci        pciephy_2: phy@3000 {
17762306a36Sopenharmony_ci            reg = <0x3000 0x130>,
17862306a36Sopenharmony_ci                  <0x3200 0x200>,
17962306a36Sopenharmony_ci                  <0x3400 0x1dc>;
18062306a36Sopenharmony_ci
18162306a36Sopenharmony_ci            clocks = <&gcc GCC_PCIE_2_PIPE_CLK>;
18262306a36Sopenharmony_ci            resets = <&gcc GCC_PCIE_2_PHY_BCR>;
18362306a36Sopenharmony_ci
18462306a36Sopenharmony_ci            #clock-cells = <0>;
18562306a36Sopenharmony_ci            clock-output-names = "pcie_2_pipe_clk_src";
18662306a36Sopenharmony_ci
18762306a36Sopenharmony_ci            #phy-cells = <0>;
18862306a36Sopenharmony_ci        };
18962306a36Sopenharmony_ci    };
190