Hey, Gentle ping, so that you don't forget about me ;) Benjamin On 12/05/2022 09:40, Benjamin Mugnier wrote: > Hey, > > This series adds a driver for the ST VGXY61 camera sensor. This camera sensor is using the i2c bus > for control and the csi-2 bus for data. > These commits introduce the MEDIA_BUS_FMT_Y16_1X16 as a media bus format (1/5), reserve 16 user > controls for the driver (2/5), add a uapi header file to declare a control for the hdr mode (3/5), > dt bindings (3/5), and finally the driver (5/5). > Tested on DragonBoard 410c and on Raspberry Pi 4. > > Unfortunately, I was not able to do the freely configurable frame size as advised by Laurent, and > I'm stuck. I tried to mimic the ov5693 driver as it seems to work mostly the same but was not > successful. > I managed to implement the get_selection to set the sensor crop, and set the set_format call to the > same frame size. By doing that my captured frame has black lines appearing if I don't use the sensor > native resolution, and seem to have issues with matching the sensor internal frame size and the one > I want to display (as lines appear wider than they should be). > If anyone has an example driver for this please tell me. Any help is appreciated. > I hope this fixed frame sizes will be ok, and I could come back to it later once I figure it out. > > Thanks, > > Benjamin > > v2->v3: > - Fix errors in dt bindings > - Use alphabetical order where applicable > - Remove US_PER_MS macro > - Rename device specific macros > - Fix some control grabs not releasing > - Move user controls to public header and add documentation > - Rename set_framerate to set_framelength > - Rework i2c access > - Remove branchings that should never happen > - Rework pattern generator setting > - Update information on sensor rules of thumb > - Remove temperature control > - Remove suspend and resume > - Move mutex init to probe > - Move detect to probe > - Fix async_subdev_register order > - Support autosuspend > - Add init_cfg > - Fix controls not updating when sensor was off > - Various cleaning > - Rebase on master > > v1->v2: > - Move temperature control to v4l2-controls.h as a standard control > - Reserve controls in v4l2-controls.h for HDR control > - Remove GPIO strobbing controls > - Remove references to unused controls in sensor struct > - Use v4l2_find_nearest_size > - Use V4L2_COLORSPACE_RAW instead of V4L2_COLORSPACE_SRGB > - Fill ycbcr_enc, quantization, and xfer_func in v4l2_mbus_framefmt > - Change gain from formula to a register RAW write > - Change temperature control value directly > - Remove clock-name and clock-lanes from device tree bindings > - Declare crop zones in mode_info structure > - Remove frame_interval functions and add hblank and vblank instead > - Update controls dependencies on change > - Fix first exposure rule of thumb being too restrictive > - Disable hflip and vflip controls while streaming > - Change RGB media bus code to Y as the sensor is monochrome > - Add Y16 format to v4l2 media bus formats > - Add get_selection API > - Fix timeout errors while disabling streaming on high framerates > - Support pm_runtime > - Rebase on master > > Benjamin Mugnier (5): > media: v4l: Add 1X16 16-bit greyscale media bus code definition > media: v4l: ctrls: Add user control base for st-vgxy61 controls > media: uapi: Add ST VGXY61 header file > media: dt-bindings: media: i2c: Add ST VGXY61 camera sensor binding > media: i2c: Add driver for ST VGXY61 camera sensor > > .../bindings/media/i2c/st,st-vgxy61.yaml | 117 + > .../userspace-api/media/drivers/st-vgxy61.rst | 23 + > .../media/v4l/subdev-formats.rst | 37 + > MAINTAINERS | 9 + > drivers/media/i2c/Kconfig | 10 + > drivers/media/i2c/Makefile | 1 + > drivers/media/i2c/st-vgxy61.c | 1940 +++++++++++++++++ > include/uapi/linux/media-bus-format.h | 3 +- > include/uapi/linux/st-vgxy61.h | 15 + > include/uapi/linux/v4l2-controls.h | 5 + > 10 files changed, 2159 insertions(+), 1 deletion(-) > create mode 100644 Documentation/devicetree/bindings/media/i2c/st,st-vgxy61.yaml > create mode 100644 Documentation/userspace-api/media/drivers/st-vgxy61.rst > create mode 100644 drivers/media/i2c/st-vgxy61.c > create mode 100644 include/uapi/linux/st-vgxy61.h >