| /* SPDX-License-Identifier: GPL-2.0 */ |
| /* |
| * Copyright (C) 2017 Etnaviv Project |
| */ |
| |
| #ifndef __ETNAVIV_CMDBUF_H__ |
| #define __ETNAVIV_CMDBUF_H__ |
| |
| #include <linux/types.h> |
| |
| struct device; |
| struct etnaviv_iommu_context; |
| struct etnaviv_vram_mapping; |
| struct etnaviv_cmdbuf_suballoc; |
| struct etnaviv_perfmon_request; |
| |
| struct etnaviv_cmdbuf { |
| /* suballocator this cmdbuf is allocated from */ |
| struct etnaviv_cmdbuf_suballoc *suballoc; |
| /* cmdbuf properties */ |
| int suballoc_offset; |
| void *vaddr; |
| u32 size; |
| u32 user_size; |
| }; |
| |
| struct etnaviv_cmdbuf_suballoc * |
| etnaviv_cmdbuf_suballoc_new(struct device *dev); |
| void etnaviv_cmdbuf_suballoc_destroy(struct etnaviv_cmdbuf_suballoc *suballoc); |
| int etnaviv_cmdbuf_suballoc_map(struct etnaviv_cmdbuf_suballoc *suballoc, |
| struct etnaviv_iommu_context *context, |
| struct etnaviv_vram_mapping *mapping, |
| u32 memory_base); |
| void etnaviv_cmdbuf_suballoc_unmap(struct etnaviv_iommu_context *context, |
| struct etnaviv_vram_mapping *mapping); |
| |
| |
| int etnaviv_cmdbuf_init(struct etnaviv_cmdbuf_suballoc *suballoc, |
| struct etnaviv_cmdbuf *cmdbuf, u32 size); |
| void etnaviv_cmdbuf_free(struct etnaviv_cmdbuf *cmdbuf); |
| |
| u32 etnaviv_cmdbuf_get_va(struct etnaviv_cmdbuf *buf, |
| struct etnaviv_vram_mapping *mapping); |
| dma_addr_t etnaviv_cmdbuf_get_pa(struct etnaviv_cmdbuf *buf); |
| |
| #endif /* __ETNAVIV_CMDBUF_H__ */ |