Lines Matching full:imem
54 struct gk20a_instmem *imem; member
145 struct gk20a_instmem *imem = obj->base.imem; in gk20a_instobj_iommu_recycle_vaddr() local
151 imem->vaddr_use -= nvkm_memory_size(&obj->base.memory); in gk20a_instobj_iommu_recycle_vaddr()
152 nvkm_debug(&imem->base.subdev, "vaddr used: %x/%x\n", imem->vaddr_use, in gk20a_instobj_iommu_recycle_vaddr()
153 imem->vaddr_max); in gk20a_instobj_iommu_recycle_vaddr()
160 gk20a_instmem_vaddr_gc(struct gk20a_instmem *imem, const u64 size) in gk20a_instmem_vaddr_gc() argument
162 while (imem->vaddr_use + size > imem->vaddr_max) { in gk20a_instmem_vaddr_gc()
164 if (list_empty(&imem->vaddr_lru)) in gk20a_instmem_vaddr_gc()
168 list_first_entry(&imem->vaddr_lru, in gk20a_instmem_vaddr_gc()
177 struct gk20a_instmem *imem = node->imem; in gk20a_instobj_acquire_dma() local
178 struct nvkm_ltc *ltc = imem->base.subdev.device->ltc; in gk20a_instobj_acquire_dma()
189 struct gk20a_instmem *imem = node->base.imem; in gk20a_instobj_acquire_iommu() local
190 struct nvkm_ltc *ltc = imem->base.subdev.device->ltc; in gk20a_instobj_acquire_iommu()
195 mutex_lock(&imem->lock); in gk20a_instobj_acquire_iommu()
206 gk20a_instmem_vaddr_gc(imem, size); in gk20a_instobj_acquire_iommu()
212 nvkm_error(&imem->base.subdev, "cannot map instobj - " in gk20a_instobj_acquire_iommu()
217 imem->vaddr_use += size; in gk20a_instobj_acquire_iommu()
218 nvkm_debug(&imem->base.subdev, "vaddr used: %x/%x\n", in gk20a_instobj_acquire_iommu()
219 imem->vaddr_use, imem->vaddr_max); in gk20a_instobj_acquire_iommu()
223 mutex_unlock(&imem->lock); in gk20a_instobj_acquire_iommu()
232 struct gk20a_instmem *imem = node->imem; in gk20a_instobj_release_dma() local
233 struct nvkm_ltc *ltc = imem->base.subdev.device->ltc; in gk20a_instobj_release_dma()
244 struct gk20a_instmem *imem = node->base.imem; in gk20a_instobj_release_iommu() local
245 struct nvkm_ltc *ltc = imem->base.subdev.device->ltc; in gk20a_instobj_release_iommu()
247 mutex_lock(&imem->lock); in gk20a_instobj_release_iommu()
255 list_add_tail(&node->vaddr_node, &imem->vaddr_lru); in gk20a_instobj_release_iommu()
258 mutex_unlock(&imem->lock); in gk20a_instobj_release_iommu()
298 struct gk20a_instmem *imem = node->base.imem; in gk20a_instobj_dtor_dma() local
299 struct device *dev = imem->base.subdev.device->dev; in gk20a_instobj_dtor_dma()
305 node->base.vaddr, node->handle, imem->attrs); in gk20a_instobj_dtor_dma()
315 struct gk20a_instmem *imem = node->base.imem; in gk20a_instobj_dtor_iommu() local
316 struct device *dev = imem->base.subdev.device->dev; in gk20a_instobj_dtor_iommu()
323 mutex_lock(&imem->lock); in gk20a_instobj_dtor_iommu()
329 mutex_unlock(&imem->lock); in gk20a_instobj_dtor_iommu()
332 r->offset &= ~BIT(imem->iommu_bit - imem->iommu_pgshift); in gk20a_instobj_dtor_iommu()
336 iommu_unmap(imem->domain, in gk20a_instobj_dtor_iommu()
337 (r->offset + i) << imem->iommu_pgshift, PAGE_SIZE); in gk20a_instobj_dtor_iommu()
344 mutex_lock(imem->mm_mutex); in gk20a_instobj_dtor_iommu()
345 nvkm_mm_free(imem->mm, &r); in gk20a_instobj_dtor_iommu()
346 mutex_unlock(imem->mm_mutex); in gk20a_instobj_dtor_iommu()
383 gk20a_instobj_ctor_dma(struct gk20a_instmem *imem, u32 npages, u32 align, in gk20a_instobj_ctor_dma() argument
387 struct nvkm_subdev *subdev = &imem->base.subdev; in gk20a_instobj_ctor_dma()
399 imem->attrs); in gk20a_instobj_ctor_dma()
421 gk20a_instobj_ctor_iommu(struct gk20a_instmem *imem, u32 npages, u32 align, in gk20a_instobj_ctor_iommu() argument
425 struct nvkm_subdev *subdev = &imem->base.subdev; in gk20a_instobj_ctor_iommu()
463 mutex_lock(imem->mm_mutex); in gk20a_instobj_ctor_iommu()
465 ret = nvkm_mm_head(imem->mm, 0, 1, npages, npages, in gk20a_instobj_ctor_iommu()
466 align >> imem->iommu_pgshift, &r); in gk20a_instobj_ctor_iommu()
467 mutex_unlock(imem->mm_mutex); in gk20a_instobj_ctor_iommu()
475 u32 offset = (r->offset + i) << imem->iommu_pgshift; in gk20a_instobj_ctor_iommu()
477 ret = iommu_map(imem->domain, offset, node->dma_addrs[i], in gk20a_instobj_ctor_iommu()
484 iommu_unmap(imem->domain, offset, PAGE_SIZE); in gk20a_instobj_ctor_iommu()
491 r->offset |= BIT(imem->iommu_bit - imem->iommu_pgshift); in gk20a_instobj_ctor_iommu()
497 mutex_lock(imem->mm_mutex); in gk20a_instobj_ctor_iommu()
498 nvkm_mm_free(imem->mm, &r); in gk20a_instobj_ctor_iommu()
499 mutex_unlock(imem->mm_mutex); in gk20a_instobj_ctor_iommu()
517 struct gk20a_instmem *imem = gk20a_instmem(base); in gk20a_instobj_new() local
518 struct nvkm_subdev *subdev = &imem->base.subdev; in gk20a_instobj_new()
523 imem->domain ? "IOMMU" : "DMA", size, align); in gk20a_instobj_new()
529 if (imem->domain) in gk20a_instobj_new()
530 ret = gk20a_instobj_ctor_iommu(imem, size >> PAGE_SHIFT, in gk20a_instobj_new()
533 ret = gk20a_instobj_ctor_dma(imem, size >> PAGE_SHIFT, in gk20a_instobj_new()
539 node->imem = imem; in gk20a_instobj_new()
550 struct gk20a_instmem *imem = gk20a_instmem(base); in gk20a_instmem_dtor() local
553 if (!list_empty(&imem->vaddr_lru)) in gk20a_instmem_dtor()
556 if (imem->vaddr_use != 0) in gk20a_instmem_dtor()
558 "0x%x bytes still mapped\n", imem->vaddr_use); in gk20a_instmem_dtor()
560 return imem; in gk20a_instmem_dtor()
575 struct gk20a_instmem *imem; in gk20a_instmem_new() local
577 if (!(imem = kzalloc(sizeof(*imem), GFP_KERNEL))) in gk20a_instmem_new()
579 nvkm_instmem_ctor(&gk20a_instmem, device, index, &imem->base); in gk20a_instmem_new()
580 mutex_init(&imem->lock); in gk20a_instmem_new()
581 *pimem = &imem->base; in gk20a_instmem_new()
584 imem->vaddr_use = 0; in gk20a_instmem_new()
585 imem->vaddr_max = 0x100000; in gk20a_instmem_new()
586 INIT_LIST_HEAD(&imem->vaddr_lru); in gk20a_instmem_new()
589 imem->mm_mutex = &tdev->iommu.mutex; in gk20a_instmem_new()
590 imem->mm = &tdev->iommu.mm; in gk20a_instmem_new()
591 imem->domain = tdev->iommu.domain; in gk20a_instmem_new()
592 imem->iommu_pgshift = tdev->iommu.pgshift; in gk20a_instmem_new()
593 imem->iommu_bit = tdev->func->iommu_bit; in gk20a_instmem_new()
595 nvkm_info(&imem->base.subdev, "using IOMMU\n"); in gk20a_instmem_new()
597 imem->attrs = DMA_ATTR_WEAK_ORDERING | in gk20a_instmem_new()
600 nvkm_info(&imem->base.subdev, "using DMA API\n"); in gk20a_instmem_new()