Patch Detail
Show a patch.
GET /api/1.1/patches/2535/?format=api
{ "id": 2535, "url": "https://patchwork.libcamera.org/api/1.1/patches/2535/?format=api", "web_url": "https://patchwork.libcamera.org/patch/2535/", "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": "<20200108163434.19530-4-jacopo@jmondi.org>", "date": "2020-01-08T16:34:27", "name": "[libcamera-devel,v4,03/10] libcamera: properties: Generate libcamera properties", "commit_ref": null, "pull_url": null, "state": "superseded", "archived": false, "hash": "c4490c0d9c787b44a1bb1a61260c76574c376f6f", "submitter": { "id": 3, "url": "https://patchwork.libcamera.org/api/1.1/people/3/?format=api", "name": "Jacopo Mondi", "email": "jacopo@jmondi.org" }, "delegate": { "id": 15, "url": "https://patchwork.libcamera.org/api/1.1/users/15/?format=api", "username": "jmondi", "first_name": "Jacopo", "last_name": "Mondi", "email": "jacopo@jmondi.org" }, "mbox": "https://patchwork.libcamera.org/patch/2535/mbox/", "series": [ { "id": 610, "url": "https://patchwork.libcamera.org/api/1.1/series/610/?format=api", "web_url": "https://patchwork.libcamera.org/project/libcamera/list/?series=610", "date": "2020-01-08T16:34:24", "name": "Camera properties", "version": 4, "mbox": "https://patchwork.libcamera.org/series/610/mbox/" } ], "comments": "https://patchwork.libcamera.org/api/patches/2535/comments/", "check": "pending", "checks": "https://patchwork.libcamera.org/api/patches/2535/checks/", "tags": {}, "headers": { "Return-Path": "<jacopo@jmondi.org>", "Received": [ "from relay8-d.mail.gandi.net (relay8-d.mail.gandi.net\n\t[217.70.183.201])\n\tby lancelot.ideasonboard.com (Postfix) with ESMTPS id 52CAE6062A\n\tfor <libcamera-devel@lists.libcamera.org>;\n\tWed, 8 Jan 2020 17:32:19 +0100 (CET)", "from uno.lan (93-34-114-233.ip49.fastwebnet.it [93.34.114.233])\n\t(Authenticated sender: jacopo@jmondi.org)\n\tby relay8-d.mail.gandi.net (Postfix) with ESMTPSA id D0DCD1BF20F;\n\tWed, 8 Jan 2020 16:32:18 +0000 (UTC)" ], "X-Originating-IP": "93.34.114.233", "From": "Jacopo Mondi <jacopo@jmondi.org>", "To": "libcamera-devel@lists.libcamera.org", "Date": "Wed, 8 Jan 2020 17:34:27 +0100", "Message-Id": "<20200108163434.19530-4-jacopo@jmondi.org>", "X-Mailer": "git-send-email 2.24.0", "In-Reply-To": "<20200108163434.19530-1-jacopo@jmondi.org>", "References": "<20200108163434.19530-1-jacopo@jmondi.org>", "MIME-Version": "1.0", "Content-Transfer-Encoding": "8bit", "Subject": "[libcamera-devel] [PATCH v4 03/10] libcamera: properties: Generate\n\tlibcamera properties", "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>", "X-List-Received-Date": "Wed, 08 Jan 2020 16:32:20 -0000" }, "content": "Re-use the Control generation infrastructure to generate libcamera properties.\n\nIntroduce three additional files:\n- include/libcamera/property_ids.h\n Defines the properties ids\n\n- src/libcamera/property_ids.cpp\n Defines the properties Control<> instances\n\n- src/libcamera/property_ids.yaml\n Provide properties definitions\n\nSigned-off-by: Jacopo Mondi <jacopo@jmondi.org>\n---\n include/libcamera/meson.build | 26 ++-\n include/libcamera/property_ids.h.in | 33 +++\n src/libcamera/meson.build | 21 +-\n src/libcamera/property_ids.cpp.in | 43 ++++\n src/libcamera/property_ids.yaml | 334 ++++++++++++++++++++++++++++\n 5 files changed, 440 insertions(+), 17 deletions(-)\n create mode 100644 include/libcamera/property_ids.h.in\n create mode 100644 src/libcamera/property_ids.cpp.in\n create mode 100644 src/libcamera/property_ids.yaml", "diff": "diff --git a/include/libcamera/meson.build b/include/libcamera/meson.build\nindex 99abf0609940..25f503660960 100644\n--- a/include/libcamera/meson.build\n+++ b/include/libcamera/meson.build\n@@ -23,15 +23,23 @@ install_headers(libcamera_api,\n \n gen_controls = files('../../src/libcamera/gen-controls.py')\n \n-control_ids_h = custom_target('control_ids_h',\n- input : files('../../src/libcamera/control_ids.yaml', 'control_ids.h.in'),\n- output : 'control_ids.h',\n- depend_files : gen_controls,\n- command : [gen_controls, '-o', '@OUTPUT@', '@INPUT@'],\n- install : true,\n- install_dir : join_paths('include', include_dir))\n-\n-libcamera_api += control_ids_h\n+control_source_files = [\n+ 'control_ids',\n+ 'property_ids',\n+]\n+\n+control_headers = []\n+\n+foreach header : control_source_files\n+ input_files = files('../../src/libcamera/' + header +'.yaml', header + '.h.in')\n+ control_headers += custom_target(header + '_h',\n+ input : input_files,\n+ output : header + '.h',\n+ depend_files : gen_controls,\n+ command : [gen_controls, '-o', '@OUTPUT@', '@INPUT@'],\n+ install : true,\n+ install_dir : join_paths('include', include_dir))\n+endforeach\n \n gen_header = files('gen-header.sh')\n \ndiff --git a/include/libcamera/property_ids.h.in b/include/libcamera/property_ids.h.in\nnew file mode 100644\nindex 000000000000..62799b3e8c54\n--- /dev/null\n+++ b/include/libcamera/property_ids.h.in\n@@ -0,0 +1,33 @@\n+/* SPDX-License-Identifier: LGPL-2.1-or-later */\n+/*\n+ * Copyright (C) 2019, Google Inc.\n+ *\n+ * property_ids.h : Property ID list\n+ *\n+ * This file is auto-generated. Do not edit.\n+ */\n+\n+#ifndef __LIBCAMERA_PROPERTY_IDS_H__\n+#define __LIBCAMERA_PROPERTY_IDS_H__\n+\n+#include <stdint.h>\n+\n+#include <libcamera/controls.h>\n+\n+namespace libcamera {\n+\n+namespace properties {\n+\n+enum {\n+${ids}\n+};\n+\n+${controls}\n+\n+extern const ControlIdMap properties;\n+\n+} /* namespace propertiess */\n+\n+} /* namespace libcamera */\n+\n+#endif // __LIBCAMERA_PROPERTY_IDS_H__\ndiff --git a/src/libcamera/meson.build b/src/libcamera/meson.build\nindex c4f965bd7413..14aff6e5fc13 100644\n--- a/src/libcamera/meson.build\n+++ b/src/libcamera/meson.build\n@@ -67,14 +67,19 @@ endif\n \n gen_controls = files('gen-controls.py')\n \n-control_ids_cpp = custom_target('control_ids_cpp',\n- input : files('control_ids.yaml', 'control_ids.cpp.in'),\n- output : 'control_ids.cpp',\n- depend_files : gen_controls,\n- command : [gen_controls, '-o', '@OUTPUT@', '@INPUT@'])\n-\n-libcamera_sources += control_ids_cpp\n-libcamera_sources += control_ids_h\n+control_sources = []\n+\n+foreach source : control_source_files\n+ input_files = files(source +'.yaml', source + '.cpp.in')\n+ control_sources += custom_target(source + '_cpp',\n+ input : input_files,\n+ output : source + '.cpp',\n+ depend_files : gen_controls,\n+ command : [gen_controls, '-o', '@OUTPUT@', '@INPUT@'])\n+endforeach\n+\n+libcamera_sources += control_headers\n+libcamera_sources += control_sources\n \n gen_version = join_paths(meson.source_root(), 'utils', 'gen-version.sh')\n \ndiff --git a/src/libcamera/property_ids.cpp.in b/src/libcamera/property_ids.cpp.in\nnew file mode 100644\nindex 000000000000..bfdd823f63b0\n--- /dev/null\n+++ b/src/libcamera/property_ids.cpp.in\n@@ -0,0 +1,43 @@\n+/* SPDX-License-Identifier: LGPL-2.1-or-later */\n+/*\n+ * Copyright (C) 2019, Google Inc.\n+ *\n+ * property_ids.cpp : Property ID list\n+ *\n+ * This file is auto-generated. Do not edit.\n+ */\n+\n+#include <libcamera/property_ids.h>\n+\n+/**\n+ * \\file property_ids.h\n+ * \\brief Camera property identifiers\n+ */\n+\n+namespace libcamera {\n+\n+/**\n+ * \\brief Namespace for libcamera properties\n+ */\n+namespace properties {\n+\n+${controls_doc}\n+\n+#ifndef __DOXYGEN__\n+/*\n+ * Keep the properties definitions hidden from doxygen as it incorrectly parses\n+ * them as functions.\n+ */\n+${controls_def}\n+#endif\n+\n+/**\n+ * \\brief List of all supported libcamera properties\n+ */\n+extern const ControlIdMap properties {\n+${controls_map}\n+};\n+\n+} /* namespace properties */\n+\n+} /* namespace libcamera */\ndiff --git a/src/libcamera/property_ids.yaml b/src/libcamera/property_ids.yaml\nnew file mode 100644\nindex 000000000000..4a24bec12b9c\n--- /dev/null\n+++ b/src/libcamera/property_ids.yaml\n@@ -0,0 +1,334 @@\n+# SPDX-License-Identifier: LGPL-2.1-or-later\n+#\n+# Copyright (C) 2019, Google Inc.\n+#\n+%YAML 1.2\n+---\n+controls:\n+ - Location:\n+ type: int32_t\n+ description: |\n+ Camera mounting location\n+ enum:\n+ - CameraLocationFront:\n+ value: 0\n+ description: |\n+ The camera is mounted on the front side of the device, facing the\n+ user\n+ - CameraLocationBack:\n+ value: 1\n+ description: |\n+ The camera is mounted on the back facing side of the device\n+ - CameraLocationExternal:\n+ value: 2\n+ description: |\n+ The camera is attached to the device in a way that allows it to\n+ move freely\n+\n+ - Rotation:\n+ type: int32_t\n+ description: |\n+ The camera rotation is expressed as the angular difference in degrees\n+ between two reference systems, one implicitly defined by the camera\n+ module intrinsics characteristics, and one artificially defined on the\n+ external world scene to be captured when projected on the image sensor\n+ pixel array.\n+\n+ A camera sensor has an implicitly defined 2-dimensional reference\n+ system 'Rc' defined by its pixel array scan-out order, with its origin\n+ posed at pixel address (0,0), the x-axis progressing from there towards\n+ the last scanned out column of the pixel array and the y-axis\n+ progressing towards the last scanned out line.\n+\n+ A typical example for a sensor with a (2592x1944) pixel array matrix\n+ observed from the front is\n+\n+ (2592) x-axis 0\n+ <------------------------+ 0\n+ .......... ... ..........!\n+ .......... ... ..........! y-axis\n+ ... !\n+ .......... ... ..........!\n+ .......... ... ..........! (1944)\n+ V\n+\n+ The external world scene reference system scene 'Rs' is defined as a\n+ 2-dimensional reference system on the parallel plane posed in front\n+ of the camera module's focal plane, with its origin placed on the\n+ visible top-left corner, the x-axis progressing towards the right from\n+ there and the y-axis progressing towards the bottom of the visible\n+ scene.\n+\n+ A typical example of a (very common) picture of a shark swimming from\n+ left to right is\n+\n+ x-axis\n+ (0,0)---------------------->\n+ !\n+ !\n+ ! |\\____)\\___\n+ ! ) _____ __`<\n+ ! |/ )/\n+ !\n+ V\n+ y-axis\n+\n+ With the reference plane posed in front of the camera module and\n+ parallel to its focal plane\n+\n+ !\n+ / !\n+ / !\n+ / !\n+ _ / !\n+ +-/ \\-+ / !\n+ | (o) | ! 'Rs' reference plane\n+ +-----+ \\ !\n+ \\ !\n+ \\ !\n+ \\ !\n+ \\ !\n+ !\n+\n+ When projected on the sensor's pixel array, the image and the associated\n+ reference system 'Rs' are typically inverted, due to the camera module's\n+ lens optical inversion effect.\n+\n+ Assuming the above represented scene of the swimming shark, the lens\n+ inversion projects on the sensor pixel array the reference plane 'Rp'\n+\n+ y-axis\n+ ^\n+ !\n+ ! |\\_____)\\__\n+ ! ) ____ ___.<\n+ ! |/ )/\n+ !\n+ !\n+ (0,0)---------------------->\n+ x-axis\n+\n+ The camera rotation property is then defined as the angular difference\n+ between the origin of the camera reference system 'Rc', defined by the\n+ camera sensor scan-out direction and its mounting rotation, and the\n+ origin of the projected scene reference system 'Rp', result of the\n+ optical projection of the scene reference system 'Rs' on the sensor\n+ pixel array.\n+\n+ Examples\n+\n+ 0 degrees camera rotation\n+\n+ y-Rp\n+ y-Rc ^\n+ ^ !\n+ ! !\n+ ! !\n+ ! !\n+ ! !\n+ ! !\n+ ! (0,0)---------------------->\n+ ! x-Rp\n+ 0 +------------------------------------->\n+ 0 x-Rc\n+\n+\n+ x-Rc 0\n+ <------------------------+ 0\n+ x-Rp !\n+ <-----------------------(0,0) !\n+ ! !\n+ ! !\n+ ! !\n+ ! V\n+ ! y-Rc\n+ V\n+ y-Rp\n+\n+ -90 degrees camera rotation\n+\n+ 0 y-Rc\n+ 0 +----------------------->\n+ !\n+ ! y-Rp\n+ ! ^\n+ ! !\n+ ! !\n+ ! !\n+ ! !\n+ ! !\n+ ! !\n+ ! (0,0)---------------------->\n+ ! x-Rp\n+ !\n+ V\n+ x-Rc\n+\n+ +90 degrees camera rotation\n+\n+ 0 y-Rc\n+ 0 +----------------------->\n+ ! x-Rp\n+ ! <-----------------------(0,0\n+ ! !\n+ ! !\n+ ! !\n+ ! !\n+ ! !\n+ ! V\n+ ! y-Rp\n+ !\n+ !\n+ V\n+ x-Rc\n+\n+ 180 degrees camera rotation\n+\n+ x-Cr 0\n+ <------------------------+ 0\n+ y-Rp !\n+ ^ !\n+ ! ! y-Cr\n+ ! !\n+ ! !\n+ ! V\n+ !\n+ !\n+ (0,0)--------------------->\n+ x-Rp\n+\n+\n+\n+ Example one - Webcam\n+\n+ A camera module installed on the user facing part of a laptop screen\n+ casing used for video calls. The captured images are meant to be\n+ displayed in landscape mode (width > height) on the laptop screen.\n+\n+ The camera is typically mounted 180 degrees rotated to compensate the\n+ lens optical inversion effect.\n+\n+ y-Rp\n+ y-Rc ^\n+ ^ !\n+ ! ! |\\_____)\\__\n+ ! ! ) ____ ___.<\n+ ! ! |/ )/\n+ ! !\n+ ! !\n+ ! (0,0)---------------------->\n+ ! x-Rp\n+ 0 +------------------------------------->\n+ 0 x-Rc\n+\n+ The two reference systems are aligned, the resulting camera rotation is\n+ 0 degrees, no rotation correction should be applied to the resulting\n+ image once captured to memory buffers.\n+\n+ +--------------------------+\n+ ! |\\____)\\___ !\n+ ! ) _____ __`< !\n+ ! |/ )/ !\n+ +--------------------------+\n+\n+ If the camera modules is not mounted 180 degrees rotated to compensate\n+ the lens optical inversion, the two reference system will result not\n+ aligned, with 'Rp' plane 180 degrees rotated in respect to the 'Rc'\n+ plane (the sign is irrelevant in this case)\n+\n+ x-Rc 0\n+ <------------------------+ 0\n+ y-Rp !\n+ ^ !\n+ ! ! y-Rc\n+ ! |\\_____)\\__ !\n+ ! ) ____ ___.< !\n+ ! |/ )/ V\n+ !\n+ !\n+ (0,0)--------------------->\n+ x-Rp\n+\n+ The image once captured to memory will result 180 degrees rotated\n+\n+ +--------------------------+\n+ ! __/(_____/| !\n+ ! >.___ ____ ( !\n+ ! \\( \\| !\n+ +--------------------------+\n+\n+ And a software rotation of 180 degrees should be applied to correctly\n+ display the image\n+\n+ +--------------------------+\n+ ! |\\____)\\___ !\n+ ! ) _____ __`< !\n+ ! |/ )/ !\n+ +--------------------------+\n+\n+ Example two - Phone camera\n+\n+ A camera installed on the back-side of a mobile device facing away from\n+ the user. The captured images are meant to be displayed in portrait mode\n+ (height > width) to match the device screen orientation and the device\n+ usage orientation used when taking the picture.\n+\n+ The camera is typically mounted with its pixel array longer side aligned\n+ to the device longer side and 180 degrees rotated to compensate the lens\n+ optical inversion effect.\n+\n+ 0 y-Rc\n+ 0 +----------------------->\n+ !\n+ ! y-Rp\n+ ! ^\n+ ! !\n+ ! ! |\\_____)\\__\n+ ! ! ) ____ ___.<\n+ ! ! |/ )/\n+ ! !\n+ ! !\n+ ! (0,0)---------------------->\n+ ! x-Rp\n+ !\n+ !\n+ V\n+ x-Rc\n+\n+ The two reference systems are not aligned and the 'Rp' reference\n+ system is -90 degrees rotated in respect to the 'Rc' reference system.\n+\n+ The image, when captured to memory buffer will result rotated\n+\n+ +---------------------------------------+\n+ | _ _ |\n+ | \\ / |\n+ | | | |\n+ | | | |\n+ | | > |\n+ | < | |\n+ | | | |\n+ | . |\n+ | V |\n+ +---------------------------------------+\n+\n+ And a correction of the same -90 degrees have to applied to correctly\n+ display the image in portrait mode\n+\n+ +-----------------+\n+ | |\n+ | |\n+ | |\n+ | |\n+ | |\n+ | |\n+ | |\\____)\\___ |\n+ | ) _____ __`< |\n+ | |/ )/ |\n+ | |\n+ | |\n+ | |\n+ | |\n+ | |\n+ +-----------------+\n+...\n", "prefixes": [ "libcamera-devel", "v4", "03/10" ] }