Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp66911ybp; Thu, 3 Oct 2019 10:15:20 -0700 (PDT) X-Google-Smtp-Source: APXvYqxjzXA0VpREHnGR3l01biPrTIz5PN3YFYzLHZIqEgxyeAnI8oEeNjIYPfLZ3N/JzWMKjFlR X-Received: by 2002:a50:a8c5:: with SMTP id k63mr10713376edc.122.1570122919909; Thu, 03 Oct 2019 10:15:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1570122919; cv=none; d=google.com; s=arc-20160816; b=sDZzVRdOAeiU/I2o8badLThcGL2ZxnORIUxrYVckXRWX5fixRBX+MJ/sQOAT8mc7Oh UmIimpM/Q/1xlyI+j9bPnBcIt3cSla9IyAE5aDc/bj3QMKxcnSjOH6H38JBlxCqBEflY 4iUTWNNEWlZTErBxS+Q9rAjy3y2XIRrhOAkdMX0pxDdzu4TjjmDdUJvjcG76jjpjA5jb iek31cXRRlnR5/veRK4EPqri/hDGFW1trb3DHTkU7LxiXPpxu+zQPNt5werwMq+YheOQ OKglQKTvxI/QWXzunDbH5ngy+NL5oS8Z+m+qnClsB8pleFZiWc+NFTKrXlkkZLl0BNqk dWLA== 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=vtqBs0bSFtIfxrgywFVEnh/9zs2gggbsmjs6LrXok3s=; b=yimr6LWOEBT2VKCI+58zvF2P1cFvYRhNkd+rpdNrDj/NZmStm8mbOW1EXo7wwbTUJZ PaiyiuiTfQwp1t+lGPalwXROZHEnwOjLA/u+gRjcSVb5iVfX6V0hwrY2Hbd88QwwUW8K x/bMO9SrGu115VtWwBhbJUcMcMR/Ztpy3xtlMuiVxQ0mWY4SPoSq8HRWmmsD3ixviJwc KmVK3pmJ8EZ7cbxUig8yvAKqWrNpbqaAYo4RSnkMCMct8DwiKHqWfTgEiNCCDb7X+lCG R4OrL0m7OBVkOvNBYeaxu7Hv30DVyUaWKzZ3l+Hjh1rqgUi2bfXEuOKlmmnOkQ+EI6l2 1q/g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=m+ShSmHH; 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 i12si1614823ejj.119.2019.10.03.10.14.54; Thu, 03 Oct 2019 10:15: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=m+ShSmHH; 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 S2403955AbfJCRN2 (ORCPT + 99 others); Thu, 3 Oct 2019 13:13:28 -0400 Received: from mail.kernel.org ([198.145.29.99]:33524 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389505AbfJCQ2s (ORCPT ); Thu, 3 Oct 2019 12:28:48 -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 9475B222CB; Thu, 3 Oct 2019 16:28:47 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1570120128; bh=UgYhas+Ne82pUddsBnQzmIKiDCnGAB4Tisqknu33vB4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=m+ShSmHH6EU+ZDymlMlU3VcSx1th/cnuaxqd+NWmSWsKappC7i8qmEc3AZVqqNN7V MaV4IxUR/7ENfoil5xGeTTtXy7NZVfl/seg9H//dd4AK+/W81bShoPrkFpKRw355zE TWh14rtADgUn9Dt6wogArA7Kif+9OOBaWINuaS/g= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Ezequiel Garcia , Fabio Estevam , Steve Longerbeam , Philipp Zabel , Sakari Ailus , Mauro Carvalho Chehab , Sasha Levin Subject: [PATCH 5.2 106/313] media: imx: mipi csi-2: Dont fail if initial state times-out Date: Thu, 3 Oct 2019 17:51:24 +0200 Message-Id: <20191003154543.310627899@linuxfoundation.org> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20191003154533.590915454@linuxfoundation.org> References: <20191003154533.590915454@linuxfoundation.org> User-Agent: quilt/0.66 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 From: Ezequiel Garcia [ Upstream commit 0d5078c7172c46db6c58718d817b9fcf769554b4 ] Not all sensors will be able to guarantee a proper initial state. This may be either because the driver is not properly written, or (probably unlikely) because the hardware won't support it. While the right solution in the former case is to fix the sensor driver, the real world not always allows right solutions, due to lack of available documentation and support on these sensors. Let's relax this requirement, and allow the driver to support stream start, even if the sensor initial sequence wasn't the expected. Also improve the warning message to better explain the problem and provide a hint that the sensor driver needs to be fixed. Signed-off-by: Ezequiel Garcia Signed-off-by: Fabio Estevam Reviewed-by: Steve Longerbeam Reviewed-by: Philipp Zabel Signed-off-by: Sakari Ailus Signed-off-by: Mauro Carvalho Chehab Signed-off-by: Sasha Levin --- drivers/staging/media/imx/imx6-mipi-csi2.c | 12 ++++-------- 1 file changed, 4 insertions(+), 8 deletions(-) diff --git a/drivers/staging/media/imx/imx6-mipi-csi2.c b/drivers/staging/media/imx/imx6-mipi-csi2.c index f29e28df36ed8..bfa4b254c4e48 100644 --- a/drivers/staging/media/imx/imx6-mipi-csi2.c +++ b/drivers/staging/media/imx/imx6-mipi-csi2.c @@ -243,7 +243,7 @@ static int __maybe_unused csi2_dphy_wait_ulp(struct csi2_dev *csi2) } /* Waits for low-power LP-11 state on data and clock lanes. */ -static int csi2_dphy_wait_stopstate(struct csi2_dev *csi2) +static void csi2_dphy_wait_stopstate(struct csi2_dev *csi2) { u32 mask, reg; int ret; @@ -254,11 +254,9 @@ static int csi2_dphy_wait_stopstate(struct csi2_dev *csi2) ret = readl_poll_timeout(csi2->base + CSI2_PHY_STATE, reg, (reg & mask) == mask, 0, 500000); if (ret) { - v4l2_err(&csi2->sd, "LP-11 timeout, phy_state = 0x%08x\n", reg); - return ret; + v4l2_warn(&csi2->sd, "LP-11 wait timeout, likely a sensor driver bug, expect capture failures.\n"); + v4l2_warn(&csi2->sd, "phy_state = 0x%08x\n", reg); } - - return 0; } /* Wait for active clock on the clock lane. */ @@ -316,9 +314,7 @@ static int csi2_start(struct csi2_dev *csi2) csi2_enable(csi2, true); /* Step 5 */ - ret = csi2_dphy_wait_stopstate(csi2); - if (ret) - goto err_assert_reset; + csi2_dphy_wait_stopstate(csi2); /* Step 6 */ ret = v4l2_subdev_call(csi2->src_sd, video, s_stream, 1); -- 2.20.1