From patchwork Fri Dec 11 13:35:08 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Naushir Patuck X-Patchwork-Id: 10645 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 6CE4FBD808 for ; Fri, 11 Dec 2020 13:35:17 +0000 (UTC) Received: from lancelot.ideasonboard.com (localhost [IPv6:::1]) by lancelot.ideasonboard.com (Postfix) with ESMTP id F2A2567F9F; Fri, 11 Dec 2020 14:35:16 +0100 (CET) Authentication-Results: lancelot.ideasonboard.com; dkim=fail reason="signature verification failed" (2048-bit key; unprotected) header.d=raspberrypi.com header.i=@raspberrypi.com header.b="Be1Qa6qC"; dkim-atps=neutral Received: from mail-wm1-x32f.google.com (mail-wm1-x32f.google.com [IPv6:2a00:1450:4864:20::32f]) by lancelot.ideasonboard.com (Postfix) with ESMTPS id 2DA1267F06 for ; Fri, 11 Dec 2020 14:35:15 +0100 (CET) Received: by mail-wm1-x32f.google.com with SMTP id a6so7579602wmc.2 for ; Fri, 11 Dec 2020 05:35:15 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=raspberrypi.com; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=gH8HMYcOquTPDuesHKOTcqJ/C07iagYJVPlUMXZ+2JM=; b=Be1Qa6qCD5p282E5AzSWBkYvUS57vwLw0tn6jf17BVIb/5Zel3aDjHyjVPwNoRyVKV swxcCSVjQHuuGqyqmN5+zWwl1vm1T5/FTh3UFXw84V706Ed0G7Q8SbvR1QVnYNZFaox/ B3OHkMD3J4xOY3sAI7+dUh5Fsof8S+vjSJFsICwp7U6VvPRAcIY0A28s3r6Wvgv8V505 rznuL5lE5ZAYe2EGltDc9uRuS4LC/1Yn4CdVT4lJRnwtLIUA7xwBBnMANqWANy2NIuTX FWVVzVKYOrlNTfyf/PttAtbmIHDQ/TWo7YGrfn8DBOdrMbFiGlb0yxTMcig+z4dxGM/h jgbQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=gH8HMYcOquTPDuesHKOTcqJ/C07iagYJVPlUMXZ+2JM=; b=k8LAur+ujF9f3zRaEiEpW17iFkdieSDiUaId++I33v6fTBjQW6AvnpLV+dRjwydJ7Y hH4qH5pUl/xC4ZPixtL24Rg9iWPBDaL8mNi/S1lBfT03kZ6WVUtzdaUPY5h0EJK56jnQ aT+pUZNq136QY3JLBEtiBrjXGULqV4PrH3iXhhRSO0DGCFChZSyp+JyZUrrjvmJqROEK gbN7xmjxGK8IITx7o+NUqfZg/ru2V9pGtXp4lqJ4u2tZ7DDqq17jCwPSZhXKLMZjFkNn JPtMUvSBRhmDdisEZyszJqb3bxzoVW1bMUIZ4XJSKWaPkOQxLzSC5W1vdzIw/kHdEtZB DWxQ== X-Gm-Message-State: AOAM531k8jZY+yIGfuh4ZSjQJ0gjiYiZSM3tQvjBEaQcV7jOo4y3MohU i3m1LOdBGT1WzaifdIwDd9EJ2GQBz4mwRA== X-Google-Smtp-Source: ABdhPJyzQ6H5wJwx0nbD9nuoxbPM6ImNXL/zn1dowau/PTkD0xmRr99oUyyhSWaI9dfji+n8gi+pHw== X-Received: by 2002:a1c:f405:: with SMTP id z5mr13469006wma.93.1607693714322; Fri, 11 Dec 2020 05:35:14 -0800 (PST) Received: from naushir-VirtualBox.pitowers.org ([2a00:1098:3142:14:a00:27ff:fe4d:f6a2]) by smtp.gmail.com with ESMTPSA id q15sm14889428wrw.75.2020.12.11.05.35.13 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 11 Dec 2020 05:35:13 -0800 (PST) From: Naushir Patuck To: libcamera-devel@lists.libcamera.org Date: Fri, 11 Dec 2020 13:35:08 +0000 Message-Id: <20201211133510.391037-1-naush@raspberrypi.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Subject: [libcamera-devel] [PATCH v7 1/3] libcamera: controls: Add frame duration control 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" Add an int64_t array control (controls::FrameDurations) to specify the minimum and maximum (in that order) frame duration to be used by the camera sensor. Signed-off-by: Naushir Patuck Reviewed-by: David Plowman Tested-by: David Plowman Reviewed-by: Jacopo Mondi --- src/libcamera/control_ids.yaml | 40 ++++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) diff --git a/src/libcamera/control_ids.yaml b/src/libcamera/control_ids.yaml index 6d6f0fee..43a7cfb7 100644 --- a/src/libcamera/control_ids.yaml +++ b/src/libcamera/control_ids.yaml @@ -306,6 +306,46 @@ controls: maximum valid value is given by the properties::ScalerCropMaximum property, and the two can be used to implement digital zoom. + - FrameDurations: + type: int64_t + description: | + The minimum and maximum (in that order) frame duration, + expressed in micro-seconds. + + When provided by applications, the control specifies the sensor frame + duration interval the pipeline has to use. This could also limit the + largest exposure time the sensor can use. For example, if a maximum + frame duration of 33ms is requested (corresponding to 30 frames per + second), the sensor will not be able to raise the exposure time above + 33ms. A fixed frame duration is achieved by setting the minimum and + maximum values to be the same. + + The maximum frame duration provides the absolute limit to the shutter + speed computed by the AE algorithm and it overrides any exposure mode + setting specified with controls::AeExposureMode. Similarly, when a + manual exposure time is set through controls::ExposureTime, it also + gets clipped to the limits set by this control. + + \sa AeExposureMode + \sa ExposureTime + + \todo Refer to the frame duration limits property to describe how + application-provided values gets clipped and reset. + + When reported by pipelines, the control expresses the duration of the + sensor frame used to produce streams part of the completed Request. + The minimum and maximum values shall then be the same, as the sensor + frame duration is a fixed parameter. The sensor frame duration is one + of the parameter that defines the capture frame rate but it does not + alone provide enough information to fully calculate it as it does not + account for pipeline processing delays. + + \todo Define how to calculate the capture frame rate by + defining controls to report additional delays introduced by + the capture pipeline or post-processing stages (ie JPEG + conversion, frame scaling). + size: [2] + # ---------------------------------------------------------------------------- # Draft controls section