media: amphion: release core lock before reset vpu core
authorMing Qian <ming.qian@nxp.com>
Tue, 28 Jun 2022 05:19:52 +0000 (06:19 +0100)
committerMauro Carvalho Chehab <mchehab@kernel.org>
Fri, 8 Jul 2022 13:53:35 +0000 (14:53 +0100)
In reset vpu core, driver will wait for a response event,
but if there are still some events unhandled,
they will be handled first, driver may acquire core lock for that.
So if we do reset in core lock, it may led to reset timeout.

Fixes: 9f599f351e86a ("media: amphion: add vpu core driver")
Signed-off-by: Ming Qian <ming.qian@nxp.com>
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: Mauro Carvalho Chehab <mchehab@kernel.org>
drivers/media/platform/amphion/vpu_core.c

index 3cca7ae..73faa50 100644 (file)
@@ -452,8 +452,13 @@ int vpu_inst_unregister(struct vpu_inst *inst)
        }
        vpu_core_check_hang(core);
        if (core->state == VPU_CORE_HANG && !core->instance_mask) {
+               int err;
+
                dev_info(core->dev, "reset hang core\n");
-               if (!vpu_core_sw_reset(core)) {
+               mutex_unlock(&core->lock);
+               err = vpu_core_sw_reset(core);
+               mutex_lock(&core->lock);
+               if (!err) {
                        core->state = VPU_CORE_ACTIVE;
                        core->hang_mask = 0;
                }