Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp229506pxf; Wed, 10 Mar 2021 05:10:40 -0800 (PST) X-Google-Smtp-Source: ABdhPJzSb18E7iiAQMu5WU/GTX61D5dAgGvazAzvQnIE2P5Oht8tf78mgUVJ/AzU+chXC+iROOCy X-Received: by 2002:a17:906:296a:: with SMTP id x10mr3517246ejd.240.1615381840212; Wed, 10 Mar 2021 05:10:40 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1615381840; cv=none; d=google.com; s=arc-20160816; b=bktjaBpsFKagb2THpQFpUmgo2TX599VSpCm1LOq3GDaoAiprdSKpmHsqdRpfjKknjO sEgmKFoCAv8jSF/07WMpUc7YQhyKjhWd4CMqJo93HiJgVYVGN64d1ZUSQCeSusjruBSn SvFsoqMlavsa3+zn6wrYYxgVYSy65rUkCaCzVspyclKKyEMgcuORVeXKDvNtedeBdmPu MTE4dja6Dr0o8q/v3kIUbM12NodiVgbhAhmmUi5KexRZqXXeABkDco2yi3WAb22AdpP2 zW74nytcGFBcpzqcNerye10DABGUslSrBAelrrW5xn/JLVokqyPQLkpcBygOjJhi0x/f pS/A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=AuIkG5mFalgNcUDwhfpUKnF07Cv7k5E48oJPkOG41VA=; b=CS46NKN77gUrOMUgX5R0IJx1bx5C3KqjO2u3LnmZ7ACGVRdXqAV2IaXB0InsxO4zRc mVLIUI0Td1SD/ywimNlHSzF4y50UXgvbS8rI7wVEomFwKp0QLJ+J3xw6y3CwLwkjCPKg 8h4XgoBmWkNfU7QPuZNjW3E+8cva8PYuLjSOUOnwwNyveF+rrs7ERQN/RSLxpTtqFC4z 0nROR+IsM4V5JSWLUnwXeXL/Fgg8vQtJFqJrwd9t9BsKUa7gyxvxZa3GdKy+X3X3u/vt FVNidMyRe2xIGN02d4BY4TDixX9BjThbu6uAUdPNY/1x/5AJel2iGs18HOX7cMxpYRiX gX4A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=VYtNRqZ6; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id w10si11617146ejv.500.2021.03.10.05.10.15; Wed, 10 Mar 2021 05:10:40 -0800 (PST) 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=@gmail.com header.s=20161025 header.b=VYtNRqZ6; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232772AbhCJNJG (ORCPT + 99 others); Wed, 10 Mar 2021 08:09:06 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42622 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232710AbhCJNIr (ORCPT ); Wed, 10 Mar 2021 08:08:47 -0500 Received: from mail-yb1-xb2b.google.com (mail-yb1-xb2b.google.com [IPv6:2607:f8b0:4864:20::b2b]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 27188C061760; Wed, 10 Mar 2021 05:08:47 -0800 (PST) Received: by mail-yb1-xb2b.google.com with SMTP id 133so17764055ybd.5; Wed, 10 Mar 2021 05:08:47 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=AuIkG5mFalgNcUDwhfpUKnF07Cv7k5E48oJPkOG41VA=; b=VYtNRqZ6X1ixEPGetG5UzE4NmdWJ+xCmwr86X9AhSM1nJWwpRZvdDqhxK6DX3MfIog 6ABMb4FuUquBo45lj1qEz/vnIo58z6QhfAuNU7DAmPf0a6Pw8WHHCCEl5Wwi12+rViVz CCGErfTOIbrWVMk+4WEK6opS3ZUwC8oCYhtxR0Jn4N1mZBreYUma4aoPPTdCdKssRz0d AT2eGOwqQCr6ssnwoCUUH/voPIDY0fTBo8LZ6LCcF1iazklGSTlqov9Opf8iHRsXNJeR esdPHWUlidbCxaIOYcLio7mgb3coJ3tJpxCtKsb1R3emOZsm90I2S8EQxS3tH0L4NcKg oFxA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=AuIkG5mFalgNcUDwhfpUKnF07Cv7k5E48oJPkOG41VA=; b=bCvX7Fa/29JjJAA16n6Xmx75qLBoSTrou5yBZ2qQCMdlzErcC4AIMJRIRDnWjoJrPe mNgnQAbL0Q3Xgcn3PyGYXLhGi+SMQTGno1mwtwzRxXj9uTteBmlD2TOhsQg/bvFatYGo Kcq8B39gbOxM2apaLQwuc2f6QAbUs7n3CmeapiCNkEWzsbOiA4FAujgnGtZixi6do8Og yNUsXDNqEeFyrljTLvPDmf7Xhr72HYT1hsImAaLvefvMYFpNCG6kRt3g91CHAtdxQPFP gVDvkw4Qo6CR8JniFtGeZrreYClXCjSHfNHsejnxxSnCxS0umAlg9JDZUQ7//RHHf9WZ OlEA== X-Gm-Message-State: AOAM533Q5DnL7j3iJp+Wn37we96O9xRNSYX11D5wgMkPiJ2gNtMgDCFq y1MzQDPQtHfYjTjB27uVluNFnU3+3rEtHMurH8s= X-Received: by 2002:a25:d54:: with SMTP id 81mr3736951ybn.401.1615381726302; Wed, 10 Mar 2021 05:08:46 -0800 (PST) MIME-Version: 1.0 References: <20210310122014.28353-1-prabhakar.mahadev-lad.rj@bp.renesas.com> <20210310122014.28353-3-prabhakar.mahadev-lad.rj@bp.renesas.com> In-Reply-To: From: "Lad, Prabhakar" Date: Wed, 10 Mar 2021 13:08:20 +0000 Message-ID: Subject: Re: [PATCH 2/3] media: i2c: imx219: Serialize during stream start/stop To: Laurent Pinchart Cc: Lad Prabhakar , Dave Stevenson , Mauro Carvalho Chehab , Pavel Machek , Andrey Konovalov , Sakari Ailus , Jacopo Mondi , Hans Verkuil , linux-media , LKML , Linux-Renesas , Biju Das Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Laurent, On Wed, Mar 10, 2021 at 12:54 PM Laurent Pinchart wrote: > > Hi Prabhakar, > > On Wed, Mar 10, 2021 at 12:46:39PM +0000, Lad, Prabhakar wrote: > > On Wed, Mar 10, 2021 at 12:40 PM Laurent Pinchart wrote: > > > On Wed, Mar 10, 2021 at 12:20:13PM +0000, Lad Prabhakar wrote: > > > > Serialize during stream start/stop in suspend/resume callbacks. > > > > > > Could you please explain why this is needed ? > > > > > The streaming variable in this driver has serialized access, but this > > wasn't taken care during suspend/resume callbacks. > > But nothing that touches the streaming variable can run concurrently to > suspend/resume, isn't it ? > You are right, we could drop this patch. > I'm actually even quite dubious about the need to start and stop > streaming during resume and suspend, the driver using the subdev should > start/stop the whole video pipeline at suspend/resume time. > I see, do we have any documentation on how bridge/subdevs should behave on suspend/resume ? I did have a quick look at the omp3isp bridge driver and it does start/stop on resume/suspend callbacks. Cheers, Prabhakar > > > > Signed-off-by: Lad Prabhakar > > > > --- > > > > drivers/media/i2c/imx219.c | 5 +++++ > > > > 1 file changed, 5 insertions(+) > > > > > > > > diff --git a/drivers/media/i2c/imx219.c b/drivers/media/i2c/imx219.c > > > > index f0cf1985a4dc..87c021de1460 100644 > > > > --- a/drivers/media/i2c/imx219.c > > > > +++ b/drivers/media/i2c/imx219.c > > > > @@ -1172,8 +1172,10 @@ static int __maybe_unused imx219_suspend(struct device *dev) > > > > struct v4l2_subdev *sd = dev_get_drvdata(dev); > > > > struct imx219 *imx219 = to_imx219(sd); > > > > > > > > + mutex_lock(&imx219->mutex); > > > > if (imx219->streaming) > > > > imx219_stop_streaming(imx219); > > > > + mutex_unlock(&imx219->mutex); > > > > > > > > return 0; > > > > } > > > > @@ -1184,11 +1186,13 @@ static int __maybe_unused imx219_resume(struct device *dev) > > > > struct imx219 *imx219 = to_imx219(sd); > > > > int ret; > > > > > > > > + mutex_lock(&imx219->mutex); > > > > if (imx219->streaming) { > > > > ret = imx219_start_streaming(imx219); > > > > if (ret) > > > > goto error; > > > > } > > > > + mutex_unlock(&imx219->mutex); > > > > > > > > return 0; > > > > > > > > @@ -1197,6 +1201,7 @@ static int __maybe_unused imx219_resume(struct device *dev) > > > > imx219->streaming = false; > > > > __v4l2_ctrl_grab(imx219->vflip, false); > > > > __v4l2_ctrl_grab(imx219->hflip, false); > > > > + mutex_unlock(&imx219->mutex); > > > > > > > > return ret; > > > > } > > -- > Regards, > > Laurent Pinchart