From patchwork Thu Feb 10 11:04:45 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jacopo Mondi X-Patchwork-Id: 541984 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id B9CF0C433EF for ; Thu, 10 Feb 2022 11:04:32 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240501AbiBJLEa (ORCPT ); Thu, 10 Feb 2022 06:04:30 -0500 Received: from mxb-00190b01.gslb.pphosted.com ([23.128.96.19]:39706 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234177AbiBJLE2 (ORCPT ); Thu, 10 Feb 2022 06:04:28 -0500 Received: from relay12.mail.gandi.net (relay12.mail.gandi.net [217.70.178.232]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 78A9AFFF for ; Thu, 10 Feb 2022 03:04:29 -0800 (PST) Received: (Authenticated sender: jacopo@jmondi.org) by mail.gandi.net (Postfix) with ESMTPSA id 51C3720000E; Thu, 10 Feb 2022 11:04:25 +0000 (UTC) From: Jacopo Mondi To: Steve Longerbeam Cc: Jacopo Mondi , laurent.pinchart@ideasonboard.com, sakari.ailus@iki.fi, hverkuil-cisco@xs4all.nl, mirela.rabulea@nxp.com, xavier.roumegue@oss.nxp.com, tomi.valkeinen@ideasonboard.com, hugues.fruchet@st.com, prabhakar.mahadev-lad.rj@bp.renesas.com, aford173@gmail.com, festevam@gmail.com, Eugen.Hristev@microchip.com, jbrunet@baylibre.com, Mauro Carvalho Chehab , linux-media@vger.kernel.org Subject: [PATCH v2 10/23] media: ov5640: Rework analog crop rectangles Date: Thu, 10 Feb 2022 12:04:45 +0100 Message-Id: <20220210110458.152494-11-jacopo@jmondi.org> X-Mailer: git-send-email 2.35.0 In-Reply-To: <20220210110458.152494-1-jacopo@jmondi.org> References: <20220210110458.152494-1-jacopo@jmondi.org> MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: linux-media@vger.kernel.org The OV5640 pixel array is composed as: - vertically: 16 dummy columns, 1944 valid ones and 16 dummy columns - horizontally: 8 optical black lines, 6 dummy ones, 2592 valid and 6 dummies Adjust the analog crop rectangle in all modes to: - Skip the first 16 dummy columns - Skip the first 14 black/dummy lines - Pass the whole valid pixel array size to the ISP for all modes except 1920x1080 which is obtained by cropping the valid pixel array. Adjust how timings is programmed to comply with the new definitions. Tested in RGB565, UYVY, RGB565 and RGB888 modes. Signed-off-by: Jacopo Mondi --- drivers/media/i2c/ov5640.c | 138 +++++++++++++++++++++---------------- 1 file changed, 79 insertions(+), 59 deletions(-) diff --git a/drivers/media/i2c/ov5640.c b/drivers/media/i2c/ov5640.c index f817f865ad16..72b78201f089 100644 --- a/drivers/media/i2c/ov5640.c +++ b/drivers/media/i2c/ov5640.c @@ -626,14 +626,14 @@ static const struct ov5640_mode_info ov5640_mode_init_data = { .dn_mode = SUBSAMPLING, .pixel_rate = OV5640_PIXEL_RATE_96M, .analog_crop = { - .left = 0, - .top = 4, - .width = 2623, - .height = 1947, + .left = OV5640_PIXEL_ARRAY_LEFT, + .top = OV5640_PIXEL_ARRAY_TOP, + .width = OV5640_PIXEL_ARRAY_WIDTH, + .height = OV5640_PIXEL_ARRAY_HEIGHT, }, .crop = { - .left = 16, - .top = 6, + .left = 2, + .top = 4, .width = 640, .height = 480, }, @@ -644,22 +644,23 @@ static const struct ov5640_mode_info ov5640_mode_init_data = { .max_fps = OV5640_30_FPS }; -static const struct ov5640_mode_info -ov5640_mode_data[OV5640_NUM_MODES] = { +static const struct ov5640_mode_info ov5640_mode_data[OV5640_NUM_MODES] = { { /* 160x120 */ .id = OV5640_MODE_QQVGA_160_120, .dn_mode = SUBSAMPLING, .pixel_rate = OV5640_PIXEL_RATE_48M, .analog_crop = { - .left = 0, - .top = 4, - .width = 2623, - .height = 1947, + /* Feed the full valid pixel array to the ISP. */ + .left = OV5640_PIXEL_ARRAY_LEFT, + .top = OV5640_PIXEL_ARRAY_TOP, + .width = OV5640_PIXEL_ARRAY_WIDTH, + .height = OV5640_PIXEL_ARRAY_HEIGHT, }, .crop = { - .left = 16, - .top = 6, + /* Maintain a minimum digital crop processing margins. */ + .left = 2, + .top = 4, .width = 160, .height = 120, }, @@ -674,14 +675,16 @@ ov5640_mode_data[OV5640_NUM_MODES] = { .dn_mode = SUBSAMPLING, .pixel_rate = OV5640_PIXEL_RATE_48M, .analog_crop = { - .left = 0, - .top = 4, - .width = 2623, - .height = 1947, + /* Feed the full valid pixel array to the ISP. */ + .left = OV5640_PIXEL_ARRAY_LEFT, + .top = OV5640_PIXEL_ARRAY_TOP, + .width = OV5640_PIXEL_ARRAY_WIDTH, + .height = OV5640_PIXEL_ARRAY_HEIGHT, }, .crop = { - .left = 16, - .top = 6, + /* Maintain a minimum digital crop processing margins. */ + .left = 2, + .top = 4, .width = 176, .height = 144, }, @@ -696,14 +699,16 @@ ov5640_mode_data[OV5640_NUM_MODES] = { .dn_mode = SUBSAMPLING, .pixel_rate = OV5640_PIXEL_RATE_48M, .analog_crop = { - .left = 0, - .top = 4, - .width = 2623, - .height = 1947, + /* Feed the full valid pixel array to the ISP. */ + .left = OV5640_PIXEL_ARRAY_LEFT, + .top = OV5640_PIXEL_ARRAY_TOP, + .width = OV5640_PIXEL_ARRAY_WIDTH, + .height = OV5640_PIXEL_ARRAY_HEIGHT, }, .crop = { - .left = 16, - .top = 6, + /* Maintain a minimum digital crop processing margins. */ + .left = 2, + .top = 4, .width = 320, .height = 240, }, @@ -718,14 +723,16 @@ ov5640_mode_data[OV5640_NUM_MODES] = { .dn_mode = SUBSAMPLING, .pixel_rate = OV5640_PIXEL_RATE_48M, .analog_crop = { - .left = 0, - .top = 4, - .width = 2623, - .height = 1947, + /* Feed the full valid pixel array to the ISP. */ + .left = OV5640_PIXEL_ARRAY_LEFT, + .top = OV5640_PIXEL_ARRAY_TOP, + .width = OV5640_PIXEL_ARRAY_WIDTH, + .height = OV5640_PIXEL_ARRAY_HEIGHT, }, .crop = { - .left = 16, - .top = 6, + /* Maintain a minimum digital crop processing margins. */ + .left = 2, + .top = 4, .width = 640, .height = 480, }, @@ -740,12 +747,14 @@ ov5640_mode_data[OV5640_NUM_MODES] = { .dn_mode = SUBSAMPLING, .pixel_rate = OV5640_PIXEL_RATE_96M, .analog_crop = { - .left = 0, - .top = 4, - .width = 2623, - .height = 1947, + /* Feed the full valid pixel array to the ISP. */ + .left = OV5640_PIXEL_ARRAY_LEFT, + .top = OV5640_PIXEL_ARRAY_TOP, + .width = OV5640_PIXEL_ARRAY_WIDTH, + .height = OV5640_PIXEL_ARRAY_HEIGHT, }, .crop = { + /* Maintain a minimum digital crop processing margins. */ .left = 56, .top = 60, .width = 720, @@ -762,12 +771,14 @@ ov5640_mode_data[OV5640_NUM_MODES] = { .dn_mode = SUBSAMPLING, .pixel_rate = OV5640_PIXEL_RATE_96M, .analog_crop = { - .left = 0, - .top = 4, - .width = 2623, - .height = 1947, + /* Feed the full valid pixel array to the ISP. */ + .left = OV5640_PIXEL_ARRAY_LEFT, + .top = OV5640_PIXEL_ARRAY_TOP, + .width = OV5640_PIXEL_ARRAY_WIDTH, + .height = OV5640_PIXEL_ARRAY_HEIGHT, }, .crop = { + /* Maintain a minimum digital crop processing margins. */ .left = 56, .top = 6, .width = 720, @@ -784,14 +795,16 @@ ov5640_mode_data[OV5640_NUM_MODES] = { .dn_mode = SUBSAMPLING, .pixel_rate = OV5640_PIXEL_RATE_96M, .analog_crop = { - .left = 0, - .top = 4, - .width = 2623, - .height = 1947, + /* Feed the full valid pixel array to the ISP. */ + .left = OV5640_PIXEL_ARRAY_LEFT, + .top = OV5640_PIXEL_ARRAY_TOP, + .width = OV5640_PIXEL_ARRAY_WIDTH, + .height = OV5640_PIXEL_ARRAY_HEIGHT, }, .crop = { - .left = 16, - .top = 6, + /* Maintain a minimum digital crop processing margins. */ + .left = 2, + .top = 4, .width = 1024, .height = 768, }, @@ -806,13 +819,15 @@ ov5640_mode_data[OV5640_NUM_MODES] = { .dn_mode = SUBSAMPLING, .pixel_rate = OV5640_PIXEL_RATE_124M, .analog_crop = { - .left = 0, - .top = 250, - .width = 2623, - .height = 1705, + /* Feed the full valid pixel array to the ISP. */ + .left = OV5640_PIXEL_ARRAY_LEFT, + .top = OV5640_PIXEL_ARRAY_TOP, + .width = OV5640_PIXEL_ARRAY_WIDTH, + .height = OV5640_PIXEL_ARRAY_HEIGHT, }, .crop = { - .left = 16, + /* Maintain a minimum digital crop processing margins. */ + .left = 2, .top = 4, .width = 1280, .height = 720, @@ -828,12 +843,14 @@ ov5640_mode_data[OV5640_NUM_MODES] = { .dn_mode = SCALING, .pixel_rate = OV5640_PIXEL_RATE_148M, .analog_crop = { + /* Crop the full valid pixel array in the center. */ .left = 336, .top = 434, - .width = 2287, - .height = 1521, + .width = 1952, + .height = 1088, }, .crop = { + /* Maintain a larger digital crop processing margins. */ .left = 16, .top = 4, .width = 1920, @@ -850,16 +867,17 @@ ov5640_mode_data[OV5640_NUM_MODES] = { .dn_mode = SCALING, .pixel_rate = OV5640_PIXEL_RATE_168M, .analog_crop = { + /* Give more processing margin to full resolution. */ .left = 0, .top = 0, - .width = 2623, - .height = 1951, + .width = OV5640_NATIVE_WIDTH, + .height = 1952, }, .crop = { .left = 16, .top = 4, - .width = 2592, - .height = 1944, + .width = OV5640_PIXEL_ARRAY_WIDTH, + .height = OV5640_PIXEL_ARRAY_HEIGHT, }, .htot = 2844, .vblank_def = 24, @@ -1384,11 +1402,13 @@ static int ov5640_set_timings(struct ov5640_dev *sensor, if (ret < 0) return ret; - ret = ov5640_write_reg16(sensor, OV5640_REG_TIMING_HW, analog_crop->width); + ret = ov5640_write_reg16(sensor, OV5640_REG_TIMING_HW, + analog_crop->width + analog_crop->left - 1); if (ret < 0) return ret; - ret = ov5640_write_reg16(sensor, OV5640_REG_TIMING_VH, analog_crop->height); + ret = ov5640_write_reg16(sensor, OV5640_REG_TIMING_VH, + analog_crop->height + analog_crop->top - 1); if (ret < 0) return ret;