]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
ARM: dts: bcm6846: Add ARM PL081 DMA block
authorLinus Walleij <linus.walleij@linaro.org>
Sat, 19 Oct 2024 20:39:35 +0000 (22:39 +0200)
committerFlorian Fainelli <florian.fainelli@broadcom.com>
Tue, 17 Dec 2024 18:23:28 +0000 (10:23 -0800)
The ARM PL081 DMA controller can be found in the BCM6846
memory map, and it turns out to work.

The block may be used as DMA engine for some of the
peripherals (maybe the EMMC controller found in the same
group of peripherals?) but it can always be used as a
memcpy engine, which is a generic "blitter".

I tested it with the dmatest module, and it copies
lots of data very fast and fires hundreds of thousands
of interrupts so it works just fine.

Add it to the BCM6846 DTSI file.

Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Link: https://lore.kernel.org/r/20241019-genexis-xg6846b-base-v3-6-8375a0e1f89f@linaro.org
Signed-off-by: Florian Fainelli <florian.fainelli@broadcom.com>
arch/arm/boot/dts/broadcom/bcm6846.dtsi

index 378dbd1b41b312badf691e44f086018716bf6d41..e0e06af3fe891df3c3d8c2005cf1980d33a7762b 100644 (file)
                        #size-cells = <0>;
                        status = "disabled";
                };
+
+               pl081_dma: dma-controller@59000 {
+                       compatible = "arm,pl081", "arm,primecell";
+                       // The magic B105F00D info is missing
+                       arm,primecell-periphid = <0x00041081>;
+                       reg = <0x59000 0x1000>;
+                       interrupts = <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>;
+                       memcpy-burst-size = <256>;
+                       memcpy-bus-width = <32>;
+                       clocks = <&periph_clk>;
+                       clock-names = "apb_pclk";
+                       #dma-cells = <2>;
+               };
        };
 };