Patch Detail
Show a patch.
GET /api/patches/1724/?format=api
{ "id": 1724, "url": "https://patchwork.libcamera.org/api/patches/1724/?format=api", "web_url": "https://patchwork.libcamera.org/patch/1724/", "project": { "id": 1, "url": "https://patchwork.libcamera.org/api/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": "<20190801155420.24694-5-jacopo@jmondi.org>", "date": "2019-08-01T15:54:19", "name": "[libcamera-devel,4/5] android: Add camera metadata library", "commit_ref": null, "pull_url": null, "state": "superseded", "archived": false, "hash": "118d1345f401b279e32507827cb0febae5705ba0", "submitter": { "id": 3, "url": "https://patchwork.libcamera.org/api/people/3/?format=api", "name": "Jacopo Mondi", "email": "jacopo@jmondi.org" }, "delegate": null, "mbox": "https://patchwork.libcamera.org/patch/1724/mbox/", "series": [ { "id": 444, "url": "https://patchwork.libcamera.org/api/series/444/?format=api", "web_url": "https://patchwork.libcamera.org/project/libcamera/list/?series=444", "date": "2019-08-01T15:54:15", "name": "android: Add initial Camera HAL implementation", "version": 1, "mbox": "https://patchwork.libcamera.org/series/444/mbox/" } ], "comments": "https://patchwork.libcamera.org/api/patches/1724/comments/", "check": "pending", "checks": "https://patchwork.libcamera.org/api/patches/1724/checks/", "tags": {}, "headers": { "Return-Path": "<jacopo@jmondi.org>", "Received": [ "from relay4-d.mail.gandi.net (relay4-d.mail.gandi.net\n\t[217.70.183.196])\n\tby lancelot.ideasonboard.com (Postfix) with ESMTPS id 5F84F615FF\n\tfor <libcamera-devel@lists.libcamera.org>;\n\tThu, 1 Aug 2019 17:53:27 +0200 (CEST)", "from uno.homenet.telecomitalia.it\n\t(host211-19-dynamic.58-82-r.retail.telecomitalia.it [82.58.19.211])\n\t(Authenticated sender: jacopo@jmondi.org)\n\tby relay4-d.mail.gandi.net (Postfix) with ESMTPSA id 4C12DE0003;\n\tThu, 1 Aug 2019 15:53:21 +0000 (UTC)" ], "X-Originating-IP": "82.58.19.211", "From": "Jacopo Mondi <jacopo@jmondi.org>", "To": "libcamera-devel@lists.libcamera.org", "Date": "Thu, 1 Aug 2019 17:54:19 +0200", "Message-Id": "<20190801155420.24694-5-jacopo@jmondi.org>", "X-Mailer": "git-send-email 2.22.0", "In-Reply-To": "<20190801155420.24694-1-jacopo@jmondi.org>", "References": "<20190801155420.24694-1-jacopo@jmondi.org>", "MIME-Version": "1.0", "Content-Transfer-Encoding": "8bit", "Subject": "[libcamera-devel] [PATCH 4/5] android: Add camera metadata library", "X-BeenThere": "libcamera-devel@lists.libcamera.org", "X-Mailman-Version": "2.1.23", "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": "Thu, 01 Aug 2019 15:53:27 -0000" }, "content": "Import the Android camera metadata library from the ChromiumOS build\nsystem.\n\nThe camera metadata library has been copied from\nhttps://chromium.googlesource.com/chromiumos/platform2\nat revision ceb477360a8012ee38e80746258f4828aad6b4c7.\n\nThe original path in the Cros platform2/ repository is:\ncamera/android/libcamera_metadata/src\n\nCreate a new build target for the camera metadata library to\ncompile the libcamera Android HAL implementation against it.\n\nSigned-off-by: Jacopo Mondi <jacopo@jmondi.org>\n---\n src/android/meson.build | 10 +\n src/android/metadata/camera_metadata.c | 1204 +++++++\n .../metadata/camera_metadata_tag_info.c | 2811 +++++++++++++++++\n 3 files changed, 4025 insertions(+)\n create mode 100644 src/android/meson.build\n create mode 100644 src/android/metadata/camera_metadata.c\n create mode 100644 src/android/metadata/camera_metadata_tag_info.c", "diff": "diff --git a/src/android/meson.build b/src/android/meson.build\nnew file mode 100644\nindex 000000000000..e988dfa9ee63\n--- /dev/null\n+++ b/src/android/meson.build\n@@ -0,0 +1,10 @@\n+android_camera_metadata_sources = files([\n+ 'metadata/camera_metadata.c',\n+])\n+\n+# Do not install by default as the target systems (Android, ChromeOS) already\n+# ship a libcamera_metadata.so library.\n+android_camera_metadata = shared_library('camera_metadata',\n+ android_camera_metadata_sources,\n+ install : false,\n+ include_directories : android_includes)\ndiff --git a/src/android/metadata/camera_metadata.c b/src/android/metadata/camera_metadata.c\nnew file mode 100644\nindex 000000000000..6bfd02da29c7\n--- /dev/null\n+++ b/src/android/metadata/camera_metadata.c\n@@ -0,0 +1,1204 @@\n+/*\n+ * Copyright (C) 2012 The Android Open Source Project\n+ *\n+ * Licensed under the Apache License, Version 2.0 (the \"License\");\n+ * you may not use this file except in compliance with the License.\n+ * You may obtain a copy of the License at\n+ *\n+ * http://www.apache.org/licenses/LICENSE-2.0\n+ *\n+ * Unless required by applicable law or agreed to in writing, software\n+ * distributed under the License is distributed on an \"AS IS\" BASIS,\n+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n+ * See the License for the specific language governing permissions and\n+ * limitations under the License.\n+ */\n+\n+#define LOG_TAG \"camera_metadata\"\n+\n+/*\n+ * Replace ALOGE() with a fprintf to stderr so that we don't need to\n+ * re-implement Android's logging system. The log/log.h header file is no\n+ * longer necessary once we removed dependency on ALOGE().\n+ */\n+#define ALOGE(...) fprintf(stderr, LOG_TAG __VA_ARGS__)\n+\n+#include <system/camera_metadata.h>\n+#include <camera_metadata_hidden.h>\n+\n+#include <assert.h>\n+#include <errno.h>\n+#include <inttypes.h>\n+#include <stddef.h> // for offsetof\n+#include <stdio.h>\n+#include <stdlib.h>\n+\n+#define OK 0\n+#define ERROR 1\n+#define NOT_FOUND (-ENOENT)\n+#define SN_EVENT_LOG_ID 0x534e4554\n+\n+#define ALIGN_TO(val, alignment) \\\n+ (((uintptr_t)(val) + ((alignment) - 1)) & ~((alignment) - 1))\n+\n+/**\n+ * A single metadata entry, storing an array of values of a given type. If the\n+ * array is no larger than 4 bytes in size, it is stored in the data.value[]\n+ * array; otherwise, it can found in the parent's data array at index\n+ * data.offset.\n+ */\n+#define ENTRY_ALIGNMENT ((size_t) 4)\n+typedef struct camera_metadata_buffer_entry {\n+ uint32_t tag;\n+ uint32_t count;\n+ union {\n+ uint32_t offset;\n+ uint8_t value[4];\n+ } data;\n+ uint8_t type;\n+ uint8_t reserved[3];\n+} camera_metadata_buffer_entry_t;\n+\n+typedef uint32_t metadata_uptrdiff_t;\n+typedef uint32_t metadata_size_t;\n+\n+/**\n+ * A packet of metadata. This is a list of entries, each of which may point to\n+ * its values stored at an offset in data.\n+ *\n+ * It is assumed by the utility functions that the memory layout of the packet\n+ * is as follows:\n+ *\n+ * |-----------------------------------------------|\n+ * | camera_metadata_t |\n+ * | |\n+ * |-----------------------------------------------|\n+ * | reserved for future expansion |\n+ * |-----------------------------------------------|\n+ * | camera_metadata_buffer_entry_t #0 |\n+ * |-----------------------------------------------|\n+ * | .... |\n+ * |-----------------------------------------------|\n+ * | camera_metadata_buffer_entry_t #entry_count-1 |\n+ * |-----------------------------------------------|\n+ * | free space for |\n+ * | (entry_capacity-entry_count) entries |\n+ * |-----------------------------------------------|\n+ * | start of camera_metadata.data |\n+ * | |\n+ * |-----------------------------------------------|\n+ * | free space for |\n+ * | (data_capacity-data_count) bytes |\n+ * |-----------------------------------------------|\n+ *\n+ * With the total length of the whole packet being camera_metadata.size bytes.\n+ *\n+ * In short, the entries and data are contiguous in memory after the metadata\n+ * header.\n+ */\n+#define METADATA_ALIGNMENT ((size_t) 4)\n+struct camera_metadata {\n+ metadata_size_t size;\n+ uint32_t version;\n+ uint32_t flags;\n+ metadata_size_t entry_count;\n+ metadata_size_t entry_capacity;\n+ metadata_uptrdiff_t entries_start; // Offset from camera_metadata\n+ metadata_size_t data_count;\n+ metadata_size_t data_capacity;\n+ metadata_uptrdiff_t data_start; // Offset from camera_metadata\n+ uint32_t padding; // padding to 8 bytes boundary\n+ metadata_vendor_id_t vendor_id;\n+};\n+\n+/**\n+ * A datum of metadata. This corresponds to camera_metadata_entry_t::data\n+ * with the difference that each element is not a pointer. We need to have a\n+ * non-pointer type description in order to figure out the largest alignment\n+ * requirement for data (DATA_ALIGNMENT).\n+ */\n+#define DATA_ALIGNMENT ((size_t) 8)\n+typedef union camera_metadata_data {\n+ uint8_t u8;\n+ int32_t i32;\n+ float f;\n+ int64_t i64;\n+ double d;\n+ camera_metadata_rational_t r;\n+} camera_metadata_data_t;\n+\n+_Static_assert(sizeof(metadata_size_t) == 4,\n+ \"Size of metadata_size_t must be 4\");\n+_Static_assert(sizeof(metadata_uptrdiff_t) == 4,\n+ \"Size of metadata_uptrdiff_t must be 4\");\n+_Static_assert(sizeof(metadata_vendor_id_t) == 8,\n+ \"Size of metadata_vendor_id_t must be 8\");\n+_Static_assert(sizeof(camera_metadata_data_t) == 8,\n+ \"Size of camera_metadata_data_t must be 8\");\n+\n+_Static_assert(offsetof(camera_metadata_buffer_entry_t, tag) == 0,\n+ \"Offset of tag must be 0\");\n+_Static_assert(offsetof(camera_metadata_buffer_entry_t, count) == 4,\n+ \"Offset of count must be 4\");\n+_Static_assert(offsetof(camera_metadata_buffer_entry_t, data) == 8,\n+ \"Offset of data must be 8\");\n+_Static_assert(offsetof(camera_metadata_buffer_entry_t, type) == 12,\n+ \"Offset of type must be 12\");\n+_Static_assert(sizeof(camera_metadata_buffer_entry_t) == 16,\n+ \"Size of camera_metadata_buffer_entry_t must be 16\");\n+\n+_Static_assert(offsetof(camera_metadata_t, size) == 0,\n+ \"Offset of size must be 0\");\n+_Static_assert(offsetof(camera_metadata_t, version) == 4,\n+ \"Offset of version must be 4\");\n+_Static_assert(offsetof(camera_metadata_t, flags) == 8,\n+ \"Offset of flags must be 8\");\n+_Static_assert(offsetof(camera_metadata_t, entry_count) == 12,\n+ \"Offset of entry_count must be 12\");\n+_Static_assert(offsetof(camera_metadata_t, entry_capacity) == 16,\n+ \"Offset of entry_capacity must be 16\");\n+_Static_assert(offsetof(camera_metadata_t, entries_start) == 20,\n+ \"Offset of entries_start must be 20\");\n+_Static_assert(offsetof(camera_metadata_t, data_count) == 24,\n+ \"Offset of data_count must be 24\");\n+_Static_assert(offsetof(camera_metadata_t, data_capacity) == 28,\n+ \"Offset of data_capacity must be 28\");\n+_Static_assert(offsetof(camera_metadata_t, data_start) == 32,\n+ \"Offset of data_start must be 32\");\n+_Static_assert(offsetof(camera_metadata_t, vendor_id) == 40,\n+ \"Offset of vendor_id must be 40\");\n+_Static_assert(sizeof(camera_metadata_t) == 48,\n+ \"Size of camera_metadata_t must be 48\");\n+\n+/**\n+ * The preferred alignment of a packet of camera metadata. In general,\n+ * this is the lowest common multiple of the constituents of a metadata\n+ * package, i.e, of DATA_ALIGNMENT and ENTRY_ALIGNMENT.\n+ */\n+#define MAX_ALIGNMENT(A, B) (((A) > (B)) ? (A) : (B))\n+#define METADATA_PACKET_ALIGNMENT \\\n+ MAX_ALIGNMENT(MAX_ALIGNMENT(DATA_ALIGNMENT, METADATA_ALIGNMENT), ENTRY_ALIGNMENT)\n+\n+/** Versioning information */\n+#define CURRENT_METADATA_VERSION 1\n+\n+/** Flag definitions */\n+#define FLAG_SORTED 0x00000001\n+\n+/** Tag information */\n+\n+typedef struct tag_info {\n+ const char *tag_name;\n+ uint8_t tag_type;\n+} tag_info_t;\n+\n+#include \"camera_metadata_tag_info.c\"\n+\n+const size_t camera_metadata_type_size[NUM_TYPES] = {\n+ [TYPE_BYTE] = sizeof(uint8_t),\n+ [TYPE_INT32] = sizeof(int32_t),\n+ [TYPE_FLOAT] = sizeof(float),\n+ [TYPE_INT64] = sizeof(int64_t),\n+ [TYPE_DOUBLE] = sizeof(double),\n+ [TYPE_RATIONAL] = sizeof(camera_metadata_rational_t)\n+};\n+\n+const char *camera_metadata_type_names[NUM_TYPES] = {\n+ [TYPE_BYTE] = \"byte\",\n+ [TYPE_INT32] = \"int32\",\n+ [TYPE_FLOAT] = \"float\",\n+ [TYPE_INT64] = \"int64\",\n+ [TYPE_DOUBLE] = \"double\",\n+ [TYPE_RATIONAL] = \"rational\"\n+};\n+\n+static camera_metadata_buffer_entry_t *get_entries(\n+ const camera_metadata_t *metadata) {\n+ return (camera_metadata_buffer_entry_t*)\n+ ((uint8_t*)metadata + metadata->entries_start);\n+}\n+\n+static uint8_t *get_data(const camera_metadata_t *metadata) {\n+ return (uint8_t*)metadata + metadata->data_start;\n+}\n+\n+size_t get_camera_metadata_alignment() {\n+ return METADATA_PACKET_ALIGNMENT;\n+}\n+\n+camera_metadata_t *allocate_copy_camera_metadata_checked(\n+ const camera_metadata_t *src,\n+ size_t src_size) {\n+\n+ if (src == NULL) {\n+ return NULL;\n+ }\n+\n+ if (src_size < sizeof(camera_metadata_t)) {\n+ ALOGE(\"%s: Source size too small!\", __FUNCTION__);\n+ // android_errorWriteLog(0x534e4554, \"67782345\");\n+ return NULL;\n+ }\n+\n+ void *buffer = malloc(src_size);\n+ memcpy(buffer, src, src_size);\n+\n+ camera_metadata_t *metadata = (camera_metadata_t*) buffer;\n+ if (validate_camera_metadata_structure(metadata, &src_size) != OK) {\n+ free(buffer);\n+ return NULL;\n+ }\n+\n+ return metadata;\n+}\n+\n+camera_metadata_t *allocate_camera_metadata(size_t entry_capacity,\n+ size_t data_capacity) {\n+\n+ size_t memory_needed = calculate_camera_metadata_size(entry_capacity,\n+ data_capacity);\n+ void *buffer = malloc(memory_needed);\n+ camera_metadata_t *metadata = place_camera_metadata(\n+ buffer, memory_needed, entry_capacity, data_capacity);\n+ if (!metadata) {\n+ /* This should not happen when memory_needed is the same\n+ * calculated in this function and in place_camera_metadata.\n+ */\n+ free(buffer);\n+ }\n+ return metadata;\n+}\n+\n+camera_metadata_t *place_camera_metadata(void *dst,\n+ size_t dst_size,\n+ size_t entry_capacity,\n+ size_t data_capacity) {\n+ if (dst == NULL) return NULL;\n+\n+ size_t memory_needed = calculate_camera_metadata_size(entry_capacity,\n+ data_capacity);\n+ if (memory_needed > dst_size) return NULL;\n+\n+ camera_metadata_t *metadata = (camera_metadata_t*)dst;\n+ metadata->version = CURRENT_METADATA_VERSION;\n+ metadata->flags = 0;\n+ metadata->entry_count = 0;\n+ metadata->entry_capacity = entry_capacity;\n+ metadata->entries_start =\n+ ALIGN_TO(sizeof(camera_metadata_t), ENTRY_ALIGNMENT);\n+ metadata->data_count = 0;\n+ metadata->data_capacity = data_capacity;\n+ metadata->size = memory_needed;\n+ size_t data_unaligned = (uint8_t*)(get_entries(metadata) +\n+ metadata->entry_capacity) - (uint8_t*)metadata;\n+ metadata->data_start = ALIGN_TO(data_unaligned, DATA_ALIGNMENT);\n+ metadata->vendor_id = CAMERA_METADATA_INVALID_VENDOR_ID;\n+\n+ assert(validate_camera_metadata_structure(metadata, NULL) == OK);\n+ return metadata;\n+}\n+void free_camera_metadata(camera_metadata_t *metadata) {\n+ free(metadata);\n+}\n+\n+size_t calculate_camera_metadata_size(size_t entry_count,\n+ size_t data_count) {\n+ size_t memory_needed = sizeof(camera_metadata_t);\n+ // Start entry list at aligned boundary\n+ memory_needed = ALIGN_TO(memory_needed, ENTRY_ALIGNMENT);\n+ memory_needed += sizeof(camera_metadata_buffer_entry_t[entry_count]);\n+ // Start buffer list at aligned boundary\n+ memory_needed = ALIGN_TO(memory_needed, DATA_ALIGNMENT);\n+ memory_needed += sizeof(uint8_t[data_count]);\n+ // Make sure camera metadata can be stacked in continuous memory\n+ memory_needed = ALIGN_TO(memory_needed, METADATA_PACKET_ALIGNMENT);\n+ return memory_needed;\n+}\n+\n+size_t get_camera_metadata_size(const camera_metadata_t *metadata) {\n+ if (metadata == NULL) return ERROR;\n+\n+ return metadata->size;\n+}\n+\n+size_t get_camera_metadata_compact_size(const camera_metadata_t *metadata) {\n+ if (metadata == NULL) return ERROR;\n+\n+ return calculate_camera_metadata_size(metadata->entry_count,\n+ metadata->data_count);\n+}\n+\n+size_t get_camera_metadata_entry_count(const camera_metadata_t *metadata) {\n+ return metadata->entry_count;\n+}\n+\n+size_t get_camera_metadata_entry_capacity(const camera_metadata_t *metadata) {\n+ return metadata->entry_capacity;\n+}\n+\n+size_t get_camera_metadata_data_count(const camera_metadata_t *metadata) {\n+ return metadata->data_count;\n+}\n+\n+size_t get_camera_metadata_data_capacity(const camera_metadata_t *metadata) {\n+ return metadata->data_capacity;\n+}\n+\n+camera_metadata_t* copy_camera_metadata(void *dst, size_t dst_size,\n+ const camera_metadata_t *src) {\n+ size_t memory_needed = get_camera_metadata_compact_size(src);\n+\n+ if (dst == NULL) return NULL;\n+ if (dst_size < memory_needed) return NULL;\n+\n+ camera_metadata_t *metadata =\n+ place_camera_metadata(dst, dst_size, src->entry_count, src->data_count);\n+\n+ metadata->flags = src->flags;\n+ metadata->entry_count = src->entry_count;\n+ metadata->data_count = src->data_count;\n+ metadata->vendor_id = src->vendor_id;\n+\n+ memcpy(get_entries(metadata), get_entries(src),\n+ sizeof(camera_metadata_buffer_entry_t[metadata->entry_count]));\n+ memcpy(get_data(metadata), get_data(src),\n+ sizeof(uint8_t[metadata->data_count]));\n+\n+ assert(validate_camera_metadata_structure(metadata, NULL) == OK);\n+ return metadata;\n+}\n+\n+// This method should be used when the camera metadata cannot be trusted. For example, when it's\n+// read from Parcel.\n+static int validate_and_calculate_camera_metadata_entry_data_size(size_t *data_size, uint8_t type,\n+ size_t data_count) {\n+ if (type >= NUM_TYPES) return ERROR;\n+\n+ // Check for overflow\n+ if (data_count != 0 &&\n+ camera_metadata_type_size[type] > (SIZE_MAX - DATA_ALIGNMENT + 1) / data_count) {\n+ // android_errorWriteLog(SN_EVENT_LOG_ID, \"30741779\");\n+ return ERROR;\n+ }\n+\n+ size_t data_bytes = data_count * camera_metadata_type_size[type];\n+\n+ if (data_size) {\n+ *data_size = data_bytes <= 4 ? 0 : ALIGN_TO(data_bytes, DATA_ALIGNMENT);\n+ }\n+\n+ return OK;\n+}\n+\n+size_t calculate_camera_metadata_entry_data_size(uint8_t type,\n+ size_t data_count) {\n+ if (type >= NUM_TYPES) return 0;\n+\n+ size_t data_bytes = data_count *\n+ camera_metadata_type_size[type];\n+\n+ return data_bytes <= 4 ? 0 : ALIGN_TO(data_bytes, DATA_ALIGNMENT);\n+}\n+\n+int validate_camera_metadata_structure(const camera_metadata_t *metadata,\n+ const size_t *expected_size) {\n+\n+ if (metadata == NULL) {\n+ ALOGE(\"%s: metadata is null!\", __FUNCTION__);\n+ return CAMERA_METADATA_VALIDATION_ERROR;\n+ }\n+\n+ uintptr_t aligned_ptr = ALIGN_TO(metadata, METADATA_PACKET_ALIGNMENT);\n+ const uintptr_t alignmentOffset = aligned_ptr - (uintptr_t) metadata;\n+\n+ // Check that the metadata pointer is well-aligned first.\n+ {\n+ static const struct {\n+ const char *name;\n+ size_t alignment;\n+ } alignments[] = {\n+ {\n+ .name = \"camera_metadata\",\n+ .alignment = METADATA_ALIGNMENT\n+ },\n+ {\n+ .name = \"camera_metadata_buffer_entry\",\n+ .alignment = ENTRY_ALIGNMENT\n+ },\n+ {\n+ .name = \"camera_metadata_data\",\n+ .alignment = DATA_ALIGNMENT\n+ },\n+ };\n+\n+ for (size_t i = 0; i < sizeof(alignments)/sizeof(alignments[0]); ++i) {\n+ uintptr_t aligned_ptr = ALIGN_TO((uintptr_t) metadata + alignmentOffset,\n+ alignments[i].alignment);\n+\n+ if ((uintptr_t)metadata + alignmentOffset != aligned_ptr) {\n+ ALOGE(\"%s: Metadata pointer is not aligned (actual %p, \"\n+ \"expected %p, offset %\" PRIuPTR \") to type %s\",\n+ __FUNCTION__, metadata,\n+ (void*)aligned_ptr, alignmentOffset, alignments[i].name);\n+ return CAMERA_METADATA_VALIDATION_ERROR;\n+ }\n+ }\n+ }\n+\n+ /**\n+ * Check that the metadata contents are correct\n+ */\n+\n+ if (expected_size != NULL && metadata->size > *expected_size) {\n+ ALOGE(\"%s: Metadata size (%\" PRIu32 \") should be <= expected size (%zu)\",\n+ __FUNCTION__, metadata->size, *expected_size);\n+ return CAMERA_METADATA_VALIDATION_ERROR;\n+ }\n+\n+ if (metadata->entry_count > metadata->entry_capacity) {\n+ ALOGE(\"%s: Entry count (%\" PRIu32 \") should be <= entry capacity \"\n+ \"(%\" PRIu32 \")\",\n+ __FUNCTION__, metadata->entry_count, metadata->entry_capacity);\n+ return CAMERA_METADATA_VALIDATION_ERROR;\n+ }\n+\n+ if (metadata->data_count > metadata->data_capacity) {\n+ ALOGE(\"%s: Data count (%\" PRIu32 \") should be <= data capacity \"\n+ \"(%\" PRIu32 \")\",\n+ __FUNCTION__, metadata->data_count, metadata->data_capacity);\n+ // android_errorWriteLog(SN_EVENT_LOG_ID, \"30591838\");\n+ return CAMERA_METADATA_VALIDATION_ERROR;\n+ }\n+\n+ const metadata_uptrdiff_t entries_end =\n+ metadata->entries_start + metadata->entry_capacity;\n+ if (entries_end < metadata->entries_start || // overflow check\n+ entries_end > metadata->data_start) {\n+\n+ ALOGE(\"%s: Entry start + capacity (%\" PRIu32 \") should be <= data start \"\n+ \"(%\" PRIu32 \")\",\n+ __FUNCTION__,\n+ (metadata->entries_start + metadata->entry_capacity),\n+ metadata->data_start);\n+ return CAMERA_METADATA_VALIDATION_ERROR;\n+ }\n+\n+ const metadata_uptrdiff_t data_end =\n+ metadata->data_start + metadata->data_capacity;\n+ if (data_end < metadata->data_start || // overflow check\n+ data_end > metadata->size) {\n+\n+ ALOGE(\"%s: Data start + capacity (%\" PRIu32 \") should be <= total size \"\n+ \"(%\" PRIu32 \")\",\n+ __FUNCTION__,\n+ (metadata->data_start + metadata->data_capacity),\n+ metadata->size);\n+ return CAMERA_METADATA_VALIDATION_ERROR;\n+ }\n+\n+ // Validate each entry\n+ const metadata_size_t entry_count = metadata->entry_count;\n+ camera_metadata_buffer_entry_t *entries = get_entries(metadata);\n+\n+ for (size_t i = 0; i < entry_count; ++i) {\n+\n+ if ((uintptr_t)&entries[i] + alignmentOffset !=\n+ ALIGN_TO((uintptr_t)&entries[i] + alignmentOffset, ENTRY_ALIGNMENT)) {\n+ ALOGE(\"%s: Entry index %zu had bad alignment (address %p),\"\n+ \" expected alignment %zu\",\n+ __FUNCTION__, i, &entries[i], ENTRY_ALIGNMENT);\n+ return CAMERA_METADATA_VALIDATION_ERROR;\n+ }\n+\n+ camera_metadata_buffer_entry_t entry = entries[i];\n+\n+ if (entry.type >= NUM_TYPES) {\n+ ALOGE(\"%s: Entry index %zu had a bad type %d\",\n+ __FUNCTION__, i, entry.type);\n+ return CAMERA_METADATA_VALIDATION_ERROR;\n+ }\n+\n+ // TODO: fix vendor_tag_ops across processes so we don't need to special\n+ // case vendor-specific tags\n+ uint32_t tag_section = entry.tag >> 16;\n+ int tag_type = get_local_camera_metadata_tag_type(entry.tag, metadata);\n+ if (tag_type != (int)entry.type && tag_section < VENDOR_SECTION) {\n+ ALOGE(\"%s: Entry index %zu had tag type %d, but the type was %d\",\n+ __FUNCTION__, i, tag_type, entry.type);\n+ return CAMERA_METADATA_VALIDATION_ERROR;\n+ }\n+\n+ size_t data_size;\n+ if (validate_and_calculate_camera_metadata_entry_data_size(&data_size, entry.type,\n+ entry.count) != OK) {\n+ ALOGE(\"%s: Entry data size is invalid. type: %u count: %u\", __FUNCTION__, entry.type,\n+ entry.count);\n+ return CAMERA_METADATA_VALIDATION_ERROR;\n+ }\n+\n+ if (data_size != 0) {\n+ camera_metadata_data_t *data =\n+ (camera_metadata_data_t*) (get_data(metadata) +\n+ entry.data.offset);\n+\n+ if ((uintptr_t)data + alignmentOffset !=\n+ ALIGN_TO((uintptr_t)data + alignmentOffset, DATA_ALIGNMENT)) {\n+ ALOGE(\"%s: Entry index %zu had bad data alignment (address %p),\"\n+ \" expected align %zu, (tag name %s, data size %zu)\",\n+ __FUNCTION__, i, data, DATA_ALIGNMENT,\n+ get_local_camera_metadata_tag_name(entry.tag, metadata) ?\n+ : \"unknown\", data_size);\n+ return CAMERA_METADATA_VALIDATION_ERROR;\n+ }\n+\n+ size_t data_entry_end = entry.data.offset + data_size;\n+ if (data_entry_end < entry.data.offset || // overflow check\n+ data_entry_end > metadata->data_capacity) {\n+\n+ ALOGE(\"%s: Entry index %zu data ends (%zu) beyond the capacity \"\n+ \"%\" PRIu32, __FUNCTION__, i, data_entry_end,\n+ metadata->data_capacity);\n+ return CAMERA_METADATA_VALIDATION_ERROR;\n+ }\n+\n+ } else if (entry.count == 0) {\n+ if (entry.data.offset != 0) {\n+ ALOGE(\"%s: Entry index %zu had 0 items, but offset was non-0 \"\n+ \"(%\" PRIu32 \"), tag name: %s\", __FUNCTION__, i, entry.data.offset,\n+ get_local_camera_metadata_tag_name(entry.tag, metadata) ? : \"unknown\");\n+ return CAMERA_METADATA_VALIDATION_ERROR;\n+ }\n+ } // else data stored inline, so we look at value which can be anything.\n+ }\n+\n+ if (alignmentOffset == 0) {\n+ return OK;\n+ }\n+ return CAMERA_METADATA_VALIDATION_SHIFTED;\n+}\n+\n+int append_camera_metadata(camera_metadata_t *dst,\n+ const camera_metadata_t *src) {\n+ if (dst == NULL || src == NULL ) return ERROR;\n+\n+ // Check for overflow\n+ if (src->entry_count + dst->entry_count < src->entry_count) return ERROR;\n+ if (src->data_count + dst->data_count < src->data_count) return ERROR;\n+ // Check for space\n+ if (dst->entry_capacity < src->entry_count + dst->entry_count) return ERROR;\n+ if (dst->data_capacity < src->data_count + dst->data_count) return ERROR;\n+\n+ if ((dst->vendor_id != CAMERA_METADATA_INVALID_VENDOR_ID) &&\n+ (src->vendor_id != CAMERA_METADATA_INVALID_VENDOR_ID)) {\n+ if (dst->vendor_id != src->vendor_id) {\n+ ALOGE(\"%s: Append for metadata from different vendors is\"\n+ \"not supported!\", __func__);\n+ return ERROR;\n+ }\n+ }\n+\n+ memcpy(get_entries(dst) + dst->entry_count, get_entries(src),\n+ sizeof(camera_metadata_buffer_entry_t[src->entry_count]));\n+ memcpy(get_data(dst) + dst->data_count, get_data(src),\n+ sizeof(uint8_t[src->data_count]));\n+ if (dst->data_count != 0) {\n+ camera_metadata_buffer_entry_t *entry = get_entries(dst) + dst->entry_count;\n+ for (size_t i = 0; i < src->entry_count; i++, entry++) {\n+ if ( calculate_camera_metadata_entry_data_size(entry->type,\n+ entry->count) > 0 ) {\n+ entry->data.offset += dst->data_count;\n+ }\n+ }\n+ }\n+ if (dst->entry_count == 0) {\n+ // Appending onto empty buffer, keep sorted state\n+ dst->flags |= src->flags & FLAG_SORTED;\n+ } else if (src->entry_count != 0) {\n+ // Both src, dst are nonempty, cannot assume sort remains\n+ dst->flags &= ~FLAG_SORTED;\n+ } else {\n+ // Src is empty, keep dst sorted state\n+ }\n+ dst->entry_count += src->entry_count;\n+ dst->data_count += src->data_count;\n+\n+ if (dst->vendor_id == CAMERA_METADATA_INVALID_VENDOR_ID) {\n+ dst->vendor_id = src->vendor_id;\n+ }\n+\n+ assert(validate_camera_metadata_structure(dst, NULL) == OK);\n+ return OK;\n+}\n+\n+camera_metadata_t *clone_camera_metadata(const camera_metadata_t *src) {\n+ int res;\n+ if (src == NULL) return NULL;\n+ camera_metadata_t *clone = allocate_camera_metadata(\n+ get_camera_metadata_entry_count(src),\n+ get_camera_metadata_data_count(src));\n+ if (clone != NULL) {\n+ res = append_camera_metadata(clone, src);\n+ if (res != OK) {\n+ free_camera_metadata(clone);\n+ clone = NULL;\n+ }\n+ }\n+ assert(validate_camera_metadata_structure(clone, NULL) == OK);\n+ return clone;\n+}\n+\n+static int add_camera_metadata_entry_raw(camera_metadata_t *dst,\n+ uint32_t tag,\n+ uint8_t type,\n+ const void *data,\n+ size_t data_count) {\n+\n+ if (dst == NULL) return ERROR;\n+ if (dst->entry_count == dst->entry_capacity) return ERROR;\n+ if (data_count && data == NULL) return ERROR;\n+\n+ size_t data_bytes =\n+ calculate_camera_metadata_entry_data_size(type, data_count);\n+ if (data_bytes + dst->data_count > dst->data_capacity) return ERROR;\n+\n+ size_t data_payload_bytes =\n+ data_count * camera_metadata_type_size[type];\n+ camera_metadata_buffer_entry_t *entry = get_entries(dst) + dst->entry_count;\n+ memset(entry, 0, sizeof(camera_metadata_buffer_entry_t));\n+ entry->tag = tag;\n+ entry->type = type;\n+ entry->count = data_count;\n+\n+ if (data_bytes == 0) {\n+ memcpy(entry->data.value, data,\n+ data_payload_bytes);\n+ } else {\n+ entry->data.offset = dst->data_count;\n+ memcpy(get_data(dst) + entry->data.offset, data,\n+ data_payload_bytes);\n+ dst->data_count += data_bytes;\n+ }\n+ dst->entry_count++;\n+ dst->flags &= ~FLAG_SORTED;\n+ assert(validate_camera_metadata_structure(dst, NULL) == OK);\n+ return OK;\n+}\n+\n+int add_camera_metadata_entry(camera_metadata_t *dst,\n+ uint32_t tag,\n+ const void *data,\n+ size_t data_count) {\n+\n+ int type = get_local_camera_metadata_tag_type(tag, dst);\n+ if (type == -1) {\n+ ALOGE(\"%s: Unknown tag %04x.\", __FUNCTION__, tag);\n+ return ERROR;\n+ }\n+\n+ return add_camera_metadata_entry_raw(dst,\n+ tag,\n+ type,\n+ data,\n+ data_count);\n+}\n+\n+static int compare_entry_tags(const void *p1, const void *p2) {\n+ uint32_t tag1 = ((camera_metadata_buffer_entry_t*)p1)->tag;\n+ uint32_t tag2 = ((camera_metadata_buffer_entry_t*)p2)->tag;\n+ return tag1 < tag2 ? -1 :\n+ tag1 == tag2 ? 0 :\n+ 1;\n+}\n+\n+int sort_camera_metadata(camera_metadata_t *dst) {\n+ if (dst == NULL) return ERROR;\n+ if (dst->flags & FLAG_SORTED) return OK;\n+\n+ qsort(get_entries(dst), dst->entry_count,\n+ sizeof(camera_metadata_buffer_entry_t),\n+ compare_entry_tags);\n+ dst->flags |= FLAG_SORTED;\n+\n+ assert(validate_camera_metadata_structure(dst, NULL) == OK);\n+ return OK;\n+}\n+\n+int get_camera_metadata_entry(camera_metadata_t *src,\n+ size_t index,\n+ camera_metadata_entry_t *entry) {\n+ if (src == NULL || entry == NULL) return ERROR;\n+ if (index >= src->entry_count) return ERROR;\n+\n+ camera_metadata_buffer_entry_t *buffer_entry = get_entries(src) + index;\n+\n+ entry->index = index;\n+ entry->tag = buffer_entry->tag;\n+ entry->type = buffer_entry->type;\n+ entry->count = buffer_entry->count;\n+ if (buffer_entry->count *\n+ camera_metadata_type_size[buffer_entry->type] > 4) {\n+ entry->data.u8 = get_data(src) + buffer_entry->data.offset;\n+ } else {\n+ entry->data.u8 = buffer_entry->data.value;\n+ }\n+ return OK;\n+}\n+\n+int get_camera_metadata_ro_entry(const camera_metadata_t *src,\n+ size_t index,\n+ camera_metadata_ro_entry_t *entry) {\n+ return get_camera_metadata_entry((camera_metadata_t*)src, index,\n+ (camera_metadata_entry_t*)entry);\n+}\n+\n+int find_camera_metadata_entry(camera_metadata_t *src,\n+ uint32_t tag,\n+ camera_metadata_entry_t *entry) {\n+ if (src == NULL) return ERROR;\n+\n+ uint32_t index;\n+ if (src->flags & FLAG_SORTED) {\n+ // Sorted entries, do a binary search\n+ camera_metadata_buffer_entry_t *search_entry = NULL;\n+ camera_metadata_buffer_entry_t key;\n+ key.tag = tag;\n+ search_entry = bsearch(&key,\n+ get_entries(src),\n+ src->entry_count,\n+ sizeof(camera_metadata_buffer_entry_t),\n+ compare_entry_tags);\n+ if (search_entry == NULL) return NOT_FOUND;\n+ index = search_entry - get_entries(src);\n+ } else {\n+ // Not sorted, linear search\n+ camera_metadata_buffer_entry_t *search_entry = get_entries(src);\n+ for (index = 0; index < src->entry_count; index++, search_entry++) {\n+ if (search_entry->tag == tag) {\n+ break;\n+ }\n+ }\n+ if (index == src->entry_count) return NOT_FOUND;\n+ }\n+\n+ return get_camera_metadata_entry(src, index,\n+ entry);\n+}\n+\n+int find_camera_metadata_ro_entry(const camera_metadata_t *src,\n+ uint32_t tag,\n+ camera_metadata_ro_entry_t *entry) {\n+ return find_camera_metadata_entry((camera_metadata_t*)src, tag,\n+ (camera_metadata_entry_t*)entry);\n+}\n+\n+\n+int delete_camera_metadata_entry(camera_metadata_t *dst,\n+ size_t index) {\n+ if (dst == NULL) return ERROR;\n+ if (index >= dst->entry_count) return ERROR;\n+\n+ camera_metadata_buffer_entry_t *entry = get_entries(dst) + index;\n+ size_t data_bytes = calculate_camera_metadata_entry_data_size(entry->type,\n+ entry->count);\n+\n+ if (data_bytes > 0) {\n+ // Shift data buffer to overwrite deleted data\n+ uint8_t *start = get_data(dst) + entry->data.offset;\n+ uint8_t *end = start + data_bytes;\n+ size_t length = dst->data_count - entry->data.offset - data_bytes;\n+ memmove(start, end, length);\n+\n+ // Update all entry indices to account for shift\n+ camera_metadata_buffer_entry_t *e = get_entries(dst);\n+ size_t i;\n+ for (i = 0; i < dst->entry_count; i++) {\n+ if (calculate_camera_metadata_entry_data_size(\n+ e->type, e->count) > 0 &&\n+ e->data.offset > entry->data.offset) {\n+ e->data.offset -= data_bytes;\n+ }\n+ ++e;\n+ }\n+ dst->data_count -= data_bytes;\n+ }\n+ // Shift entry array\n+ memmove(entry, entry + 1,\n+ sizeof(camera_metadata_buffer_entry_t) *\n+ (dst->entry_count - index - 1) );\n+ dst->entry_count -= 1;\n+\n+ assert(validate_camera_metadata_structure(dst, NULL) == OK);\n+ return OK;\n+}\n+\n+int update_camera_metadata_entry(camera_metadata_t *dst,\n+ size_t index,\n+ const void *data,\n+ size_t data_count,\n+ camera_metadata_entry_t *updated_entry) {\n+ if (dst == NULL) return ERROR;\n+ if (index >= dst->entry_count) return ERROR;\n+\n+ camera_metadata_buffer_entry_t *entry = get_entries(dst) + index;\n+\n+ size_t data_bytes =\n+ calculate_camera_metadata_entry_data_size(entry->type,\n+ data_count);\n+ size_t data_payload_bytes =\n+ data_count * camera_metadata_type_size[entry->type];\n+\n+ size_t entry_bytes =\n+ calculate_camera_metadata_entry_data_size(entry->type,\n+ entry->count);\n+ if (data_bytes != entry_bytes) {\n+ // May need to shift/add to data array\n+ if (dst->data_capacity < dst->data_count + data_bytes - entry_bytes) {\n+ // No room\n+ return ERROR;\n+ }\n+ if (entry_bytes != 0) {\n+ // Remove old data\n+ uint8_t *start = get_data(dst) + entry->data.offset;\n+ uint8_t *end = start + entry_bytes;\n+ size_t length = dst->data_count - entry->data.offset - entry_bytes;\n+ memmove(start, end, length);\n+ dst->data_count -= entry_bytes;\n+\n+ // Update all entry indices to account for shift\n+ camera_metadata_buffer_entry_t *e = get_entries(dst);\n+ size_t i;\n+ for (i = 0; i < dst->entry_count; i++) {\n+ if (calculate_camera_metadata_entry_data_size(\n+ e->type, e->count) > 0 &&\n+ e->data.offset > entry->data.offset) {\n+ e->data.offset -= entry_bytes;\n+ }\n+ ++e;\n+ }\n+ }\n+\n+ if (data_bytes != 0) {\n+ // Append new data\n+ entry->data.offset = dst->data_count;\n+\n+ memcpy(get_data(dst) + entry->data.offset, data, data_payload_bytes);\n+ dst->data_count += data_bytes;\n+ }\n+ } else if (data_bytes != 0) {\n+ // data size unchanged, reuse same data location\n+ memcpy(get_data(dst) + entry->data.offset, data, data_payload_bytes);\n+ }\n+\n+ if (data_bytes == 0) {\n+ // Data fits into entry\n+ memcpy(entry->data.value, data,\n+ data_payload_bytes);\n+ }\n+\n+ entry->count = data_count;\n+\n+ if (updated_entry != NULL) {\n+ get_camera_metadata_entry(dst,\n+ index,\n+ updated_entry);\n+ }\n+\n+ assert(validate_camera_metadata_structure(dst, NULL) == OK);\n+ return OK;\n+}\n+\n+static const vendor_tag_ops_t *vendor_tag_ops = NULL;\n+static const struct vendor_tag_cache_ops *vendor_cache_ops = NULL;\n+\n+// Declared in system/media/private/camera/include/camera_metadata_hidden.h\n+const char *get_local_camera_metadata_section_name_vendor_id(uint32_t tag,\n+ metadata_vendor_id_t id) {\n+ uint32_t tag_section = tag >> 16;\n+ if (tag_section >= VENDOR_SECTION && vendor_cache_ops != NULL &&\n+ id != CAMERA_METADATA_INVALID_VENDOR_ID) {\n+ return vendor_cache_ops->get_section_name(tag, id);\n+ } else if (tag_section >= VENDOR_SECTION && vendor_tag_ops != NULL) {\n+ return vendor_tag_ops->get_section_name(\n+ vendor_tag_ops,\n+ tag);\n+ }\n+ if (tag_section >= ANDROID_SECTION_COUNT) {\n+ return NULL;\n+ }\n+ return camera_metadata_section_names[tag_section];\n+}\n+\n+// Declared in system/media/private/camera/include/camera_metadata_hidden.h\n+const char *get_local_camera_metadata_tag_name_vendor_id(uint32_t tag,\n+ metadata_vendor_id_t id) {\n+ uint32_t tag_section = tag >> 16;\n+ if (tag_section >= VENDOR_SECTION && vendor_cache_ops != NULL &&\n+ id != CAMERA_METADATA_INVALID_VENDOR_ID) {\n+ return vendor_cache_ops->get_tag_name(tag, id);\n+ } else if (tag_section >= VENDOR_SECTION && vendor_tag_ops != NULL) {\n+ return vendor_tag_ops->get_tag_name(\n+ vendor_tag_ops,\n+ tag);\n+ }\n+ if (tag_section >= ANDROID_SECTION_COUNT ||\n+ tag >= camera_metadata_section_bounds[tag_section][1] ) {\n+ return NULL;\n+ }\n+ uint32_t tag_index = tag & 0xFFFF;\n+ return tag_info[tag_section][tag_index].tag_name;\n+}\n+\n+// Declared in system/media/private/camera/include/camera_metadata_hidden.h\n+int get_local_camera_metadata_tag_type_vendor_id(uint32_t tag,\n+ metadata_vendor_id_t id) {\n+ uint32_t tag_section = tag >> 16;\n+ if (tag_section >= VENDOR_SECTION && vendor_cache_ops != NULL &&\n+ id != CAMERA_METADATA_INVALID_VENDOR_ID) {\n+ return vendor_cache_ops->get_tag_type(tag, id);\n+ } else if (tag_section >= VENDOR_SECTION && vendor_tag_ops != NULL) {\n+ return vendor_tag_ops->get_tag_type(\n+ vendor_tag_ops,\n+ tag);\n+ }\n+ if (tag_section >= ANDROID_SECTION_COUNT ||\n+ tag >= camera_metadata_section_bounds[tag_section][1] ) {\n+ return -1;\n+ }\n+ uint32_t tag_index = tag & 0xFFFF;\n+ return tag_info[tag_section][tag_index].tag_type;\n+}\n+\n+const char *get_camera_metadata_section_name(uint32_t tag) {\n+ return get_local_camera_metadata_section_name(tag, NULL);\n+}\n+\n+const char *get_camera_metadata_tag_name(uint32_t tag) {\n+ return get_local_camera_metadata_tag_name(tag, NULL);\n+}\n+\n+int get_camera_metadata_tag_type(uint32_t tag) {\n+ return get_local_camera_metadata_tag_type(tag, NULL);\n+}\n+\n+const char *get_local_camera_metadata_section_name(uint32_t tag,\n+ const camera_metadata_t *meta) {\n+ metadata_vendor_id_t id = (NULL == meta) ? CAMERA_METADATA_INVALID_VENDOR_ID :\n+ meta->vendor_id;\n+\n+ return get_local_camera_metadata_section_name_vendor_id(tag, id);\n+}\n+\n+const char *get_local_camera_metadata_tag_name(uint32_t tag,\n+ const camera_metadata_t *meta) {\n+ metadata_vendor_id_t id = (NULL == meta) ? CAMERA_METADATA_INVALID_VENDOR_ID :\n+ meta->vendor_id;\n+\n+ return get_local_camera_metadata_tag_name_vendor_id(tag, id);\n+}\n+\n+int get_local_camera_metadata_tag_type(uint32_t tag,\n+ const camera_metadata_t *meta) {\n+ metadata_vendor_id_t id = (NULL == meta) ? CAMERA_METADATA_INVALID_VENDOR_ID :\n+ meta->vendor_id;\n+\n+ return get_local_camera_metadata_tag_type_vendor_id(tag, id);\n+}\n+\n+int set_camera_metadata_vendor_tag_ops(const vendor_tag_query_ops_t* ops) {\n+ // **DEPRECATED**\n+ (void) ops;\n+ ALOGE(\"%s: This function has been deprecated\", __FUNCTION__);\n+ return ERROR;\n+}\n+\n+// Declared in system/media/private/camera/include/camera_metadata_hidden.h\n+int set_camera_metadata_vendor_ops(const vendor_tag_ops_t* ops) {\n+ vendor_tag_ops = ops;\n+ return OK;\n+}\n+\n+// Declared in system/media/private/camera/include/camera_metadata_hidden.h\n+int set_camera_metadata_vendor_cache_ops(\n+ const struct vendor_tag_cache_ops *query_cache_ops) {\n+ vendor_cache_ops = query_cache_ops;\n+ return OK;\n+}\n+\n+// Declared in system/media/private/camera/include/camera_metadata_hidden.h\n+void set_camera_metadata_vendor_id(camera_metadata_t *meta,\n+ metadata_vendor_id_t id) {\n+ if (NULL != meta) {\n+ meta->vendor_id = id;\n+ }\n+}\n+\n+// Declared in system/media/private/camera/include/camera_metadata_hidden.h\n+metadata_vendor_id_t get_camera_metadata_vendor_id(\n+ const camera_metadata_t *meta) {\n+ metadata_vendor_id_t ret = CAMERA_METADATA_INVALID_VENDOR_ID;\n+\n+ if (NULL != meta) {\n+ ret = meta->vendor_id;\n+ }\n+\n+ return ret;\n+}\n+\n+static void print_data(int fd, const uint8_t *data_ptr, uint32_t tag, int type,\n+ int count,\n+ int indentation);\n+\n+void dump_camera_metadata(const camera_metadata_t *metadata,\n+ int fd,\n+ int verbosity) {\n+ dump_indented_camera_metadata(metadata, fd, verbosity, 0);\n+}\n+\n+void dump_indented_camera_metadata(const camera_metadata_t *metadata,\n+ int fd,\n+ int verbosity,\n+ int indentation) {\n+ if (metadata == NULL) {\n+ dprintf(fd, \"%*sDumping camera metadata array: Not allocated\\n\",\n+ indentation, \"\");\n+ return;\n+ }\n+ unsigned int i;\n+ dprintf(fd,\n+ \"%*sDumping camera metadata array: %\" PRIu32 \" / %\" PRIu32 \" entries, \"\n+ \"%\" PRIu32 \" / %\" PRIu32 \" bytes of extra data.\\n\", indentation, \"\",\n+ metadata->entry_count, metadata->entry_capacity,\n+ metadata->data_count, metadata->data_capacity);\n+ dprintf(fd, \"%*sVersion: %d, Flags: %08x\\n\",\n+ indentation + 2, \"\",\n+ metadata->version, metadata->flags);\n+ camera_metadata_buffer_entry_t *entry = get_entries(metadata);\n+ for (i=0; i < metadata->entry_count; i++, entry++) {\n+\n+ const char *tag_name, *tag_section;\n+ tag_section = get_local_camera_metadata_section_name(entry->tag, metadata);\n+ if (tag_section == NULL) {\n+ tag_section = \"unknownSection\";\n+ }\n+ tag_name = get_local_camera_metadata_tag_name(entry->tag, metadata);\n+ if (tag_name == NULL) {\n+ tag_name = \"unknownTag\";\n+ }\n+ const char *type_name;\n+ if (entry->type >= NUM_TYPES) {\n+ type_name = \"unknown\";\n+ } else {\n+ type_name = camera_metadata_type_names[entry->type];\n+ }\n+ dprintf(fd, \"%*s%s.%s (%05x): %s[%\" PRIu32 \"]\\n\",\n+ indentation + 2, \"\",\n+ tag_section,\n+ tag_name,\n+ entry->tag,\n+ type_name,\n+ entry->count);\n+\n+ if (verbosity < 1) continue;\n+\n+ if (entry->type >= NUM_TYPES) continue;\n+\n+ size_t type_size = camera_metadata_type_size[entry->type];\n+ uint8_t *data_ptr;\n+ if ( type_size * entry->count > 4 ) {\n+ if (entry->data.offset >= metadata->data_count) {\n+ ALOGE(\"%s: Malformed entry data offset: %\" PRIu32 \" (max %\" PRIu32 \")\",\n+ __FUNCTION__,\n+ entry->data.offset,\n+ metadata->data_count);\n+ continue;\n+ }\n+ data_ptr = get_data(metadata) + entry->data.offset;\n+ } else {\n+ data_ptr = entry->data.value;\n+ }\n+ int count = entry->count;\n+ if (verbosity < 2 && count > 16) count = 16;\n+\n+ print_data(fd, data_ptr, entry->tag, entry->type, count, indentation);\n+ }\n+}\n+\n+static void print_data(int fd, const uint8_t *data_ptr, uint32_t tag,\n+ int type, int count, int indentation) {\n+ static int values_per_line[NUM_TYPES] = {\n+ [TYPE_BYTE] = 16,\n+ [TYPE_INT32] = 4,\n+ [TYPE_FLOAT] = 8,\n+ [TYPE_INT64] = 2,\n+ [TYPE_DOUBLE] = 4,\n+ [TYPE_RATIONAL] = 2,\n+ };\n+ size_t type_size = camera_metadata_type_size[type];\n+ char value_string_tmp[CAMERA_METADATA_ENUM_STRING_MAX_SIZE];\n+ uint32_t value;\n+\n+ int lines = count / values_per_line[type];\n+ if (count % values_per_line[type] != 0) lines++;\n+\n+ int index = 0;\n+ int j, k;\n+ for (j = 0; j < lines; j++) {\n+ dprintf(fd, \"%*s[\", indentation + 4, \"\");\n+ for (k = 0;\n+ k < values_per_line[type] && count > 0;\n+ k++, count--, index += type_size) {\n+\n+ switch (type) {\n+ case TYPE_BYTE:\n+ value = *(data_ptr + index);\n+ if (camera_metadata_enum_snprint(tag,\n+ value,\n+ value_string_tmp,\n+ sizeof(value_string_tmp))\n+ == OK) {\n+ dprintf(fd, \"%s \", value_string_tmp);\n+ } else {\n+ dprintf(fd, \"%hhu \",\n+ *(data_ptr + index));\n+ }\n+ break;\n+ case TYPE_INT32:\n+ value =\n+ *(int32_t*)(data_ptr + index);\n+ if (camera_metadata_enum_snprint(tag,\n+ value,\n+ value_string_tmp,\n+ sizeof(value_string_tmp))\n+ == OK) {\n+ dprintf(fd, \"%s \", value_string_tmp);\n+ } else {\n+ dprintf(fd, \"%\" PRId32 \" \",\n+ *(int32_t*)(data_ptr + index));\n+ }\n+ break;\n+ case TYPE_FLOAT:\n+ dprintf(fd, \"%0.8f \",\n+ *(float*)(data_ptr + index));\n+ break;\n+ case TYPE_INT64:\n+ dprintf(fd, \"%\" PRId64 \" \",\n+ *(int64_t*)(data_ptr + index));\n+ break;\n+ case TYPE_DOUBLE:\n+ dprintf(fd, \"%0.8f \",\n+ *(double*)(data_ptr + index));\n+ break;\n+ case TYPE_RATIONAL: {\n+ int32_t numerator = *(int32_t*)(data_ptr + index);\n+ int32_t denominator = *(int32_t*)(data_ptr + index + 4);\n+ dprintf(fd, \"(%d / %d) \",\n+ numerator, denominator);\n+ break;\n+ }\n+ default:\n+ dprintf(fd, \"??? \");\n+ }\n+ }\n+ dprintf(fd, \"]\\n\");\n+ }\n+}\ndiff --git a/src/android/metadata/camera_metadata_tag_info.c b/src/android/metadata/camera_metadata_tag_info.c\nnew file mode 100644\nindex 000000000000..75ad1f4ca244\n--- /dev/null\n+++ b/src/android/metadata/camera_metadata_tag_info.c\n@@ -0,0 +1,2811 @@\n+/*\n+ * Copyright (C) 2012 The Android Open Source Project\n+ *\n+ * Licensed under the Apache License, Version 2.0 (the \"License\");\n+ * you may not use this file except in compliance with the License.\n+ * You may obtain a copy of the License at\n+ *\n+ * http://www.apache.org/licenses/LICENSE-2.0\n+ *\n+ * Unless required by applicable law or agreed to in writing, software\n+ * distributed under the License is distributed on an \"AS IS\" BASIS,\n+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n+ * See the License for the specific language governing permissions and\n+ * limitations under the License.\n+ */\n+\n+/**\n+ * !! Do not reference this file directly !!\n+ *\n+ * It is logically a part of camera_metadata.c. It is broken out for ease of\n+ * maintaining the tag info.\n+ *\n+ * Array assignments are done using specified-index syntax to keep things in\n+ * sync with camera_metadata_tags.h\n+ */\n+\n+/**\n+ * ! Do not edit this file directly !\n+ *\n+ * Generated automatically from camera_metadata_tag_info.mako\n+ */\n+\n+const char *camera_metadata_section_names[ANDROID_SECTION_COUNT] = {\n+ [ANDROID_COLOR_CORRECTION] = \"android.colorCorrection\",\n+ [ANDROID_CONTROL] = \"android.control\",\n+ [ANDROID_DEMOSAIC] = \"android.demosaic\",\n+ [ANDROID_EDGE] = \"android.edge\",\n+ [ANDROID_FLASH] = \"android.flash\",\n+ [ANDROID_FLASH_INFO] = \"android.flash.info\",\n+ [ANDROID_HOT_PIXEL] = \"android.hotPixel\",\n+ [ANDROID_JPEG] = \"android.jpeg\",\n+ [ANDROID_LENS] = \"android.lens\",\n+ [ANDROID_LENS_INFO] = \"android.lens.info\",\n+ [ANDROID_NOISE_REDUCTION] = \"android.noiseReduction\",\n+ [ANDROID_QUIRKS] = \"android.quirks\",\n+ [ANDROID_REQUEST] = \"android.request\",\n+ [ANDROID_SCALER] = \"android.scaler\",\n+ [ANDROID_SENSOR] = \"android.sensor\",\n+ [ANDROID_SENSOR_INFO] = \"android.sensor.info\",\n+ [ANDROID_SHADING] = \"android.shading\",\n+ [ANDROID_STATISTICS] = \"android.statistics\",\n+ [ANDROID_STATISTICS_INFO] = \"android.statistics.info\",\n+ [ANDROID_TONEMAP] = \"android.tonemap\",\n+ [ANDROID_LED] = \"android.led\",\n+ [ANDROID_INFO] = \"android.info\",\n+ [ANDROID_BLACK_LEVEL] = \"android.blackLevel\",\n+ [ANDROID_SYNC] = \"android.sync\",\n+ [ANDROID_REPROCESS] = \"android.reprocess\",\n+ [ANDROID_DEPTH] = \"android.depth\",\n+ [ANDROID_LOGICAL_MULTI_CAMERA] = \"android.logicalMultiCamera\",\n+ [ANDROID_DISTORTION_CORRECTION]\n+ = \"android.distortionCorrection\",\n+};\n+\n+unsigned int camera_metadata_section_bounds[ANDROID_SECTION_COUNT][2] = {\n+ [ANDROID_COLOR_CORRECTION] = { ANDROID_COLOR_CORRECTION_START,\n+ ANDROID_COLOR_CORRECTION_END },\n+ [ANDROID_CONTROL] = { ANDROID_CONTROL_START,\n+ ANDROID_CONTROL_END },\n+ [ANDROID_DEMOSAIC] = { ANDROID_DEMOSAIC_START,\n+ ANDROID_DEMOSAIC_END },\n+ [ANDROID_EDGE] = { ANDROID_EDGE_START,\n+ ANDROID_EDGE_END },\n+ [ANDROID_FLASH] = { ANDROID_FLASH_START,\n+ ANDROID_FLASH_END },\n+ [ANDROID_FLASH_INFO] = { ANDROID_FLASH_INFO_START,\n+ ANDROID_FLASH_INFO_END },\n+ [ANDROID_HOT_PIXEL] = { ANDROID_HOT_PIXEL_START,\n+ ANDROID_HOT_PIXEL_END },\n+ [ANDROID_JPEG] = { ANDROID_JPEG_START,\n+ ANDROID_JPEG_END },\n+ [ANDROID_LENS] = { ANDROID_LENS_START,\n+ ANDROID_LENS_END },\n+ [ANDROID_LENS_INFO] = { ANDROID_LENS_INFO_START,\n+ ANDROID_LENS_INFO_END },\n+ [ANDROID_NOISE_REDUCTION] = { ANDROID_NOISE_REDUCTION_START,\n+ ANDROID_NOISE_REDUCTION_END },\n+ [ANDROID_QUIRKS] = { ANDROID_QUIRKS_START,\n+ ANDROID_QUIRKS_END },\n+ [ANDROID_REQUEST] = { ANDROID_REQUEST_START,\n+ ANDROID_REQUEST_END },\n+ [ANDROID_SCALER] = { ANDROID_SCALER_START,\n+ ANDROID_SCALER_END },\n+ [ANDROID_SENSOR] = { ANDROID_SENSOR_START,\n+ ANDROID_SENSOR_END },\n+ [ANDROID_SENSOR_INFO] = { ANDROID_SENSOR_INFO_START,\n+ ANDROID_SENSOR_INFO_END },\n+ [ANDROID_SHADING] = { ANDROID_SHADING_START,\n+ ANDROID_SHADING_END },\n+ [ANDROID_STATISTICS] = { ANDROID_STATISTICS_START,\n+ ANDROID_STATISTICS_END },\n+ [ANDROID_STATISTICS_INFO] = { ANDROID_STATISTICS_INFO_START,\n+ ANDROID_STATISTICS_INFO_END },\n+ [ANDROID_TONEMAP] = { ANDROID_TONEMAP_START,\n+ ANDROID_TONEMAP_END },\n+ [ANDROID_LED] = { ANDROID_LED_START,\n+ ANDROID_LED_END },\n+ [ANDROID_INFO] = { ANDROID_INFO_START,\n+ ANDROID_INFO_END },\n+ [ANDROID_BLACK_LEVEL] = { ANDROID_BLACK_LEVEL_START,\n+ ANDROID_BLACK_LEVEL_END },\n+ [ANDROID_SYNC] = { ANDROID_SYNC_START,\n+ ANDROID_SYNC_END },\n+ [ANDROID_REPROCESS] = { ANDROID_REPROCESS_START,\n+ ANDROID_REPROCESS_END },\n+ [ANDROID_DEPTH] = { ANDROID_DEPTH_START,\n+ ANDROID_DEPTH_END },\n+ [ANDROID_LOGICAL_MULTI_CAMERA] = { ANDROID_LOGICAL_MULTI_CAMERA_START,\n+ ANDROID_LOGICAL_MULTI_CAMERA_END },\n+ [ANDROID_DISTORTION_CORRECTION]\n+ = { ANDROID_DISTORTION_CORRECTION_START,\n+ ANDROID_DISTORTION_CORRECTION_END },\n+};\n+\n+static tag_info_t android_color_correction[ANDROID_COLOR_CORRECTION_END -\n+ ANDROID_COLOR_CORRECTION_START] = {\n+ [ ANDROID_COLOR_CORRECTION_MODE - ANDROID_COLOR_CORRECTION_START ] =\n+ { \"mode\", TYPE_BYTE },\n+ [ ANDROID_COLOR_CORRECTION_TRANSFORM - ANDROID_COLOR_CORRECTION_START ] =\n+ { \"transform\", TYPE_RATIONAL\n+ },\n+ [ ANDROID_COLOR_CORRECTION_GAINS - ANDROID_COLOR_CORRECTION_START ] =\n+ { \"gains\", TYPE_FLOAT },\n+ [ ANDROID_COLOR_CORRECTION_ABERRATION_MODE - ANDROID_COLOR_CORRECTION_START ] =\n+ { \"aberrationMode\", TYPE_BYTE },\n+ [ ANDROID_COLOR_CORRECTION_AVAILABLE_ABERRATION_MODES - ANDROID_COLOR_CORRECTION_START ] =\n+ { \"availableAberrationModes\", TYPE_BYTE },\n+};\n+\n+static tag_info_t android_control[ANDROID_CONTROL_END -\n+ ANDROID_CONTROL_START] = {\n+ [ ANDROID_CONTROL_AE_ANTIBANDING_MODE - ANDROID_CONTROL_START ] =\n+ { \"aeAntibandingMode\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AE_EXPOSURE_COMPENSATION - ANDROID_CONTROL_START ] =\n+ { \"aeExposureCompensation\", TYPE_INT32 },\n+ [ ANDROID_CONTROL_AE_LOCK - ANDROID_CONTROL_START ] =\n+ { \"aeLock\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AE_MODE - ANDROID_CONTROL_START ] =\n+ { \"aeMode\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AE_REGIONS - ANDROID_CONTROL_START ] =\n+ { \"aeRegions\", TYPE_INT32 },\n+ [ ANDROID_CONTROL_AE_TARGET_FPS_RANGE - ANDROID_CONTROL_START ] =\n+ { \"aeTargetFpsRange\", TYPE_INT32 },\n+ [ ANDROID_CONTROL_AE_PRECAPTURE_TRIGGER - ANDROID_CONTROL_START ] =\n+ { \"aePrecaptureTrigger\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AF_MODE - ANDROID_CONTROL_START ] =\n+ { \"afMode\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AF_REGIONS - ANDROID_CONTROL_START ] =\n+ { \"afRegions\", TYPE_INT32 },\n+ [ ANDROID_CONTROL_AF_TRIGGER - ANDROID_CONTROL_START ] =\n+ { \"afTrigger\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AWB_LOCK - ANDROID_CONTROL_START ] =\n+ { \"awbLock\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AWB_MODE - ANDROID_CONTROL_START ] =\n+ { \"awbMode\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AWB_REGIONS - ANDROID_CONTROL_START ] =\n+ { \"awbRegions\", TYPE_INT32 },\n+ [ ANDROID_CONTROL_CAPTURE_INTENT - ANDROID_CONTROL_START ] =\n+ { \"captureIntent\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_EFFECT_MODE - ANDROID_CONTROL_START ] =\n+ { \"effectMode\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_MODE - ANDROID_CONTROL_START ] =\n+ { \"mode\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_SCENE_MODE - ANDROID_CONTROL_START ] =\n+ { \"sceneMode\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_VIDEO_STABILIZATION_MODE - ANDROID_CONTROL_START ] =\n+ { \"videoStabilizationMode\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AE_AVAILABLE_ANTIBANDING_MODES - ANDROID_CONTROL_START ] =\n+ { \"aeAvailableAntibandingModes\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AE_AVAILABLE_MODES - ANDROID_CONTROL_START ] =\n+ { \"aeAvailableModes\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AE_AVAILABLE_TARGET_FPS_RANGES - ANDROID_CONTROL_START ] =\n+ { \"aeAvailableTargetFpsRanges\", TYPE_INT32 },\n+ [ ANDROID_CONTROL_AE_COMPENSATION_RANGE - ANDROID_CONTROL_START ] =\n+ { \"aeCompensationRange\", TYPE_INT32 },\n+ [ ANDROID_CONTROL_AE_COMPENSATION_STEP - ANDROID_CONTROL_START ] =\n+ { \"aeCompensationStep\", TYPE_RATIONAL\n+ },\n+ [ ANDROID_CONTROL_AF_AVAILABLE_MODES - ANDROID_CONTROL_START ] =\n+ { \"afAvailableModes\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AVAILABLE_EFFECTS - ANDROID_CONTROL_START ] =\n+ { \"availableEffects\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AVAILABLE_SCENE_MODES - ANDROID_CONTROL_START ] =\n+ { \"availableSceneModes\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AVAILABLE_VIDEO_STABILIZATION_MODES - ANDROID_CONTROL_START ] =\n+ { \"availableVideoStabilizationModes\",\n+ TYPE_BYTE },\n+ [ ANDROID_CONTROL_AWB_AVAILABLE_MODES - ANDROID_CONTROL_START ] =\n+ { \"awbAvailableModes\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_MAX_REGIONS - ANDROID_CONTROL_START ] =\n+ { \"maxRegions\", TYPE_INT32 },\n+ [ ANDROID_CONTROL_SCENE_MODE_OVERRIDES - ANDROID_CONTROL_START ] =\n+ { \"sceneModeOverrides\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AE_PRECAPTURE_ID - ANDROID_CONTROL_START ] =\n+ { \"aePrecaptureId\", TYPE_INT32 },\n+ [ ANDROID_CONTROL_AE_STATE - ANDROID_CONTROL_START ] =\n+ { \"aeState\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AF_STATE - ANDROID_CONTROL_START ] =\n+ { \"afState\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AF_TRIGGER_ID - ANDROID_CONTROL_START ] =\n+ { \"afTriggerId\", TYPE_INT32 },\n+ [ ANDROID_CONTROL_AWB_STATE - ANDROID_CONTROL_START ] =\n+ { \"awbState\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AVAILABLE_HIGH_SPEED_VIDEO_CONFIGURATIONS - ANDROID_CONTROL_START ] =\n+ { \"availableHighSpeedVideoConfigurations\",\n+ TYPE_INT32 },\n+ [ ANDROID_CONTROL_AE_LOCK_AVAILABLE - ANDROID_CONTROL_START ] =\n+ { \"aeLockAvailable\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AWB_LOCK_AVAILABLE - ANDROID_CONTROL_START ] =\n+ { \"awbLockAvailable\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AVAILABLE_MODES - ANDROID_CONTROL_START ] =\n+ { \"availableModes\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_POST_RAW_SENSITIVITY_BOOST_RANGE - ANDROID_CONTROL_START ] =\n+ { \"postRawSensitivityBoostRange\", TYPE_INT32 },\n+ [ ANDROID_CONTROL_POST_RAW_SENSITIVITY_BOOST - ANDROID_CONTROL_START ] =\n+ { \"postRawSensitivityBoost\", TYPE_INT32 },\n+ [ ANDROID_CONTROL_ENABLE_ZSL - ANDROID_CONTROL_START ] =\n+ { \"enableZsl\", TYPE_BYTE },\n+ [ ANDROID_CONTROL_AF_SCENE_CHANGE - ANDROID_CONTROL_START ] =\n+ { \"afSceneChange\", TYPE_BYTE },\n+};\n+\n+static tag_info_t android_demosaic[ANDROID_DEMOSAIC_END -\n+ ANDROID_DEMOSAIC_START] = {\n+ [ ANDROID_DEMOSAIC_MODE - ANDROID_DEMOSAIC_START ] =\n+ { \"mode\", TYPE_BYTE },\n+};\n+\n+static tag_info_t android_edge[ANDROID_EDGE_END -\n+ ANDROID_EDGE_START] = {\n+ [ ANDROID_EDGE_MODE - ANDROID_EDGE_START ] =\n+ { \"mode\", TYPE_BYTE },\n+ [ ANDROID_EDGE_STRENGTH - ANDROID_EDGE_START ] =\n+ { \"strength\", TYPE_BYTE },\n+ [ ANDROID_EDGE_AVAILABLE_EDGE_MODES - ANDROID_EDGE_START ] =\n+ { \"availableEdgeModes\", TYPE_BYTE },\n+};\n+\n+static tag_info_t android_flash[ANDROID_FLASH_END -\n+ ANDROID_FLASH_START] = {\n+ [ ANDROID_FLASH_FIRING_POWER - ANDROID_FLASH_START ] =\n+ { \"firingPower\", TYPE_BYTE },\n+ [ ANDROID_FLASH_FIRING_TIME - ANDROID_FLASH_START ] =\n+ { \"firingTime\", TYPE_INT64 },\n+ [ ANDROID_FLASH_MODE - ANDROID_FLASH_START ] =\n+ { \"mode\", TYPE_BYTE },\n+ [ ANDROID_FLASH_COLOR_TEMPERATURE - ANDROID_FLASH_START ] =\n+ { \"colorTemperature\", TYPE_BYTE },\n+ [ ANDROID_FLASH_MAX_ENERGY - ANDROID_FLASH_START ] =\n+ { \"maxEnergy\", TYPE_BYTE },\n+ [ ANDROID_FLASH_STATE - ANDROID_FLASH_START ] =\n+ { \"state\", TYPE_BYTE },\n+};\n+\n+static tag_info_t android_flash_info[ANDROID_FLASH_INFO_END -\n+ ANDROID_FLASH_INFO_START] = {\n+ [ ANDROID_FLASH_INFO_AVAILABLE - ANDROID_FLASH_INFO_START ] =\n+ { \"available\", TYPE_BYTE },\n+ [ ANDROID_FLASH_INFO_CHARGE_DURATION - ANDROID_FLASH_INFO_START ] =\n+ { \"chargeDuration\", TYPE_INT64 },\n+};\n+\n+static tag_info_t android_hot_pixel[ANDROID_HOT_PIXEL_END -\n+ ANDROID_HOT_PIXEL_START] = {\n+ [ ANDROID_HOT_PIXEL_MODE - ANDROID_HOT_PIXEL_START ] =\n+ { \"mode\", TYPE_BYTE },\n+ [ ANDROID_HOT_PIXEL_AVAILABLE_HOT_PIXEL_MODES - ANDROID_HOT_PIXEL_START ] =\n+ { \"availableHotPixelModes\", TYPE_BYTE },\n+};\n+\n+static tag_info_t android_jpeg[ANDROID_JPEG_END -\n+ ANDROID_JPEG_START] = {\n+ [ ANDROID_JPEG_GPS_COORDINATES - ANDROID_JPEG_START ] =\n+ { \"gpsCoordinates\", TYPE_DOUBLE },\n+ [ ANDROID_JPEG_GPS_PROCESSING_METHOD - ANDROID_JPEG_START ] =\n+ { \"gpsProcessingMethod\", TYPE_BYTE },\n+ [ ANDROID_JPEG_GPS_TIMESTAMP - ANDROID_JPEG_START ] =\n+ { \"gpsTimestamp\", TYPE_INT64 },\n+ [ ANDROID_JPEG_ORIENTATION - ANDROID_JPEG_START ] =\n+ { \"orientation\", TYPE_INT32 },\n+ [ ANDROID_JPEG_QUALITY - ANDROID_JPEG_START ] =\n+ { \"quality\", TYPE_BYTE },\n+ [ ANDROID_JPEG_THUMBNAIL_QUALITY - ANDROID_JPEG_START ] =\n+ { \"thumbnailQuality\", TYPE_BYTE },\n+ [ ANDROID_JPEG_THUMBNAIL_SIZE - ANDROID_JPEG_START ] =\n+ { \"thumbnailSize\", TYPE_INT32 },\n+ [ ANDROID_JPEG_AVAILABLE_THUMBNAIL_SIZES - ANDROID_JPEG_START ] =\n+ { \"availableThumbnailSizes\", TYPE_INT32 },\n+ [ ANDROID_JPEG_MAX_SIZE - ANDROID_JPEG_START ] =\n+ { \"maxSize\", TYPE_INT32 },\n+ [ ANDROID_JPEG_SIZE - ANDROID_JPEG_START ] =\n+ { \"size\", TYPE_INT32 },\n+};\n+\n+static tag_info_t android_lens[ANDROID_LENS_END -\n+ ANDROID_LENS_START] = {\n+ [ ANDROID_LENS_APERTURE - ANDROID_LENS_START ] =\n+ { \"aperture\", TYPE_FLOAT },\n+ [ ANDROID_LENS_FILTER_DENSITY - ANDROID_LENS_START ] =\n+ { \"filterDensity\", TYPE_FLOAT },\n+ [ ANDROID_LENS_FOCAL_LENGTH - ANDROID_LENS_START ] =\n+ { \"focalLength\", TYPE_FLOAT },\n+ [ ANDROID_LENS_FOCUS_DISTANCE - ANDROID_LENS_START ] =\n+ { \"focusDistance\", TYPE_FLOAT },\n+ [ ANDROID_LENS_OPTICAL_STABILIZATION_MODE - ANDROID_LENS_START ] =\n+ { \"opticalStabilizationMode\", TYPE_BYTE },\n+ [ ANDROID_LENS_FACING - ANDROID_LENS_START ] =\n+ { \"facing\", TYPE_BYTE },\n+ [ ANDROID_LENS_POSE_ROTATION - ANDROID_LENS_START ] =\n+ { \"poseRotation\", TYPE_FLOAT },\n+ [ ANDROID_LENS_POSE_TRANSLATION - ANDROID_LENS_START ] =\n+ { \"poseTranslation\", TYPE_FLOAT },\n+ [ ANDROID_LENS_FOCUS_RANGE - ANDROID_LENS_START ] =\n+ { \"focusRange\", TYPE_FLOAT },\n+ [ ANDROID_LENS_STATE - ANDROID_LENS_START ] =\n+ { \"state\", TYPE_BYTE },\n+ [ ANDROID_LENS_INTRINSIC_CALIBRATION - ANDROID_LENS_START ] =\n+ { \"intrinsicCalibration\", TYPE_FLOAT },\n+ [ ANDROID_LENS_RADIAL_DISTORTION - ANDROID_LENS_START ] =\n+ { \"radialDistortion\", TYPE_FLOAT },\n+ [ ANDROID_LENS_POSE_REFERENCE - ANDROID_LENS_START ] =\n+ { \"poseReference\", TYPE_BYTE },\n+ [ ANDROID_LENS_DISTORTION - ANDROID_LENS_START ] =\n+ { \"distortion\", TYPE_FLOAT },\n+};\n+\n+static tag_info_t android_lens_info[ANDROID_LENS_INFO_END -\n+ ANDROID_LENS_INFO_START] = {\n+ [ ANDROID_LENS_INFO_AVAILABLE_APERTURES - ANDROID_LENS_INFO_START ] =\n+ { \"availableApertures\", TYPE_FLOAT },\n+ [ ANDROID_LENS_INFO_AVAILABLE_FILTER_DENSITIES - ANDROID_LENS_INFO_START ] =\n+ { \"availableFilterDensities\", TYPE_FLOAT },\n+ [ ANDROID_LENS_INFO_AVAILABLE_FOCAL_LENGTHS - ANDROID_LENS_INFO_START ] =\n+ { \"availableFocalLengths\", TYPE_FLOAT },\n+ [ ANDROID_LENS_INFO_AVAILABLE_OPTICAL_STABILIZATION - ANDROID_LENS_INFO_START ] =\n+ { \"availableOpticalStabilization\", TYPE_BYTE },\n+ [ ANDROID_LENS_INFO_HYPERFOCAL_DISTANCE - ANDROID_LENS_INFO_START ] =\n+ { \"hyperfocalDistance\", TYPE_FLOAT },\n+ [ ANDROID_LENS_INFO_MINIMUM_FOCUS_DISTANCE - ANDROID_LENS_INFO_START ] =\n+ { \"minimumFocusDistance\", TYPE_FLOAT },\n+ [ ANDROID_LENS_INFO_SHADING_MAP_SIZE - ANDROID_LENS_INFO_START ] =\n+ { \"shadingMapSize\", TYPE_INT32 },\n+ [ ANDROID_LENS_INFO_FOCUS_DISTANCE_CALIBRATION - ANDROID_LENS_INFO_START ] =\n+ { \"focusDistanceCalibration\", TYPE_BYTE },\n+};\n+\n+static tag_info_t android_noise_reduction[ANDROID_NOISE_REDUCTION_END -\n+ ANDROID_NOISE_REDUCTION_START] = {\n+ [ ANDROID_NOISE_REDUCTION_MODE - ANDROID_NOISE_REDUCTION_START ] =\n+ { \"mode\", TYPE_BYTE },\n+ [ ANDROID_NOISE_REDUCTION_STRENGTH - ANDROID_NOISE_REDUCTION_START ] =\n+ { \"strength\", TYPE_BYTE },\n+ [ ANDROID_NOISE_REDUCTION_AVAILABLE_NOISE_REDUCTION_MODES - ANDROID_NOISE_REDUCTION_START ] =\n+ { \"availableNoiseReductionModes\", TYPE_BYTE },\n+};\n+\n+static tag_info_t android_quirks[ANDROID_QUIRKS_END -\n+ ANDROID_QUIRKS_START] = {\n+ [ ANDROID_QUIRKS_METERING_CROP_REGION - ANDROID_QUIRKS_START ] =\n+ { \"meteringCropRegion\", TYPE_BYTE },\n+ [ ANDROID_QUIRKS_TRIGGER_AF_WITH_AUTO - ANDROID_QUIRKS_START ] =\n+ { \"triggerAfWithAuto\", TYPE_BYTE },\n+ [ ANDROID_QUIRKS_USE_ZSL_FORMAT - ANDROID_QUIRKS_START ] =\n+ { \"useZslFormat\", TYPE_BYTE },\n+ [ ANDROID_QUIRKS_USE_PARTIAL_RESULT - ANDROID_QUIRKS_START ] =\n+ { \"usePartialResult\", TYPE_BYTE },\n+ [ ANDROID_QUIRKS_PARTIAL_RESULT - ANDROID_QUIRKS_START ] =\n+ { \"partialResult\", TYPE_BYTE },\n+};\n+\n+static tag_info_t android_request[ANDROID_REQUEST_END -\n+ ANDROID_REQUEST_START] = {\n+ [ ANDROID_REQUEST_FRAME_COUNT - ANDROID_REQUEST_START ] =\n+ { \"frameCount\", TYPE_INT32 },\n+ [ ANDROID_REQUEST_ID - ANDROID_REQUEST_START ] =\n+ { \"id\", TYPE_INT32 },\n+ [ ANDROID_REQUEST_INPUT_STREAMS - ANDROID_REQUEST_START ] =\n+ { \"inputStreams\", TYPE_INT32 },\n+ [ ANDROID_REQUEST_METADATA_MODE - ANDROID_REQUEST_START ] =\n+ { \"metadataMode\", TYPE_BYTE },\n+ [ ANDROID_REQUEST_OUTPUT_STREAMS - ANDROID_REQUEST_START ] =\n+ { \"outputStreams\", TYPE_INT32 },\n+ [ ANDROID_REQUEST_TYPE - ANDROID_REQUEST_START ] =\n+ { \"type\", TYPE_BYTE },\n+ [ ANDROID_REQUEST_MAX_NUM_OUTPUT_STREAMS - ANDROID_REQUEST_START ] =\n+ { \"maxNumOutputStreams\", TYPE_INT32 },\n+ [ ANDROID_REQUEST_MAX_NUM_REPROCESS_STREAMS - ANDROID_REQUEST_START ] =\n+ { \"maxNumReprocessStreams\", TYPE_INT32 },\n+ [ ANDROID_REQUEST_MAX_NUM_INPUT_STREAMS - ANDROID_REQUEST_START ] =\n+ { \"maxNumInputStreams\", TYPE_INT32 },\n+ [ ANDROID_REQUEST_PIPELINE_DEPTH - ANDROID_REQUEST_START ] =\n+ { \"pipelineDepth\", TYPE_BYTE },\n+ [ ANDROID_REQUEST_PIPELINE_MAX_DEPTH - ANDROID_REQUEST_START ] =\n+ { \"pipelineMaxDepth\", TYPE_BYTE },\n+ [ ANDROID_REQUEST_PARTIAL_RESULT_COUNT - ANDROID_REQUEST_START ] =\n+ { \"partialResultCount\", TYPE_INT32 },\n+ [ ANDROID_REQUEST_AVAILABLE_CAPABILITIES - ANDROID_REQUEST_START ] =\n+ { \"availableCapabilities\", TYPE_BYTE },\n+ [ ANDROID_REQUEST_AVAILABLE_REQUEST_KEYS - ANDROID_REQUEST_START ] =\n+ { \"availableRequestKeys\", TYPE_INT32 },\n+ [ ANDROID_REQUEST_AVAILABLE_RESULT_KEYS - ANDROID_REQUEST_START ] =\n+ { \"availableResultKeys\", TYPE_INT32 },\n+ [ ANDROID_REQUEST_AVAILABLE_CHARACTERISTICS_KEYS - ANDROID_REQUEST_START ] =\n+ { \"availableCharacteristicsKeys\", TYPE_INT32 },\n+ [ ANDROID_REQUEST_AVAILABLE_SESSION_KEYS - ANDROID_REQUEST_START ] =\n+ { \"availableSessionKeys\", TYPE_INT32 },\n+ [ ANDROID_REQUEST_AVAILABLE_PHYSICAL_CAMERA_REQUEST_KEYS - ANDROID_REQUEST_START ] =\n+ { \"availablePhysicalCameraRequestKeys\",\n+ TYPE_INT32 },\n+};\n+\n+static tag_info_t android_scaler[ANDROID_SCALER_END -\n+ ANDROID_SCALER_START] = {\n+ [ ANDROID_SCALER_CROP_REGION - ANDROID_SCALER_START ] =\n+ { \"cropRegion\", TYPE_INT32 },\n+ [ ANDROID_SCALER_AVAILABLE_FORMATS - ANDROID_SCALER_START ] =\n+ { \"availableFormats\", TYPE_INT32 },\n+ [ ANDROID_SCALER_AVAILABLE_JPEG_MIN_DURATIONS - ANDROID_SCALER_START ] =\n+ { \"availableJpegMinDurations\", TYPE_INT64 },\n+ [ ANDROID_SCALER_AVAILABLE_JPEG_SIZES - ANDROID_SCALER_START ] =\n+ { \"availableJpegSizes\", TYPE_INT32 },\n+ [ ANDROID_SCALER_AVAILABLE_MAX_DIGITAL_ZOOM - ANDROID_SCALER_START ] =\n+ { \"availableMaxDigitalZoom\", TYPE_FLOAT },\n+ [ ANDROID_SCALER_AVAILABLE_PROCESSED_MIN_DURATIONS - ANDROID_SCALER_START ] =\n+ { \"availableProcessedMinDurations\",\n+ TYPE_INT64 },\n+ [ ANDROID_SCALER_AVAILABLE_PROCESSED_SIZES - ANDROID_SCALER_START ] =\n+ { \"availableProcessedSizes\", TYPE_INT32 },\n+ [ ANDROID_SCALER_AVAILABLE_RAW_MIN_DURATIONS - ANDROID_SCALER_START ] =\n+ { \"availableRawMinDurations\", TYPE_INT64 },\n+ [ ANDROID_SCALER_AVAILABLE_RAW_SIZES - ANDROID_SCALER_START ] =\n+ { \"availableRawSizes\", TYPE_INT32 },\n+ [ ANDROID_SCALER_AVAILABLE_INPUT_OUTPUT_FORMATS_MAP - ANDROID_SCALER_START ] =\n+ { \"availableInputOutputFormatsMap\",\n+ TYPE_INT32 },\n+ [ ANDROID_SCALER_AVAILABLE_STREAM_CONFIGURATIONS - ANDROID_SCALER_START ] =\n+ { \"availableStreamConfigurations\", TYPE_INT32 },\n+ [ ANDROID_SCALER_AVAILABLE_MIN_FRAME_DURATIONS - ANDROID_SCALER_START ] =\n+ { \"availableMinFrameDurations\", TYPE_INT64 },\n+ [ ANDROID_SCALER_AVAILABLE_STALL_DURATIONS - ANDROID_SCALER_START ] =\n+ { \"availableStallDurations\", TYPE_INT64 },\n+ [ ANDROID_SCALER_CROPPING_TYPE - ANDROID_SCALER_START ] =\n+ { \"croppingType\", TYPE_BYTE },\n+};\n+\n+static tag_info_t android_sensor[ANDROID_SENSOR_END -\n+ ANDROID_SENSOR_START] = {\n+ [ ANDROID_SENSOR_EXPOSURE_TIME - ANDROID_SENSOR_START ] =\n+ { \"exposureTime\", TYPE_INT64 },\n+ [ ANDROID_SENSOR_FRAME_DURATION - ANDROID_SENSOR_START ] =\n+ { \"frameDuration\", TYPE_INT64 },\n+ [ ANDROID_SENSOR_SENSITIVITY - ANDROID_SENSOR_START ] =\n+ { \"sensitivity\", TYPE_INT32 },\n+ [ ANDROID_SENSOR_REFERENCE_ILLUMINANT1 - ANDROID_SENSOR_START ] =\n+ { \"referenceIlluminant1\", TYPE_BYTE },\n+ [ ANDROID_SENSOR_REFERENCE_ILLUMINANT2 - ANDROID_SENSOR_START ] =\n+ { \"referenceIlluminant2\", TYPE_BYTE },\n+ [ ANDROID_SENSOR_CALIBRATION_TRANSFORM1 - ANDROID_SENSOR_START ] =\n+ { \"calibrationTransform1\", TYPE_RATIONAL\n+ },\n+ [ ANDROID_SENSOR_CALIBRATION_TRANSFORM2 - ANDROID_SENSOR_START ] =\n+ { \"calibrationTransform2\", TYPE_RATIONAL\n+ },\n+ [ ANDROID_SENSOR_COLOR_TRANSFORM1 - ANDROID_SENSOR_START ] =\n+ { \"colorTransform1\", TYPE_RATIONAL\n+ },\n+ [ ANDROID_SENSOR_COLOR_TRANSFORM2 - ANDROID_SENSOR_START ] =\n+ { \"colorTransform2\", TYPE_RATIONAL\n+ },\n+ [ ANDROID_SENSOR_FORWARD_MATRIX1 - ANDROID_SENSOR_START ] =\n+ { \"forwardMatrix1\", TYPE_RATIONAL\n+ },\n+ [ ANDROID_SENSOR_FORWARD_MATRIX2 - ANDROID_SENSOR_START ] =\n+ { \"forwardMatrix2\", TYPE_RATIONAL\n+ },\n+ [ ANDROID_SENSOR_BASE_GAIN_FACTOR - ANDROID_SENSOR_START ] =\n+ { \"baseGainFactor\", TYPE_RATIONAL\n+ },\n+ [ ANDROID_SENSOR_BLACK_LEVEL_PATTERN - ANDROID_SENSOR_START ] =\n+ { \"blackLevelPattern\", TYPE_INT32 },\n+ [ ANDROID_SENSOR_MAX_ANALOG_SENSITIVITY - ANDROID_SENSOR_START ] =\n+ { \"maxAnalogSensitivity\", TYPE_INT32 },\n+ [ ANDROID_SENSOR_ORIENTATION - ANDROID_SENSOR_START ] =\n+ { \"orientation\", TYPE_INT32 },\n+ [ ANDROID_SENSOR_PROFILE_HUE_SAT_MAP_DIMENSIONS - ANDROID_SENSOR_START ] =\n+ { \"profileHueSatMapDimensions\", TYPE_INT32 },\n+ [ ANDROID_SENSOR_TIMESTAMP - ANDROID_SENSOR_START ] =\n+ { \"timestamp\", TYPE_INT64 },\n+ [ ANDROID_SENSOR_TEMPERATURE - ANDROID_SENSOR_START ] =\n+ { \"temperature\", TYPE_FLOAT },\n+ [ ANDROID_SENSOR_NEUTRAL_COLOR_POINT - ANDROID_SENSOR_START ] =\n+ { \"neutralColorPoint\", TYPE_RATIONAL\n+ },\n+ [ ANDROID_SENSOR_NOISE_PROFILE - ANDROID_SENSOR_START ] =\n+ { \"noiseProfile\", TYPE_DOUBLE },\n+ [ ANDROID_SENSOR_PROFILE_HUE_SAT_MAP - ANDROID_SENSOR_START ] =\n+ { \"profileHueSatMap\", TYPE_FLOAT },\n+ [ ANDROID_SENSOR_PROFILE_TONE_CURVE - ANDROID_SENSOR_START ] =\n+ { \"profileToneCurve\", TYPE_FLOAT },\n+ [ ANDROID_SENSOR_GREEN_SPLIT - ANDROID_SENSOR_START ] =\n+ { \"greenSplit\", TYPE_FLOAT },\n+ [ ANDROID_SENSOR_TEST_PATTERN_DATA - ANDROID_SENSOR_START ] =\n+ { \"testPatternData\", TYPE_INT32 },\n+ [ ANDROID_SENSOR_TEST_PATTERN_MODE - ANDROID_SENSOR_START ] =\n+ { \"testPatternMode\", TYPE_INT32 },\n+ [ ANDROID_SENSOR_AVAILABLE_TEST_PATTERN_MODES - ANDROID_SENSOR_START ] =\n+ { \"availableTestPatternModes\", TYPE_INT32 },\n+ [ ANDROID_SENSOR_ROLLING_SHUTTER_SKEW - ANDROID_SENSOR_START ] =\n+ { \"rollingShutterSkew\", TYPE_INT64 },\n+ [ ANDROID_SENSOR_OPTICAL_BLACK_REGIONS - ANDROID_SENSOR_START ] =\n+ { \"opticalBlackRegions\", TYPE_INT32 },\n+ [ ANDROID_SENSOR_DYNAMIC_BLACK_LEVEL - ANDROID_SENSOR_START ] =\n+ { \"dynamicBlackLevel\", TYPE_FLOAT },\n+ [ ANDROID_SENSOR_DYNAMIC_WHITE_LEVEL - ANDROID_SENSOR_START ] =\n+ { \"dynamicWhiteLevel\", TYPE_INT32 },\n+ [ ANDROID_SENSOR_OPAQUE_RAW_SIZE - ANDROID_SENSOR_START ] =\n+ { \"opaqueRawSize\", TYPE_INT32 },\n+};\n+\n+static tag_info_t android_sensor_info[ANDROID_SENSOR_INFO_END -\n+ ANDROID_SENSOR_INFO_START] = {\n+ [ ANDROID_SENSOR_INFO_ACTIVE_ARRAY_SIZE - ANDROID_SENSOR_INFO_START ] =\n+ { \"activeArraySize\", TYPE_INT32 },\n+ [ ANDROID_SENSOR_INFO_SENSITIVITY_RANGE - ANDROID_SENSOR_INFO_START ] =\n+ { \"sensitivityRange\", TYPE_INT32 },\n+ [ ANDROID_SENSOR_INFO_COLOR_FILTER_ARRANGEMENT - ANDROID_SENSOR_INFO_START ] =\n+ { \"colorFilterArrangement\", TYPE_BYTE },\n+ [ ANDROID_SENSOR_INFO_EXPOSURE_TIME_RANGE - ANDROID_SENSOR_INFO_START ] =\n+ { \"exposureTimeRange\", TYPE_INT64 },\n+ [ ANDROID_SENSOR_INFO_MAX_FRAME_DURATION - ANDROID_SENSOR_INFO_START ] =\n+ { \"maxFrameDuration\", TYPE_INT64 },\n+ [ ANDROID_SENSOR_INFO_PHYSICAL_SIZE - ANDROID_SENSOR_INFO_START ] =\n+ { \"physicalSize\", TYPE_FLOAT },\n+ [ ANDROID_SENSOR_INFO_PIXEL_ARRAY_SIZE - ANDROID_SENSOR_INFO_START ] =\n+ { \"pixelArraySize\", TYPE_INT32 },\n+ [ ANDROID_SENSOR_INFO_WHITE_LEVEL - ANDROID_SENSOR_INFO_START ] =\n+ { \"whiteLevel\", TYPE_INT32 },\n+ [ ANDROID_SENSOR_INFO_TIMESTAMP_SOURCE - ANDROID_SENSOR_INFO_START ] =\n+ { \"timestampSource\", TYPE_BYTE },\n+ [ ANDROID_SENSOR_INFO_LENS_SHADING_APPLIED - ANDROID_SENSOR_INFO_START ] =\n+ { \"lensShadingApplied\", TYPE_BYTE },\n+ [ ANDROID_SENSOR_INFO_PRE_CORRECTION_ACTIVE_ARRAY_SIZE - ANDROID_SENSOR_INFO_START ] =\n+ { \"preCorrectionActiveArraySize\", TYPE_INT32 },\n+};\n+\n+static tag_info_t android_shading[ANDROID_SHADING_END -\n+ ANDROID_SHADING_START] = {\n+ [ ANDROID_SHADING_MODE - ANDROID_SHADING_START ] =\n+ { \"mode\", TYPE_BYTE },\n+ [ ANDROID_SHADING_STRENGTH - ANDROID_SHADING_START ] =\n+ { \"strength\", TYPE_BYTE },\n+ [ ANDROID_SHADING_AVAILABLE_MODES - ANDROID_SHADING_START ] =\n+ { \"availableModes\", TYPE_BYTE },\n+};\n+\n+static tag_info_t android_statistics[ANDROID_STATISTICS_END -\n+ ANDROID_STATISTICS_START] = {\n+ [ ANDROID_STATISTICS_FACE_DETECT_MODE - ANDROID_STATISTICS_START ] =\n+ { \"faceDetectMode\", TYPE_BYTE },\n+ [ ANDROID_STATISTICS_HISTOGRAM_MODE - ANDROID_STATISTICS_START ] =\n+ { \"histogramMode\", TYPE_BYTE },\n+ [ ANDROID_STATISTICS_SHARPNESS_MAP_MODE - ANDROID_STATISTICS_START ] =\n+ { \"sharpnessMapMode\", TYPE_BYTE },\n+ [ ANDROID_STATISTICS_HOT_PIXEL_MAP_MODE - ANDROID_STATISTICS_START ] =\n+ { \"hotPixelMapMode\", TYPE_BYTE },\n+ [ ANDROID_STATISTICS_FACE_IDS - ANDROID_STATISTICS_START ] =\n+ { \"faceIds\", TYPE_INT32 },\n+ [ ANDROID_STATISTICS_FACE_LANDMARKS - ANDROID_STATISTICS_START ] =\n+ { \"faceLandmarks\", TYPE_INT32 },\n+ [ ANDROID_STATISTICS_FACE_RECTANGLES - ANDROID_STATISTICS_START ] =\n+ { \"faceRectangles\", TYPE_INT32 },\n+ [ ANDROID_STATISTICS_FACE_SCORES - ANDROID_STATISTICS_START ] =\n+ { \"faceScores\", TYPE_BYTE },\n+ [ ANDROID_STATISTICS_HISTOGRAM - ANDROID_STATISTICS_START ] =\n+ { \"histogram\", TYPE_INT32 },\n+ [ ANDROID_STATISTICS_SHARPNESS_MAP - ANDROID_STATISTICS_START ] =\n+ { \"sharpnessMap\", TYPE_INT32 },\n+ [ ANDROID_STATISTICS_LENS_SHADING_CORRECTION_MAP - ANDROID_STATISTICS_START ] =\n+ { \"lensShadingCorrectionMap\", TYPE_BYTE },\n+ [ ANDROID_STATISTICS_LENS_SHADING_MAP - ANDROID_STATISTICS_START ] =\n+ { \"lensShadingMap\", TYPE_FLOAT },\n+ [ ANDROID_STATISTICS_PREDICTED_COLOR_GAINS - ANDROID_STATISTICS_START ] =\n+ { \"predictedColorGains\", TYPE_FLOAT },\n+ [ ANDROID_STATISTICS_PREDICTED_COLOR_TRANSFORM - ANDROID_STATISTICS_START ] =\n+ { \"predictedColorTransform\", TYPE_RATIONAL\n+ },\n+ [ ANDROID_STATISTICS_SCENE_FLICKER - ANDROID_STATISTICS_START ] =\n+ { \"sceneFlicker\", TYPE_BYTE },\n+ [ ANDROID_STATISTICS_HOT_PIXEL_MAP - ANDROID_STATISTICS_START ] =\n+ { \"hotPixelMap\", TYPE_INT32 },\n+ [ ANDROID_STATISTICS_LENS_SHADING_MAP_MODE - ANDROID_STATISTICS_START ] =\n+ { \"lensShadingMapMode\", TYPE_BYTE },\n+ [ ANDROID_STATISTICS_OIS_DATA_MODE - ANDROID_STATISTICS_START ] =\n+ { \"oisDataMode\", TYPE_BYTE },\n+ [ ANDROID_STATISTICS_OIS_TIMESTAMPS - ANDROID_STATISTICS_START ] =\n+ { \"oisTimestamps\", TYPE_INT64 },\n+ [ ANDROID_STATISTICS_OIS_X_SHIFTS - ANDROID_STATISTICS_START ] =\n+ { \"oisXShifts\", TYPE_FLOAT },\n+ [ ANDROID_STATISTICS_OIS_Y_SHIFTS - ANDROID_STATISTICS_START ] =\n+ { \"oisYShifts\", TYPE_FLOAT },\n+};\n+\n+static tag_info_t android_statistics_info[ANDROID_STATISTICS_INFO_END -\n+ ANDROID_STATISTICS_INFO_START] = {\n+ [ ANDROID_STATISTICS_INFO_AVAILABLE_FACE_DETECT_MODES - ANDROID_STATISTICS_INFO_START ] =\n+ { \"availableFaceDetectModes\", TYPE_BYTE },\n+ [ ANDROID_STATISTICS_INFO_HISTOGRAM_BUCKET_COUNT - ANDROID_STATISTICS_INFO_START ] =\n+ { \"histogramBucketCount\", TYPE_INT32 },\n+ [ ANDROID_STATISTICS_INFO_MAX_FACE_COUNT - ANDROID_STATISTICS_INFO_START ] =\n+ { \"maxFaceCount\", TYPE_INT32 },\n+ [ ANDROID_STATISTICS_INFO_MAX_HISTOGRAM_COUNT - ANDROID_STATISTICS_INFO_START ] =\n+ { \"maxHistogramCount\", TYPE_INT32 },\n+ [ ANDROID_STATISTICS_INFO_MAX_SHARPNESS_MAP_VALUE - ANDROID_STATISTICS_INFO_START ] =\n+ { \"maxSharpnessMapValue\", TYPE_INT32 },\n+ [ ANDROID_STATISTICS_INFO_SHARPNESS_MAP_SIZE - ANDROID_STATISTICS_INFO_START ] =\n+ { \"sharpnessMapSize\", TYPE_INT32 },\n+ [ ANDROID_STATISTICS_INFO_AVAILABLE_HOT_PIXEL_MAP_MODES - ANDROID_STATISTICS_INFO_START ] =\n+ { \"availableHotPixelMapModes\", TYPE_BYTE },\n+ [ ANDROID_STATISTICS_INFO_AVAILABLE_LENS_SHADING_MAP_MODES - ANDROID_STATISTICS_INFO_START ] =\n+ { \"availableLensShadingMapModes\", TYPE_BYTE },\n+ [ ANDROID_STATISTICS_INFO_AVAILABLE_OIS_DATA_MODES - ANDROID_STATISTICS_INFO_START ] =\n+ { \"availableOisDataModes\", TYPE_BYTE },\n+};\n+\n+static tag_info_t android_tonemap[ANDROID_TONEMAP_END -\n+ ANDROID_TONEMAP_START] = {\n+ [ ANDROID_TONEMAP_CURVE_BLUE - ANDROID_TONEMAP_START ] =\n+ { \"curveBlue\", TYPE_FLOAT },\n+ [ ANDROID_TONEMAP_CURVE_GREEN - ANDROID_TONEMAP_START ] =\n+ { \"curveGreen\", TYPE_FLOAT },\n+ [ ANDROID_TONEMAP_CURVE_RED - ANDROID_TONEMAP_START ] =\n+ { \"curveRed\", TYPE_FLOAT },\n+ [ ANDROID_TONEMAP_MODE - ANDROID_TONEMAP_START ] =\n+ { \"mode\", TYPE_BYTE },\n+ [ ANDROID_TONEMAP_MAX_CURVE_POINTS - ANDROID_TONEMAP_START ] =\n+ { \"maxCurvePoints\", TYPE_INT32 },\n+ [ ANDROID_TONEMAP_AVAILABLE_TONE_MAP_MODES - ANDROID_TONEMAP_START ] =\n+ { \"availableToneMapModes\", TYPE_BYTE },\n+ [ ANDROID_TONEMAP_GAMMA - ANDROID_TONEMAP_START ] =\n+ { \"gamma\", TYPE_FLOAT },\n+ [ ANDROID_TONEMAP_PRESET_CURVE - ANDROID_TONEMAP_START ] =\n+ { \"presetCurve\", TYPE_BYTE },\n+};\n+\n+static tag_info_t android_led[ANDROID_LED_END -\n+ ANDROID_LED_START] = {\n+ [ ANDROID_LED_TRANSMIT - ANDROID_LED_START ] =\n+ { \"transmit\", TYPE_BYTE },\n+ [ ANDROID_LED_AVAILABLE_LEDS - ANDROID_LED_START ] =\n+ { \"availableLeds\", TYPE_BYTE },\n+};\n+\n+static tag_info_t android_info[ANDROID_INFO_END -\n+ ANDROID_INFO_START] = {\n+ [ ANDROID_INFO_SUPPORTED_HARDWARE_LEVEL - ANDROID_INFO_START ] =\n+ { \"supportedHardwareLevel\", TYPE_BYTE },\n+ [ ANDROID_INFO_VERSION - ANDROID_INFO_START ] =\n+ { \"version\", TYPE_BYTE },\n+};\n+\n+static tag_info_t android_black_level[ANDROID_BLACK_LEVEL_END -\n+ ANDROID_BLACK_LEVEL_START] = {\n+ [ ANDROID_BLACK_LEVEL_LOCK - ANDROID_BLACK_LEVEL_START ] =\n+ { \"lock\", TYPE_BYTE },\n+};\n+\n+static tag_info_t android_sync[ANDROID_SYNC_END -\n+ ANDROID_SYNC_START] = {\n+ [ ANDROID_SYNC_FRAME_NUMBER - ANDROID_SYNC_START ] =\n+ { \"frameNumber\", TYPE_INT64 },\n+ [ ANDROID_SYNC_MAX_LATENCY - ANDROID_SYNC_START ] =\n+ { \"maxLatency\", TYPE_INT32 },\n+};\n+\n+static tag_info_t android_reprocess[ANDROID_REPROCESS_END -\n+ ANDROID_REPROCESS_START] = {\n+ [ ANDROID_REPROCESS_EFFECTIVE_EXPOSURE_FACTOR - ANDROID_REPROCESS_START ] =\n+ { \"effectiveExposureFactor\", TYPE_FLOAT },\n+ [ ANDROID_REPROCESS_MAX_CAPTURE_STALL - ANDROID_REPROCESS_START ] =\n+ { \"maxCaptureStall\", TYPE_INT32 },\n+};\n+\n+static tag_info_t android_depth[ANDROID_DEPTH_END -\n+ ANDROID_DEPTH_START] = {\n+ [ ANDROID_DEPTH_MAX_DEPTH_SAMPLES - ANDROID_DEPTH_START ] =\n+ { \"maxDepthSamples\", TYPE_INT32 },\n+ [ ANDROID_DEPTH_AVAILABLE_DEPTH_STREAM_CONFIGURATIONS - ANDROID_DEPTH_START ] =\n+ { \"availableDepthStreamConfigurations\",\n+ TYPE_INT32 },\n+ [ ANDROID_DEPTH_AVAILABLE_DEPTH_MIN_FRAME_DURATIONS - ANDROID_DEPTH_START ] =\n+ { \"availableDepthMinFrameDurations\",\n+ TYPE_INT64 },\n+ [ ANDROID_DEPTH_AVAILABLE_DEPTH_STALL_DURATIONS - ANDROID_DEPTH_START ] =\n+ { \"availableDepthStallDurations\", TYPE_INT64 },\n+ [ ANDROID_DEPTH_DEPTH_IS_EXCLUSIVE - ANDROID_DEPTH_START ] =\n+ { \"depthIsExclusive\", TYPE_BYTE },\n+};\n+\n+static tag_info_t android_logical_multi_camera[ANDROID_LOGICAL_MULTI_CAMERA_END -\n+ ANDROID_LOGICAL_MULTI_CAMERA_START] = {\n+ [ ANDROID_LOGICAL_MULTI_CAMERA_PHYSICAL_IDS - ANDROID_LOGICAL_MULTI_CAMERA_START ] =\n+ { \"physicalIds\", TYPE_BYTE },\n+ [ ANDROID_LOGICAL_MULTI_CAMERA_SENSOR_SYNC_TYPE - ANDROID_LOGICAL_MULTI_CAMERA_START ] =\n+ { \"sensorSyncType\", TYPE_BYTE },\n+};\n+\n+static tag_info_t android_distortion_correction[ANDROID_DISTORTION_CORRECTION_END -\n+ ANDROID_DISTORTION_CORRECTION_START] = {\n+ [ ANDROID_DISTORTION_CORRECTION_MODE - ANDROID_DISTORTION_CORRECTION_START ] =\n+ { \"mode\", TYPE_BYTE },\n+ [ ANDROID_DISTORTION_CORRECTION_AVAILABLE_MODES - ANDROID_DISTORTION_CORRECTION_START ] =\n+ { \"availableModes\", TYPE_BYTE },\n+};\n+\n+\n+tag_info_t *tag_info[ANDROID_SECTION_COUNT] = {\n+ android_color_correction,\n+ android_control,\n+ android_demosaic,\n+ android_edge,\n+ android_flash,\n+ android_flash_info,\n+ android_hot_pixel,\n+ android_jpeg,\n+ android_lens,\n+ android_lens_info,\n+ android_noise_reduction,\n+ android_quirks,\n+ android_request,\n+ android_scaler,\n+ android_sensor,\n+ android_sensor_info,\n+ android_shading,\n+ android_statistics,\n+ android_statistics_info,\n+ android_tonemap,\n+ android_led,\n+ android_info,\n+ android_black_level,\n+ android_sync,\n+ android_reprocess,\n+ android_depth,\n+ android_logical_multi_camera,\n+ android_distortion_correction,\n+};\n+\n+int camera_metadata_enum_snprint(uint32_t tag,\n+ uint32_t value,\n+ char *dst,\n+ size_t size) {\n+ const char *msg = \"error: not an enum\";\n+ int ret = -1;\n+\n+ switch(tag) {\n+ case ANDROID_COLOR_CORRECTION_MODE: {\n+ switch (value) {\n+ case ANDROID_COLOR_CORRECTION_MODE_TRANSFORM_MATRIX:\n+ msg = \"TRANSFORM_MATRIX\";\n+ ret = 0;\n+ break;\n+ case ANDROID_COLOR_CORRECTION_MODE_FAST:\n+ msg = \"FAST\";\n+ ret = 0;\n+ break;\n+ case ANDROID_COLOR_CORRECTION_MODE_HIGH_QUALITY:\n+ msg = \"HIGH_QUALITY\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_COLOR_CORRECTION_TRANSFORM: {\n+ break;\n+ }\n+ case ANDROID_COLOR_CORRECTION_GAINS: {\n+ break;\n+ }\n+ case ANDROID_COLOR_CORRECTION_ABERRATION_MODE: {\n+ switch (value) {\n+ case ANDROID_COLOR_CORRECTION_ABERRATION_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_COLOR_CORRECTION_ABERRATION_MODE_FAST:\n+ msg = \"FAST\";\n+ ret = 0;\n+ break;\n+ case ANDROID_COLOR_CORRECTION_ABERRATION_MODE_HIGH_QUALITY:\n+ msg = \"HIGH_QUALITY\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_COLOR_CORRECTION_AVAILABLE_ABERRATION_MODES: {\n+ break;\n+ }\n+\n+ case ANDROID_CONTROL_AE_ANTIBANDING_MODE: {\n+ switch (value) {\n+ case ANDROID_CONTROL_AE_ANTIBANDING_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AE_ANTIBANDING_MODE_50HZ:\n+ msg = \"50HZ\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AE_ANTIBANDING_MODE_60HZ:\n+ msg = \"60HZ\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AE_ANTIBANDING_MODE_AUTO:\n+ msg = \"AUTO\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_CONTROL_AE_EXPOSURE_COMPENSATION: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_AE_LOCK: {\n+ switch (value) {\n+ case ANDROID_CONTROL_AE_LOCK_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AE_LOCK_ON:\n+ msg = \"ON\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_CONTROL_AE_MODE: {\n+ switch (value) {\n+ case ANDROID_CONTROL_AE_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AE_MODE_ON:\n+ msg = \"ON\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AE_MODE_ON_AUTO_FLASH:\n+ msg = \"ON_AUTO_FLASH\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AE_MODE_ON_ALWAYS_FLASH:\n+ msg = \"ON_ALWAYS_FLASH\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AE_MODE_ON_AUTO_FLASH_REDEYE:\n+ msg = \"ON_AUTO_FLASH_REDEYE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AE_MODE_ON_EXTERNAL_FLASH:\n+ msg = \"ON_EXTERNAL_FLASH\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_CONTROL_AE_REGIONS: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_AE_TARGET_FPS_RANGE: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_AE_PRECAPTURE_TRIGGER: {\n+ switch (value) {\n+ case ANDROID_CONTROL_AE_PRECAPTURE_TRIGGER_IDLE:\n+ msg = \"IDLE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AE_PRECAPTURE_TRIGGER_START:\n+ msg = \"START\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AE_PRECAPTURE_TRIGGER_CANCEL:\n+ msg = \"CANCEL\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_CONTROL_AF_MODE: {\n+ switch (value) {\n+ case ANDROID_CONTROL_AF_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AF_MODE_AUTO:\n+ msg = \"AUTO\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AF_MODE_MACRO:\n+ msg = \"MACRO\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AF_MODE_CONTINUOUS_VIDEO:\n+ msg = \"CONTINUOUS_VIDEO\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AF_MODE_CONTINUOUS_PICTURE:\n+ msg = \"CONTINUOUS_PICTURE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AF_MODE_EDOF:\n+ msg = \"EDOF\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_CONTROL_AF_REGIONS: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_AF_TRIGGER: {\n+ switch (value) {\n+ case ANDROID_CONTROL_AF_TRIGGER_IDLE:\n+ msg = \"IDLE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AF_TRIGGER_START:\n+ msg = \"START\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AF_TRIGGER_CANCEL:\n+ msg = \"CANCEL\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_CONTROL_AWB_LOCK: {\n+ switch (value) {\n+ case ANDROID_CONTROL_AWB_LOCK_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AWB_LOCK_ON:\n+ msg = \"ON\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_CONTROL_AWB_MODE: {\n+ switch (value) {\n+ case ANDROID_CONTROL_AWB_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AWB_MODE_AUTO:\n+ msg = \"AUTO\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AWB_MODE_INCANDESCENT:\n+ msg = \"INCANDESCENT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AWB_MODE_FLUORESCENT:\n+ msg = \"FLUORESCENT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AWB_MODE_WARM_FLUORESCENT:\n+ msg = \"WARM_FLUORESCENT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AWB_MODE_DAYLIGHT:\n+ msg = \"DAYLIGHT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AWB_MODE_CLOUDY_DAYLIGHT:\n+ msg = \"CLOUDY_DAYLIGHT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AWB_MODE_TWILIGHT:\n+ msg = \"TWILIGHT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AWB_MODE_SHADE:\n+ msg = \"SHADE\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_CONTROL_AWB_REGIONS: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_CAPTURE_INTENT: {\n+ switch (value) {\n+ case ANDROID_CONTROL_CAPTURE_INTENT_CUSTOM:\n+ msg = \"CUSTOM\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_CAPTURE_INTENT_PREVIEW:\n+ msg = \"PREVIEW\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_CAPTURE_INTENT_STILL_CAPTURE:\n+ msg = \"STILL_CAPTURE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_CAPTURE_INTENT_VIDEO_RECORD:\n+ msg = \"VIDEO_RECORD\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_CAPTURE_INTENT_VIDEO_SNAPSHOT:\n+ msg = \"VIDEO_SNAPSHOT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_CAPTURE_INTENT_ZERO_SHUTTER_LAG:\n+ msg = \"ZERO_SHUTTER_LAG\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_CAPTURE_INTENT_MANUAL:\n+ msg = \"MANUAL\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_CAPTURE_INTENT_MOTION_TRACKING:\n+ msg = \"MOTION_TRACKING\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_CONTROL_EFFECT_MODE: {\n+ switch (value) {\n+ case ANDROID_CONTROL_EFFECT_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_EFFECT_MODE_MONO:\n+ msg = \"MONO\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_EFFECT_MODE_NEGATIVE:\n+ msg = \"NEGATIVE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_EFFECT_MODE_SOLARIZE:\n+ msg = \"SOLARIZE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_EFFECT_MODE_SEPIA:\n+ msg = \"SEPIA\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_EFFECT_MODE_POSTERIZE:\n+ msg = \"POSTERIZE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_EFFECT_MODE_WHITEBOARD:\n+ msg = \"WHITEBOARD\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_EFFECT_MODE_BLACKBOARD:\n+ msg = \"BLACKBOARD\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_EFFECT_MODE_AQUA:\n+ msg = \"AQUA\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_CONTROL_MODE: {\n+ switch (value) {\n+ case ANDROID_CONTROL_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_MODE_AUTO:\n+ msg = \"AUTO\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_MODE_USE_SCENE_MODE:\n+ msg = \"USE_SCENE_MODE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_MODE_OFF_KEEP_STATE:\n+ msg = \"OFF_KEEP_STATE\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_CONTROL_SCENE_MODE: {\n+ switch (value) {\n+ case ANDROID_CONTROL_SCENE_MODE_DISABLED:\n+ msg = \"DISABLED\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_FACE_PRIORITY:\n+ msg = \"FACE_PRIORITY\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_ACTION:\n+ msg = \"ACTION\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_PORTRAIT:\n+ msg = \"PORTRAIT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_LANDSCAPE:\n+ msg = \"LANDSCAPE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_NIGHT:\n+ msg = \"NIGHT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_NIGHT_PORTRAIT:\n+ msg = \"NIGHT_PORTRAIT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_THEATRE:\n+ msg = \"THEATRE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_BEACH:\n+ msg = \"BEACH\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_SNOW:\n+ msg = \"SNOW\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_SUNSET:\n+ msg = \"SUNSET\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_STEADYPHOTO:\n+ msg = \"STEADYPHOTO\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_FIREWORKS:\n+ msg = \"FIREWORKS\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_SPORTS:\n+ msg = \"SPORTS\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_PARTY:\n+ msg = \"PARTY\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_CANDLELIGHT:\n+ msg = \"CANDLELIGHT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_BARCODE:\n+ msg = \"BARCODE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_HIGH_SPEED_VIDEO:\n+ msg = \"HIGH_SPEED_VIDEO\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_HDR:\n+ msg = \"HDR\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_FACE_PRIORITY_LOW_LIGHT:\n+ msg = \"FACE_PRIORITY_LOW_LIGHT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_DEVICE_CUSTOM_START:\n+ msg = \"DEVICE_CUSTOM_START\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_SCENE_MODE_DEVICE_CUSTOM_END:\n+ msg = \"DEVICE_CUSTOM_END\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_CONTROL_VIDEO_STABILIZATION_MODE: {\n+ switch (value) {\n+ case ANDROID_CONTROL_VIDEO_STABILIZATION_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_VIDEO_STABILIZATION_MODE_ON:\n+ msg = \"ON\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_CONTROL_AE_AVAILABLE_ANTIBANDING_MODES: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_AE_AVAILABLE_MODES: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_AE_AVAILABLE_TARGET_FPS_RANGES: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_AE_COMPENSATION_RANGE: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_AE_COMPENSATION_STEP: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_AF_AVAILABLE_MODES: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_AVAILABLE_EFFECTS: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_AVAILABLE_SCENE_MODES: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_AVAILABLE_VIDEO_STABILIZATION_MODES: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_AWB_AVAILABLE_MODES: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_MAX_REGIONS: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_SCENE_MODE_OVERRIDES: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_AE_PRECAPTURE_ID: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_AE_STATE: {\n+ switch (value) {\n+ case ANDROID_CONTROL_AE_STATE_INACTIVE:\n+ msg = \"INACTIVE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AE_STATE_SEARCHING:\n+ msg = \"SEARCHING\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AE_STATE_CONVERGED:\n+ msg = \"CONVERGED\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AE_STATE_LOCKED:\n+ msg = \"LOCKED\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AE_STATE_FLASH_REQUIRED:\n+ msg = \"FLASH_REQUIRED\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AE_STATE_PRECAPTURE:\n+ msg = \"PRECAPTURE\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_CONTROL_AF_STATE: {\n+ switch (value) {\n+ case ANDROID_CONTROL_AF_STATE_INACTIVE:\n+ msg = \"INACTIVE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AF_STATE_PASSIVE_SCAN:\n+ msg = \"PASSIVE_SCAN\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AF_STATE_PASSIVE_FOCUSED:\n+ msg = \"PASSIVE_FOCUSED\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AF_STATE_ACTIVE_SCAN:\n+ msg = \"ACTIVE_SCAN\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AF_STATE_FOCUSED_LOCKED:\n+ msg = \"FOCUSED_LOCKED\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AF_STATE_NOT_FOCUSED_LOCKED:\n+ msg = \"NOT_FOCUSED_LOCKED\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AF_STATE_PASSIVE_UNFOCUSED:\n+ msg = \"PASSIVE_UNFOCUSED\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_CONTROL_AF_TRIGGER_ID: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_AWB_STATE: {\n+ switch (value) {\n+ case ANDROID_CONTROL_AWB_STATE_INACTIVE:\n+ msg = \"INACTIVE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AWB_STATE_SEARCHING:\n+ msg = \"SEARCHING\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AWB_STATE_CONVERGED:\n+ msg = \"CONVERGED\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AWB_STATE_LOCKED:\n+ msg = \"LOCKED\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_CONTROL_AVAILABLE_HIGH_SPEED_VIDEO_CONFIGURATIONS: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_AE_LOCK_AVAILABLE: {\n+ switch (value) {\n+ case ANDROID_CONTROL_AE_LOCK_AVAILABLE_FALSE:\n+ msg = \"FALSE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AE_LOCK_AVAILABLE_TRUE:\n+ msg = \"TRUE\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_CONTROL_AWB_LOCK_AVAILABLE: {\n+ switch (value) {\n+ case ANDROID_CONTROL_AWB_LOCK_AVAILABLE_FALSE:\n+ msg = \"FALSE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AWB_LOCK_AVAILABLE_TRUE:\n+ msg = \"TRUE\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_CONTROL_AVAILABLE_MODES: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_POST_RAW_SENSITIVITY_BOOST_RANGE: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_POST_RAW_SENSITIVITY_BOOST: {\n+ break;\n+ }\n+ case ANDROID_CONTROL_ENABLE_ZSL: {\n+ switch (value) {\n+ case ANDROID_CONTROL_ENABLE_ZSL_FALSE:\n+ msg = \"FALSE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_ENABLE_ZSL_TRUE:\n+ msg = \"TRUE\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_CONTROL_AF_SCENE_CHANGE: {\n+ switch (value) {\n+ case ANDROID_CONTROL_AF_SCENE_CHANGE_NOT_DETECTED:\n+ msg = \"NOT_DETECTED\";\n+ ret = 0;\n+ break;\n+ case ANDROID_CONTROL_AF_SCENE_CHANGE_DETECTED:\n+ msg = \"DETECTED\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+\n+ case ANDROID_DEMOSAIC_MODE: {\n+ switch (value) {\n+ case ANDROID_DEMOSAIC_MODE_FAST:\n+ msg = \"FAST\";\n+ ret = 0;\n+ break;\n+ case ANDROID_DEMOSAIC_MODE_HIGH_QUALITY:\n+ msg = \"HIGH_QUALITY\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+\n+ case ANDROID_EDGE_MODE: {\n+ switch (value) {\n+ case ANDROID_EDGE_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_EDGE_MODE_FAST:\n+ msg = \"FAST\";\n+ ret = 0;\n+ break;\n+ case ANDROID_EDGE_MODE_HIGH_QUALITY:\n+ msg = \"HIGH_QUALITY\";\n+ ret = 0;\n+ break;\n+ case ANDROID_EDGE_MODE_ZERO_SHUTTER_LAG:\n+ msg = \"ZERO_SHUTTER_LAG\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_EDGE_STRENGTH: {\n+ break;\n+ }\n+ case ANDROID_EDGE_AVAILABLE_EDGE_MODES: {\n+ break;\n+ }\n+\n+ case ANDROID_FLASH_FIRING_POWER: {\n+ break;\n+ }\n+ case ANDROID_FLASH_FIRING_TIME: {\n+ break;\n+ }\n+ case ANDROID_FLASH_MODE: {\n+ switch (value) {\n+ case ANDROID_FLASH_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_FLASH_MODE_SINGLE:\n+ msg = \"SINGLE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_FLASH_MODE_TORCH:\n+ msg = \"TORCH\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_FLASH_COLOR_TEMPERATURE: {\n+ break;\n+ }\n+ case ANDROID_FLASH_MAX_ENERGY: {\n+ break;\n+ }\n+ case ANDROID_FLASH_STATE: {\n+ switch (value) {\n+ case ANDROID_FLASH_STATE_UNAVAILABLE:\n+ msg = \"UNAVAILABLE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_FLASH_STATE_CHARGING:\n+ msg = \"CHARGING\";\n+ ret = 0;\n+ break;\n+ case ANDROID_FLASH_STATE_READY:\n+ msg = \"READY\";\n+ ret = 0;\n+ break;\n+ case ANDROID_FLASH_STATE_FIRED:\n+ msg = \"FIRED\";\n+ ret = 0;\n+ break;\n+ case ANDROID_FLASH_STATE_PARTIAL:\n+ msg = \"PARTIAL\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+\n+ case ANDROID_FLASH_INFO_AVAILABLE: {\n+ switch (value) {\n+ case ANDROID_FLASH_INFO_AVAILABLE_FALSE:\n+ msg = \"FALSE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_FLASH_INFO_AVAILABLE_TRUE:\n+ msg = \"TRUE\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_FLASH_INFO_CHARGE_DURATION: {\n+ break;\n+ }\n+\n+ case ANDROID_HOT_PIXEL_MODE: {\n+ switch (value) {\n+ case ANDROID_HOT_PIXEL_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_HOT_PIXEL_MODE_FAST:\n+ msg = \"FAST\";\n+ ret = 0;\n+ break;\n+ case ANDROID_HOT_PIXEL_MODE_HIGH_QUALITY:\n+ msg = \"HIGH_QUALITY\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_HOT_PIXEL_AVAILABLE_HOT_PIXEL_MODES: {\n+ break;\n+ }\n+\n+ case ANDROID_JPEG_GPS_COORDINATES: {\n+ break;\n+ }\n+ case ANDROID_JPEG_GPS_PROCESSING_METHOD: {\n+ break;\n+ }\n+ case ANDROID_JPEG_GPS_TIMESTAMP: {\n+ break;\n+ }\n+ case ANDROID_JPEG_ORIENTATION: {\n+ break;\n+ }\n+ case ANDROID_JPEG_QUALITY: {\n+ break;\n+ }\n+ case ANDROID_JPEG_THUMBNAIL_QUALITY: {\n+ break;\n+ }\n+ case ANDROID_JPEG_THUMBNAIL_SIZE: {\n+ break;\n+ }\n+ case ANDROID_JPEG_AVAILABLE_THUMBNAIL_SIZES: {\n+ break;\n+ }\n+ case ANDROID_JPEG_MAX_SIZE: {\n+ break;\n+ }\n+ case ANDROID_JPEG_SIZE: {\n+ break;\n+ }\n+\n+ case ANDROID_LENS_APERTURE: {\n+ break;\n+ }\n+ case ANDROID_LENS_FILTER_DENSITY: {\n+ break;\n+ }\n+ case ANDROID_LENS_FOCAL_LENGTH: {\n+ break;\n+ }\n+ case ANDROID_LENS_FOCUS_DISTANCE: {\n+ break;\n+ }\n+ case ANDROID_LENS_OPTICAL_STABILIZATION_MODE: {\n+ switch (value) {\n+ case ANDROID_LENS_OPTICAL_STABILIZATION_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_LENS_OPTICAL_STABILIZATION_MODE_ON:\n+ msg = \"ON\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_LENS_FACING: {\n+ switch (value) {\n+ case ANDROID_LENS_FACING_FRONT:\n+ msg = \"FRONT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_LENS_FACING_BACK:\n+ msg = \"BACK\";\n+ ret = 0;\n+ break;\n+ case ANDROID_LENS_FACING_EXTERNAL:\n+ msg = \"EXTERNAL\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_LENS_POSE_ROTATION: {\n+ break;\n+ }\n+ case ANDROID_LENS_POSE_TRANSLATION: {\n+ break;\n+ }\n+ case ANDROID_LENS_FOCUS_RANGE: {\n+ break;\n+ }\n+ case ANDROID_LENS_STATE: {\n+ switch (value) {\n+ case ANDROID_LENS_STATE_STATIONARY:\n+ msg = \"STATIONARY\";\n+ ret = 0;\n+ break;\n+ case ANDROID_LENS_STATE_MOVING:\n+ msg = \"MOVING\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_LENS_INTRINSIC_CALIBRATION: {\n+ break;\n+ }\n+ case ANDROID_LENS_RADIAL_DISTORTION: {\n+ break;\n+ }\n+ case ANDROID_LENS_POSE_REFERENCE: {\n+ switch (value) {\n+ case ANDROID_LENS_POSE_REFERENCE_PRIMARY_CAMERA:\n+ msg = \"PRIMARY_CAMERA\";\n+ ret = 0;\n+ break;\n+ case ANDROID_LENS_POSE_REFERENCE_GYROSCOPE:\n+ msg = \"GYROSCOPE\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_LENS_DISTORTION: {\n+ break;\n+ }\n+\n+ case ANDROID_LENS_INFO_AVAILABLE_APERTURES: {\n+ break;\n+ }\n+ case ANDROID_LENS_INFO_AVAILABLE_FILTER_DENSITIES: {\n+ break;\n+ }\n+ case ANDROID_LENS_INFO_AVAILABLE_FOCAL_LENGTHS: {\n+ break;\n+ }\n+ case ANDROID_LENS_INFO_AVAILABLE_OPTICAL_STABILIZATION: {\n+ break;\n+ }\n+ case ANDROID_LENS_INFO_HYPERFOCAL_DISTANCE: {\n+ break;\n+ }\n+ case ANDROID_LENS_INFO_MINIMUM_FOCUS_DISTANCE: {\n+ break;\n+ }\n+ case ANDROID_LENS_INFO_SHADING_MAP_SIZE: {\n+ break;\n+ }\n+ case ANDROID_LENS_INFO_FOCUS_DISTANCE_CALIBRATION: {\n+ switch (value) {\n+ case ANDROID_LENS_INFO_FOCUS_DISTANCE_CALIBRATION_UNCALIBRATED:\n+ msg = \"UNCALIBRATED\";\n+ ret = 0;\n+ break;\n+ case ANDROID_LENS_INFO_FOCUS_DISTANCE_CALIBRATION_APPROXIMATE:\n+ msg = \"APPROXIMATE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_LENS_INFO_FOCUS_DISTANCE_CALIBRATION_CALIBRATED:\n+ msg = \"CALIBRATED\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+\n+ case ANDROID_NOISE_REDUCTION_MODE: {\n+ switch (value) {\n+ case ANDROID_NOISE_REDUCTION_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_NOISE_REDUCTION_MODE_FAST:\n+ msg = \"FAST\";\n+ ret = 0;\n+ break;\n+ case ANDROID_NOISE_REDUCTION_MODE_HIGH_QUALITY:\n+ msg = \"HIGH_QUALITY\";\n+ ret = 0;\n+ break;\n+ case ANDROID_NOISE_REDUCTION_MODE_MINIMAL:\n+ msg = \"MINIMAL\";\n+ ret = 0;\n+ break;\n+ case ANDROID_NOISE_REDUCTION_MODE_ZERO_SHUTTER_LAG:\n+ msg = \"ZERO_SHUTTER_LAG\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_NOISE_REDUCTION_STRENGTH: {\n+ break;\n+ }\n+ case ANDROID_NOISE_REDUCTION_AVAILABLE_NOISE_REDUCTION_MODES: {\n+ break;\n+ }\n+\n+ case ANDROID_QUIRKS_METERING_CROP_REGION: {\n+ break;\n+ }\n+ case ANDROID_QUIRKS_TRIGGER_AF_WITH_AUTO: {\n+ break;\n+ }\n+ case ANDROID_QUIRKS_USE_ZSL_FORMAT: {\n+ break;\n+ }\n+ case ANDROID_QUIRKS_USE_PARTIAL_RESULT: {\n+ break;\n+ }\n+ case ANDROID_QUIRKS_PARTIAL_RESULT: {\n+ switch (value) {\n+ case ANDROID_QUIRKS_PARTIAL_RESULT_FINAL:\n+ msg = \"FINAL\";\n+ ret = 0;\n+ break;\n+ case ANDROID_QUIRKS_PARTIAL_RESULT_PARTIAL:\n+ msg = \"PARTIAL\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+\n+ case ANDROID_REQUEST_FRAME_COUNT: {\n+ break;\n+ }\n+ case ANDROID_REQUEST_ID: {\n+ break;\n+ }\n+ case ANDROID_REQUEST_INPUT_STREAMS: {\n+ break;\n+ }\n+ case ANDROID_REQUEST_METADATA_MODE: {\n+ switch (value) {\n+ case ANDROID_REQUEST_METADATA_MODE_NONE:\n+ msg = \"NONE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_REQUEST_METADATA_MODE_FULL:\n+ msg = \"FULL\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_REQUEST_OUTPUT_STREAMS: {\n+ break;\n+ }\n+ case ANDROID_REQUEST_TYPE: {\n+ switch (value) {\n+ case ANDROID_REQUEST_TYPE_CAPTURE:\n+ msg = \"CAPTURE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_REQUEST_TYPE_REPROCESS:\n+ msg = \"REPROCESS\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_REQUEST_MAX_NUM_OUTPUT_STREAMS: {\n+ break;\n+ }\n+ case ANDROID_REQUEST_MAX_NUM_REPROCESS_STREAMS: {\n+ break;\n+ }\n+ case ANDROID_REQUEST_MAX_NUM_INPUT_STREAMS: {\n+ break;\n+ }\n+ case ANDROID_REQUEST_PIPELINE_DEPTH: {\n+ break;\n+ }\n+ case ANDROID_REQUEST_PIPELINE_MAX_DEPTH: {\n+ break;\n+ }\n+ case ANDROID_REQUEST_PARTIAL_RESULT_COUNT: {\n+ break;\n+ }\n+ case ANDROID_REQUEST_AVAILABLE_CAPABILITIES: {\n+ switch (value) {\n+ case ANDROID_REQUEST_AVAILABLE_CAPABILITIES_BACKWARD_COMPATIBLE:\n+ msg = \"BACKWARD_COMPATIBLE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_REQUEST_AVAILABLE_CAPABILITIES_MANUAL_SENSOR:\n+ msg = \"MANUAL_SENSOR\";\n+ ret = 0;\n+ break;\n+ case ANDROID_REQUEST_AVAILABLE_CAPABILITIES_MANUAL_POST_PROCESSING:\n+ msg = \"MANUAL_POST_PROCESSING\";\n+ ret = 0;\n+ break;\n+ case ANDROID_REQUEST_AVAILABLE_CAPABILITIES_RAW:\n+ msg = \"RAW\";\n+ ret = 0;\n+ break;\n+ case ANDROID_REQUEST_AVAILABLE_CAPABILITIES_PRIVATE_REPROCESSING:\n+ msg = \"PRIVATE_REPROCESSING\";\n+ ret = 0;\n+ break;\n+ case ANDROID_REQUEST_AVAILABLE_CAPABILITIES_READ_SENSOR_SETTINGS:\n+ msg = \"READ_SENSOR_SETTINGS\";\n+ ret = 0;\n+ break;\n+ case ANDROID_REQUEST_AVAILABLE_CAPABILITIES_BURST_CAPTURE:\n+ msg = \"BURST_CAPTURE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_REQUEST_AVAILABLE_CAPABILITIES_YUV_REPROCESSING:\n+ msg = \"YUV_REPROCESSING\";\n+ ret = 0;\n+ break;\n+ case ANDROID_REQUEST_AVAILABLE_CAPABILITIES_DEPTH_OUTPUT:\n+ msg = \"DEPTH_OUTPUT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_REQUEST_AVAILABLE_CAPABILITIES_CONSTRAINED_HIGH_SPEED_VIDEO:\n+ msg = \"CONSTRAINED_HIGH_SPEED_VIDEO\";\n+ ret = 0;\n+ break;\n+ case ANDROID_REQUEST_AVAILABLE_CAPABILITIES_MOTION_TRACKING:\n+ msg = \"MOTION_TRACKING\";\n+ ret = 0;\n+ break;\n+ case ANDROID_REQUEST_AVAILABLE_CAPABILITIES_LOGICAL_MULTI_CAMERA:\n+ msg = \"LOGICAL_MULTI_CAMERA\";\n+ ret = 0;\n+ break;\n+ case ANDROID_REQUEST_AVAILABLE_CAPABILITIES_MONOCHROME:\n+ msg = \"MONOCHROME\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_REQUEST_AVAILABLE_REQUEST_KEYS: {\n+ break;\n+ }\n+ case ANDROID_REQUEST_AVAILABLE_RESULT_KEYS: {\n+ break;\n+ }\n+ case ANDROID_REQUEST_AVAILABLE_CHARACTERISTICS_KEYS: {\n+ break;\n+ }\n+ case ANDROID_REQUEST_AVAILABLE_SESSION_KEYS: {\n+ break;\n+ }\n+ case ANDROID_REQUEST_AVAILABLE_PHYSICAL_CAMERA_REQUEST_KEYS: {\n+ break;\n+ }\n+\n+ case ANDROID_SCALER_CROP_REGION: {\n+ break;\n+ }\n+ case ANDROID_SCALER_AVAILABLE_FORMATS: {\n+ switch (value) {\n+ case ANDROID_SCALER_AVAILABLE_FORMATS_RAW16:\n+ msg = \"RAW16\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SCALER_AVAILABLE_FORMATS_RAW_OPAQUE:\n+ msg = \"RAW_OPAQUE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SCALER_AVAILABLE_FORMATS_YV12:\n+ msg = \"YV12\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SCALER_AVAILABLE_FORMATS_YCrCb_420_SP:\n+ msg = \"YCrCb_420_SP\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SCALER_AVAILABLE_FORMATS_IMPLEMENTATION_DEFINED:\n+ msg = \"IMPLEMENTATION_DEFINED\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SCALER_AVAILABLE_FORMATS_YCbCr_420_888:\n+ msg = \"YCbCr_420_888\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SCALER_AVAILABLE_FORMATS_BLOB:\n+ msg = \"BLOB\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_SCALER_AVAILABLE_JPEG_MIN_DURATIONS: {\n+ break;\n+ }\n+ case ANDROID_SCALER_AVAILABLE_JPEG_SIZES: {\n+ break;\n+ }\n+ case ANDROID_SCALER_AVAILABLE_MAX_DIGITAL_ZOOM: {\n+ break;\n+ }\n+ case ANDROID_SCALER_AVAILABLE_PROCESSED_MIN_DURATIONS: {\n+ break;\n+ }\n+ case ANDROID_SCALER_AVAILABLE_PROCESSED_SIZES: {\n+ break;\n+ }\n+ case ANDROID_SCALER_AVAILABLE_RAW_MIN_DURATIONS: {\n+ break;\n+ }\n+ case ANDROID_SCALER_AVAILABLE_RAW_SIZES: {\n+ break;\n+ }\n+ case ANDROID_SCALER_AVAILABLE_INPUT_OUTPUT_FORMATS_MAP: {\n+ break;\n+ }\n+ case ANDROID_SCALER_AVAILABLE_STREAM_CONFIGURATIONS: {\n+ switch (value) {\n+ case ANDROID_SCALER_AVAILABLE_STREAM_CONFIGURATIONS_OUTPUT:\n+ msg = \"OUTPUT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SCALER_AVAILABLE_STREAM_CONFIGURATIONS_INPUT:\n+ msg = \"INPUT\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_SCALER_AVAILABLE_MIN_FRAME_DURATIONS: {\n+ break;\n+ }\n+ case ANDROID_SCALER_AVAILABLE_STALL_DURATIONS: {\n+ break;\n+ }\n+ case ANDROID_SCALER_CROPPING_TYPE: {\n+ switch (value) {\n+ case ANDROID_SCALER_CROPPING_TYPE_CENTER_ONLY:\n+ msg = \"CENTER_ONLY\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SCALER_CROPPING_TYPE_FREEFORM:\n+ msg = \"FREEFORM\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+\n+ case ANDROID_SENSOR_EXPOSURE_TIME: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_FRAME_DURATION: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_SENSITIVITY: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1: {\n+ switch (value) {\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1_DAYLIGHT:\n+ msg = \"DAYLIGHT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1_FLUORESCENT:\n+ msg = \"FLUORESCENT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1_TUNGSTEN:\n+ msg = \"TUNGSTEN\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1_FLASH:\n+ msg = \"FLASH\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1_FINE_WEATHER:\n+ msg = \"FINE_WEATHER\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1_CLOUDY_WEATHER:\n+ msg = \"CLOUDY_WEATHER\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1_SHADE:\n+ msg = \"SHADE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1_DAYLIGHT_FLUORESCENT:\n+ msg = \"DAYLIGHT_FLUORESCENT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1_DAY_WHITE_FLUORESCENT:\n+ msg = \"DAY_WHITE_FLUORESCENT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1_COOL_WHITE_FLUORESCENT:\n+ msg = \"COOL_WHITE_FLUORESCENT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1_WHITE_FLUORESCENT:\n+ msg = \"WHITE_FLUORESCENT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1_STANDARD_A:\n+ msg = \"STANDARD_A\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1_STANDARD_B:\n+ msg = \"STANDARD_B\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1_STANDARD_C:\n+ msg = \"STANDARD_C\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1_D55:\n+ msg = \"D55\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1_D65:\n+ msg = \"D65\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1_D75:\n+ msg = \"D75\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1_D50:\n+ msg = \"D50\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT1_ISO_STUDIO_TUNGSTEN:\n+ msg = \"ISO_STUDIO_TUNGSTEN\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_SENSOR_REFERENCE_ILLUMINANT2: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_CALIBRATION_TRANSFORM1: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_CALIBRATION_TRANSFORM2: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_COLOR_TRANSFORM1: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_COLOR_TRANSFORM2: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_FORWARD_MATRIX1: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_FORWARD_MATRIX2: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_BASE_GAIN_FACTOR: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_BLACK_LEVEL_PATTERN: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_MAX_ANALOG_SENSITIVITY: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_ORIENTATION: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_PROFILE_HUE_SAT_MAP_DIMENSIONS: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_TIMESTAMP: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_TEMPERATURE: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_NEUTRAL_COLOR_POINT: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_NOISE_PROFILE: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_PROFILE_HUE_SAT_MAP: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_PROFILE_TONE_CURVE: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_GREEN_SPLIT: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_TEST_PATTERN_DATA: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_TEST_PATTERN_MODE: {\n+ switch (value) {\n+ case ANDROID_SENSOR_TEST_PATTERN_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_TEST_PATTERN_MODE_SOLID_COLOR:\n+ msg = \"SOLID_COLOR\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_TEST_PATTERN_MODE_COLOR_BARS:\n+ msg = \"COLOR_BARS\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_TEST_PATTERN_MODE_COLOR_BARS_FADE_TO_GRAY:\n+ msg = \"COLOR_BARS_FADE_TO_GRAY\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_TEST_PATTERN_MODE_PN9:\n+ msg = \"PN9\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_TEST_PATTERN_MODE_CUSTOM1:\n+ msg = \"CUSTOM1\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_SENSOR_AVAILABLE_TEST_PATTERN_MODES: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_ROLLING_SHUTTER_SKEW: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_OPTICAL_BLACK_REGIONS: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_DYNAMIC_BLACK_LEVEL: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_DYNAMIC_WHITE_LEVEL: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_OPAQUE_RAW_SIZE: {\n+ break;\n+ }\n+\n+ case ANDROID_SENSOR_INFO_ACTIVE_ARRAY_SIZE: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_INFO_SENSITIVITY_RANGE: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_INFO_COLOR_FILTER_ARRANGEMENT: {\n+ switch (value) {\n+ case ANDROID_SENSOR_INFO_COLOR_FILTER_ARRANGEMENT_RGGB:\n+ msg = \"RGGB\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_INFO_COLOR_FILTER_ARRANGEMENT_GRBG:\n+ msg = \"GRBG\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_INFO_COLOR_FILTER_ARRANGEMENT_GBRG:\n+ msg = \"GBRG\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_INFO_COLOR_FILTER_ARRANGEMENT_BGGR:\n+ msg = \"BGGR\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_INFO_COLOR_FILTER_ARRANGEMENT_RGB:\n+ msg = \"RGB\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_SENSOR_INFO_EXPOSURE_TIME_RANGE: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_INFO_MAX_FRAME_DURATION: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_INFO_PHYSICAL_SIZE: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_INFO_PIXEL_ARRAY_SIZE: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_INFO_WHITE_LEVEL: {\n+ break;\n+ }\n+ case ANDROID_SENSOR_INFO_TIMESTAMP_SOURCE: {\n+ switch (value) {\n+ case ANDROID_SENSOR_INFO_TIMESTAMP_SOURCE_UNKNOWN:\n+ msg = \"UNKNOWN\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_INFO_TIMESTAMP_SOURCE_REALTIME:\n+ msg = \"REALTIME\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_SENSOR_INFO_LENS_SHADING_APPLIED: {\n+ switch (value) {\n+ case ANDROID_SENSOR_INFO_LENS_SHADING_APPLIED_FALSE:\n+ msg = \"FALSE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SENSOR_INFO_LENS_SHADING_APPLIED_TRUE:\n+ msg = \"TRUE\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_SENSOR_INFO_PRE_CORRECTION_ACTIVE_ARRAY_SIZE: {\n+ break;\n+ }\n+\n+ case ANDROID_SHADING_MODE: {\n+ switch (value) {\n+ case ANDROID_SHADING_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SHADING_MODE_FAST:\n+ msg = \"FAST\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SHADING_MODE_HIGH_QUALITY:\n+ msg = \"HIGH_QUALITY\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_SHADING_STRENGTH: {\n+ break;\n+ }\n+ case ANDROID_SHADING_AVAILABLE_MODES: {\n+ break;\n+ }\n+\n+ case ANDROID_STATISTICS_FACE_DETECT_MODE: {\n+ switch (value) {\n+ case ANDROID_STATISTICS_FACE_DETECT_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_STATISTICS_FACE_DETECT_MODE_SIMPLE:\n+ msg = \"SIMPLE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_STATISTICS_FACE_DETECT_MODE_FULL:\n+ msg = \"FULL\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_STATISTICS_HISTOGRAM_MODE: {\n+ switch (value) {\n+ case ANDROID_STATISTICS_HISTOGRAM_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_STATISTICS_HISTOGRAM_MODE_ON:\n+ msg = \"ON\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_STATISTICS_SHARPNESS_MAP_MODE: {\n+ switch (value) {\n+ case ANDROID_STATISTICS_SHARPNESS_MAP_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_STATISTICS_SHARPNESS_MAP_MODE_ON:\n+ msg = \"ON\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_STATISTICS_HOT_PIXEL_MAP_MODE: {\n+ switch (value) {\n+ case ANDROID_STATISTICS_HOT_PIXEL_MAP_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_STATISTICS_HOT_PIXEL_MAP_MODE_ON:\n+ msg = \"ON\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_STATISTICS_FACE_IDS: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_FACE_LANDMARKS: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_FACE_RECTANGLES: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_FACE_SCORES: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_HISTOGRAM: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_SHARPNESS_MAP: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_LENS_SHADING_CORRECTION_MAP: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_LENS_SHADING_MAP: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_PREDICTED_COLOR_GAINS: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_PREDICTED_COLOR_TRANSFORM: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_SCENE_FLICKER: {\n+ switch (value) {\n+ case ANDROID_STATISTICS_SCENE_FLICKER_NONE:\n+ msg = \"NONE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_STATISTICS_SCENE_FLICKER_50HZ:\n+ msg = \"50HZ\";\n+ ret = 0;\n+ break;\n+ case ANDROID_STATISTICS_SCENE_FLICKER_60HZ:\n+ msg = \"60HZ\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_STATISTICS_HOT_PIXEL_MAP: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_LENS_SHADING_MAP_MODE: {\n+ switch (value) {\n+ case ANDROID_STATISTICS_LENS_SHADING_MAP_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_STATISTICS_LENS_SHADING_MAP_MODE_ON:\n+ msg = \"ON\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_STATISTICS_OIS_DATA_MODE: {\n+ switch (value) {\n+ case ANDROID_STATISTICS_OIS_DATA_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_STATISTICS_OIS_DATA_MODE_ON:\n+ msg = \"ON\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_STATISTICS_OIS_TIMESTAMPS: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_OIS_X_SHIFTS: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_OIS_Y_SHIFTS: {\n+ break;\n+ }\n+\n+ case ANDROID_STATISTICS_INFO_AVAILABLE_FACE_DETECT_MODES: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_INFO_HISTOGRAM_BUCKET_COUNT: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_INFO_MAX_FACE_COUNT: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_INFO_MAX_HISTOGRAM_COUNT: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_INFO_MAX_SHARPNESS_MAP_VALUE: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_INFO_SHARPNESS_MAP_SIZE: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_INFO_AVAILABLE_HOT_PIXEL_MAP_MODES: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_INFO_AVAILABLE_LENS_SHADING_MAP_MODES: {\n+ break;\n+ }\n+ case ANDROID_STATISTICS_INFO_AVAILABLE_OIS_DATA_MODES: {\n+ break;\n+ }\n+\n+ case ANDROID_TONEMAP_CURVE_BLUE: {\n+ break;\n+ }\n+ case ANDROID_TONEMAP_CURVE_GREEN: {\n+ break;\n+ }\n+ case ANDROID_TONEMAP_CURVE_RED: {\n+ break;\n+ }\n+ case ANDROID_TONEMAP_MODE: {\n+ switch (value) {\n+ case ANDROID_TONEMAP_MODE_CONTRAST_CURVE:\n+ msg = \"CONTRAST_CURVE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_TONEMAP_MODE_FAST:\n+ msg = \"FAST\";\n+ ret = 0;\n+ break;\n+ case ANDROID_TONEMAP_MODE_HIGH_QUALITY:\n+ msg = \"HIGH_QUALITY\";\n+ ret = 0;\n+ break;\n+ case ANDROID_TONEMAP_MODE_GAMMA_VALUE:\n+ msg = \"GAMMA_VALUE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_TONEMAP_MODE_PRESET_CURVE:\n+ msg = \"PRESET_CURVE\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_TONEMAP_MAX_CURVE_POINTS: {\n+ break;\n+ }\n+ case ANDROID_TONEMAP_AVAILABLE_TONE_MAP_MODES: {\n+ break;\n+ }\n+ case ANDROID_TONEMAP_GAMMA: {\n+ break;\n+ }\n+ case ANDROID_TONEMAP_PRESET_CURVE: {\n+ switch (value) {\n+ case ANDROID_TONEMAP_PRESET_CURVE_SRGB:\n+ msg = \"SRGB\";\n+ ret = 0;\n+ break;\n+ case ANDROID_TONEMAP_PRESET_CURVE_REC709:\n+ msg = \"REC709\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+\n+ case ANDROID_LED_TRANSMIT: {\n+ switch (value) {\n+ case ANDROID_LED_TRANSMIT_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_LED_TRANSMIT_ON:\n+ msg = \"ON\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_LED_AVAILABLE_LEDS: {\n+ switch (value) {\n+ case ANDROID_LED_AVAILABLE_LEDS_TRANSMIT:\n+ msg = \"TRANSMIT\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+\n+ case ANDROID_INFO_SUPPORTED_HARDWARE_LEVEL: {\n+ switch (value) {\n+ case ANDROID_INFO_SUPPORTED_HARDWARE_LEVEL_LIMITED:\n+ msg = \"LIMITED\";\n+ ret = 0;\n+ break;\n+ case ANDROID_INFO_SUPPORTED_HARDWARE_LEVEL_FULL:\n+ msg = \"FULL\";\n+ ret = 0;\n+ break;\n+ case ANDROID_INFO_SUPPORTED_HARDWARE_LEVEL_LEGACY:\n+ msg = \"LEGACY\";\n+ ret = 0;\n+ break;\n+ case ANDROID_INFO_SUPPORTED_HARDWARE_LEVEL_3:\n+ msg = \"3\";\n+ ret = 0;\n+ break;\n+ case ANDROID_INFO_SUPPORTED_HARDWARE_LEVEL_EXTERNAL:\n+ msg = \"EXTERNAL\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_INFO_VERSION: {\n+ break;\n+ }\n+\n+ case ANDROID_BLACK_LEVEL_LOCK: {\n+ switch (value) {\n+ case ANDROID_BLACK_LEVEL_LOCK_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_BLACK_LEVEL_LOCK_ON:\n+ msg = \"ON\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+\n+ case ANDROID_SYNC_FRAME_NUMBER: {\n+ switch (value) {\n+ case ANDROID_SYNC_FRAME_NUMBER_CONVERGING:\n+ msg = \"CONVERGING\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SYNC_FRAME_NUMBER_UNKNOWN:\n+ msg = \"UNKNOWN\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_SYNC_MAX_LATENCY: {\n+ switch (value) {\n+ case ANDROID_SYNC_MAX_LATENCY_PER_FRAME_CONTROL:\n+ msg = \"PER_FRAME_CONTROL\";\n+ ret = 0;\n+ break;\n+ case ANDROID_SYNC_MAX_LATENCY_UNKNOWN:\n+ msg = \"UNKNOWN\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+\n+ case ANDROID_REPROCESS_EFFECTIVE_EXPOSURE_FACTOR: {\n+ break;\n+ }\n+ case ANDROID_REPROCESS_MAX_CAPTURE_STALL: {\n+ break;\n+ }\n+\n+ case ANDROID_DEPTH_MAX_DEPTH_SAMPLES: {\n+ break;\n+ }\n+ case ANDROID_DEPTH_AVAILABLE_DEPTH_STREAM_CONFIGURATIONS: {\n+ switch (value) {\n+ case ANDROID_DEPTH_AVAILABLE_DEPTH_STREAM_CONFIGURATIONS_OUTPUT:\n+ msg = \"OUTPUT\";\n+ ret = 0;\n+ break;\n+ case ANDROID_DEPTH_AVAILABLE_DEPTH_STREAM_CONFIGURATIONS_INPUT:\n+ msg = \"INPUT\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_DEPTH_AVAILABLE_DEPTH_MIN_FRAME_DURATIONS: {\n+ break;\n+ }\n+ case ANDROID_DEPTH_AVAILABLE_DEPTH_STALL_DURATIONS: {\n+ break;\n+ }\n+ case ANDROID_DEPTH_DEPTH_IS_EXCLUSIVE: {\n+ switch (value) {\n+ case ANDROID_DEPTH_DEPTH_IS_EXCLUSIVE_FALSE:\n+ msg = \"FALSE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_DEPTH_DEPTH_IS_EXCLUSIVE_TRUE:\n+ msg = \"TRUE\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+\n+ case ANDROID_LOGICAL_MULTI_CAMERA_PHYSICAL_IDS: {\n+ break;\n+ }\n+ case ANDROID_LOGICAL_MULTI_CAMERA_SENSOR_SYNC_TYPE: {\n+ switch (value) {\n+ case ANDROID_LOGICAL_MULTI_CAMERA_SENSOR_SYNC_TYPE_APPROXIMATE:\n+ msg = \"APPROXIMATE\";\n+ ret = 0;\n+ break;\n+ case ANDROID_LOGICAL_MULTI_CAMERA_SENSOR_SYNC_TYPE_CALIBRATED:\n+ msg = \"CALIBRATED\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+\n+ case ANDROID_DISTORTION_CORRECTION_MODE: {\n+ switch (value) {\n+ case ANDROID_DISTORTION_CORRECTION_MODE_OFF:\n+ msg = \"OFF\";\n+ ret = 0;\n+ break;\n+ case ANDROID_DISTORTION_CORRECTION_MODE_FAST:\n+ msg = \"FAST\";\n+ ret = 0;\n+ break;\n+ case ANDROID_DISTORTION_CORRECTION_MODE_HIGH_QUALITY:\n+ msg = \"HIGH_QUALITY\";\n+ ret = 0;\n+ break;\n+ default:\n+ msg = \"error: enum value out of range\";\n+ }\n+ break;\n+ }\n+ case ANDROID_DISTORTION_CORRECTION_AVAILABLE_MODES: {\n+ break;\n+ }\n+\n+ }\n+\n+ strncpy(dst, msg, size - 1);\n+ dst[size - 1] = '\\0';\n+\n+ return ret;\n+}\n+\n+\n+#define CAMERA_METADATA_ENUM_STRING_MAX_SIZE 29\n", "prefixes": [ "libcamera-devel", "4/5" ] }