Patch Detail
Show a patch.
GET /api/1.1/patches/9268/?format=api
{ "id": 9268, "url": "https://patchwork.libcamera.org/api/1.1/patches/9268/?format=api", "web_url": "https://patchwork.libcamera.org/patch/9268/", "project": { "id": 1, "url": "https://patchwork.libcamera.org/api/1.1/projects/1/?format=api", "name": "libcamera", "link_name": "libcamera", "list_id": "libcamera_core", "list_email": "libcamera-devel@lists.libcamera.org", "web_url": "", "scm_url": "", "webscm_url": "" }, "msgid": "<20200806163639.12971-6-david.plowman@raspberrypi.com>", "date": "2020-08-06T16:36:39", "name": "[libcamera-devel,v2,5/5] libcamera: ipa: raspberrypi: ALSC: Handle user transform", "commit_ref": null, "pull_url": null, "state": "accepted", "archived": false, "hash": "925b363fef36d092def50ce22ca02dce4058de08", "submitter": { "id": 42, "url": "https://patchwork.libcamera.org/api/1.1/people/42/?format=api", "name": "David Plowman", "email": "david.plowman@raspberrypi.com" }, "delegate": null, "mbox": "https://patchwork.libcamera.org/patch/9268/mbox/", "series": [ { "id": 1208, "url": "https://patchwork.libcamera.org/api/1.1/series/1208/?format=api", "web_url": "https://patchwork.libcamera.org/project/libcamera/list/?series=1208", "date": "2020-08-06T16:36:34", "name": "Transform implementation", "version": 2, "mbox": "https://patchwork.libcamera.org/series/1208/mbox/" } ], "comments": "https://patchwork.libcamera.org/api/patches/9268/comments/", "check": "pending", "checks": "https://patchwork.libcamera.org/api/patches/9268/checks/", "tags": {}, "headers": { "Return-Path": "<libcamera-devel-bounces@lists.libcamera.org>", "X-Original-To": "parsemail@patchwork.libcamera.org", "Delivered-To": "parsemail@patchwork.libcamera.org", "Received": [ "from lancelot.ideasonboard.com (lancelot.ideasonboard.com\n\t[92.243.16.209])\n\tby patchwork.libcamera.org (Postfix) with ESMTPS id 88DD2BD86F\n\tfor <parsemail@patchwork.libcamera.org>;\n\tThu, 6 Aug 2020 16:36:58 +0000 (UTC)", "from lancelot.ideasonboard.com (localhost [IPv6:::1])\n\tby lancelot.ideasonboard.com (Postfix) with ESMTP id 55DE960BF7;\n\tThu, 6 Aug 2020 18:36:58 +0200 (CEST)", "from mail-wm1-x32a.google.com (mail-wm1-x32a.google.com\n\t[IPv6:2a00:1450:4864:20::32a])\n\tby lancelot.ideasonboard.com (Postfix) with ESMTPS id 8F5E860E00\n\tfor <libcamera-devel@lists.libcamera.org>;\n\tThu, 6 Aug 2020 18:36:54 +0200 (CEST)", "by mail-wm1-x32a.google.com with SMTP id x5so9417498wmi.2\n\tfor <libcamera-devel@lists.libcamera.org>;\n\tThu, 06 Aug 2020 09:36:54 -0700 (PDT)", "from pi4-davidp.lan (plowpeople3.plus.com. [80.229.223.72])\n\tby smtp.gmail.com with ESMTPSA id\n\te5sm7405076wrc.37.2020.08.06.09.36.52\n\t(version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256);\n\tThu, 06 Aug 2020 09:36:53 -0700 (PDT)" ], "Authentication-Results": "lancelot.ideasonboard.com;\n\tdkim=fail reason=\"signature verification failed\" (2048-bit key;\n\tunprotected) header.d=raspberrypi.com header.i=@raspberrypi.com\n\theader.b=\"bwVCpo/u\"; dkim-atps=neutral", "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n\td=raspberrypi.com; s=google;\n\th=from:to:cc:subject:date:message-id:in-reply-to:references\n\t:mime-version:content-transfer-encoding;\n\tbh=pU4KCuTRMlbv0WdNJxhxE+59YkBpPb4btW7ceGvrAzo=;\n\tb=bwVCpo/ufljfPzwWZkOTeEfkDx9yaF/MKF9JfNKTZNryzOSilp6lZnhfl7uR8Cmn/J\n\tK6Tma8W6KufP4WMf08s95C6y0UFzmSnXgOv34Jcj9vSj8lGcHmOYKLukB2Bwygz+448l\n\trKUioAFGJdsj4TtH1Z+WiXz/UNAhqpGSC7w9D+bLBJGl52vCdemhA/ttEvM38diH/gon\n\tr63xM9Lr9AXRKQ8gEJuygBDFn2TVu0V4wR7THNicLGgZ4xD43SCTG4uUauSAi6nEWMPV\n\tKjuJKIyZRMLBMdFmRwq7DH2QXLYkHYdZB7M5+vlW3uue/5KhVwjlBjVmu6uuyrvo+DIe\n\ty7aA==", "X-Google-DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n\td=1e100.net; s=20161025;\n\th=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to\n\t:references:mime-version:content-transfer-encoding;\n\tbh=pU4KCuTRMlbv0WdNJxhxE+59YkBpPb4btW7ceGvrAzo=;\n\tb=UF65Kd3bW9z8MSrLCTEuOX57P/XG9OfCisvzugshLNH/MK3zh5h1KGglntqol0ACzy\n\tRGSd6QltXFpUYHwGYVzrQqlj/V+ClJnjA9Fd9sCXsWl4JFrFkIkbQsOyXmkDaFFhPf40\n\tNE+YAnS2X2Ns0rGEUurGaUov+Y4Imx0A7nXtZNnUW9yLTDHdCdXkdP/U8CW1iUawRL2+\n\tK+vPb5JAMVaxF9UKBQQC4KOuN8YvOjkBBAvAF4SMmYkPhFUOrzAZK00/QonP+JZrUcDh\n\tbbcRP8Un8YWmcyfq0iDVb0vBxyKMhkHeXOWkqLcKGSgsNcSG0wFFMZ1ZlCQexu3XY1jB\n\tQ4GQ==", "X-Gm-Message-State": "AOAM530BmECTZa4YoeEq5TyYeyTcVEdfOIZo7edcXjQeXhzMGfUHTXIv\n\tRS5TflVCi1D8Ptj83kMOnSHB7rUXqlYvpQ==", "X-Google-Smtp-Source": "ABdhPJw0YLKejQph28OHGMu0hmW3YSmetRLmv6vBkdAIWXqJN4r1Y7RJwVd+i2lDrasTRJRFNviIFQ==", "X-Received": "by 2002:a1c:678b:: with SMTP id\n\tb133mr9523240wmc.117.1596731813922; \n\tThu, 06 Aug 2020 09:36:53 -0700 (PDT)", "From": "David Plowman <david.plowman@raspberrypi.com>", "To": "libcamera-devel@lists.libcamera.org", "Date": "Thu, 6 Aug 2020 17:36:39 +0100", "Message-Id": "<20200806163639.12971-6-david.plowman@raspberrypi.com>", "X-Mailer": "git-send-email 2.20.1", "In-Reply-To": "<20200806163639.12971-1-david.plowman@raspberrypi.com>", "References": "<20200806163639.12971-1-david.plowman@raspberrypi.com>", "MIME-Version": "1.0", "Subject": "[libcamera-devel] [PATCH v2 5/5] libcamera: ipa: raspberrypi: ALSC:\n\tHandle user transform", "X-BeenThere": "libcamera-devel@lists.libcamera.org", "X-Mailman-Version": "2.1.29", "Precedence": "list", "List-Id": "<libcamera-devel.lists.libcamera.org>", "List-Unsubscribe": "<https://lists.libcamera.org/options/libcamera-devel>,\n\t<mailto:libcamera-devel-request@lists.libcamera.org?subject=unsubscribe>", "List-Archive": "<https://lists.libcamera.org/pipermail/libcamera-devel/>", "List-Post": "<mailto:libcamera-devel@lists.libcamera.org>", "List-Help": "<mailto:libcamera-devel-request@lists.libcamera.org?subject=help>", "List-Subscribe": "<https://lists.libcamera.org/listinfo/libcamera-devel>,\n\t<mailto:libcamera-devel-request@lists.libcamera.org?subject=subscribe>", "Content-Type": "text/plain; charset=\"us-ascii\"", "Content-Transfer-Encoding": "7bit", "Errors-To": "libcamera-devel-bounces@lists.libcamera.org", "Sender": "\"libcamera-devel\" <libcamera-devel-bounces@lists.libcamera.org>" }, "content": "Update ALSC (Auto Lens Shading Correction) to handle correctly the\nuser transform now passed in the camera mode.\n\nThe user transform is applied directly in the sensor so the image\nstatistics already incorporate it, and the adaptive algorithm is\nentirely agnostic towards it, so all we have to do is flip the\ncalibrated tables to match. (These tables will have been calibrated\nwithout the user transform.)\n---\n src/ipa/raspberrypi/controller/rpi/alsc.cpp | 13 ++++++++++++-\n 1 file changed, 12 insertions(+), 1 deletion(-)", "diff": "diff --git a/src/ipa/raspberrypi/controller/rpi/alsc.cpp b/src/ipa/raspberrypi/controller/rpi/alsc.cpp\nindex 9df713a..fdeda21 100644\n--- a/src/ipa/raspberrypi/controller/rpi/alsc.cpp\n+++ b/src/ipa/raspberrypi/controller/rpi/alsc.cpp\n@@ -184,7 +184,10 @@ void Alsc::waitForAysncThread()\n \n static bool compare_modes(CameraMode const &cm0, CameraMode const &cm1)\n {\n-\t// Return true if the modes crop from the sensor significantly differently.\n+\t// Return true if the modes crop from the sensor significantly differently,\n+\t// or if the user transform has changed.\n+\tif (cm0.transform != cm1.transform)\n+\t\treturn true;\n \tint left_diff = abs(cm0.crop_x - cm1.crop_x);\n \tint top_diff = abs(cm0.crop_y - cm1.crop_y);\n \tint right_diff = fabs(cm0.crop_x + cm0.scale_x * cm0.width -\n@@ -429,6 +432,10 @@ void resample_cal_table(double const cal_table_in[XY],\n \t\txf[i] = x - x_lo[i];\n \t\tx_hi[i] = std::min(x_lo[i] + 1, X - 1);\n \t\tx_lo[i] = std::max(x_lo[i], 0);\n+\t\tif (!!(camera_mode.transform & libcamera::Transform::HFlip)) {\n+\t\t\tx_lo[i] = X - 1 - x_lo[i];\n+\t\t\tx_hi[i] = X - 1 - x_hi[i];\n+\t\t}\n \t}\n \t// Now march over the output table generating the new values.\n \tdouble scale_y = camera_mode.sensor_height /\n@@ -441,6 +448,10 @@ void resample_cal_table(double const cal_table_in[XY],\n \t\tdouble yf = y - y_lo;\n \t\tint y_hi = std::min(y_lo + 1, Y - 1);\n \t\ty_lo = std::max(y_lo, 0);\n+\t\tif (!!(camera_mode.transform & libcamera::Transform::VFlip)) {\n+\t\t\ty_lo = Y - 1 - y_lo;\n+\t\t\ty_hi = Y - 1 - y_hi;\n+\t\t}\n \t\tdouble const *row_above = cal_table_in + X * y_lo;\n \t\tdouble const *row_below = cal_table_in + X * y_hi;\n \t\tfor (int i = 0; i < X; i++) {\n", "prefixes": [ "libcamera-devel", "v2", "5/5" ] }