Re: [PATCH v2 1/2] drivers: dma-coherent: Fix dev->cma_area vs dev->dma_mem breakage

From: Vladimir Murzin
Date: Fri Jul 07 2017 - 11:40:39 EST


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