mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-24 23:04:17 +08:00
accel/ivpu: Free buffer sgt on unbind
Call dma_unmap() on all buffers before the VPU is unbinded to avoid "device driver has pending DMA allocations while released from device" warning when DMA-API debug is enabled. Signed-off-by: Jacek Lawrynowicz <jacek.lawrynowicz@linux.intel.com> Reviewed-by: Jeffrey Hugo <quic_jhugo@quicinc.com> Link: https://patchwork.freedesktop.org/patch/msgid/20240115134434.493839-7-jacek.lawrynowicz@linux.intel.com
This commit is contained in:
parent
7f66319927
commit
a8c099d5d0
@ -112,8 +112,6 @@ static void ivpu_bo_unbind_locked(struct ivpu_bo *bo)
|
|||||||
|
|
||||||
ivpu_dbg_bo(vdev, bo, "unbind");
|
ivpu_dbg_bo(vdev, bo, "unbind");
|
||||||
|
|
||||||
/* TODO: dma_unmap */
|
|
||||||
|
|
||||||
if (bo->mmu_mapped) {
|
if (bo->mmu_mapped) {
|
||||||
drm_WARN_ON(&vdev->drm, !bo->ctx);
|
drm_WARN_ON(&vdev->drm, !bo->ctx);
|
||||||
drm_WARN_ON(&vdev->drm, !bo->vpu_addr);
|
drm_WARN_ON(&vdev->drm, !bo->vpu_addr);
|
||||||
@ -127,6 +125,18 @@ static void ivpu_bo_unbind_locked(struct ivpu_bo *bo)
|
|||||||
bo->vpu_addr = 0;
|
bo->vpu_addr = 0;
|
||||||
bo->ctx = NULL;
|
bo->ctx = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (bo->base.base.import_attach)
|
||||||
|
return;
|
||||||
|
|
||||||
|
dma_resv_lock(bo->base.base.resv, NULL);
|
||||||
|
if (bo->base.sgt) {
|
||||||
|
dma_unmap_sgtable(vdev->drm.dev, bo->base.sgt, DMA_BIDIRECTIONAL, 0);
|
||||||
|
sg_free_table(bo->base.sgt);
|
||||||
|
kfree(bo->base.sgt);
|
||||||
|
bo->base.sgt = NULL;
|
||||||
|
}
|
||||||
|
dma_resv_unlock(bo->base.base.resv);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ivpu_bo_unbind(struct ivpu_bo *bo)
|
static void ivpu_bo_unbind(struct ivpu_bo *bo)
|
||||||
|
Loading…
Reference in New Issue
Block a user