13d0407baSopenharmony_ci/*
23d0407baSopenharmony_ci * This program is free software; you can redistribute it and/or modify
33d0407baSopenharmony_ci * it under the terms of the GNU General Public License version 2 as
43d0407baSopenharmony_ci * published by the Free Software Foundation.
53d0407baSopenharmony_ci */
63d0407baSopenharmony_ci
73d0407baSopenharmony_ci#ifndef ASM_PLAT_IOVMM_H
83d0407baSopenharmony_ci#define ASM_PLAT_IOVMM_H
93d0407baSopenharmony_ci
103d0407baSopenharmony_ci#include <linux/list.h>
113d0407baSopenharmony_ci#include <linux/atomic.h>
123d0407baSopenharmony_ci#include <linux/spinlock.h>
133d0407baSopenharmony_ci
143d0407baSopenharmony_ci#define IEP_IOMMU_COMPATIBLE_NAME "rockchip,iep_mmu"
153d0407baSopenharmony_ci#define VIP_IOMMU_COMPATIBLE_NAME "rockchip,vip_mmu"
163d0407baSopenharmony_ci#define ISP_IOMMU_COMPATIBLE_NAME "rockchip,isp_mmu"
173d0407baSopenharmony_ci#define ISP0_IOMMU_COMPATIBLE_NAME "rockchip,isp0_mmu"
183d0407baSopenharmony_ci#define ISP1_IOMMU_COMPATIBLE_NAME "rockchip,isp1_mmu"
193d0407baSopenharmony_ci#define VOPB_IOMMU_COMPATIBLE_NAME "rockchip,vopb_mmu"
203d0407baSopenharmony_ci#define VOPL_IOMMU_COMPATIBLE_NAME "rockchip,vopl_mmu"
213d0407baSopenharmony_ci#define VOP_IOMMU_COMPATIBLE_NAME "rockchip,vop_mmu"
223d0407baSopenharmony_ci#define HEVC_IOMMU_COMPATIBLE_NAME "rockchip,hevc_mmu"
233d0407baSopenharmony_ci#define VPU_IOMMU_COMPATIBLE_NAME "rockchip,vpu_mmu"
243d0407baSopenharmony_ci#define VDEC_IOMMU_COMPATIBLE_NAME "rockchip,vdec_mmu"
253d0407baSopenharmony_ci
263d0407baSopenharmony_cienum rk_iommu_inttype { IOMMU_PAGEFAULT, IOMMU_BUSERROR, IOMMU_FAULT_UNKNOWN, IOMMU_FAULTS_NUM };
273d0407baSopenharmony_ci
283d0407baSopenharmony_cistruct iommu_drvdata;
293d0407baSopenharmony_ci
303d0407baSopenharmony_ci/*
313d0407baSopenharmony_ci * @itype: type of fault.
323d0407baSopenharmony_ci * @pgtable_base: the physical address of page table base. This is 0 if @itype
333d0407baSopenharmony_ci *                  is IOMMU_BUSERROR.
343d0407baSopenharmony_ci * @fault_addr: the device (virtual) address that the System MMU tried to
353d0407baSopenharmony_ci *               translated. This is 0 if @itype is IOMMU_BUSERROR.
363d0407baSopenharmony_ci */
373d0407baSopenharmony_citypedef int (*rockchip_iommu_fault_handler_t)(struct device *dev, enum rk_iommu_inttype itype,
383d0407baSopenharmony_ci                                              unsigned long pgtable_base, unsigned long fault_addr, unsigned int statu);
393d0407baSopenharmony_ci
403d0407baSopenharmony_cistruct scatterlist;
413d0407baSopenharmony_cistruct device;
423d0407baSopenharmony_ci
433d0407baSopenharmony_cistatic inline int rockchip_iovmm_activate(struct device *dev)
443d0407baSopenharmony_ci{
453d0407baSopenharmony_ci    return -ENOSYS;
463d0407baSopenharmony_ci}
473d0407baSopenharmony_ci
483d0407baSopenharmony_cistatic inline void rockchip_iovmm_deactivate(struct device *dev)
493d0407baSopenharmony_ci{
503d0407baSopenharmony_ci}
513d0407baSopenharmony_ci
523d0407baSopenharmony_cistatic inline dma_addr_t rockchip_iovmm_map(struct device *dev, struct scatterlist *sg, off_t offset, size_t size)
533d0407baSopenharmony_ci{
543d0407baSopenharmony_ci    return -ENOSYS;
553d0407baSopenharmony_ci}
563d0407baSopenharmony_ci
573d0407baSopenharmony_cistatic inline void rockchip_iovmm_unmap(struct device *dev, dma_addr_t iova)
583d0407baSopenharmony_ci{
593d0407baSopenharmony_ci}
603d0407baSopenharmony_ci
613d0407baSopenharmony_cistatic inline int rockchip_iovmm_map_oto(struct device *dev, phys_addr_t phys, size_t size)
623d0407baSopenharmony_ci{
633d0407baSopenharmony_ci    return -ENOSYS;
643d0407baSopenharmony_ci}
653d0407baSopenharmony_ci
663d0407baSopenharmony_cistatic inline void rockchip_iovmm_unmap_oto(struct device *dev, phys_addr_t phys)
673d0407baSopenharmony_ci{
683d0407baSopenharmony_ci}
693d0407baSopenharmony_ci
703d0407baSopenharmony_cistatic inline void rockchip_iovmm_set_fault_handler(struct device *dev, rockchip_iommu_fault_handler_t handler)
713d0407baSopenharmony_ci{
723d0407baSopenharmony_ci}
733d0407baSopenharmony_cistatic inline int rockchip_iovmm_invalidate_tlb(struct device *dev)
743d0407baSopenharmony_ci{
753d0407baSopenharmony_ci    return -ENOSYS;
763d0407baSopenharmony_ci}
773d0407baSopenharmony_ci
783d0407baSopenharmony_ci#endif /* __ASM_PLAT_IOVMM_H */
79