]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
arm64: dts: qcom: ipq5424: Add QPIC SPI NAND controller support
authorMd Sadre Alam <quic_mdalam@quicinc.com>
Fri, 6 Mar 2026 11:39:37 +0000 (17:09 +0530)
committerBjorn Andersson <andersson@kernel.org>
Thu, 26 Mar 2026 14:40:54 +0000 (09:40 -0500)
Add device tree nodes for QPIC SPI NAND flash controller support
on IPQ5424 SoC.

The IPQ5424 SoC includes a QPIC controller that supports SPI NAND flash
devices with hardware ECC capabilities and DMA support through BAM
(Bus Access Manager).

Reviewed-by: Konrad Dybcio <konrad.dybcio@oss.qualcomm.com>
Signed-off-by: Md Sadre Alam <quic_mdalam@quicinc.com>
Link: https://lore.kernel.org/r/20260306113940.1654304-2-quic_mdalam@quicinc.com
Signed-off-by: Bjorn Andersson <andersson@kernel.org>
arch/arm64/boot/dts/qcom/ipq5424.dtsi

index eb393f3fd728f0b2fc8cd93c849f8c170d76e312..f20cda429094971dff47495be1dd2ab9157a8ef3 100644 (file)
                        status = "disabled";
                };
 
+               qpic_bam: dma-controller@7984000 {
+                       compatible = "qcom,bam-v1.7.4", "qcom,bam-v1.7.0";
+                       reg = <0x0 0x07984000 0x0 0x1c000>;
+                       interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
+                       clocks = <&gcc GCC_QPIC_AHB_CLK>;
+                       clock-names = "bam_clk";
+                       #dma-cells = <1>;
+                       qcom,ee = <0>;
+                       status = "disabled";
+               };
+
+               qpic_nand: spi@79b0000 {
+                       compatible = "qcom,ipq5424-snand", "qcom,ipq9574-snand";
+                       reg = <0x0 0x079b0000 0x0 0x10000>;
+                       #address-cells = <1>;
+                       #size-cells = <0>;
+                       clocks = <&gcc GCC_QPIC_CLK>,
+                                <&gcc GCC_QPIC_AHB_CLK>,
+                                <&gcc GCC_QPIC_IO_MACRO_CLK>;
+                       clock-names = "core",
+                                     "aon",
+                                     "iom";
+
+                       dmas = <&qpic_bam 0>,
+                              <&qpic_bam 1>,
+                              <&qpic_bam 2>;
+                       dma-names = "tx",
+                                   "rx",
+                                   "cmd";
+
+                       status = "disabled";
+               };
+
                intc: interrupt-controller@f200000 {
                        compatible = "arm,gic-v3";
                        reg = <0 0xf200000 0 0x10000>, /* GICD */