diff --git a/drivers/dma/dma_gd32.c b/drivers/dma/dma_gd32.c index 8fcc3f221b..4972345d74 100644 --- a/drivers/dma/dma_gd32.c +++ b/drivers/dma/dma_gd32.c @@ -58,6 +58,7 @@ struct dma_gd32_config { uint32_t reg; uint32_t channels; uint16_t clkid; + bool mem2mem; #ifdef CONFIG_SOC_SERIES_GD32F4XX struct reset_dt_spec reset; #endif @@ -403,6 +404,11 @@ static int dma_gd32_config(const struct device *dev, uint32_t channel, return -ENOTSUP; } + if (dma_cfg->channel_direction == MEMORY_TO_MEMORY && !cfg->mem2mem) { + LOG_ERR("not supporting MEMORY_TO_MEMORY"); + return -ENOTSUP; + } + #ifdef CONFIG_SOC_SERIES_GD32F4XX if (dma_cfg->dma_slot > 0xF) { LOG_ERR("dma_slot must be <7 (%" PRIu32 ")", @@ -665,10 +671,11 @@ static const struct dma_driver_api dma_gd32_driver_api = { } \ static const struct dma_gd32_config dma_gd32##inst##_config = { \ .reg = DT_INST_REG_ADDR(inst), \ + .channels = DT_INST_PROP(inst, dma_channels), \ .clkid = DT_INST_CLOCKS_CELL(inst, id), \ + .mem2mem = DT_INST_PROP(inst, gd_mem2mem), \ IF_ENABLED(CONFIG_SOC_SERIES_GD32F4XX, \ (.reset = RESET_DT_SPEC_INST_GET(inst),)) \ - .channels = DT_INST_PROP(inst, dma_channels), \ .irq_configure = dma_gd32##inst##_irq_configure, \ }; \ \ diff --git a/dts/arm/gigadevice/gd32e50x/gd32e50x.dtsi b/dts/arm/gigadevice/gd32e50x/gd32e50x.dtsi index 0116507345..e073dd8ff4 100644 --- a/dts/arm/gigadevice/gd32e50x/gd32e50x.dtsi +++ b/dts/arm/gigadevice/gd32e50x/gd32e50x.dtsi @@ -411,6 +411,7 @@ <15 0>, <16 0>, <17 0>; clocks = <&cctl GD32_CLOCK_DMA0>; dma-channels = <7>; + gd,mem2mem; #dma-cells = <2>; status = "disabled"; }; @@ -422,6 +423,7 @@ <60 0>; clocks = <&cctl GD32_CLOCK_DMA1>; dma-channels = <5>; + gd,mem2mem; #dma-cells = <2>; status = "disabled"; }; diff --git a/dts/arm/gigadevice/gd32f403/gd32f403.dtsi b/dts/arm/gigadevice/gd32f403/gd32f403.dtsi index b7258e470a..b1440eb541 100644 --- a/dts/arm/gigadevice/gd32f403/gd32f403.dtsi +++ b/dts/arm/gigadevice/gd32f403/gd32f403.dtsi @@ -496,6 +496,7 @@ <15 0>, <16 0>, <17 0>; clocks = <&cctl GD32_CLOCK_DMA0>; dma-channels = <7>; + gd,mem2mem; #dma-cells = <2>; status = "disabled"; }; @@ -507,6 +508,7 @@ <60 0>; clocks = <&cctl GD32_CLOCK_DMA1>; dma-channels = <5>; + gd,mem2mem; #dma-cells = <2>; status = "disabled"; }; diff --git a/dts/arm/gigadevice/gd32f4xx/gd32f4xx.dtsi b/dts/arm/gigadevice/gd32f4xx/gd32f4xx.dtsi index 6d32371451..31cc3fd930 100644 --- a/dts/arm/gigadevice/gd32f4xx/gd32f4xx.dtsi +++ b/dts/arm/gigadevice/gd32f4xx/gd32f4xx.dtsi @@ -625,6 +625,7 @@ clocks = <&cctl GD32_CLOCK_DMA0>; resets = <&rctl GD32_RESET_DMA0>; dma-channels = <8>; + gd,mem2mem; #dma-cells = <2>; status = "disabled"; }; @@ -637,6 +638,7 @@ clocks = <&cctl GD32_CLOCK_DMA1>; resets = <&rctl GD32_RESET_DMA1>; dma-channels = <8>; + gd,mem2mem; #dma-cells = <2>; status = "disabled"; }; diff --git a/dts/bindings/dma/gd,gd32-dma-base.yaml b/dts/bindings/dma/gd,gd32-dma-base.yaml index 7b061d4a3e..36c12a4505 100644 --- a/dts/bindings/dma/gd,gd32-dma-base.yaml +++ b/dts/bindings/dma/gd,gd32-dma-base.yaml @@ -15,3 +15,7 @@ properties: clocks: required: true + + gd,mem2mem: + type: boolean + description: The DMA controller supporting memory to memory transfer diff --git a/dts/riscv/gigadevice/gd32vf103.dtsi b/dts/riscv/gigadevice/gd32vf103.dtsi index 75c237a766..7db0dcec5e 100644 --- a/dts/riscv/gigadevice/gd32vf103.dtsi +++ b/dts/riscv/gigadevice/gd32vf103.dtsi @@ -392,6 +392,7 @@ <34 0>, <35 0>, <36 0>; clocks = <&cctl GD32_CLOCK_DMA0>; dma-channels = <7>; + gd,mem2mem; #dma-cells = <2>; status = "disabled"; }; @@ -403,6 +404,7 @@ <79 0>; clocks = <&cctl GD32_CLOCK_DMA1>; dma-channels = <5>; + gd,mem2mem; #dma-cells = <2>; status = "disabled"; };