Re: Re: [RFC 2/2] Documentation: media: Describe exposure and gain controls for multiple captures

From: Mirela Rabulea
Date: Sun Jul 20 2025 - 15:02:31 EST


Hi Laurent,

On 7/16/25 03:07, Laurent Pinchart wrote:


Hi Mirela,

Thank you for the patch.

On Fri, Jul 11, 2025 at 01:05:44AM +0300, Mirela Rabulea wrote:
The standard controls for exposure and gains allow a
single value, for a single capture. For sensors with HDR
capabilities or context switching, this is not enough, so
add new controls that allow multiple values, one for each
capture.

One important question not addressed by this patch is how the new
controls interact with the old ones. For instance, if a sensor
implements 2-DOL, it should expose a V4L2_CID_EXPOSURE_MULTI control
with 2 elements. Should it also expose the V4L2_CID_EXPOSURE control,
when operating in SDR mode ? What should happen when both controls are
set ?

Yes, it's a good point. I experimented with the option of implementing both, at least for backward compatibility (libcamera requires them) and kept them consistent, I mean if V4L2_CID_EXPOSURE_MULTI values change, also change V4L2_CID_EXPOSURE and viceversa, so basically keep consistent the values from V4L2_CID_EXPOSURE with the values for the first exposure from V4L2_CID_EXPOSURE_MULTI. Also, I had to check if hdr mode is not enabled, do nothing in s_ctrl for V4L2_CID_EXPOSURE_MULTI (cannot return error, as it will make __v4l2_ctrl_handler_setup fail).


There are also sensors that implement multi-exposure with direct control
of the long exposure, and indirect control of the short exposure through
an exposure ratio. The sensors I'm working on support both, so we could
just ignore the exposure ratio, but if I recall correctly CCS allows
sensors to implement exposure ratio only without direct short exposure
control. How should we deal with that ?

I'm not sure I understand, but in case of indirect short exposure control I think we do not need these multiple exposure controls, we can use the existing ones, as only the value for the long exposure is needed, the driver can derive the value for the short exposure using the ratio. In some cases, this may be enough, but when direct individual control is needed for both long and short exposure, then we need the multiple exposure controls. Do you have a specific sensor example in mind?
I think in the past we looked at imx708, and my understanding was that the exposure control affects only the long exposure and the sensor will automatically divide the medium and short one with the corresponding ratio:
https://github.com/raspberrypi/linux/blob/rpi-6.12.y/drivers/media/i2c/imx708.c


Finally, I was recently wondering if it would be possible to reuse the
existing controls instead, allowing them to be either single values or
arrays. The idea would be that setting the control to a single value
(essentially ignoring it's an array) would provide the current
behaviour, while setting values for multiple elements would control the
separate exposures.

You mean to divide the 32 bits value of the current controls between the multiple exposures?
Just one comment here, we have encountered the ox03c10 sensor with 4 exposures (that will leave only 8 bits per exposure), and the ox05b1s sensor with context switching and the exposure on 24 bits (for 2 contexts, 2x24=48). So reusing current 32 bit controls might not be enough.
Or do you mean changing the current controls type from V4L2_CTRL_TYPE_INTEGER to u32 array? Would that not cause issues with applications already using current controls?

I haven't checked if the control framework supports
this, or if it could be supported with minimum changes. The advantage is
that we wouldn't need to define how the new and old controls interact if
we don't introduce new controls.

I think the same advantage will be achieved with stream-aware controls (no new controls, also the min/max/def semantics remain clear), but there is the issue we do not have streams if the sensor does internally the hdr merge. Does it sound any better to introduce some fake streams or pads that are not associated with any pixel stream, but just to allow multiple exposure control?

BTW, Jay, what are your plans around the stream-aware controls?

Thanks again for feedback, Laurent!

Hans, what do you think ?

Same question from me ;)

Regards,
Mirela


Signed-off-by: Mirela Rabulea <mirela.rabulea@xxxxxxx>
---
.../media/v4l/ext-ctrls-image-source.rst | 12 ++++++++++++
1 file changed, 12 insertions(+)

diff --git a/Documentation/userspace-api/media/v4l/ext-ctrls-image-source.rst b/Documentation/userspace-api/media/v4l/ext-ctrls-image-source.rst
index 71f23f131f97..6efdb58dacf5 100644
--- a/Documentation/userspace-api/media/v4l/ext-ctrls-image-source.rst
+++ b/Documentation/userspace-api/media/v4l/ext-ctrls-image-source.rst
@@ -92,3 +92,15 @@ Image Source Control IDs
representing a gain of exactly 1.0. For example, if this default value
is reported as being (say) 128, then a value of 192 would represent
a gain of exactly 1.5.
+
+``V4L2_CID_EXPOSURE_MULTI (__u32 array)``
+ Same as V4L2_CID_EXPOSURE, but for multiple exposure sensors. Each
+ element of the array holds the exposure value for one capture.
+
+``V4L2_CID_AGAIN_MULTI (__u32 array)``
+ Same as V4L2_CID_ANALOGUE_GAIN, but for multiple exposure sensors. Each
+ element of the array holds the analog gain value for one capture.
+
+``V4L2_CID_DGAIN_MULTI (__u32 array)``
+ Same as V4L2_CID_DIGITAL_GAIN, but for multiple exposure sensors. Each
+ element of the array holds the digital gain value for one capture.

--
Regards,

Laurent Pinchart