162306a36Sopenharmony_ci# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause 262306a36Sopenharmony_ci%YAML 1.2 362306a36Sopenharmony_ci--- 462306a36Sopenharmony_ci$id: http://devicetree.org/schemas/ufs/qcom,ufs.yaml# 562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml# 662306a36Sopenharmony_ci 762306a36Sopenharmony_cititle: Qualcomm Universal Flash Storage (UFS) Controller 862306a36Sopenharmony_ci 962306a36Sopenharmony_cimaintainers: 1062306a36Sopenharmony_ci - Bjorn Andersson <bjorn.andersson@linaro.org> 1162306a36Sopenharmony_ci - Andy Gross <agross@kernel.org> 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_ci# Select only our matches, not all jedec,ufs-2.0 1462306a36Sopenharmony_ciselect: 1562306a36Sopenharmony_ci properties: 1662306a36Sopenharmony_ci compatible: 1762306a36Sopenharmony_ci contains: 1862306a36Sopenharmony_ci const: qcom,ufshc 1962306a36Sopenharmony_ci required: 2062306a36Sopenharmony_ci - compatible 2162306a36Sopenharmony_ci 2262306a36Sopenharmony_ciproperties: 2362306a36Sopenharmony_ci compatible: 2462306a36Sopenharmony_ci items: 2562306a36Sopenharmony_ci - enum: 2662306a36Sopenharmony_ci - qcom,msm8994-ufshc 2762306a36Sopenharmony_ci - qcom,msm8996-ufshc 2862306a36Sopenharmony_ci - qcom,msm8998-ufshc 2962306a36Sopenharmony_ci - qcom,sa8775p-ufshc 3062306a36Sopenharmony_ci - qcom,sc8280xp-ufshc 3162306a36Sopenharmony_ci - qcom,sdm845-ufshc 3262306a36Sopenharmony_ci - qcom,sm6115-ufshc 3362306a36Sopenharmony_ci - qcom,sm6350-ufshc 3462306a36Sopenharmony_ci - qcom,sm8150-ufshc 3562306a36Sopenharmony_ci - qcom,sm8250-ufshc 3662306a36Sopenharmony_ci - qcom,sm8350-ufshc 3762306a36Sopenharmony_ci - qcom,sm8450-ufshc 3862306a36Sopenharmony_ci - qcom,sm8550-ufshc 3962306a36Sopenharmony_ci - const: qcom,ufshc 4062306a36Sopenharmony_ci - const: jedec,ufs-2.0 4162306a36Sopenharmony_ci 4262306a36Sopenharmony_ci clocks: 4362306a36Sopenharmony_ci minItems: 8 4462306a36Sopenharmony_ci maxItems: 11 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_ci clock-names: 4762306a36Sopenharmony_ci minItems: 8 4862306a36Sopenharmony_ci maxItems: 11 4962306a36Sopenharmony_ci 5062306a36Sopenharmony_ci dma-coherent: true 5162306a36Sopenharmony_ci 5262306a36Sopenharmony_ci interconnects: 5362306a36Sopenharmony_ci minItems: 2 5462306a36Sopenharmony_ci maxItems: 2 5562306a36Sopenharmony_ci 5662306a36Sopenharmony_ci interconnect-names: 5762306a36Sopenharmony_ci items: 5862306a36Sopenharmony_ci - const: ufs-ddr 5962306a36Sopenharmony_ci - const: cpu-ufs 6062306a36Sopenharmony_ci 6162306a36Sopenharmony_ci iommus: 6262306a36Sopenharmony_ci minItems: 1 6362306a36Sopenharmony_ci maxItems: 2 6462306a36Sopenharmony_ci 6562306a36Sopenharmony_ci phys: 6662306a36Sopenharmony_ci maxItems: 1 6762306a36Sopenharmony_ci 6862306a36Sopenharmony_ci phy-names: 6962306a36Sopenharmony_ci items: 7062306a36Sopenharmony_ci - const: ufsphy 7162306a36Sopenharmony_ci 7262306a36Sopenharmony_ci power-domains: 7362306a36Sopenharmony_ci maxItems: 1 7462306a36Sopenharmony_ci 7562306a36Sopenharmony_ci qcom,ice: 7662306a36Sopenharmony_ci $ref: /schemas/types.yaml#/definitions/phandle 7762306a36Sopenharmony_ci description: phandle to the Inline Crypto Engine node 7862306a36Sopenharmony_ci 7962306a36Sopenharmony_ci reg: 8062306a36Sopenharmony_ci minItems: 1 8162306a36Sopenharmony_ci maxItems: 2 8262306a36Sopenharmony_ci 8362306a36Sopenharmony_ci reg-names: 8462306a36Sopenharmony_ci items: 8562306a36Sopenharmony_ci - const: std 8662306a36Sopenharmony_ci - const: ice 8762306a36Sopenharmony_ci 8862306a36Sopenharmony_ci required-opps: 8962306a36Sopenharmony_ci maxItems: 1 9062306a36Sopenharmony_ci 9162306a36Sopenharmony_ci resets: 9262306a36Sopenharmony_ci maxItems: 1 9362306a36Sopenharmony_ci 9462306a36Sopenharmony_ci '#reset-cells': 9562306a36Sopenharmony_ci const: 1 9662306a36Sopenharmony_ci 9762306a36Sopenharmony_ci reset-names: 9862306a36Sopenharmony_ci items: 9962306a36Sopenharmony_ci - const: rst 10062306a36Sopenharmony_ci 10162306a36Sopenharmony_ci reset-gpios: 10262306a36Sopenharmony_ci maxItems: 1 10362306a36Sopenharmony_ci description: 10462306a36Sopenharmony_ci GPIO connected to the RESET pin of the UFS memory device. 10562306a36Sopenharmony_ci 10662306a36Sopenharmony_cirequired: 10762306a36Sopenharmony_ci - compatible 10862306a36Sopenharmony_ci - reg 10962306a36Sopenharmony_ci 11062306a36Sopenharmony_ciallOf: 11162306a36Sopenharmony_ci - $ref: ufs-common.yaml 11262306a36Sopenharmony_ci 11362306a36Sopenharmony_ci - if: 11462306a36Sopenharmony_ci properties: 11562306a36Sopenharmony_ci compatible: 11662306a36Sopenharmony_ci contains: 11762306a36Sopenharmony_ci enum: 11862306a36Sopenharmony_ci - qcom,msm8998-ufshc 11962306a36Sopenharmony_ci - qcom,sa8775p-ufshc 12062306a36Sopenharmony_ci - qcom,sc8280xp-ufshc 12162306a36Sopenharmony_ci - qcom,sm8250-ufshc 12262306a36Sopenharmony_ci - qcom,sm8350-ufshc 12362306a36Sopenharmony_ci - qcom,sm8450-ufshc 12462306a36Sopenharmony_ci - qcom,sm8550-ufshc 12562306a36Sopenharmony_ci then: 12662306a36Sopenharmony_ci properties: 12762306a36Sopenharmony_ci clocks: 12862306a36Sopenharmony_ci minItems: 8 12962306a36Sopenharmony_ci maxItems: 8 13062306a36Sopenharmony_ci clock-names: 13162306a36Sopenharmony_ci items: 13262306a36Sopenharmony_ci - const: core_clk 13362306a36Sopenharmony_ci - const: bus_aggr_clk 13462306a36Sopenharmony_ci - const: iface_clk 13562306a36Sopenharmony_ci - const: core_clk_unipro 13662306a36Sopenharmony_ci - const: ref_clk 13762306a36Sopenharmony_ci - const: tx_lane0_sync_clk 13862306a36Sopenharmony_ci - const: rx_lane0_sync_clk 13962306a36Sopenharmony_ci - const: rx_lane1_sync_clk 14062306a36Sopenharmony_ci reg: 14162306a36Sopenharmony_ci minItems: 1 14262306a36Sopenharmony_ci maxItems: 1 14362306a36Sopenharmony_ci reg-names: 14462306a36Sopenharmony_ci maxItems: 1 14562306a36Sopenharmony_ci 14662306a36Sopenharmony_ci - if: 14762306a36Sopenharmony_ci properties: 14862306a36Sopenharmony_ci compatible: 14962306a36Sopenharmony_ci contains: 15062306a36Sopenharmony_ci enum: 15162306a36Sopenharmony_ci - qcom,sdm845-ufshc 15262306a36Sopenharmony_ci - qcom,sm6350-ufshc 15362306a36Sopenharmony_ci - qcom,sm8150-ufshc 15462306a36Sopenharmony_ci then: 15562306a36Sopenharmony_ci properties: 15662306a36Sopenharmony_ci clocks: 15762306a36Sopenharmony_ci minItems: 9 15862306a36Sopenharmony_ci maxItems: 9 15962306a36Sopenharmony_ci clock-names: 16062306a36Sopenharmony_ci items: 16162306a36Sopenharmony_ci - const: core_clk 16262306a36Sopenharmony_ci - const: bus_aggr_clk 16362306a36Sopenharmony_ci - const: iface_clk 16462306a36Sopenharmony_ci - const: core_clk_unipro 16562306a36Sopenharmony_ci - const: ref_clk 16662306a36Sopenharmony_ci - const: tx_lane0_sync_clk 16762306a36Sopenharmony_ci - const: rx_lane0_sync_clk 16862306a36Sopenharmony_ci - const: rx_lane1_sync_clk 16962306a36Sopenharmony_ci - const: ice_core_clk 17062306a36Sopenharmony_ci reg: 17162306a36Sopenharmony_ci minItems: 2 17262306a36Sopenharmony_ci maxItems: 2 17362306a36Sopenharmony_ci reg-names: 17462306a36Sopenharmony_ci minItems: 2 17562306a36Sopenharmony_ci required: 17662306a36Sopenharmony_ci - reg-names 17762306a36Sopenharmony_ci 17862306a36Sopenharmony_ci - if: 17962306a36Sopenharmony_ci properties: 18062306a36Sopenharmony_ci compatible: 18162306a36Sopenharmony_ci contains: 18262306a36Sopenharmony_ci enum: 18362306a36Sopenharmony_ci - qcom,msm8996-ufshc 18462306a36Sopenharmony_ci then: 18562306a36Sopenharmony_ci properties: 18662306a36Sopenharmony_ci clocks: 18762306a36Sopenharmony_ci minItems: 11 18862306a36Sopenharmony_ci maxItems: 11 18962306a36Sopenharmony_ci clock-names: 19062306a36Sopenharmony_ci items: 19162306a36Sopenharmony_ci - const: core_clk_src 19262306a36Sopenharmony_ci - const: core_clk 19362306a36Sopenharmony_ci - const: bus_clk 19462306a36Sopenharmony_ci - const: bus_aggr_clk 19562306a36Sopenharmony_ci - const: iface_clk 19662306a36Sopenharmony_ci - const: core_clk_unipro_src 19762306a36Sopenharmony_ci - const: core_clk_unipro 19862306a36Sopenharmony_ci - const: core_clk_ice 19962306a36Sopenharmony_ci - const: ref_clk 20062306a36Sopenharmony_ci - const: tx_lane0_sync_clk 20162306a36Sopenharmony_ci - const: rx_lane0_sync_clk 20262306a36Sopenharmony_ci reg: 20362306a36Sopenharmony_ci minItems: 1 20462306a36Sopenharmony_ci maxItems: 1 20562306a36Sopenharmony_ci reg-names: 20662306a36Sopenharmony_ci maxItems: 1 20762306a36Sopenharmony_ci 20862306a36Sopenharmony_ci - if: 20962306a36Sopenharmony_ci properties: 21062306a36Sopenharmony_ci compatible: 21162306a36Sopenharmony_ci contains: 21262306a36Sopenharmony_ci enum: 21362306a36Sopenharmony_ci - qcom,sm6115-ufshc 21462306a36Sopenharmony_ci then: 21562306a36Sopenharmony_ci properties: 21662306a36Sopenharmony_ci clocks: 21762306a36Sopenharmony_ci minItems: 8 21862306a36Sopenharmony_ci maxItems: 8 21962306a36Sopenharmony_ci clock-names: 22062306a36Sopenharmony_ci items: 22162306a36Sopenharmony_ci - const: core_clk 22262306a36Sopenharmony_ci - const: bus_aggr_clk 22362306a36Sopenharmony_ci - const: iface_clk 22462306a36Sopenharmony_ci - const: core_clk_unipro 22562306a36Sopenharmony_ci - const: ref_clk 22662306a36Sopenharmony_ci - const: tx_lane0_sync_clk 22762306a36Sopenharmony_ci - const: rx_lane0_sync_clk 22862306a36Sopenharmony_ci - const: ice_core_clk 22962306a36Sopenharmony_ci reg: 23062306a36Sopenharmony_ci minItems: 2 23162306a36Sopenharmony_ci maxItems: 2 23262306a36Sopenharmony_ci reg-names: 23362306a36Sopenharmony_ci minItems: 2 23462306a36Sopenharmony_ci required: 23562306a36Sopenharmony_ci - reg-names 23662306a36Sopenharmony_ci 23762306a36Sopenharmony_ci # TODO: define clock bindings for qcom,msm8994-ufshc 23862306a36Sopenharmony_ci 23962306a36Sopenharmony_ci - if: 24062306a36Sopenharmony_ci required: 24162306a36Sopenharmony_ci - qcom,ice 24262306a36Sopenharmony_ci then: 24362306a36Sopenharmony_ci properties: 24462306a36Sopenharmony_ci reg: 24562306a36Sopenharmony_ci maxItems: 1 24662306a36Sopenharmony_ci clocks: 24762306a36Sopenharmony_ci minItems: 8 24862306a36Sopenharmony_ci maxItems: 8 24962306a36Sopenharmony_ci else: 25062306a36Sopenharmony_ci properties: 25162306a36Sopenharmony_ci reg: 25262306a36Sopenharmony_ci minItems: 1 25362306a36Sopenharmony_ci maxItems: 2 25462306a36Sopenharmony_ci clocks: 25562306a36Sopenharmony_ci minItems: 8 25662306a36Sopenharmony_ci maxItems: 11 25762306a36Sopenharmony_ci 25862306a36Sopenharmony_ciunevaluatedProperties: false 25962306a36Sopenharmony_ci 26062306a36Sopenharmony_ciexamples: 26162306a36Sopenharmony_ci - | 26262306a36Sopenharmony_ci #include <dt-bindings/clock/qcom,gcc-sm8450.h> 26362306a36Sopenharmony_ci #include <dt-bindings/clock/qcom,rpmh.h> 26462306a36Sopenharmony_ci #include <dt-bindings/gpio/gpio.h> 26562306a36Sopenharmony_ci #include <dt-bindings/interconnect/qcom,sm8450.h> 26662306a36Sopenharmony_ci #include <dt-bindings/interrupt-controller/arm-gic.h> 26762306a36Sopenharmony_ci 26862306a36Sopenharmony_ci soc { 26962306a36Sopenharmony_ci #address-cells = <2>; 27062306a36Sopenharmony_ci #size-cells = <2>; 27162306a36Sopenharmony_ci 27262306a36Sopenharmony_ci ufs@1d84000 { 27362306a36Sopenharmony_ci compatible = "qcom,sm8450-ufshc", "qcom,ufshc", 27462306a36Sopenharmony_ci "jedec,ufs-2.0"; 27562306a36Sopenharmony_ci reg = <0 0x01d84000 0 0x3000>; 27662306a36Sopenharmony_ci interrupts = <GIC_SPI 265 IRQ_TYPE_LEVEL_HIGH>; 27762306a36Sopenharmony_ci phys = <&ufs_mem_phy_lanes>; 27862306a36Sopenharmony_ci phy-names = "ufsphy"; 27962306a36Sopenharmony_ci lanes-per-direction = <2>; 28062306a36Sopenharmony_ci #reset-cells = <1>; 28162306a36Sopenharmony_ci resets = <&gcc GCC_UFS_PHY_BCR>; 28262306a36Sopenharmony_ci reset-names = "rst"; 28362306a36Sopenharmony_ci reset-gpios = <&tlmm 210 GPIO_ACTIVE_LOW>; 28462306a36Sopenharmony_ci 28562306a36Sopenharmony_ci vcc-supply = <&vreg_l7b_2p5>; 28662306a36Sopenharmony_ci vcc-max-microamp = <1100000>; 28762306a36Sopenharmony_ci vccq-supply = <&vreg_l9b_1p2>; 28862306a36Sopenharmony_ci vccq-max-microamp = <1200000>; 28962306a36Sopenharmony_ci 29062306a36Sopenharmony_ci power-domains = <&gcc UFS_PHY_GDSC>; 29162306a36Sopenharmony_ci iommus = <&apps_smmu 0xe0 0x0>; 29262306a36Sopenharmony_ci interconnects = <&aggre1_noc MASTER_UFS_MEM &mc_virt SLAVE_EBI1>, 29362306a36Sopenharmony_ci <&gem_noc MASTER_APPSS_PROC &config_noc SLAVE_UFS_MEM_CFG>; 29462306a36Sopenharmony_ci interconnect-names = "ufs-ddr", "cpu-ufs"; 29562306a36Sopenharmony_ci 29662306a36Sopenharmony_ci clock-names = "core_clk", 29762306a36Sopenharmony_ci "bus_aggr_clk", 29862306a36Sopenharmony_ci "iface_clk", 29962306a36Sopenharmony_ci "core_clk_unipro", 30062306a36Sopenharmony_ci "ref_clk", 30162306a36Sopenharmony_ci "tx_lane0_sync_clk", 30262306a36Sopenharmony_ci "rx_lane0_sync_clk", 30362306a36Sopenharmony_ci "rx_lane1_sync_clk"; 30462306a36Sopenharmony_ci clocks = <&gcc GCC_UFS_PHY_AXI_CLK>, 30562306a36Sopenharmony_ci <&gcc GCC_AGGRE_UFS_PHY_AXI_CLK>, 30662306a36Sopenharmony_ci <&gcc GCC_UFS_PHY_AHB_CLK>, 30762306a36Sopenharmony_ci <&gcc GCC_UFS_PHY_UNIPRO_CORE_CLK>, 30862306a36Sopenharmony_ci <&rpmhcc RPMH_CXO_CLK>, 30962306a36Sopenharmony_ci <&gcc GCC_UFS_PHY_TX_SYMBOL_0_CLK>, 31062306a36Sopenharmony_ci <&gcc GCC_UFS_PHY_RX_SYMBOL_0_CLK>, 31162306a36Sopenharmony_ci <&gcc GCC_UFS_PHY_RX_SYMBOL_1_CLK>; 31262306a36Sopenharmony_ci freq-table-hz = <75000000 300000000>, 31362306a36Sopenharmony_ci <0 0>, 31462306a36Sopenharmony_ci <0 0>, 31562306a36Sopenharmony_ci <75000000 300000000>, 31662306a36Sopenharmony_ci <75000000 300000000>, 31762306a36Sopenharmony_ci <0 0>, 31862306a36Sopenharmony_ci <0 0>, 31962306a36Sopenharmony_ci <0 0>; 32062306a36Sopenharmony_ci qcom,ice = <&ice>; 32162306a36Sopenharmony_ci }; 32262306a36Sopenharmony_ci }; 323