Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp2706204pxv; Sun, 11 Jul 2021 23:19:19 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyuC7r6oq28sotccGz/vF8DChDb2xjuGaWoLe5syF8yLBX81+0rt6x1n+4Aevx8HoWTXkZ2 X-Received: by 2002:a05:6638:39c2:: with SMTP id o2mr11451377jav.87.1626070759307; Sun, 11 Jul 2021 23:19:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626070759; cv=none; d=google.com; s=arc-20160816; b=mHPgbFtQg/D2zZOlRR+W3pKhGA/ACMFYJS9AWQJAi4znXKteqYnSxu8HcjSYsq20qM ovjVA5UlI+j9B51ngMHvpglU2g0NYkq190JmSZCb8w1X/qQqs4c9q1+2f3zzQIkiZsLs XHRJVoC1g3HK8VdwgxPs4zxndE0urlx32hzRUEypqlBbsduhpe++AV8QZmKFdv1lGqKX aVAiloHx3CEaBiImW/DPdT9oYsfkwPed+YiaHxxp17beDlWjXwKI5W0l728LWiSE1u6F nrPQQtlYOSg9wDBxaI3r98remNyYYAbcM3uchGczmfxbIMDohFrzwQ2E2I5+gzprR9Bd GwvA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=boNceQtCGvtewO9FusbPSvhtuRHwJ6lG8K1kHIhsSQk=; b=GKa7g/IVEqyUhbxwP5Fv8UyuFk38OTqycrA5rjtwpKHR4U4ylj81V84azrjkSiaF9P Km3ZjVfOE3+x2ALE52ZbgXsWlOq9GcR46Xsj+7OsZpZMTRXcmqV1uXu6tiRLFiMPfWnQ m9HpzhzeNoGdEO/IRBPciD5Wl/k+eMmAmlYdM76vaVbtG1Sq8i5htyaG+PHHy+6Nc9GY B8hoCrFLwbbg/ZrLrpiHlEuka9nbYvaZy3mMG1f6Vw8jeGjBW/DifqD1XXpei5yQ0+E5 MTRCd6Y4TXq9bjQ5nFsZC9I4LhVfniPLDL5EjjTaH9JFnpWFY87SNxA979QAEp4PyXbM 72Rw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=d6IIo4XA; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v15si5699475jas.5.2021.07.11.23.19.07; Sun, 11 Jul 2021 23:19:19 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=d6IIo4XA; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233398AbhGLGUd (ORCPT + 99 others); Mon, 12 Jul 2021 02:20:33 -0400 Received: from mail.kernel.org ([198.145.29.99]:38866 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234040AbhGLGTv (ORCPT ); Mon, 12 Jul 2021 02:19:51 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 51353610D0; Mon, 12 Jul 2021 06:17:02 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626070622; bh=LrLTm9w/kHOJ+FdwiIgnNgBM8M9WiMvLXdVAYHNZ3KQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=d6IIo4XA8+wFn/K4CR1gUJN5trCfiam4yPFEVjzPU2j0eBKPgzfaWbA/bAR66pP35 qgUk0FrbsMzAStJDa/tqB7QMhzjhuggcaM5K3O5deVWWPCsfNwKaI70V+E4wm6OfTr hFKrUubkIAgX0TLp7oauy6XmalMeCpNm6SNPlKIo= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jonathan Cameron , Mauro Carvalho Chehab , Sasha Levin Subject: [PATCH 5.4 067/348] media: sh_vou: fix pm_runtime_get_sync() usage count Date: Mon, 12 Jul 2021 08:07:31 +0200 Message-Id: <20210712060710.917379986@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210712060659.886176320@linuxfoundation.org> References: <20210712060659.886176320@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Mauro Carvalho Chehab [ 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 dd8088d5a896 ("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 Signed-off-by: Mauro Carvalho Chehab Signed-off-by: Sasha Levin --- drivers/media/platform/sh_vou.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/drivers/media/platform/sh_vou.c b/drivers/media/platform/sh_vou.c index 2236702c21b4..84c4b19fb107 100644 --- a/drivers/media/platform/sh_vou.c +++ b/drivers/media/platform/sh_vou.c @@ -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); -- 2.30.2