Commit 6eb439df authored by Frank Li's avatar Frank Li Committed by Vinod Koul

dt-bindings: fsl-dma: fsl-edma: add edma3 compatible string

Extend Freescale eDMA driver bindings to support eDMA3 IP blocks in
i.MX8QM and i.MX8QXP SoCs. In i.MX93, both eDMA3 and eDMA4 are now.
Reviewed-by: default avatarKrzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
Signed-off-by: default avatarFrank Li <Frank.Li@nxp.com>
Link: https://lore.kernel.org/r/20230821161617.2142561-12-Frank.Li@nxp.comSigned-off-by: default avatarVinod Koul <vkoul@kernel.org>
parent 7536f8b3
...@@ -21,32 +21,41 @@ properties: ...@@ -21,32 +21,41 @@ properties:
- enum: - enum:
- fsl,vf610-edma - fsl,vf610-edma
- fsl,imx7ulp-edma - fsl,imx7ulp-edma
- fsl,imx8qm-adma
- fsl,imx8qm-edma
- fsl,imx93-edma3
- fsl,imx93-edma4
- items: - items:
- const: fsl,ls1028a-edma - const: fsl,ls1028a-edma
- const: fsl,vf610-edma - const: fsl,vf610-edma
reg: reg:
minItems: 2 minItems: 1
maxItems: 3 maxItems: 3
interrupts: interrupts:
minItems: 2 minItems: 1
maxItems: 17 maxItems: 64
interrupt-names: interrupt-names:
minItems: 2 minItems: 1
maxItems: 17 maxItems: 64
"#dma-cells": "#dma-cells":
const: 2 enum:
- 2
- 3
dma-channels: dma-channels:
const: 32 minItems: 1
maxItems: 64
clocks: clocks:
minItems: 1
maxItems: 2 maxItems: 2
clock-names: clock-names:
minItems: 1
maxItems: 2 maxItems: 2
big-endian: big-endian:
...@@ -65,6 +74,29 @@ required: ...@@ -65,6 +74,29 @@ required:
allOf: allOf:
- $ref: dma-controller.yaml# - $ref: dma-controller.yaml#
- if:
properties:
compatible:
contains:
enum:
- fsl,imx8qm-adma
- fsl,imx8qm-edma
- fsl,imx93-edma3
- fsl,imx93-edma4
then:
properties:
"#dma-cells":
const: 3
# It is not necessary to write the interrupt name for each channel.
# instead, you can simply maintain the sequential IRQ numbers as
# defined for the DMA channels.
interrupt-names: false
clock-names:
items:
- const: dma
clocks:
maxItems: 1
- if: - if:
properties: properties:
compatible: compatible:
...@@ -72,18 +104,26 @@ allOf: ...@@ -72,18 +104,26 @@ allOf:
const: fsl,vf610-edma const: fsl,vf610-edma
then: then:
properties: properties:
clocks:
minItems: 2
clock-names: clock-names:
items: items:
- const: dmamux0 - const: dmamux0
- const: dmamux1 - const: dmamux1
interrupts: interrupts:
minItems: 2
maxItems: 2 maxItems: 2
interrupt-names: interrupt-names:
items: items:
- const: edma-tx - const: edma-tx
- const: edma-err - const: edma-err
reg: reg:
minItems: 2
maxItems: 3 maxItems: 3
"#dma-cells":
const: 2
dma-channels:
const: 32
- if: - if:
properties: properties:
...@@ -92,14 +132,22 @@ allOf: ...@@ -92,14 +132,22 @@ allOf:
const: fsl,imx7ulp-edma const: fsl,imx7ulp-edma
then: then:
properties: properties:
clock:
minItems: 2
clock-names: clock-names:
items: items:
- const: dma - const: dma
- const: dmamux0 - const: dmamux0
interrupts: interrupts:
minItems: 2
maxItems: 17 maxItems: 17
reg: reg:
minItems: 2
maxItems: 2 maxItems: 2
"#dma-cells":
const: 2
dma-channels:
const: 32
unevaluatedProperties: false unevaluatedProperties: false
...@@ -153,3 +201,47 @@ examples: ...@@ -153,3 +201,47 @@ examples:
clock-names = "dma", "dmamux0"; clock-names = "dma", "dmamux0";
clocks = <&pcc2 IMX7ULP_CLK_DMA1>, <&pcc2 IMX7ULP_CLK_DMA_MUX1>; clocks = <&pcc2 IMX7ULP_CLK_DMA1>, <&pcc2 IMX7ULP_CLK_DMA_MUX1>;
}; };
- |
#include <dt-bindings/interrupt-controller/arm-gic.h>
#include <dt-bindings/clock/imx93-clock.h>
dma-controller@44000000 {
compatible = "fsl,imx93-edma3";
reg = <0x44000000 0x200000>;
#dma-cells = <3>;
dma-channels = <31>;
interrupts = <GIC_SPI 95 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 110 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 112 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 113 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 115 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 116 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 117 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 118 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 119 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 120 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 121 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 122 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 123 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 124 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 125 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&clk IMX93_CLK_EDMA1_GATE>;
clock-names = "dma";
};
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment