This patch series is a collection of miscellaneous cleanups and improvements to the imx214 driver. The series converts the driver to the CCI helpers and adds controls needed to make the driver work with libcamera. The changes are inspired by the imx219 driver. Signed-off-by: André Apitzsch <git@xxxxxxxxxxx> --- Changes in v6: - Make series bisectable - Add A-b tag - Link to v5: https://lore.kernel.org/r/20241217-imx214-v5-0-387f52adef4d@xxxxxxxxxxx Changes in v5: - Remove cur_mode field - Link to v4: https://lore.kernel.org/r/20241216-imx214-v4-0-8cbda160fbce@xxxxxxxxxxx Changes in v4: - Drop function name from dev error message - Initialize *format to fix compile error - Improve comment "Update {FPS -> blank} limit" - Improve code formatting - Warn once on usage of frame_interval functions - Fix commit message - Add patch to fix clock handling on probe error or remove - Warn if number of DT provided link frequencies != 1 - Add A-b tags - Link to v3: https://lore.kernel.org/r/20241207-imx214-v3-0-ab60af7ee915@xxxxxxxxxxx Changes in v3: - Also keep previous link freq for backward compatibility - Move link freq patch to the end of the series - Remove return-early check from imx214_set_format() - Remove unneeded struct imx214 function parameter - Use correct ret value on number of data lanes error - Revert changing order (imx214_parse_fwnode, devm_kzalloc) - Fix typo - Remove unused definition IMX214_EXPOSURE_MAX - Don't set FPS to default - Simplify exposure_def definition - Set state and format only if control id is V4L2_CID_VBLANK - Restore Ricardo's message to Sony - Drop "media: i2c: imx214: Extract format and crop settings" patch - Add A-b tag - Link to v2: https://lore.kernel.org/r/20241021-imx214-v2-0-fbd23e99541e@xxxxxxxxxxx Changes in v2: - Add patch to fix link frequency - Don't use and remove fmt and crop from struct imx214 - Squash patch 1/13 and 2/13 - Only check if #lanes == 4 - Add comment that enum_frame_interval() shouldn't be used by userspace - Set V4L2_CID_VBLANK step size to 2 (according to datasheet Table 4-4) - Increase IMX214_VBLANK_MIN to limit max frame rate of full resolution to the documented 30 fps - As bpp is always 10, simplify setting IMX214_REG_CSI_DATA_FORMAT and IMX214_REG_OPPXCK_DIV - Simplify imx214_get_format_code() - Cluster hflip and vflip - Remove kernel log note from 11/13, issue was fixed by a kernel update - Add A-b tags - Link to v1: https://lore.kernel.org/r/20240902-imx214-v1-0-c96cba989315@xxxxxxxxxxx --- André Apitzsch (13): media: i2c: imx214: Use subdev active state media: i2c: imx214: Simplify with dev_err_probe() media: i2c: imx214: Convert to CCI register access helpers media: i2c: imx214: Replace register addresses with macros media: i2c: imx214: Drop IMX214_REG_EXPOSURE from mode reg arrays media: i2c: imx214: Check number of lanes from device tree media: i2c: imx214: Add vblank and hblank controls media: i2c: imx214: Implement vflip/hflip controls media: i2c: imx214: Add analogue/digital gain control media: i2c: imx214: Verify chip ID media: i2c: imx214: Add test pattern control media: i2c: imx214: Fix clock handling on probe error or remove media: i2c: imx214: Fix link frequency validation drivers/media/i2c/Kconfig | 1 + drivers/media/i2c/imx214.c | 1265 ++++++++++++++++++++++++++------------------ 2 files changed, 752 insertions(+), 514 deletions(-) --- base-commit: 62f608176a46b6a794725022101d0d7f42faedb9 change-id: 20240818-imx214-8324784c7bee Best regards, -- André Apitzsch <git@xxxxxxxxxxx>