/* * drivers/video/tegra/host/nvhost_memmgr.h * * Tegra Graphics Host Memory Management Abstraction header * * Copyright (c) 2012-2013, NVIDIA CORPORATION. All rights reserved. * * This program is free software; you can redistribute it and/or modify it * under the terms and conditions of the GNU General Public License, * version 2, as published by the Free Software Foundation. * * This program is distributed in the hope 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. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #ifndef _NVHOST_MEM_MGR_H_ #define _NVHOST_MEM_MGR_H_ #include #include #include #include struct nvhost_chip_support; struct mem_mgr; struct mem_handle; struct platform_device; struct device; struct nvhost_allocator; struct nvhost_comptags { u32 offset; u32 lines; }; enum mem_mgr_flag { mem_mgr_flag_uncacheable = 0, mem_mgr_flag_write_combine = 1, }; enum mem_rw_flag { mem_flag_none = 0, mem_flag_read_only = 1, mem_flag_write_only = 2, }; enum mem_mgr_type { mem_mgr_type_nvmap = 0, mem_mgr_type_dmabuf = 1, mem_mgr_type_invalid = 2, }; #ifdef CONFIG_NVMAP_USE_FD_FOR_HANDLE #define MEMMGR_TYPE_MASK 0x0 #else #define MEMMGR_TYPE_MASK 0x3 #endif #define MEMMGR_ID_MASK (~MEMMGR_TYPE_MASK) int nvhost_memmgr_init(struct nvhost_chip_support *chip); struct mem_mgr *nvhost_memmgr_alloc_mgr(void); void nvhost_memmgr_put_mgr(struct mem_mgr *); struct mem_mgr *nvhost_memmgr_get_mgr(struct mem_mgr *); struct mem_mgr *nvhost_memmgr_get_mgr_file(int fd); struct mem_handle *nvhost_memmgr_alloc(struct mem_mgr *, size_t size, size_t align, int flags, unsigned int heap_mask); struct mem_handle *nvhost_memmgr_get(struct mem_mgr *, ulong id, struct platform_device *dev); void nvhost_memmgr_put(struct mem_mgr *mgr, struct mem_handle *handle); struct sg_table *nvhost_memmgr_pin(struct mem_mgr *, struct mem_handle *handle, struct device *dev, int rw_flag); void nvhost_memmgr_unpin(struct mem_mgr *mgr, struct mem_handle *handle, struct device *dev, struct sg_table *sgt); void *nvhost_memmgr_mmap(struct mem_handle *handle); void nvhost_memmgr_munmap(struct mem_handle *handle, void *addr); void *nvhost_memmgr_kmap(struct mem_handle *handle, unsigned int pagenum); void nvhost_memmgr_kunmap(struct mem_handle *handle, unsigned int pagenum, void *addr); struct sg_table *nvhost_memmgr_sg_table(struct mem_mgr *mgr, struct mem_handle *handle); void nvhost_memmgr_free_sg_table(struct mem_mgr *mgr, struct mem_handle *handle, struct sg_table *sgt); extern struct dma_buf_ops nvmap_dma_buf_ops; static inline int nvhost_memmgr_type(ulong id) { struct dma_buf* db = (struct dma_buf*)id; #ifdef CONFIG_NVMAP_USE_FD_FOR_HANDLE if (id >= NVMAP_HANDLE_NATIVE_FD_START && id < NVMAP_HANDLE_FOREIGN_FD_START) return mem_mgr_type_nvmap; else if (id >= NVMAP_HANDLE_FOREIGN_FD_START && id < NVMAP_HANDLE_FOREIGN_FD_END) return mem_mgr_type_dmabuf; #endif /* nvtest would give wrong ID for kernel verification */ if (id == ~0) return mem_mgr_type_invalid; if (db->ops == &nvmap_dma_buf_ops) return mem_mgr_type_nvmap; else return mem_mgr_type_dmabuf; } static inline int nvhost_memmgr_id(ulong id) { return id & MEMMGR_ID_MASK; } u32 nvhost_memmgr_handle_to_id(struct mem_handle *handle); int nvhost_memmgr_get_param(struct mem_mgr *mem_mgr, struct mem_handle *mem_handle, u32 param, u64 *result); void nvhost_memmgr_get_comptags(struct mem_handle *mem, struct nvhost_comptags *comptags); int nvhost_memmgr_alloc_comptags(struct mem_handle *mem, struct nvhost_allocator *allocator, int lines); #ifdef CONFIG_TEGRA_IOMMU_SMMU int nvhost_memmgr_smmu_map(struct sg_table *sgt, size_t size, struct device *dev); void nvhost_memmgr_smmu_unmap(struct sg_table *sgt, size_t size, struct device *dev); #endif /* * Return IOVA for buffers allocated from IOVMM heap and have IOVA assigned. * Otherwise assume the buffer was allocated from carveout and return physical * address. */ static inline dma_addr_t nvhost_memmgr_dma_addr(struct sg_table *sgt) { return sg_dma_address(sgt->sgl) && sg_dma_address(sgt->sgl) != DMA_ERROR_CODE ? sg_dma_address(sgt->sgl) : sg_phys(sgt->sgl); } #endif