dmaengine: sun6i: Add support for Allwinner A83T (sun8i) variant
authorJean-Francois Moine <moinejf@free.fr>
Sun, 18 Sep 2016 07:59:50 +0000 (09:59 +0200)
committerVinod Koul <vinod.koul@intel.com>
Mon, 26 Sep 2016 17:45:06 +0000 (23:15 +0530)
The A83T SoC has the same dma engine as the A31 (sun6i), with a reduced
amount of endpoints and physical channels.

Signed-off-by: Jean-Francois Moine <moinejf@free.fr>
Acked-by: Maxime Ripard <maxime.ripard@free-electrons.com>
Signed-off-by: Vinod Koul <vinod.koul@intel.com>
Documentation/devicetree/bindings/dma/sun6i-dma.txt
drivers/dma/sun6i-dma.c

index d13c136cef8c4384ae663626aa7318d5543e2333..6b267045f5221c40524e9da19cf28bd1e2c3d8c6 100644 (file)
@@ -7,6 +7,7 @@ Required properties:
 - compatible:  Must be one of
                  "allwinner,sun6i-a31-dma"
                  "allwinner,sun8i-a23-dma"
+                 "allwinner,sun8i-a83t-dma"
                  "allwinner,sun8i-h3-dma"
 - reg:         Should contain the registers base address and length
 - interrupts:  Should contain a reference to the interrupt used by this device
index 3835fcde35456fb20e89e77d5b02644b98df4df8..83461994e4181a67b73c5ceaa7bfb24bada1f9d5 100644 (file)
@@ -1011,6 +1011,12 @@ static struct sun6i_dma_config sun8i_a23_dma_cfg = {
        .nr_max_vchans   = 37,
 };
 
+static struct sun6i_dma_config sun8i_a83t_dma_cfg = {
+       .nr_max_channels = 8,
+       .nr_max_requests = 28,
+       .nr_max_vchans   = 39,
+};
+
 /*
  * The H3 has 12 physical channels, a maximum DRQ port id of 27,
  * and a total of 34 usable source and destination endpoints.
@@ -1025,6 +1031,7 @@ static struct sun6i_dma_config sun8i_h3_dma_cfg = {
 static const struct of_device_id sun6i_dma_match[] = {
        { .compatible = "allwinner,sun6i-a31-dma", .data = &sun6i_a31_dma_cfg },
        { .compatible = "allwinner,sun8i-a23-dma", .data = &sun8i_a23_dma_cfg },
+       { .compatible = "allwinner,sun8i-a83t-dma", .data = &sun8i_a83t_dma_cfg },
        { .compatible = "allwinner,sun8i-h3-dma", .data = &sun8i_h3_dma_cfg },
        { /* sentinel */ }
 };