<div dir="ltr"><div dir="ltr">Hi Niklas,<div><br></div><div>Thank you for the clarification.</div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Wed, 28 Oct 2020 at 13:26, Niklas Söderlund <<a href="mailto:niklas.soderlund@ragnatech.se">niklas.soderlund@ragnatech.se</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Hi Naushir,<br>
<br>
Thanks for your feedback.<br>
<br>
On 2020-10-28 11:51:13 +0000, Naushir Patuck wrote:<br>
> Hi Niklas,<br>
> <br>
> Thank you for the changes. I will go through all the patches with review<br>
> comment in due course, but wanted to raise a critical point below:<br>
> <br>
> On Wed, 28 Oct 2020 at 01:01, Niklas Söderlund <<br>
> <a href="mailto:niklas.soderlund@ragnatech.se" target="_blank">niklas.soderlund@ragnatech.se</a>> wrote:<br>
> <br>
> > Expose the optional DelayedControls interface to pipeline handlers. If<br>
> > used by a pipeline generic delays are used. In the future the delay<br>
> > values should be fetched to match the specific sensor module, either<br>
> > from a new kernel interface or worst case a sensors database.<br>
> ><br>
> > Signed-off-by: Niklas Söderlund <<a href="mailto:niklas.soderlund@ragnatech.se" target="_blank">niklas.soderlund@ragnatech.se</a>><br>
> > ---<br>
> > include/libcamera/internal/camera_sensor.h | 5 ++++<br>
> > src/libcamera/camera_sensor.cpp | 31 ++++++++++++++++++++++<br>
> > 2 files changed, 36 insertions(+)<br>
> ><br>
> > diff --git a/include/libcamera/internal/camera_sensor.h<br>
> > b/include/libcamera/internal/camera_sensor.h<br>
> > index b9eba89f00fba882..6be1cfd49134c534 100644<br>
> > --- a/include/libcamera/internal/camera_sensor.h<br>
> > +++ b/include/libcamera/internal/camera_sensor.h<br>
> > @@ -14,6 +14,7 @@<br>
> > #include <libcamera/controls.h><br>
> > #include <libcamera/geometry.h><br>
> ><br>
> > +#include "libcamera/internal/delayed_controls.h"<br>
> > #include "libcamera/internal/formats.h"<br>
> > #include "libcamera/internal/log.h"<br>
> > #include "libcamera/internal/v4l2_subdevice.h"<br>
> > @@ -61,6 +62,8 @@ public:<br>
> > ControlList getControls(const std::vector<uint32_t> &ids);<br>
> > int setControls(ControlList *ctrls);<br>
> ><br>
> > + DelayedControls *delayedContols();<br>
> > +<br>
> > const ControlList &properties() const { return properties_; }<br>
> > int sensorInfo(CameraSensorInfo *info) const;<br>
> ><br>
> > @@ -83,6 +86,8 @@ private:<br>
> > std::vector<Size> sizes_;<br>
> ><br>
> > ControlList properties_;<br>
> > +<br>
> > + std::unique_ptr<DelayedControls> delayedControls_;<br>
> > };<br>
> ><br>
> > } /* namespace libcamera */<br>
> > diff --git a/src/libcamera/camera_sensor.cpp<br>
> > b/src/libcamera/camera_sensor.cpp<br>
> > index 935de528c4963453..6c92c97f4cc2547a 100644<br>
> > --- a/src/libcamera/camera_sensor.cpp<br>
> > +++ b/src/libcamera/camera_sensor.cpp<br>
> > @@ -493,6 +493,37 @@ int CameraSensor::setControls(ControlList *ctrls)<br>
> > return subdev_->setControls(ctrls);<br>
> > }<br>
> ><br>
> > +/**<br>
> > + * \brief Get the sensors delayed controls interface<br>
> > + *<br>
> > + * Access the sensors delayed controls interface. This interface aids<br>
> > pipelines<br>
> > + * keeping tack of controls that needs time to take effect. The interface<br>
> > is<br>
> > + * optional to use and does not interact with setControls() and<br>
> > getControls()<br>
> > + * that operates directly on the sensor device.<br>
> > + *<br>
> > + * \sa DelayedControls<br>
> > + * \return The delayed controls interface<br>
> > + */<br>
> > +DelayedControls *CameraSensor::delayedContols()<br>
> > +{<br>
> > + if (!delayedControls_) {<br>
> > + /*<br>
> > + * \todo Read dealy values from the sensor itself or from a<br>
> > + * a sensor database. For now use generic values taken from<br>
> > + * the Raspberry Pi and listed as generic values.<br>
> > + */<br>
> > + std::unordered_map<uint32_t, unsigned int> delays = {<br>
> > + { V4L2_CID_ANALOGUE_GAIN, 1 },<br>
> > + { V4L2_CID_EXPOSURE, 2 },<br>
> > + };<br>
> ><br>
> <br>
> This will break the OV5647 sensor usage with Raspberry Pi without<br>
> referring back to a sensor database . OV5647 has a delay of 2 for gain and<br>
> exposure, so will not work with the above hard-coded settings.<br>
<br>
I understand your point, and we really should get started with a <br>
solution on how to get sensor specific data into CameraSensor database.<br>
<br>
But with this series there is no problem for the Raspberry Pi pipeline <br>
as it does not deal with controls on the CameraSensor but the V4L2 video <br>
device. Therefor the RPi pipeline creates a private instance of <br>
DelayedControls witch delays still are initialized by the RPi IPA, just <br>
as things worked before using StaggerdCtrls.<br>
<br>
When developing this I ran DelayedControls and StaggerdCtrls in parallel <br>
on the RPi and the output of both matched perfectly frame by frame.<br></blockquote><div><br></div><div>Yes, I see that now. So there should be no problems for pipeline handlers to allocate a DelayedControl for its own use? In that case, the above should not be a problem. But you are correct, this does show the need to get a central sensor database available soon.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
> <br>
> In a more general sense, I wonder if initialising the DelayedControl here<br>
> is the right thing to do? I have some changes waiting to be submitted for<br>
> review that add framerate control to the Raspberry Pi stack. In this<br>
> change, I've added a VBLANK control to the staggered writer. There are<br>
> also some changes to control very long exposures on the imx477 that go<br>
> through the staggered writer. In these cases, I would have to add values<br>
> to the map above, but other pipeline handlers would never need to use<br>
> them. This may be a bit wasteful, I don't know... Would it make more<br>
> sense for the pipeline handlers to initialise the DelayedControls as they<br>
> need to?<br>
<br>
First, we are still thinking about how VBLANK and other controls that <br>
can modify the frame length are to be modelled in the CameraSensor. If <br>
you have any ideas or tips in this area I would greatly appreciate them.<br></blockquote><div><br></div><div>I could possibly share with you (privately for now, to avoid too much noise on this mailing list) my changes to add VBLANK control, to discuss what I have done? </div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
I really think CameraSensor is the location to initialising the delays, <br>
this separates the sensor from the pipeline. I think this is important <br>
as otherwise each pipeline will have have a list of sensors it knows <br>
about and will not function popery with different ones. By "forcing" <br>
pipelines to learn about the sensor used thru CameraSensor interface we <br>
ensure that we can add more sensors in the future without having to <br>
update all pipelines and/or IPAs. This is even more important if we <br>
consider closed-source IPAs as we can't just add a new sensor with <br>
timings recompile.<br>
<br>
Yet again as the Raspberry Pi pipeline is video device centric it can't <br>
really use the CameraSensor to deal with controls and must instead <br>
create and configure its local version of DelayedControls. I still think <br>
in the future such pipelines can benefit from a sensor database in <br>
CameraSensor as it should be possible to query the datbase and use the <br>
delays reported while still creating a private local DelayedControls.<br></blockquote><div><br></div><div>Yes, I agree with this. Just want to raise the point that some sensors will have controls not available to others, e.g. imx477 long exposure settings. So it would be good to have as much flexibility in the sensor database to allow for these variations.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
Does this relive your worries bout this series?<br></blockquote><div><br></div><div>Indeed it does. I will get to reviewing the full patchset shortly and send over my comments.</div><div><br></div><div>Best regards,</div><div>Naush</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
> <br>
> Regards,<br>
> Naush<br>
> <br>
> <br>
> <br>
> > +<br>
> > + delayedControls_ =<br>
> > + std::make_unique<DelayedControls>(subdev_.get(),<br>
> > delays);<br>
> > + }<br>
> > +<br>
> > + return delayedControls_.get();<br>
> > +}<br>
> > +<br>
> > /**<br>
> > * \brief Assemble and return the camera sensor info<br>
> > * \param[out] info The camera sensor info<br>
> > --<br>
> > 2.29.1<br>
> ><br>
> ><br>
<br>
-- <br>
Regards,<br>
Niklas Söderlund<br>
</blockquote></div></div>