Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752026AbdGGPkV (ORCPT ); Fri, 7 Jul 2017 11:40:21 -0400 Received: from foss.arm.com ([217.140.101.70]:48660 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751023AbdGGPkT (ORCPT ); Fri, 7 Jul 2017 11:40:19 -0400 Subject: Re: [PATCH v2 1/2] drivers: dma-coherent: Fix dev->cma_area vs dev->dma_mem breakage To: Christoph Hellwig , Vitaly Kuzmichev References: <1499433759-16397-1-git-send-email-vitaly_kuzmichev@mentor.com> <1499433779-16437-1-git-send-email-vitaly_kuzmichev@mentor.com> <20170707142746.GB10818@lst.de> Cc: gregkh@linuxfoundation.org, m.szyprowski@samsung.com, robin.murphy@arm.com, linux-kernel@vger.kernel.org, linux-next@vger.kernel.org, "George G. Davis" From: Vladimir Murzin Message-ID: Date: Fri, 7 Jul 2017 16:40:16 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:45.0) Gecko/20100101 Thunderbird/45.7.0 MIME-Version: 1.0 In-Reply-To: <20170707142746.GB10818@lst.de> Content-Type: text/plain; charset=windows-1252 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2363 Lines: 78 Christoph, On 07/07/17 15:27, Christoph Hellwig wrote: > Vladimir, > > this is why I really didn't like overloading the current > dma coherent infrastructure with the global pool. > > And this new patch seems like piling hacks over hacks. I think we > should go back and make sure allocations from the global coherent > pool are done by the dma ops implementation, and not before calling > into them - preferably still reusing the common code for it. > > Vladimir or Vitaly - can you look into that? > It is really sad that Vitaly and George did not join to discussions earlier, so we could avoid being in situation like this. Likely I'm missing something, but what should happen if device relies on dma_contiguous_default_area? Originally, intention behind dma-default was to simplify things, so instead of reserved-memory { #address-cells = <1>; #size-cells = <1>; ranges; coherent_dma: linux,dma { compatible = "shared-dma-pool"; no-map; reg = <0x78000000 0x800000>; }; }; dev0: dev@12300000 { memory-region = <&coherent_dma>; /* ... */ }; dev1: dev@12500000 { memory-region = <&coherent_dma>; /* ... */ }; dev2: dev@12600000 { memory-region = <&coherent_dma>; /* ... */ }; in device tree we could simply have reserved-memory { #address-cells = <1>; #size-cells = <1>; ranges; coherent_dma: linux,dma { compatible = "shared-dma-pool"; no-map; reg = <0x78000000 0x800000>; linux,dma-default; }; }; and that just work in my (NOMMU) case because there is no CMA there... However, given that dma-default is being overloaded and there are no device tree users merged yet, I would not object stepping back, reverting "drivers: dma-coherent: Introduce default DMA pool" and cooperatively rethinking design/implementation, so every party gets happy. The rest of my original patch set should be enough to keep NOMMU working. Cheers Vladimir