/* Copyright (c) 2011-2012, The Linux Foundation. All rights reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 and * only version 2 as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. */ #ifndef _ARCH_IOMMU_DOMAINS_H #define _ARCH_IOMMU_DOMAINS_H #include enum { VIDEO_DOMAIN, CAMERA_DOMAIN, DISPLAY_READ_DOMAIN, DISPLAY_WRITE_DOMAIN, ROTATOR_SRC_DOMAIN, ROTATOR_DST_DOMAIN, MAX_DOMAINS }; enum { VIDEO_FIRMWARE_POOL, VIDEO_MAIN_POOL, GEN_POOL, }; struct msm_iommu_domain_name { char *name; int domain; }; struct msm_iommu_domain { /* iommu domain to map in */ struct iommu_domain *domain; /* total number of allocations from this domain */ atomic_t allocation_cnt; /* number of iova pools */ int npools; /* * array of gen_pools for allocating iovas. * behavior is undefined if these overlap */ struct mem_pool *iova_pools; }; struct iommu_domains_pdata { struct msm_iommu_domain *domains; int ndomains; struct msm_iommu_domain_name *domain_names; int nnames; unsigned int domain_alloc_flags; }; struct msm_iova_partition { unsigned long start; unsigned long size; }; struct msm_iova_layout { struct msm_iova_partition *partitions; int npartitions; const char *client_name; unsigned int domain_flags; }; #if defined(CONFIG_MSM_IOMMU) extern struct iommu_domain *msm_get_iommu_domain(int domain_num); extern int msm_allocate_iova_address(unsigned int iommu_domain, unsigned int partition_no, unsigned long size, unsigned long align, unsigned long *iova); extern void msm_free_iova_address(unsigned long iova, unsigned int iommu_domain, unsigned int partition_no, unsigned long size); extern int msm_use_iommu(void); extern int msm_iommu_map_extra(struct iommu_domain *domain, unsigned long start_iova, unsigned long size, unsigned long page_size, int cached); extern void msm_iommu_unmap_extra(struct iommu_domain *domain, unsigned long start_iova, unsigned long size, unsigned long page_size); extern int msm_iommu_map_contig_buffer(unsigned long phys, unsigned int domain_no, unsigned int partition_no, unsigned long size, unsigned long align, unsigned long cached, unsigned long *iova_val); extern void msm_iommu_unmap_contig_buffer(unsigned long iova, unsigned int domain_no, unsigned int partition_no, unsigned long size); extern int msm_register_domain(struct msm_iova_layout *layout); #else static inline struct iommu_domain *msm_get_iommu_domain(int subsys_id) { return NULL; } static inline int msm_allocate_iova_address(unsigned int iommu_domain, unsigned int partition_no, unsigned long size, unsigned long align, unsigned long *iova) { return -ENOMEM; } static inline void msm_free_iova_address(unsigned long iova, unsigned int iommu_domain, unsigned int partition_no, unsigned long size) { return; } static inline int msm_use_iommu(void) { return 0; } static inline int msm_iommu_map_extra(struct iommu_domain *domain, unsigned long start_iova, unsigned long size, unsigned long page_size, int cached) { return -ENODEV; } static inline void msm_iommu_unmap_extra(struct iommu_domain *domain, unsigned long start_iova, unsigned long size, unsigned long page_size) { } static inline int msm_iommu_map_contig_buffer(unsigned long phys, unsigned int domain_no, unsigned int partition_no, unsigned long size, unsigned long align, unsigned long cached, unsigned long *iova_val) { *iova_val = phys; return 0; } static inline void msm_iommu_unmap_contig_buffer(unsigned long iova, unsigned int domain_no, unsigned int partition_no, unsigned long size) { return; } static inline int msm_register_domain(struct msm_iova_layout *layout) { return -ENODEV; } #endif #endif