Re: [PATCH 2/5] pcm990 baseboard: add camera bus width switch setting

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, 14 Apr 2009, Sascha Hauer wrote:

> On Tue, Apr 14, 2009 at 10:57:32AM +0200, Guennadi Liakhovetski wrote:
> > On Thu, 9 Apr 2009, Guennadi Liakhovetski wrote:

[snip]

> > > > +static unsigned long pcm990_camera_query_bus_param(struct soc_camera_link *link)
> > > > +{
> > > > +	int ret;
> > > > +
> > > > +	if (!gpio_bus_switch) {
> > > > +		ret = gpio_request(NR_BUILTIN_GPIO + 1, "camera");
> > > 
> > > There's no gpio_free() now... So, for example, you cannot unload the 
> > > extender driver any more, unloading i2c adapter driver (i2c-pxa) produces 
> > > ugly stuff like
> > > 
> > > pca953x 0-0041: gpiochip_remove() failed, -16
> > > 
> > > So, we either have to request and free the GPIO in each query / set, or we 
> > > need an explicit .free_bus() call in soc_camera_link. None of the two 
> > > really pleases me, but maybe the latter is slightly less ugly, what do you 
> > > think?
> > > 
> > > Thanks
> > > Guennadi
> > > 
> > > > +		if (!ret) {
> > > > +			gpio_bus_switch = NR_BUILTIN_GPIO + 1;
> > > > +			gpio_direction_output(gpio_bus_switch, 0);
> > > > +		} else
> > > > +			gpio_bus_switch = -EINVAL;
> > > >  	}
> > 
> > If you first do not load pca953x and try to start capture, thus calling 
> > pcm990_camera_query_bus_param(), gpio_request() will fail and you get 
> > gpio_bus_switch < 0. Then if you load pca953x it doesn't help any more - 
> > by testing for "if (!gpio_bus_switch)" you do not retry after the first 
> > error.
> 
> So how do we proceed? Add init/exit functions for the bus?

If you don't object, I'll just add a .free_bus method to soc_camera_link, 
and switch pcm990 to only use two values: a negative value for a 
non-allocated gpio - either before the first attempt or after an error, 
thus re-trying every time if gpio is negative, in case a driver has been 
loaded in the meantime.

Thanks
Guennadi
---
Guennadi Liakhovetski, Ph.D.
Freelance Open-Source Software Developer
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Input]     [Video for Linux]     [Gstreamer Embedded]     [Mplayer Users]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]
  Powered by Linux