From patchwork Tue Jul 6 14:22:20 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Umang Jain X-Patchwork-Id: 12812 X-Patchwork-Delegate: umang.jain@ideasonboard.com Return-Path: X-Original-To: parsemail@patchwork.libcamera.org Delivered-To: parsemail@patchwork.libcamera.org Received: from lancelot.ideasonboard.com (lancelot.ideasonboard.com [92.243.16.209]) by patchwork.libcamera.org (Postfix) with ESMTPS id 8D446BD794 for ; Tue, 6 Jul 2021 14:22:30 +0000 (UTC) Received: from lancelot.ideasonboard.com (localhost [IPv6:::1]) by lancelot.ideasonboard.com (Postfix) with ESMTP id EA143684EA; Tue, 6 Jul 2021 16:22:29 +0200 (CEST) Authentication-Results: lancelot.ideasonboard.com; dkim=fail reason="signature verification failed" (1024-bit key; unprotected) header.d=ideasonboard.com header.i=@ideasonboard.com header.b="JxLx9MEz"; dkim-atps=neutral Received: from perceval.ideasonboard.com (perceval.ideasonboard.com [IPv6:2001:4b98:dc2:55:216:3eff:fef7:d647]) by lancelot.ideasonboard.com (Postfix) with ESMTPS id 21B7360288 for ; Tue, 6 Jul 2021 16:22:28 +0200 (CEST) Received: from perceval.ideasonboard.com (unknown [103.251.226.59]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id E6027A5E; Tue, 6 Jul 2021 16:22:26 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1625581347; bh=SADRb4LmyLSLeImLAwgNKawSILoG6PjUEyGbx6WWUYY=; h=From:To:Cc:Subject:Date:From; b=JxLx9MEzyVnHHf65TCjetWOjFdVdljUy1IfFlnZXVRVxgrLSKqZ8y/U5Oiw8kckn9 Ov1y49SEGjoxF8RdZTZtMAp1LiFBOZ9FIyD5fJfolhIz30u4E8vP5h2H4r7lby3gbz AOpm0xK19LkiwS+vVC+6Xgf++5Lcsqck3IhYQ37U= From: Umang Jain To: libcamera-devel@lists.libcamera.org Date: Tue, 6 Jul 2021 19:52:20 +0530 Message-Id: <20210706142220.747614-1-umang.jain@ideasonboard.com> X-Mailer: git-send-email 2.31.1 MIME-Version: 1.0 Subject: [libcamera-devel] [RFC PATCH] camera_sensor: Do not always prioritize aspect-ratios X-BeenThere: libcamera-devel@lists.libcamera.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: libcamera-devel-bounces@lists.libcamera.org Sender: "libcamera-devel" In some cases, the maximum sensor resolution will provide the best aspect-ratio for a requested stream size. It may also happen that, the difference between max sensor resolution's aspect-ratio vs a lower sensor resolution aspect-ratio is very marginal(for e.g. <1%). In such cases, we should actually lean towards the lower sensor resolution. One of such cases is observed on nautilus, where all requested stream sizes seems to map to 4208x3118-SGRBG10_IPU3. Even though, the aspect ratios for lower sensor resolution aren't that far from 4208x3118. For a stream size request of 1080p: - 1080p = 1.777777778 (requested) - 4208x3118 = 1.349583066 (originally selected) - 2104x1560 = 1.348717949 - 1048x780 = 1.343589744 This patch introduces some flexibility on part of sensor resolution selection procedure. It attempts to provide a sensor resolution, closest to the requested stream size, whilst keeping best aspect-ratio. Signed-off-by: Umang Jain --- - This patch has been written with "[PATCH] camera_sensor: Remove redundant aspect-ratio check" applied. - There is also known issue/handle on why IPU3 currently selects max sensor resolution config possible, we will use "raw" to see this patch in action. - Findings via cam: (master) ($) cam -c1 -swidth=640,height=320,role=raw Using camera \_SB_.PCI0.I2C2.CAM0 [10:12:57.975110123] [550] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 4208x3118-SGRBG10_IPU3 [10:12:57.975199686] [550] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 4208x3118-SGRBG10_IPU3 Camera configuration adjusted ($) cam -c1 -swidth=1280,height=720,role=raw Using camera \_SB_.PCI0.I2C2.CAM0 [10:14:23.492963456] [651] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 4208x3118-SGRBG10_IPU3 [10:14:23.493028736] [651] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 4208x3118-SGRBG10_IPU3 Camera configuration adjusted ($) cam -c1 -swidth=1920,height=1080,role=raw Using camera \_SB_.PCI0.I2C2.CAM0 [10:14:34.020592838] [660] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 4208x3118-SGRBG10_IPU3 [10:14:34.020636493] [660] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 4208x3118-SGRBG10_IPU3 Camera configuration adjusted ($) cam -c1 -swidth=3840,height=2160,role=raw Using camera \_SB_.PCI0.I2C2.CAM0 [10:15:20.530557765] [727] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 4208x3118-SGRBG10_IPU3 [10:15:20.530625404] [727] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 4208x3118-SGRBG10_IPU3 Camera configuration adjusted ($) cam -c1 -swidth=4200,height=3000,role=raw Using camera \_SB_.PCI0.I2C2.CAM0 [10:15:33.027468976] [737] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 4208x3118-SGRBG10_IPU3 [10:15:33.027558684] [737] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 4208x3118-SGRBG10_IPU3 Camera configuration adjusted (With this Patch) ($) cam -c1 -swidth=640,height=320,role=raw Using camera \_SB_.PCI0.I2C2.CAM0 [10:19:04.270812870] [1457] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 4208x3118-SGRBG10_IPU3 [10:19:04.270859868] [1457] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 1048x780-SGRBG10_IPU3 Camera configuration adjusted ($) cam -c1 -swidth=1280,height=720,role=raw Using camera \_SB_.PCI0.I2C2.CAM0 [10:19:15.515222045] [1465] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 4208x3118-SGRBG10_IPU3 [10:19:15.515265834] [1465] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 2104x1560-SGRBG10_IPU3 Camera configuration adjusted ($) cam -c1 -swidth=1920,height=1080,role=raw Using camera \_SB_.PCI0.I2C2.CAM0 [10:19:23.333048232] [1471] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 4208x3118-SGRBG10_IPU3 [10:19:23.333101431] [1471] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 2104x1560-SGRBG10_IPU3 Camera configuration adjusted ($) cam -c1 -swidth=3840,height=2160,role=raw Using camera \_SB_.PCI0.I2C2.CAM0 [10:19:29.774700339] [1480] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 4208x3118-SGRBG10_IPU3 [10:19:29.774800035] [1480] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 4208x3118-SGRBG10_IPU3 Camera configuration adjusted ($) cam -c1 -swidth=4200,height=3000,role=raw Using camera \_SB_.PCI0.I2C2.CAM0 [10:19:59.786068223] [1541] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 4208x3118-SGRBG10_IPU3 [10:19:59.786176204] [1541] INFO IPU3 ipu3.cpp:277 CIO2 configuration: 4208x3118-SGRBG10_IPU3 Camera configuration adjusted --- src/libcamera/camera_sensor.cpp | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/src/libcamera/camera_sensor.cpp b/src/libcamera/camera_sensor.cpp index 1bf42acf..fb24480b 100644 --- a/src/libcamera/camera_sensor.cpp +++ b/src/libcamera/camera_sensor.cpp @@ -569,7 +569,14 @@ V4L2SubdeviceFormat CameraSensor::getFormat(const std::vector &mbu unsigned int area = sz.width * sz.height; unsigned int areaDiff = area - desiredArea; - if (ratioDiff > bestRatio) + /* + * Check if we have a better aspect ratio match than + * whatever we have seen before. ~1% change is acceptable + * if it leads to a selection of lower resolution below. + */ + if (bestRatio == FLT_MAX) + bestRatio = ratioDiff; + else if (fabsf(ratioDiff - bestRatio) > 0.01) continue; if (areaDiff < bestArea) {