2021-10-23 14:58:01 +00:00
|
|
|
#ifndef _IOMMU_H
|
|
|
|
#define _IOMMU_H
|
|
|
|
|
|
|
|
struct udevice;
|
|
|
|
|
2023-01-21 19:27:52 +00:00
|
|
|
struct iommu_ops {
|
|
|
|
/**
|
|
|
|
* map() - map DMA memory
|
|
|
|
*
|
|
|
|
* @dev: device for which to map DMA memory
|
|
|
|
* @addr: CPU address of the memory
|
|
|
|
* @size: size of the memory
|
|
|
|
* @return DMA address for the device
|
|
|
|
*/
|
|
|
|
dma_addr_t (*map)(struct udevice *dev, void *addr, size_t size);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* unmap() - unmap DMA memory
|
|
|
|
*
|
|
|
|
* @dev: device for which to unmap DMA memory
|
|
|
|
* @addr: DMA address of the memory
|
|
|
|
* @size: size of the memory
|
|
|
|
*/
|
|
|
|
void (*unmap)(struct udevice *dev, dma_addr_t addr, size_t size);
|
|
|
|
};
|
|
|
|
|
2021-10-23 14:58:01 +00:00
|
|
|
#if (CONFIG_IS_ENABLED(OF_CONTROL) && !CONFIG_IS_ENABLED(OF_PLATDATA)) && \
|
|
|
|
CONFIG_IS_ENABLED(IOMMU)
|
|
|
|
int dev_iommu_enable(struct udevice *dev);
|
|
|
|
#else
|
|
|
|
static inline int dev_iommu_enable(struct udevice *dev)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2023-01-21 19:27:52 +00:00
|
|
|
dma_addr_t dev_iommu_dma_map(struct udevice *dev, void *addr, size_t size);
|
|
|
|
void dev_iommu_dma_unmap(struct udevice *dev, dma_addr_t addr, size_t size);
|
|
|
|
|
2021-10-23 14:58:01 +00:00
|
|
|
#endif
|