Message ID | 20231126141517.7534-9-hdegoede@redhat.com (mailing list archive) |
---|---|
State | Superseded |
Delegated to: | Sakari Ailus |
Headers |
Received: from sv.mirrors.kernel.org ([139.178.88.99]) by www.linuxtv.org with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from <linux-media+bounces-1047-patchwork=linuxtv.org@vger.kernel.org>) id 1r7FvU-001Mjh-Uq for patchwork@linuxtv.org; Sun, 26 Nov 2023 14:16:02 +0000 Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id B241928124C for <patchwork@linuxtv.org>; Sun, 26 Nov 2023 14:15:57 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id CDFA4D2F9; Sun, 26 Nov 2023 14:15:41 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=redhat.com header.i=@redhat.com header.b="Eal7+5U/" X-Original-To: linux-media@vger.kernel.org Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.129.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E4DD410F for <linux-media@vger.kernel.org>; Sun, 26 Nov 2023 06:15:38 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1701008138; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=u305bXb7/Pe+KIe1xHscT/pjlkbHUw3eN875aO4vCl0=; b=Eal7+5U/E2jxr2AN7ynLQ+7t5VooeuRUj3Dx/V9QSFmkHJEjqJjPjFLmGbre7O6jWxryTf 5GU00AbSnRGiaw4lm53ZY5500Q4xJiWFM1/hTiIn7/OXdSCemijTI38qQDH2fnId6MxUgG 9feK94FD9ghEcoPqfgNGPmU549kRIq8= Received: from mimecast-mx02.redhat.com (mimecast-mx02.redhat.com [66.187.233.88]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-639-Df3R6fB5MY2yRTq_BYN1Wg-1; Sun, 26 Nov 2023 09:15:34 -0500 X-MC-Unique: Df3R6fB5MY2yRTq_BYN1Wg-1 Received: from smtp.corp.redhat.com (int-mx04.intmail.prod.int.rdu2.redhat.com [10.11.54.4]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256) (No client certificate requested) by mimecast-mx02.redhat.com (Postfix) with ESMTPS id BD3DB85A59D; Sun, 26 Nov 2023 14:15:33 +0000 (UTC) Received: from localhost.localdomain (unknown [10.39.192.41]) by smtp.corp.redhat.com (Postfix) with ESMTP id C4CAB2026D33; Sun, 26 Nov 2023 14:15:32 +0000 (UTC) From: Hans de Goede <hdegoede@redhat.com> To: Sakari Ailus <sakari.ailus@linux.intel.com>, Tianshu Qiu <tian.shu.qiu@intel.com>, Bingbu Cao <bingbu.cao@intel.com> Cc: Hans de Goede <hdegoede@redhat.com>, Mauro Carvalho Chehab <mchehab@kernel.org>, Kate Hsuan <hpa@redhat.com>, linux-media@vger.kernel.org Subject: [PATCH v2 8/9] media: ov2740: Add a sleep after resetting the sensor Date: Sun, 26 Nov 2023 15:15:16 +0100 Message-ID: <20231126141517.7534-9-hdegoede@redhat.com> In-Reply-To: <20231126141517.7534-1-hdegoede@redhat.com> References: <20231126141517.7534-1-hdegoede@redhat.com> Precedence: bulk X-Mailing-List: linux-media@vger.kernel.org List-Id: <linux-media.vger.kernel.org> List-Subscribe: <mailto:linux-media+subscribe@vger.kernel.org> List-Unsubscribe: <mailto:linux-media+unsubscribe@vger.kernel.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 3.4.1 on 10.11.54.4 X-LSpam-Score: -4.8 (----) X-LSpam-Report: No, score=-4.8 required=5.0 tests=BAYES_00=-1.9,DKIMWL_WL_HIGH=0.001,DKIM_SIGNED=0.1,DKIM_VALID=-0.1,DKIM_VALID_AU=-0.1,HEADER_FROM_DIFFERENT_DOMAINS=0.5,MAILING_LIST_MULTI=-1,RCVD_IN_DNSWL_MED=-2.3 autolearn=unavailable autolearn_force=no |
Series |
media: ov2740: reset GPIO, clk and 180 MHz link-frequency support
|
|
Commit Message
Hans de Goede
Nov. 26, 2023, 2:15 p.m. UTC
Split the resetting of the sensor out of the link_freq_config reg_list
and add a delay after this.
This hopefully fixes the stream sometimes not starting, this was
taken from the ov2740 sensor driver in the out of tree IPU6 driver:
https://github.com/intel/ipu6-drivers/
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
---
drivers/media/i2c/ov2740.c | 11 +++++++++--
1 file changed, 9 insertions(+), 2 deletions(-)
Comments
Hans, On 11/26/23 10:15 PM, Hans de Goede wrote: > Split the resetting of the sensor out of the link_freq_config reg_list > and add a delay after this. > > This hopefully fixes the stream sometimes not starting, this was > taken from the ov2740 sensor driver in the out of tree IPU6 driver: Thanks for your patch. I don't know the details for ov2740 here, we met some similar issues with another OminiVision camera sensor, it is somehow related to the OTP read. Unfortunately, we didn't find the root-cause. Maybe you can remove the OTP read to check, I think the OTP is useless if I don't forget anything. Hao, do you have any details for this issue? > > https://github.com/intel/ipu6-drivers/ > > Signed-off-by: Hans de Goede <hdegoede@redhat.com> > --- > drivers/media/i2c/ov2740.c | 11 +++++++++-- > 1 file changed, 9 insertions(+), 2 deletions(-) > > diff --git a/drivers/media/i2c/ov2740.c b/drivers/media/i2c/ov2740.c > index 8f5c33f68d42..a49c065c6cf4 100644 > --- a/drivers/media/i2c/ov2740.c > +++ b/drivers/media/i2c/ov2740.c > @@ -128,7 +128,6 @@ struct ov2740_mode { > }; > > static const struct ov2740_reg mipi_data_rate_720mbps[] = { > - {0x0103, 0x01}, > {0x0302, 0x4b}, > {0x030d, 0x4b}, > {0x030e, 0x02}, > @@ -137,7 +136,6 @@ static const struct ov2740_reg mipi_data_rate_720mbps[] = { > }; > > static const struct ov2740_reg mipi_data_rate_360mbps[] = { > - {0x0103, 0x01}, > {0x0302, 0x4b}, > {0x0303, 0x01}, > {0x030d, 0x4b}, > @@ -935,6 +933,15 @@ static int ov2740_start_streaming(struct ov2740 *ov2740) > if (ov2740->nvm) > ov2740_load_otp_data(ov2740->nvm); > > + /* Reset the sensor */ > + ret = ov2740_write_reg(ov2740, 0x0103, 1, 0x01); > + if (ret) { > + dev_err(&client->dev, "failed to reset\n"); > + return ret; > + } > + > + usleep_range(10000, 15000); > + > link_freq_index = ov2740->cur_mode->link_freq_index; > reg_list = &link_freq_configs[link_freq_index].reg_list; > ret = ov2740_write_reg_list(ov2740, reg_list); >
Hi Bingbu, Hans, On 2023/11/27 12:15, Bingbu Cao wrote: > > Hans, > > On 11/26/23 10:15 PM, Hans de Goede wrote: >> Split the resetting of the sensor out of the link_freq_config reg_list >> and add a delay after this. >> >> This hopefully fixes the stream sometimes not starting, this was >> taken from the ov2740 sensor driver in the out of tree IPU6 driver: > > Thanks for your patch. > > I don't know the details for ov2740 here, we met some similar issues > with another OminiVision camera sensor, it is somehow related to the > OTP read. Unfortunately, we didn't find the root-cause. > > Maybe you can remove the OTP read to check, I think the OTP is useless > if I don't forget anything. > > Hao, do you have any details for this issue? > Are we talking about this Github issue? https://github.com/intel/ipu6-drivers/issues/187 I remembered that I added sleep after the power on/off. As for software resetting, I encountered similar issue when I worked on HM2170 sensor. It hangs if we transfer I2C messages immediately after software reset. Even OV2740 document didn't say anything about delay after software reset, I think it's worth a try. I didn't use the OTP feature so I didn't look into it on OV2740. Best Regards, Hao Yao >> >> https://github.com/intel/ipu6-drivers/ >> >> Signed-off-by: Hans de Goede <hdegoede@redhat.com> >> --- >> drivers/media/i2c/ov2740.c | 11 +++++++++-- >> 1 file changed, 9 insertions(+), 2 deletions(-) >> >> diff --git a/drivers/media/i2c/ov2740.c b/drivers/media/i2c/ov2740.c >> index 8f5c33f68d42..a49c065c6cf4 100644 >> --- a/drivers/media/i2c/ov2740.c >> +++ b/drivers/media/i2c/ov2740.c >> @@ -128,7 +128,6 @@ struct ov2740_mode { >> }; >> >> static const struct ov2740_reg mipi_data_rate_720mbps[] = { >> - {0x0103, 0x01}, >> {0x0302, 0x4b}, >> {0x030d, 0x4b}, >> {0x030e, 0x02}, >> @@ -137,7 +136,6 @@ static const struct ov2740_reg mipi_data_rate_720mbps[] = { >> }; >> >> static const struct ov2740_reg mipi_data_rate_360mbps[] = { >> - {0x0103, 0x01}, >> {0x0302, 0x4b}, >> {0x0303, 0x01}, >> {0x030d, 0x4b}, >> @@ -935,6 +933,15 @@ static int ov2740_start_streaming(struct ov2740 *ov2740) >> if (ov2740->nvm) >> ov2740_load_otp_data(ov2740->nvm); >> >> + /* Reset the sensor */ >> + ret = ov2740_write_reg(ov2740, 0x0103, 1, 0x01); >> + if (ret) { >> + dev_err(&client->dev, "failed to reset\n"); >> + return ret; >> + } >> + >> + usleep_range(10000, 15000); >> + >> link_freq_index = ov2740->cur_mode->link_freq_index; >> reg_list = &link_freq_configs[link_freq_index].reg_list; >> ret = ov2740_write_reg_list(ov2740, reg_list); >> >
diff --git a/drivers/media/i2c/ov2740.c b/drivers/media/i2c/ov2740.c index 8f5c33f68d42..a49c065c6cf4 100644 --- a/drivers/media/i2c/ov2740.c +++ b/drivers/media/i2c/ov2740.c @@ -128,7 +128,6 @@ struct ov2740_mode { }; static const struct ov2740_reg mipi_data_rate_720mbps[] = { - {0x0103, 0x01}, {0x0302, 0x4b}, {0x030d, 0x4b}, {0x030e, 0x02}, @@ -137,7 +136,6 @@ static const struct ov2740_reg mipi_data_rate_720mbps[] = { }; static const struct ov2740_reg mipi_data_rate_360mbps[] = { - {0x0103, 0x01}, {0x0302, 0x4b}, {0x0303, 0x01}, {0x030d, 0x4b}, @@ -935,6 +933,15 @@ static int ov2740_start_streaming(struct ov2740 *ov2740) if (ov2740->nvm) ov2740_load_otp_data(ov2740->nvm); + /* Reset the sensor */ + ret = ov2740_write_reg(ov2740, 0x0103, 1, 0x01); + if (ret) { + dev_err(&client->dev, "failed to reset\n"); + return ret; + } + + usleep_range(10000, 15000); + link_freq_index = ov2740->cur_mode->link_freq_index; reg_list = &link_freq_configs[link_freq_index].reg_list; ret = ov2740_write_reg_list(ov2740, reg_list);