media: sh_vou: fix pm_runtime_get_sync() usage count
[ Upstream commit 6e8b1526db164c9d4b9dacfb9bc48e365d7c4860 ]
The pm_runtime_get_sync() internally increments the
dev->power.usage_count without decrementing it, even on errors.
Replace it by the new pm_runtime_resume_and_get(), introduced by:
commit dd8088d5a8
("PM: runtime: Add pm_runtime_resume_and_get to deal with usage counter")
in order to properly decrement the usage counter, avoiding
a potential PM usage counter leak.
While here, check if the PM runtime error was caught at open time.
Reviewed-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:

committed by
Greg Kroah-Hartman

parent
64e291d697
commit
8318f7bc0e
@@ -1133,7 +1133,11 @@ static int sh_vou_open(struct file *file)
|
||||
if (v4l2_fh_is_singular_file(file) &&
|
||||
vou_dev->status == SH_VOU_INITIALISING) {
|
||||
/* First open */
|
||||
pm_runtime_get_sync(vou_dev->v4l2_dev.dev);
|
||||
err = pm_runtime_resume_and_get(vou_dev->v4l2_dev.dev);
|
||||
if (err < 0) {
|
||||
v4l2_fh_release(file);
|
||||
goto done_open;
|
||||
}
|
||||
err = sh_vou_hw_init(vou_dev);
|
||||
if (err < 0) {
|
||||
pm_runtime_put(vou_dev->v4l2_dev.dev);
|
||||
|
Reference in New Issue
Block a user