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/spi/qcom,spi-geni-qcom.yaml# 562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml# 662306a36Sopenharmony_ci 762306a36Sopenharmony_cititle: GENI based Qualcomm Universal Peripheral (QUP) Serial Peripheral Interface (SPI) 862306a36Sopenharmony_ci 962306a36Sopenharmony_cimaintainers: 1062306a36Sopenharmony_ci - Andy Gross <agross@kernel.org> 1162306a36Sopenharmony_ci - Bjorn Andersson <bjorn.andersson@linaro.org> 1262306a36Sopenharmony_ci - Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org> 1362306a36Sopenharmony_ci 1462306a36Sopenharmony_cidescription: 1562306a36Sopenharmony_ci The QUP v3 core is a GENI based AHB slave that provides a common data path 1662306a36Sopenharmony_ci (an output FIFO and an input FIFO) for serial peripheral interface (SPI) 1762306a36Sopenharmony_ci mini-core. 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_ci SPI in master mode supports up to 50MHz, up to four chip selects, 2062306a36Sopenharmony_ci programmable data path from 4 bits to 32 bits and numerous protocol variants. 2162306a36Sopenharmony_ci 2262306a36Sopenharmony_ci SPI Controller nodes must be child of GENI based Qualcomm Universal 2362306a36Sopenharmony_ci Peripharal. Please refer GENI based QUP wrapper controller node bindings 2462306a36Sopenharmony_ci described in Documentation/devicetree/bindings/soc/qcom/qcom,geni-se.yaml. 2562306a36Sopenharmony_ci 2662306a36Sopenharmony_ciallOf: 2762306a36Sopenharmony_ci - $ref: /schemas/spi/spi-controller.yaml# 2862306a36Sopenharmony_ci 2962306a36Sopenharmony_ciproperties: 3062306a36Sopenharmony_ci compatible: 3162306a36Sopenharmony_ci const: qcom,geni-spi 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_ci clocks: 3462306a36Sopenharmony_ci maxItems: 1 3562306a36Sopenharmony_ci 3662306a36Sopenharmony_ci clock-names: 3762306a36Sopenharmony_ci const: se 3862306a36Sopenharmony_ci 3962306a36Sopenharmony_ci dmas: 4062306a36Sopenharmony_ci maxItems: 2 4162306a36Sopenharmony_ci 4262306a36Sopenharmony_ci dma-names: 4362306a36Sopenharmony_ci items: 4462306a36Sopenharmony_ci - const: tx 4562306a36Sopenharmony_ci - const: rx 4662306a36Sopenharmony_ci 4762306a36Sopenharmony_ci interconnects: 4862306a36Sopenharmony_ci minItems: 2 4962306a36Sopenharmony_ci maxItems: 3 5062306a36Sopenharmony_ci 5162306a36Sopenharmony_ci interconnect-names: 5262306a36Sopenharmony_ci minItems: 2 5362306a36Sopenharmony_ci items: 5462306a36Sopenharmony_ci - const: qup-core 5562306a36Sopenharmony_ci - const: qup-config 5662306a36Sopenharmony_ci - const: qup-memory 5762306a36Sopenharmony_ci 5862306a36Sopenharmony_ci interrupts: 5962306a36Sopenharmony_ci maxItems: 1 6062306a36Sopenharmony_ci 6162306a36Sopenharmony_ci operating-points-v2: true 6262306a36Sopenharmony_ci 6362306a36Sopenharmony_ci power-domains: 6462306a36Sopenharmony_ci maxItems: 1 6562306a36Sopenharmony_ci 6662306a36Sopenharmony_ci reg: 6762306a36Sopenharmony_ci maxItems: 1 6862306a36Sopenharmony_ci 6962306a36Sopenharmony_cirequired: 7062306a36Sopenharmony_ci - compatible 7162306a36Sopenharmony_ci - clocks 7262306a36Sopenharmony_ci - clock-names 7362306a36Sopenharmony_ci - interrupts 7462306a36Sopenharmony_ci - reg 7562306a36Sopenharmony_ci 7662306a36Sopenharmony_ciunevaluatedProperties: false 7762306a36Sopenharmony_ci 7862306a36Sopenharmony_ciexamples: 7962306a36Sopenharmony_ci - | 8062306a36Sopenharmony_ci #include <dt-bindings/clock/qcom,gcc-sc7180.h> 8162306a36Sopenharmony_ci #include <dt-bindings/interconnect/qcom,sc7180.h> 8262306a36Sopenharmony_ci #include <dt-bindings/interrupt-controller/arm-gic.h> 8362306a36Sopenharmony_ci #include <dt-bindings/power/qcom-rpmpd.h> 8462306a36Sopenharmony_ci 8562306a36Sopenharmony_ci spi@880000 { 8662306a36Sopenharmony_ci compatible = "qcom,geni-spi"; 8762306a36Sopenharmony_ci reg = <0x00880000 0x4000>; 8862306a36Sopenharmony_ci clock-names = "se"; 8962306a36Sopenharmony_ci clocks = <&gcc GCC_QUPV3_WRAP0_S0_CLK>; 9062306a36Sopenharmony_ci pinctrl-names = "default"; 9162306a36Sopenharmony_ci pinctrl-0 = <&qup_spi0_default>; 9262306a36Sopenharmony_ci interrupts = <GIC_SPI 601 IRQ_TYPE_LEVEL_HIGH>; 9362306a36Sopenharmony_ci #address-cells = <1>; 9462306a36Sopenharmony_ci #size-cells = <0>; 9562306a36Sopenharmony_ci power-domains = <&rpmhpd SC7180_CX>; 9662306a36Sopenharmony_ci operating-points-v2 = <&qup_opp_table>; 9762306a36Sopenharmony_ci interconnects = <&qup_virt MASTER_QUP_CORE_0 0 &qup_virt SLAVE_QUP_CORE_0 0>, 9862306a36Sopenharmony_ci <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_0 0>; 9962306a36Sopenharmony_ci interconnect-names = "qup-core", "qup-config"; 10062306a36Sopenharmony_ci }; 10162306a36Sopenharmony_ci 10262306a36Sopenharmony_ci - | 10362306a36Sopenharmony_ci #include <dt-bindings/dma/qcom-gpi.h> 10462306a36Sopenharmony_ci 10562306a36Sopenharmony_ci spi@884000 { 10662306a36Sopenharmony_ci compatible = "qcom,geni-spi"; 10762306a36Sopenharmony_ci reg = <0x00884000 0x4000>; 10862306a36Sopenharmony_ci clock-names = "se"; 10962306a36Sopenharmony_ci clocks = <&gcc GCC_QUPV3_WRAP0_S1_CLK>; 11062306a36Sopenharmony_ci dmas = <&gpi_dma0 0 1 QCOM_GPI_SPI>, 11162306a36Sopenharmony_ci <&gpi_dma0 1 1 QCOM_GPI_SPI>; 11262306a36Sopenharmony_ci dma-names = "tx", "rx"; 11362306a36Sopenharmony_ci pinctrl-names = "default"; 11462306a36Sopenharmony_ci pinctrl-0 = <&qup_spi1_default>; 11562306a36Sopenharmony_ci interrupts = <GIC_SPI 602 IRQ_TYPE_LEVEL_HIGH>; 11662306a36Sopenharmony_ci #address-cells = <1>; 11762306a36Sopenharmony_ci #size-cells = <0>; 11862306a36Sopenharmony_ci }; 119