Hi Javier,

On Tuesday 24 May 2011 10:56:22 javier Martin wrote:
> On 24 May 2011 10:39, Laurent Pinchart wrote:
> > On Tuesday 24 May 2011 10:31:46 javier Martin wrote:
> >> On 23 May 2011 11:03, Laurent Pinchart wrote:
> >> > On Saturday 21 May 2011 17:29:18 Guennadi Liakhovetski wrote:
> >> >> On Fri, 20 May 2011, Javier Martin wrote:
> >> > [snip]
> >> > 
> >> >> > diff --git a/drivers/media/video/mt9p031.c
> >> >> > b/drivers/media/video/mt9p031.c new file mode 100644
> >> >> > index 0000000..e406b64
> >> >> > --- /dev/null
> >> >> > +++ b/drivers/media/video/mt9p031.c
> >> > 
> >> > [snip]
> >> > 
> >> >> > +}
> >> >> > +
> >> >> > +static int mt9p031_power_on(struct mt9p031 *mt9p031)
> >> >> > +{
> >> >> > +   int ret;
> >> >> > +
> >> >> > +   /* turn on VDD_IO */
> >> >> > +   ret = regulator_enable(mt9p031->reg_2v8);
> >> >> > +   if (ret) {
> >> >> > +           pr_err("Failed to enable 2.8v regulator: %d\n", ret);
> >> >> 
> >> >> dev_err()
> >> >> 
> >> >> > +           return ret;
> >> >> > +   }
> >> >> > +   if (mt9p031->pdata->set_xclk)
> >> >> > +           mt9p031->pdata->set_xclk(&mt9p031->subdev, 54000000);
> >> > 
> >> > Can you make 54000000 a #define at the beginning of the file ?
> >> > 
> >> > You should soft-reset the chip here by calling mt9p031_reset().
> >> 
> >> If I do this, I would be force to cache some registers and restart
> >> them. I've tried to do this but I don't know what is failing that
> >> there are some artifacts consisting on horizontal black lines in the
> >> image.
> > 
> > You need to cache registers anyway, as the chip will be reset to default
> > values by the core power cycling. And as I'm writing those lines I
> > realize that you don't power cycle reg_1v8. This needs to be done to
> > save power.
> > 
> >> Please, let me push this to mainline without this feature as a first
> >> step, since I'll have to spend some assigned to another project.
> > 
> > Power handling is an important feature. I don't think the driver is ready
> > without it.
> > 
> >> [snip]
> >> 
> >> >> > + */
> >> >> > +static int mt9p031_video_probe(struct i2c_client *client)
> >> >> > +{
> >> >> > +   s32 data;
> >> >> > +   int ret;
> >> >> > +
> >> >> > +   /* Read out the chip version register */
> >> >> > +   data = reg_read(client, MT9P031_CHIP_VERSION);
> >> >> > +   if (data != MT9P031_CHIP_VERSION_VALUE) {
> >> >> > +           dev_err(&client->dev,
> >> >> > +                   "No MT9P031 chip detected, register read %x\n",
> >> >> > data); +           return -ENODEV;
> >> >> > +   }
> >> >> > +
> >> >> > +   dev_info(&client->dev, "Detected a MT9P031 chip ID %x\n",
> >> >> > data); +
> >> >> > +   ret = mt9p031_reset(client);
> >> >> > +   if (ret < 0)
> >> >> > +           dev_err(&client->dev, "Failed to initialise the
> >> >> > camera\n");
> >> > 
> >> > If you move the soft-reset operation to mt9p031_power_on(), you don't
> >> > need to call it here.
> >> 
> >> The reason for this is the same as before. I haven't still been able
> >> to success on restarting registers and getting everything to work
> >> fine.
> >> It would be great if you allowed me to push this as it is as an
> >> intermediate step.
> > 
> > Sorry, but I'd like to see power management properly implemented before
> > the driver hits mainline. Other less important features (such as
> > exposure/gain controls for instance) can be missing, but proper power
> > management is important.
> 
> OK, I'll focus on this feature from now on. However, I can't guarantee
> that I won't be removed from the project in the process. If that
> happens I will send my current patches to the community and someone
> else will have to complete the job.

I understand. I could take over but I don't have an MT9P031 hardware :-S

> >> [snip]
> >> 
> >> >> > +   mt9p031->rect.width     = MT9P031_MAX_WIDTH;
> >> >> > +   mt9p031->rect.height    = MT9P031_MAX_HEIGHT;
> >> >> > +
> >> >> > +   mt9p031->format.code = V4L2_MBUS_FMT_SGRBG12_1X12;
> >> >> > +
> >> >> > +   mt9p031->format.width = MT9P031_MAX_WIDTH;
> >> >> > +   mt9p031->format.height = MT9P031_MAX_HEIGHT;
> >> >> > +   mt9p031->format.field = V4L2_FIELD_NONE;
> >> >> > +   mt9p031->format.colorspace = V4L2_COLORSPACE_SRGB;
> >> >> > +
> >> >> > +   mt9p031->xskip = 1;
> >> >> > +   mt9p031->yskip = 1;
> >> >> > +
> >> >> > +   mt9p031->reg_1v8 = regulator_get(NULL, "cam_1v8");
> >> >> > +   if (IS_ERR(mt9p031->reg_1v8)) {
> >> >> > +           ret = PTR_ERR(mt9p031->reg_1v8);
> >> >> > +           pr_err("Failed 1.8v regulator: %d\n", ret);
> >> >> 
> >> >> dev_err()
> >> >> 
> >> >> > +           goto e1v8;
> >> >> > +   }
> >> > 
> >> > The driver can be used with boards where either or both of the 1.8V
> >> > and 2.8V supplies are always on, thus not connected to any regulator.
> >> > I'm not sure how that's usually handled, if board code should define
> >> > an "always-on" power supply, or if the driver shouldn't fail when no
> >> > regulator is present. In any case, this must be handled.
> >> 
> >> I think board code should define an "always-on" power supply.
> > 
> > Fine with me. How is that done BTW ?
> 
> You can use a fixed regulator for that purpose:
> http://lxr.linux.no/#linux+v2.6.37.2/include/linux/regulator/fixed.h

struct fixed_voltage_config is meant to be passed to drivers through platform 
data. It doesn't declare an "always-on" regulator.

-- 
Regards,

Laurent Pinchart
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to