Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp1024739yba; Thu, 4 Apr 2019 02:41:19 -0700 (PDT) X-Google-Smtp-Source: APXvYqxxFyX175lleYo/+haIyTp9JDp2MFtxHdHJdeOBMSX/1ik3lxRdWhiroV/ch8kI1iCmqJnh X-Received: by 2002:a62:6402:: with SMTP id y2mr4729731pfb.194.1554370879512; Thu, 04 Apr 2019 02:41:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1554370879; cv=none; d=google.com; s=arc-20160816; b=R35EkZMDNKTU13cyDg/iaUBQhWH1Gnnmw4wj8QFXqTpF0AxmfT80kC/etnhw+q6j8X CiVQPaGntSopnX3kmllmeqsq+ZY4+Vdc+rduZwL+/XBTNIUi5CgjdxV7REJ8n5keYS2v NMN4n0IBsWkm5TkSz+UEVxsU6i1F99bqWFrr5++iHPsR+DH6miBseRDz80spf2dzSkE+ 3RUWRt+4MmKasqVhpcvnfhQZg5ZFp2dzjiR1bZANbCuo6DN+7AZuA0LWBf5OtkTfjpq0 DlKiKgiQ3PNZudz4Mu9QHSdhhdggRz77rdOtkKyMwfB74yo5OVQubZIc5wp8M9qdAwrJ S6Qg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=0rDhpCVM7F6PJSm/DKkNgIXerUH5bc5ncB/tfPe0GZc=; b=JIueyWRpzqY996iVcir8/fb9Ikr0pMMEbpaFZpnRTQTMehsrsORBsieA6kuKfCrly8 Yfm2yb0MBT4YVROz0MDnbrcrRAmgYN4LwAuNJ4pN6Phl45AfTTkKywyqdWzlJji9p/gl MEf9dxyaOxq1SSz6qM8/Jv+8wUYJxTRfSWpcRcC+n/Kn9KFaiDgjGuu0Xg2nFBZ2p4uC GgD4Cfk/GX3wzAlMsNUREYRXHf/2V/xnPdakgg/vc9bOcrC1Wcp6BgPSnUvkaBO57EII maxA+9wZLO3WuNNiyYJi5pLkpD45f+ld/113XtrC0qe9dcqR+XLv0GFyLqhfafKGiqGm EVFg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=FcgkoOrS; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w3si5339444plp.260.2019.04.04.02.41.04; Thu, 04 Apr 2019 02:41:19 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=FcgkoOrS; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731679AbfDDJCm (ORCPT + 99 others); Thu, 4 Apr 2019 05:02:42 -0400 Received: from mail.kernel.org ([198.145.29.99]:40134 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731651AbfDDJCk (ORCPT ); Thu, 4 Apr 2019 05:02:40 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id BE70D2183E; Thu, 4 Apr 2019 09:02:39 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1554368560; bh=flin8mdXjaVD25xk/6vgdvbM/euxZkxQ0Km8b3p4pSA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=FcgkoOrScTiDV8yB69zkSB6LHq4FauNlKBCeRI85I4dS2uSIpemMCHaem21IbmawX j1tge5u2f2ZprLXYRzgv4UZn75J9VzCamSZNlLrX37Osn6+6sCd3TsUE1cxXGPGF1C vzDfBtg8/0MPX2UP6SjieWyR7lZ/WP61tE+5hPzU= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Wenyou Yang , Akinobu Mita , Eugen Hristev , Sakari Ailus , Mauro Carvalho Chehab , Sasha Levin Subject: [PATCH 4.19 084/187] media: ov7740: fix runtime pm initialization Date: Thu, 4 Apr 2019 10:47:01 +0200 Message-Id: <20190404084606.993507672@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190404084603.119654039@linuxfoundation.org> References: <20190404084603.119654039@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.19-stable review patch. If anyone has any objections, please let me know. ------------------ [ Upstream commit 12aceee1f412c3ddc7750155fec06c906f14ab51 ] The runtime PM of this device is enabled after v4l2_ctrl_handler_setup(), and this makes this device's runtime PM usage count a negative value. The ov7740_set_ctrl() tries to do something only if the device's runtime PM usage counter is nonzero. ov7740_set_ctrl() { if (!pm_runtime_get_if_in_use(&client->dev)) return 0; ; pm_runtime_put(&client->dev); return ret; } However, the ov7740_set_ctrl() is called by v4l2_ctrl_handler_setup() while the runtime PM of this device is not yet enabled. In this case, the pm_runtime_get_if_in_use() returns -EINVAL (!= 0). Therefore we can't bail out of this function and the usage count is decreased by pm_runtime_put() without increment. This fixes this problem by enabling the runtime PM of this device before v4l2_ctrl_handler_setup() so that the ov7740_set_ctrl() is always called when the runtime PM is enabled. Cc: Wenyou Yang Signed-off-by: Akinobu Mita Tested-by: Eugen Hristev Signed-off-by: Sakari Ailus Signed-off-by: Mauro Carvalho Chehab Signed-off-by: Sasha Levin --- drivers/media/i2c/ov7740.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/drivers/media/i2c/ov7740.c b/drivers/media/i2c/ov7740.c index 605f3e25ad82..f5a1ee90a6c5 100644 --- a/drivers/media/i2c/ov7740.c +++ b/drivers/media/i2c/ov7740.c @@ -1101,6 +1101,9 @@ static int ov7740_probe(struct i2c_client *client, if (ret) return ret; + pm_runtime_set_active(&client->dev); + pm_runtime_enable(&client->dev); + ret = ov7740_detect(ov7740); if (ret) goto error_detect; @@ -1123,8 +1126,6 @@ static int ov7740_probe(struct i2c_client *client, if (ret) goto error_async_register; - pm_runtime_set_active(&client->dev); - pm_runtime_enable(&client->dev); pm_runtime_idle(&client->dev); return 0; @@ -1134,6 +1135,8 @@ error_async_register: error_init_controls: ov7740_free_controls(ov7740); error_detect: + pm_runtime_disable(&client->dev); + pm_runtime_set_suspended(&client->dev); ov7740_set_power(ov7740, 0); media_entity_cleanup(&ov7740->subdev.entity); -- 2.19.1