arm64: tegra: Add dma-channel-mask in GPCDMA node
authorAkhil R <akhilrajeev@nvidia.com>
Thu, 10 Nov 2022 17:17:47 +0000 (22:47 +0530)
committerThierry Reding <treding@nvidia.com>
Mon, 21 Nov 2022 12:30:13 +0000 (13:30 +0100)
Add dma-channel-mask property in Tegra GPCDMA device tree node.

The property would help to specify the channels to be used in
kernel and reserve few for the firmware. This was previously
achieved by limiting the channel number to 31 in the driver.
This is wrong and does not align with the hardware. Correct this
and update the interrupts property to list all 32 interrupts.

Signed-off-by: Akhil R <akhilrajeev@nvidia.com>
Signed-off-by: Thierry Reding <treding@nvidia.com>
arch/arm64/boot/dts/nvidia/tegra186.dtsi
arch/arm64/boot/dts/nvidia/tegra194.dtsi
arch/arm64/boot/dts/nvidia/tegra234.dtsi

index bd4a099fca01cf0d25d525dce6573d16c97a17b1..b3f1494c02c11e639356c69aee1ba80d3983122e 100644 (file)
@@ -78,7 +78,8 @@
                reg = <0x0 0x2600000 0x0 0x210000>;
                resets = <&bpmp TEGRA186_RESET_GPCDMA>;
                reset-names = "gpcdma";
-               interrupts = <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>,
+               interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>,
+                            <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>,
                             <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>,
                             <GIC_SPI 78 IRQ_TYPE_LEVEL_HIGH>,
                             <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>,
                #dma-cells = <1>;
                iommus = <&smmu TEGRA186_SID_GPCDMA_0>;
                dma-coherent;
+               dma-channel-mask = <0xfffffffe>;
                status = "okay";
        };
 
index c6c10580e664c63e2cd4d531cd8707bc0dec3da2..a6721bb82bbd6f2fe4cd85ff48f45fb9c1cb5b1b 100644 (file)
                        reg = <0x2600000 0x210000>;
                        resets = <&bpmp TEGRA194_RESET_GPCDMA>;
                        reset-names = "gpcdma";
-                       interrupts = <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>,
+                       interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>,
+                                    <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>,
                                     <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>,
                                     <GIC_SPI 78 IRQ_TYPE_LEVEL_HIGH>,
                                     <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>,
                        #dma-cells = <1>;
                        iommus = <&smmu TEGRA194_SID_GPCDMA_0>;
                        dma-coherent;
+                       dma-channel-mask = <0xfffffffe>;
                        status = "okay";
                };
 
index aa278f565eea71e77eab32da9614fe61bab6201f..97d47327afdd847b615dce41903b4122bc1d714c 100644 (file)
@@ -28,7 +28,8 @@
                        reg = <0x2600000 0x210000>;
                        resets = <&bpmp TEGRA234_RESET_GPCDMA>;
                        reset-names = "gpcdma";
-                       interrupts = <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>,
+                       interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>,
+                                    <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>,
                                     <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>,
                                     <GIC_SPI 78 IRQ_TYPE_LEVEL_HIGH>,
                                     <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>,
@@ -61,6 +62,7 @@
                                     <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>;
                        #dma-cells = <1>;
                        iommus = <&smmu_niso0 TEGRA234_SID_GPCDMA>;
+                       dma-channel-mask = <0xfffffffe>;
                        dma-coherent;
                };