Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp629313img; Fri, 22 Mar 2019 05:29:50 -0700 (PDT) X-Google-Smtp-Source: APXvYqxp/zWBuPMoUUHBuCdCB4fE7PY4Hu2ryAKBVI/r9TveZEnN68ajCsSaRBfFKNcZuWQWfzBF X-Received: by 2002:a62:4214:: with SMTP id p20mr9200632pfa.204.1553257790201; Fri, 22 Mar 2019 05:29:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553257790; cv=none; d=google.com; s=arc-20160816; b=onmDbUME9eBJCHC6ojLVy1/XjDkTv5Cxn1lCbx3SSGqAAGIL/lpWz31gHk3erxF3iU 7CFB1CVm9KJDTcCYOh024+m+ULn0CaDlnSfk1O0SNwZti7kd0horF5PK/vVRS9uZ7NHy 5mUH4DTsBVnY+1ZNho6YP3oxTsJkNAdGE0/D3xFXNpJb9PvD+MQ05G0nzWBHz87LJdWs /aR3MBbOkg/OTl20Dhni1j/vyW7PQvFfq0fP5wMSPmjjacBS8jlrV/F3Vq3GjAEC5DXN 2nywe6AiQXlou/l7JbhUdAmjlR3BdvHkbM4uk6onqsCOxTsxIrJnHjBJ8m7UFBUfVCG9 vHMA== 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=xMSX87ePDCUva0nKCLGW/xbfob/i0izWjXnxFuKYsY0=; b=u8izJo6NsSd5ga5AAAs6XD4VD7VLs83qL/LCxulXPjvoQ7lFvQeDIKjaBTPwsre233 f5AHn3tBaY4jTDgG6w7n6RbZ9p/7doHpN4DpoJdgdl0h8W0Idulwzv/MVdjCrrBV/UVS zsg1tKaLgGzo67mwimcMmi0Ade1YaA0iOKvm2iBF0ijWvZWCW1YyqFF0DaXZSIV2lbB2 7C6NmpC4KjVsfD+Mkc0TC+x/Sv7S+zCyRDw+e1sBNYEeJIXxl1TxX1ij/0ijEGvl05YK YUpA7Ei+duWtKpmfWrC6nboP8vYyxAZdUa6N7NaCJwMNJfQTti4C3F+Pq+74g+L9Qyca EgdA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=HskMJtrA; 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 i69si6941753plb.75.2019.03.22.05.29.32; Fri, 22 Mar 2019 05:29:50 -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=HskMJtrA; 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 S2390877AbfCVMWy (ORCPT + 99 others); Fri, 22 Mar 2019 08:22:54 -0400 Received: from mail.kernel.org ([198.145.29.99]:34170 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390852AbfCVMWw (ORCPT ); Fri, 22 Mar 2019 08:22:52 -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 724AE2054F; Fri, 22 Mar 2019 12:22:51 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1553257372; bh=pGKTugbWZrGldnIT/AIVmu0h3JfoiuCYFfBYUhVDcDM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=HskMJtrAmNFrjRwdcx1TqrDVbfliu2Jb6h3GZxUXdtNRH38whywL3JoN8wPNZWPR0 464DrwPuTiL271cBMogI5MMb64DpvldAzrUlPQvG9zs7sW09Q/5IEmbHLIFTslNhI0 JCifcJWetd/gV7UVmKFM1UGHpGeoIUNyqpO3G3yc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, =?UTF-8?q?Ga=C3=ABl=20PORTAY?= , Steve Longerbeam , Hans Verkuil , Mauro Carvalho Chehab Subject: [PATCH 5.0 212/238] media: imx: prpencvf: Stop upstream before disabling IDMA channel Date: Fri, 22 Mar 2019 12:17:11 +0100 Message-Id: <20190322111310.772674681@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190322111258.383569278@linuxfoundation.org> References: <20190322111258.383569278@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 5.0-stable review patch. If anyone has any objections, please let me know. ------------------ From: Steve Longerbeam commit a19c22677377b87e4354f7306f46ad99bc982a9f upstream. Upstream must be stopped immediately after receiving the last EOF and before disabling the IDMA channel. This can be accomplished by moving upstream stream off to just after receiving the last EOF completion in prp_stop(). For symmetry also move upstream stream on to end of prp_start(). This fixes a complete system hard lockup on the SabreAuto when streaming from the ADV7180, by repeatedly sending a stream off immediately followed by stream on: while true; do v4l2-ctl -d1 --stream-mmap --stream-count=3; done Eventually this either causes the system lockup or EOF timeouts at all subsequent stream on, until a system reset. The lockup occurs when disabling the IDMA channel at stream off. Stopping the video data stream entering the IDMA channel before disabling the channel itself appears to be a reliable fix for the hard lockup. Fixes: f0d9c8924e2c3 ("[media] media: imx: Add IC subdev drivers") Reported-by: Gaël PORTAY Tested-by: Gaël PORTAY Signed-off-by: Steve Longerbeam Cc: stable@vger.kernel.org # for 4.13 and up Signed-off-by: Hans Verkuil Signed-off-by: Mauro Carvalho Chehab Signed-off-by: Greg Kroah-Hartman --- drivers/staging/media/imx/imx-ic-prpencvf.c | 26 +++++++++++++++++--------- 1 file changed, 17 insertions(+), 9 deletions(-) --- a/drivers/staging/media/imx/imx-ic-prpencvf.c +++ b/drivers/staging/media/imx/imx-ic-prpencvf.c @@ -680,12 +680,23 @@ static int prp_start(struct prp_priv *pr goto out_free_nfb4eof_irq; } + /* start upstream */ + ret = v4l2_subdev_call(priv->src_sd, video, s_stream, 1); + ret = (ret && ret != -ENOIOCTLCMD) ? ret : 0; + if (ret) { + v4l2_err(&ic_priv->sd, + "upstream stream on failed: %d\n", ret); + goto out_free_eof_irq; + } + /* start the EOF timeout timer */ mod_timer(&priv->eof_timeout_timer, jiffies + msecs_to_jiffies(IMX_MEDIA_EOF_TIMEOUT)); return 0; +out_free_eof_irq: + devm_free_irq(ic_priv->dev, priv->eof_irq, priv); out_free_nfb4eof_irq: devm_free_irq(ic_priv->dev, priv->nfb4eof_irq, priv); out_unsetup: @@ -717,6 +728,12 @@ static void prp_stop(struct prp_priv *pr if (ret == 0) v4l2_warn(&ic_priv->sd, "wait last EOF timeout\n"); + /* stop upstream */ + ret = v4l2_subdev_call(priv->src_sd, video, s_stream, 0); + if (ret && ret != -ENOIOCTLCMD) + v4l2_warn(&ic_priv->sd, + "upstream stream off failed: %d\n", ret); + devm_free_irq(ic_priv->dev, priv->eof_irq, priv); devm_free_irq(ic_priv->dev, priv->nfb4eof_irq, priv); @@ -1148,15 +1165,6 @@ static int prp_s_stream(struct v4l2_subd if (ret) goto out; - /* start/stop upstream */ - ret = v4l2_subdev_call(priv->src_sd, video, s_stream, enable); - ret = (ret && ret != -ENOIOCTLCMD) ? ret : 0; - if (ret) { - if (enable) - prp_stop(priv); - goto out; - } - update_count: priv->stream_count += enable ? 1 : -1; if (priv->stream_count < 0)