mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-07 14:24:18 +08:00
media: amphion: release core lock before reset vpu core
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: 9f599f351e
("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>
This commit is contained in:
parent
eca78a9e40
commit
a621cc4bed
@ -452,8 +452,13 @@ int vpu_inst_unregister(struct vpu_inst *inst)
|
|||||||
}
|
}
|
||||||
vpu_core_check_hang(core);
|
vpu_core_check_hang(core);
|
||||||
if (core->state == VPU_CORE_HANG && !core->instance_mask) {
|
if (core->state == VPU_CORE_HANG && !core->instance_mask) {
|
||||||
|
int err;
|
||||||
|
|
||||||
dev_info(core->dev, "reset hang core\n");
|
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->state = VPU_CORE_ACTIVE;
|
||||||
core->hang_mask = 0;
|
core->hang_mask = 0;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user