Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751961AbdG1Maz (ORCPT ); Fri, 28 Jul 2017 08:30:55 -0400 Received: from mx07-00178001.pphosted.com ([62.209.51.94]:31114 "EHLO mx07-00178001.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751792AbdG1Max (ORCPT ); Fri, 28 Jul 2017 08:30:53 -0400 Subject: Re: [RESEND PATCH] ARM: dts: stm32: Add DMA support for STM32H743 SoC To: Pierre-Yves MORDRET , Rob Herring , Mark Rutland , Russell King , Maxime Coquelin CC: , , , Vladimir Murzin References: <1499756176-540-1-git-send-email-pierre-yves.mordret@st.com> From: Alexandre Torgue Message-ID: Date: Fri, 28 Jul 2017 14:30:03 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.2.1 MIME-Version: 1.0 In-Reply-To: <1499756176-540-1-git-send-email-pierre-yves.mordret@st.com> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [10.75.127.50] X-ClientProxiedBy: SFHDAG1NODE2.st.com (10.75.127.2) To SFHDAG3NODE2.st.com (10.75.127.8) X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:,, definitions=2017-07-28_05:,, signatures=0 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2164 Lines: 86 Hi, On 07/11/2017 08:56 AM, Pierre-Yves MORDRET wrote: > This patch adds DMA support for STM32H743 SoC. > > Signed-off-by: Pierre-Yves MORDRET > --- > arch/arm/boot/dts/stm32h743.dtsi | 32 ++++++++++++++++++++++++++++++++ > 1 file changed, 32 insertions(+) > > diff --git a/arch/arm/boot/dts/stm32h743.dtsi b/arch/arm/boot/dts/stm32h743.dtsi > index 4685629..3d1cd88 100644 > --- a/arch/arm/boot/dts/stm32h743.dtsi > +++ b/arch/arm/boot/dts/stm32h743.dtsi > @@ -74,6 +74,38 @@ > interrupts = <50>; > clocks = <&timer_clk>; > }; > + > + dma1: dma@40020000 { > + compatible = "st,stm32-dma"; > + reg = <0x40020000 0x400>; > + interrupts = <11>, > + <12>, > + <13>, > + <14>, > + <15>, > + <16>, > + <17>, > + <47>; > + clocks = <&timer_clk>; > + #dma-cells = <4>; > + st,mem2mem; > + }; > + > + dma2: dma@40020400 { > + compatible = "st,stm32-dma"; > + reg = <0x40020400 0x400>; > + interrupts = <56>, > + <57>, > + <58>, > + <59>, > + <60>, > + <68>, > + <69>, > + <70>; > + clocks = <&timer_clk>; > + #dma-cells = <4>; > + st,mem2mem; > + }; > }; > }; > > Applied on stm32-dt-for-v4.14 branch. However, I prefer to keep DMA nodes disabled. Indeed on cortex-M7, dma allocations have to be done in a "strongly-ordered" area. So If you want to use DMA you need to create in your device tree a "reserved memory" area like that: + reserved-memory { + #address-cells = <1>; + #size-cells = <1>; + ranges; + + linux,dma { + compatible = "shared-dma-pool"; + linux,dma-default; + no-map; + reg = <0xd1c00000 0x400000>; + }; + }; In the same time, you have to configure in the same way the cortex-m7 MPU in your bootloader. FYI, patches are under review to configure MPU directly in the kernel (bootloader will not longer have to configure it). It seems also that discussions are ongoing about the way to declare "linux,dma" area in devicetree. As soon all discussions will close and MPU patches applied, we will be able to enable DMA. Regards Alex