From patchwork Fri Feb 12 11:33:07 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Naushir Patuck X-Patchwork-Id: 11253 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 2DFACBD160 for ; Fri, 12 Feb 2021 11:37:34 +0000 (UTC) Received: from lancelot.ideasonboard.com (localhost [IPv6:::1]) by lancelot.ideasonboard.com (Postfix) with ESMTP id 667DC63776; Fri, 12 Feb 2021 12:37:33 +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="lq+06Qyg"; dkim-atps=neutral Received: from mail-wm1-x32c.google.com (mail-wm1-x32c.google.com [IPv6:2a00:1450:4864:20::32c]) by lancelot.ideasonboard.com (Postfix) with ESMTPS id D560B6376F for ; Fri, 12 Feb 2021 12:37:31 +0100 (CET) Received: by mail-wm1-x32c.google.com with SMTP id y134so653508wmd.3 for ; Fri, 12 Feb 2021 03:37:31 -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=0qhb53j9t0gM4sA8vnT7g+jOOUA5U3dRZj1Rfci4bIU=; b=lq+06Qyg1aOKCHuICq494ZpzkX7oW7r0ti2WWiOtZwBZwy1uOAUcEHoQHcHVdb2fHE QkycBeviYUXLdxqygP2EgoMvT7NA9HBJWBwj/G9eso0zLWOUj07+jT5yOKhoi1EvByh5 qatXDD9AI2eVpZ5R03qqCuU992P2baVowZPcURjzuyknLYnx94b6znC/mgnRtFI9JplT qaZls/bwSFYaWzwEGXfMWsEzv34IhqH87HGMVtjSoQL4UwFGBSCLlXex4WkRNuFN1KFH 9v8RFexvjBkWhwYbtNBYMohEMaEzzuvU/DugWpmPmJdvJtHC1hm1Kl+d6aFUvfOnu62n m1zg== 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=0qhb53j9t0gM4sA8vnT7g+jOOUA5U3dRZj1Rfci4bIU=; b=RbYL3VCWkx7wd+C9E+GQk9TsEBq+v7bsBs6i1fzHPE5DvBSfCcSENK78kwUT4EnW7Q lygDnL+vbqoTJzTEhBW6cj47OauMoxew6Uygu3HlLUhlk9WjurFdO09pPAVe53vEpe/4 +xa9vY6ndg7bvLFazkULL8IsY5/xqKGSR3rVjKClKjmFtXz6N45yO+G8psbX5eQk2CzP kD/Kc/S2UkcxxjcrCdlTw47SvKGG2smAT+7NQJjrg4rNTtwEqZgDQkTQjXDMYFz93nK0 TS2QyQtn2BFMT7jYQ3SKVYxZG0m/cgYqScSWP/6Goru4/odzavRhmjejNU5NSR/kCwrg zUPw== X-Gm-Message-State: AOAM531QL+DBVzWUQ9HkuQ48poOwgPdD/HAHAQ+jNH2g93+E0Q/JyobJ 3WCu38GuW4mt7pq5rw8aBesVVgcsTHUOgQuU X-Google-Smtp-Source: ABdhPJxI27fHa5EICCUrQ+9MD105RojGYQhj+vh+jMiCZJfqjjy6HSzC9RP2NqN0jW2WcMB53LYqOA== X-Received: by 2002:a1c:29c4:: with SMTP id p187mr2130004wmp.8.1613129851065; Fri, 12 Feb 2021 03:37:31 -0800 (PST) Received: from naush-laptop.patuck.local ([88.97.76.4]) by smtp.gmail.com with ESMTPSA id v5sm10005020wro.71.2021.02.12.03.37.30 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 12 Feb 2021 03:37:30 -0800 (PST) From: Naushir Patuck To: libcamera-devel@lists.libcamera.org Date: Fri, 12 Feb 2021 11:33:07 +0000 Message-Id: <20210212113312.239076-1-naush@raspberrypi.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Subject: [libcamera-devel] [PATCH 0/5] DelayedControls updates and fixes 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" Hi all, This patchset mainly addresses some minor issues we have encountered with DelayedControls when running on the Raspberry Pi platform. Apologies for the slightly long cover letter, but I wanted to explain the problems we are seeing in a bit of detail :-) Patch 1/5 This adds the notion of priority write to fixup the known issue of settings VBLANK and EXPOSURE in a single batch. It is simply a port of the fix applied to StaggeredCtrl that had been reviewed and subsequently deprecated, so hopefully nothing too controversial. Patch 2/5 This is simply a python script that I am using to debug the small problems (more details below) that we have encountered. It parses the DelayedControls logs and nicely tabulates the results to show what controls and values have been set/queued/get on each frame. This has helped me tremendously in identifying problems and fixing them. However, this may not be useful to others, so I am happy to not have this merged if folks do not think it is the right place to put it. Patch 3/5 Fixes a spurious write to the device on startup. The following is an extract from using the script to parse the logs: Frame Action Gain Exposure Vblank 0 Write 0 [0] 52 [0] 531 [0] <<<<< 0 Get 0 [0] 52 [0] 531 [0] 0 Queue --- [-] --- [-] --- [-] 1 Write 0 [0] --- [-] --- [-] 1 Get 0 [0] 52 [0] 531 [0] 1 Queue --- [-] --- [-] --- [-] 2 Write --- [-] --- [-] --- [-] 2 Get 0 [1] 52 [1] 531 [1] 2 Queue 192 [4] 1664 [4] 531 [4] You can see above, on frame 0 we are writing controls to the sensor, but this is unneeded. This spurious write should really not happen as there is no controls queued by the pipeline_handler at this point. It is, however, mostly inconsequential at runtime. Patch 4/5 This fixes an issue where controls queued by the pipeline handler are delayed by and additional frame when writing. You can see better in the parsed log: Frame Action Gain Exposure Vblank 2 Write --- [-] --- [-] --- [-] 2 Get 0 [1] 52 [1] 531 [1] 2 Queue 192 [4] 1664 [4] 531 [4] <<<<< 3 Write --- [-] --- [-] --- [-] <<<<< 3 Get 0 [2] 52 [2] 531 [2] 3 Queue 192 [5] 1664 [5] 531 [5] 4 Write --- [-] 1664 [4] 531 [4] <<<<< 4 Get 0 [3] 52 [3] 531 [3] 4 Queue 192 [6] 1664 [6] 531 [6] On frame 2, we queue controls from the pipeline handler. Exposure and Vblank must be written one frame before gain, so you would expect them to be written on frame 3 as nothing else is in the queue. However, they only get written on frame 4, one frame later than expected. This is because of how DelayedControls handles "no-op" queue items, i.e. frames where we do not provide the helper with controls to use. It was adding one more no-op than needed, and causing an extra frame delay when setting the control on the device. Patch 5/5 We had an off-by-one error when reading back values from the queues. See the parsed logs below: Frame Action Gain Exposure Vblank 7 Write 192 [6] 1664 [7] 531 [7] <<<<< 7 Get 192 [6] 1664 [6] 531 [6] 7 Queue 210 [9] 3174 [9] 1946 [9] 8 Write 192 [7] 3526 [8] 2298 [8] 8 Get 192 [7] 1664 [7] 531 [7] <<<<< 8 Queue 210 [10] 3174 [10] 1946 [10] 9 Write 213 [8] 3174 [9] 1946 [9] 9 Get 213 [8] 3526 [8] 2298 [8] <<<<< 9 Queue 213 [12] 3526 [12] 2298 [12] On frame 7, we write exposure and vblank with values 1664 and 531 respectively. These values take 2 frames to consume, so should be retuned to the pipeline handler by the DelayedControls::get() on frame 9. However, it returns on frame 8 instead. This only causes slight (but visible) oscillations in brightness in the AGC loop as the values used by the sensor are not in lock-step to what is reported by DelayedControls::get(). Hope that is all reasonably well explained :-) Any questions, please do shout. Regards, Naush Naushir Patuck (5): libcamera: delayed_controls: Add notion of priority write utils: raspberrypi: Add a DelayedControls log parser libcamera: delayed_controls: Remove unneeded write when starting up libcamera: delayed_controls: Remove spurious no-op queued controls libcamera: delayed_controls: Fix off-by-one error in get() include/libcamera/internal/delayed_controls.h | 13 ++- src/libcamera/delayed_controls.cpp | 72 ++++++++++------ src/libcamera/pipeline/ipu3/ipu3.cpp | 8 +- .../pipeline/raspberrypi/raspberrypi.cpp | 13 ++- src/libcamera/pipeline/rkisp1/rkisp1.cpp | 8 +- test/delayed_contols.cpp | 20 ++--- utils/raspberrypi/delayedctrls_parse.py | 82 +++++++++++++++++++ 7 files changed, 162 insertions(+), 54 deletions(-) create mode 100644 utils/raspberrypi/delayedctrls_parse.py