Re: [RFC PATCH] iommu/dma: Allow drivers to reserve an iova range

From: Robin Murphy
Date: Mon Feb 17 2020 - 10:50:53 EST


On 17/02/2020 8:01 am, Christoph Hellwig wrote:
On Fri, Feb 14, 2020 at 02:58:16PM -0800, Isaac J. Manjarres wrote:
From: Liam Mark <lmark@xxxxxxxxxxxxxx>

Some devices have a memory map which contains gaps or holes.
In order for the device to have as much IOVA space as possible,
allow its driver to inform the DMA-IOMMU layer that it should
not allocate addresses from these holes.

Layering violation. dma-iommu is the translation layer between the
DMA API and the IOMMU API. And calls into it from drivers performing
DMA mappings need to go through the DMA API (and be documented there).

+1

More than that, though, we already have "holes in the address space" support for the sake of PCI host bridge windows - assuming this is the same kind of thing (i.e. the holes are between memory regions and other resources in PA space, so are only relevant once address translation comes into the picture), then this is IOMMU API level stuff, so even a DMA API level interface would be inappropriate.

Robin.