From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Date: Fri, 10 Feb 2017 20:37:38 +0200 From: Sakari Ailus Subject: Re: [PATCH RESEND v7 2/2] Add support for OV5647 sensor. Message-ID: <20170210183737.GE887@mara.localdomain> References: <26e5a587f1ba9e2fbbc04284408305bc8cf8c5c0.1486136893.git.roliveir@synopsys.com> <20170203201729.GA18086@kekkonen.localdomain> <20170207173116.GC13854@valkosipuli.retiisi.org.uk> <20170209100254.GH13854@valkosipuli.retiisi.org.uk> <3d8368f8-0cae-934b-fc6a-0ead79db14aa@synopsys.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <3d8368f8-0cae-934b-fc6a-0ead79db14aa@synopsys.com> To: Ramiro Oliveira Cc: Sakari Ailus , linux-media@vger.kernel.org, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, CARLOS.PALMINHA@synopsys.com, "David S. Miller" , Geert Uytterhoeven , Greg Kroah-Hartman , Guenter Roeck , Hans Verkuil , Mark Rutland , Mauro Carvalho Chehab , Pavel Machek , Robert Jarzmik , Rob Herring , Steve Longerbeam List-ID: Hi Ramiro, On Thu, Feb 09, 2017 at 10:13:02AM +0000, Ramiro Oliveira wrote: > Hi Sakari > > On 2/9/2017 10:02 AM, Sakari Ailus wrote: > > Hi Ramiro, > > > > On Wed, Feb 08, 2017 at 09:56:12AM +0000, Ramiro Oliveira wrote: > >> Hi Sakari > >> > >> On 2/7/2017 5:31 PM, Sakari Ailus wrote: > >>> Hi Ramiro, > >>> > >>> On Mon, Feb 06, 2017 at 11:38:28AM +0000, Ramiro Oliveira wrote: > >>> ... > >>>>>> + ret = ov5647_write_array(sd, ov5647_640x480, > >>>>>> + ARRAY_SIZE(ov5647_640x480)); > >>>>>> + if (ret < 0) { > >>>>>> + dev_err(&client->dev, "write sensor_default_regs error\n"); > >>>>>> + return ret; > >>>>>> + } > >>>>>> + > >>>>>> + ov5647_set_virtual_channel(sd, 0); > >>>>>> + > >>>>>> + ov5647_read(sd, 0x0100, &resetval); > >>>>>> + if (!(resetval & 0x01)) { > >>>>> > >>>>> Can this ever happen? Streaming start is at the end of the register list. > >>>>> > >>>> > >>>> I'm not sure it can happen. It was just a safeguard, but I can remove it if you > >>>> think it's not necessary > >>> > >>> You're not reading back the other registers either, albeit I'd check that > >>> the I2C accesses actually succeed. Generally the return values are ignored. > >>> > >> > >> So you're recommending I perform a random I2C access after power on to check the > >> system, and discard the read value? Or just drop this piece of code entirely? > >> > > > > I'm not. What I'm saying that you're mostly not checking whether I2C > > accesses succeed or not. > > > > > I think I'm understanding what you're saying now. You want me to check more > often the return value from write/read functions? > > That makes sense. I'll add more checks to the code Please do. That's generally a better approach with I2C than reading back register values. :-) -- Sakari Ailus sakari.ailus@linux.intel.com