accel/ivpu: Send VPU_JSM_MSG_CONTEXT_DELETE when deleting context
authorAndrzej Kacprowski <andrzej.kacprowski@linux.intel.com>
Thu, 2 Feb 2023 09:21:12 +0000 (10:21 +0100)
committerJacek Lawrynowicz <jacek.lawrynowicz@linux.intel.com>
Mon, 6 Feb 2023 08:01:56 +0000 (09:01 +0100)
The VPU_JSM_MSG_CONTEXT_DELETE will remove any resources associated
with the SSID, that included any blobs create by the user space
application.

The command can also remove doorbell registrations, but since this
does not work in HW scheduling case, we do not depend on this
capability and unregister the doorbells explicitly.

Signed-off-by: Andrzej Kacprowski <andrzej.kacprowski@linux.intel.com>
Signed-off-by: Stanislaw Gruszka <stanislaw.gruszka@linux.intel.com>
Reviewed-by: Jeffrey Hugo <quic_jhugo@quicinc.com>
Signed-off-by: Jacek Lawrynowicz <jacek.lawrynowicz@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20230202092114.2637452-3-stanislaw.gruszka@linux.intel.com
drivers/accel/ivpu/ivpu_drv.c
drivers/accel/ivpu/ivpu_jsm_msg.c
drivers/accel/ivpu/ivpu_jsm_msg.h

index a29e8ee0dce6cb6d87f87ecabb3f4a1987372d88..70c104851c6db7d2b45d14e672e86ca8a589e877 100644 (file)
@@ -90,6 +90,7 @@ static void file_priv_release(struct kref *ref)
 
        ivpu_cmdq_release_all(file_priv);
        ivpu_bo_remove_all_bos_from_context(&file_priv->ctx);
+       ivpu_jsm_context_release(vdev, file_priv->ctx.id);
        ivpu_mmu_user_context_fini(vdev, &file_priv->ctx);
        drm_WARN_ON(&vdev->drm, xa_erase_irq(&vdev->context_xa, file_priv->ctx.id) != file_priv);
        mutex_destroy(&file_priv->lock);
index af77dafac97edda2794856ad7947f8467998c22a..831bfd2b2d39d4e33c03d1c335c814d728bf50cd 100644 (file)
@@ -167,3 +167,14 @@ int ivpu_jsm_trace_set_config(struct ivpu_device *vdev, u32 trace_level, u32 tra
 
        return ret;
 }
+
+int ivpu_jsm_context_release(struct ivpu_device *vdev, u32 host_ssid)
+{
+       struct vpu_jsm_msg req = { .type = VPU_JSM_MSG_SSID_RELEASE };
+       struct vpu_jsm_msg resp;
+
+       req.payload.ssid_release.host_ssid = host_ssid;
+
+       return ivpu_ipc_send_receive(vdev, &req, VPU_JSM_MSG_SSID_RELEASE_DONE, &resp,
+                                    VPU_IPC_CHAN_ASYNC_CMD, vdev->timeout.jsm);
+}
index 1a3e2e2740bd86873b00008254a30ab6e23f86a3..ab50d7b017c1b26ec4f32e25bef770dfc2135f57 100644 (file)
@@ -19,5 +19,5 @@ int ivpu_jsm_trace_get_capability(struct ivpu_device *vdev, u32 *trace_destinati
                                  u64 *trace_hw_component_mask);
 int ivpu_jsm_trace_set_config(struct ivpu_device *vdev, u32 trace_level, u32 trace_destination_mask,
                              u64 trace_hw_component_mask);
-
+int ivpu_jsm_context_release(struct ivpu_device *vdev, u32 host_ssid);
 #endif