Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3844037pxf; Mon, 15 Mar 2021 22:03:25 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxoeX5u8nty45wRBc+m1V3U25w4Gn6sblpQzBtwS0dM+SMV7J81z3/m7RYTZr1Mv6AD/HDo X-Received: by 2002:aa7:ccd7:: with SMTP id y23mr34004310edt.190.1615871004933; Mon, 15 Mar 2021 22:03:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1615871004; cv=none; d=google.com; s=arc-20160816; b=Bc5YbGJIPus+WzKLKtS5UpwSjrYz3UpBJmruNccWj+TrwH3uxCdrRUraJ9pPWjkp2l Qm+kic/i08gXZPw2HLPbsVheiwL76lz4uujXk1mfTAKt9V2YRjEQUSNiKaY1WamEeGrg IwLhv86fxFzHUz6SYI45ykcpVt3HbfZ79mjx/Ol/qYdVH6aGUnyAvrF9LAlOrmTvJ6Dl T9EmDp2zydB98pRD2cxszvLO+E0mIqiYxFH0QwJ2ABTkHggRaa2un7c09PI763RTzESM TRzW0qKvtJPicgSFKDLtZUMwEXoV1aHZpYva1wQgo7oTSH1I96X1kgz4oj2EpeY6HiWv c6Ug== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=zdnJOW1K/cBlJQm0EJN36DvOIHvxcdqCl29dDI8vcjQ=; b=uK4PgkGlHwwPXq8zIvXRopPMZAbPVPcUuehFC5Xjx+tsZbjtXBLUAgdoOpZnF5k6G7 rdOwwcgY0mMj0Bw0jE93QTOQ/YNHoBbpvfCptn8b7LUgjG9aOWOf/fWpukTinHBuQVV/ wSLxMk/blOjgUrm8g/EyiAe2Z32ILyw+t2D3fANpg7Sp9OQA/W611G6HZW1MkOJXqKWF OWIToHIIDSNUOXlzmVtuasNjOU3qg8qkc96SwCzr46tUT5F0MGg7wOQFRswZAIs3ibYZ gdLNdss0jWj3r9XnJ6DklqYUyhyCtZUHJjEgtTpW8tEsEvPH+CEBUPswQEqdIUui4A2z gHHQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=GAkCWva6; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a10si14011345edf.499.2021.03.15.22.03.02; Mon, 15 Mar 2021 22:03:24 -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 (test mode) header.i=@ideasonboard.com header.s=mail header.b=GAkCWva6; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233607AbhCOVqm (ORCPT + 99 others); Mon, 15 Mar 2021 17:46:42 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33260 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233664AbhCOVqW (ORCPT ); Mon, 15 Mar 2021 17:46:22 -0400 Received: from perceval.ideasonboard.com (perceval.ideasonboard.com [IPv6:2001:4b98:dc2:55:216:3eff:fef7:d647]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 35D86C06174A; Mon, 15 Mar 2021 14:46:22 -0700 (PDT) Received: from pendragon.ideasonboard.com (62-78-145-57.bb.dnainternet.fi [62.78.145.57]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id 89CFB316; Mon, 15 Mar 2021 22:46:20 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1615844780; bh=5Znf7F2pIW9/0KS0yAG1GRuyRuzXBbLYiAw7C6bRsWk=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=GAkCWva6IvbMhlMMl/CRterOQ3BIiA/YzAn8m6tjQso7IOR2iRcSOOmeYS214oSiG ZpNd1/MaDH3dkcyScIL3H3ywQzFGeU/mZKUaJV7U3POhaMA0OvGNa2JvVbKPeKzdi2 cgp4q+7baeAqUhdxxkoWx9sy99M8AvuFTI2td5UE= Date: Mon, 15 Mar 2021 23:45:44 +0200 From: Laurent Pinchart To: Jacopo Mondi Cc: kieran.bingham+renesas@ideasonboard.com, niklas.soderlund+renesas@ragnatech.se, geert@linux-m68k.org, Mauro Carvalho Chehab , linux-media@vger.kernel.org, linux-renesas-soc@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v2 11/18] media: i2c: rdacm21: Fix OV10640 powerdown Message-ID: References: <20210315131512.133720-1-jacopo+renesas@jmondi.org> <20210315131512.133720-12-jacopo+renesas@jmondi.org> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20210315131512.133720-12-jacopo+renesas@jmondi.org> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Jacopo, Thank you for the patch. On Mon, Mar 15, 2021 at 02:15:05PM +0100, Jacopo Mondi wrote: > The OV10640 image sensor powerdown signal is controlled by the first > line of the OV490 GPIO pad #1, but the pad #0 identifier > OV490_GPIO_OUTPUT_VALUE0 was erroneously used. As a result the image > sensor powerdown signal was never asserted but was kept high by an > internal pull-up resistor, causing sporadic failures during the > image sensor startup phase. > > Fix this by using the correct GPIO pad identifier. > > While at it also fix the GPIO signal handling sequence, as the reset > line was released before the powerdown one, and introduce the correct > delays in between the two operations. > > Wait the mandatory 1 millisecond delay after the powerup lane is > asserted. The reset delay is not characterized in the chip manual if > not as "255 XVCLK + initialization". Wait for at least 3 milliseconds > to guarantee the SCCB bus is available. > > This commit fixes a sporadic start-up error triggered by a failure to > read the OV10640 chip ID: > rdacm21 8-0054: OV10640 ID mismatch: (0x01) > > Fixes: a59f853b3b4b ("media: i2c: Add driver for RDACM21 camera module") > Signed-off-by: Jacopo Mondi Reviewed-by: Laurent Pinchart > --- > drivers/media/i2c/rdacm21.c | 6 ++++-- > 1 file changed, 4 insertions(+), 2 deletions(-) > > diff --git a/drivers/media/i2c/rdacm21.c b/drivers/media/i2c/rdacm21.c > index 7bce55adfd7c..50a9b0d8255d 100644 > --- a/drivers/media/i2c/rdacm21.c > +++ b/drivers/media/i2c/rdacm21.c > @@ -333,13 +333,15 @@ static int ov10640_initialize(struct rdacm21_device *dev) > { > u8 val; > > - /* Power-up OV10640 by setting RESETB and PWDNB pins high. */ > + /* Power-up OV10640 by setting PWDNB and RESETB pins high. */ > ov490_write_reg(dev, OV490_GPIO_SEL0, OV490_GPIO0); > ov490_write_reg(dev, OV490_GPIO_SEL1, OV490_SPWDN0); > ov490_write_reg(dev, OV490_GPIO_DIRECTION0, OV490_GPIO0); > ov490_write_reg(dev, OV490_GPIO_DIRECTION1, OV490_SPWDN0); > + > + ov490_write_reg(dev, OV490_GPIO_OUTPUT_VALUE1, OV490_SPWDN0); > + usleep_range(1500, 3000); > ov490_write_reg(dev, OV490_GPIO_OUTPUT_VALUE0, OV490_GPIO0); > - ov490_write_reg(dev, OV490_GPIO_OUTPUT_VALUE0, OV490_SPWDN0); > usleep_range(3000, 5000); > > /* Read OV10640 ID to test communications. */ -- Regards, Laurent Pinchart