[libcamera-devel] [PATCH v2 13/24] ipa: Define serialized controls

Niklas Söderlund niklas.soderlund at ragnatech.se
Mon Nov 18 18:46:08 CET 2019


Hi Jacopo,

Thanks for your work.

On 2019-11-08 22:53:58 +0200, Laurent Pinchart wrote:
> From: Jacopo Mondi <jacopo at jmondi.org>
> 
> Define data structures to be used during interaction between IPA modules
> and pipeline handlers to serialize control lists and control info maps.
> 
> Signed-off-by: Jacopo Mondi <jacopo at jmondi.org>

Reviewed-by: Niklas Söderlund <niklas.soderlund at ragnatech.se>

> ---
>  include/ipa/ipa_controls.h     |  54 ++++++++++
>  include/ipa/meson.build        |   1 +
>  src/libcamera/ipa_controls.cpp | 187 +++++++++++++++++++++++++++++++++
>  src/libcamera/meson.build      |   1 +
>  4 files changed, 243 insertions(+)
>  create mode 100644 include/ipa/ipa_controls.h
>  create mode 100644 src/libcamera/ipa_controls.cpp
> 
> diff --git a/include/ipa/ipa_controls.h b/include/ipa/ipa_controls.h
> new file mode 100644
> index 000000000000..de3a017b0179
> --- /dev/null
> +++ b/include/ipa/ipa_controls.h
> @@ -0,0 +1,54 @@
> +/* SPDX-License-Identifier: LGPL-2.1-or-later */
> +/*
> + * Copyright (C) 2019, Google Inc.
> + *
> + * ipa_controls.h - IPA Control handling
> + */
> +#ifndef __LIBCAMERA_IPA_CONTROLS_H__
> +#define __LIBCAMERA_IPA_CONTROLS_H__
> +
> +#ifdef __cplusplus
> +extern "C" {
> +#endif
> +
> +#define IPA_CONTROLS_FORMAT_VERSION	1
> +
> +struct ipa_controls_header {
> +	uint32_t version;
> +	uint32_t handle;
> +	uint32_t entries;
> +	uint32_t size;
> +	uint32_t data_offset;
> +	uint32_t reserved[3];
> +};
> +
> +struct ipa_control_value_entry {
> +	uint32_t id;
> +	uint32_t type;
> +	uint32_t count;
> +	uint32_t offset;
> +};
> +
> +struct ipa_control_range_entry {
> +	uint32_t id;
> +	uint32_t type;
> +	uint32_t offset;
> +	uint32_t padding[1];
> +};
> +
> +union ipa_control_value_data {
> +	bool b;
> +	int32_t i32;
> +	int64_t i64;
> +};
> +
> +struct ipa_control_range_data {
> +	union ipa_control_value_data min;
> +	union ipa_control_value_data max;
> +};
> +
> +#ifdef __cplusplus
> +}
> +#endif
> +
> +#endif /* __LIBCAMERA_IPA_CONTROLS_H__ */
> diff --git a/include/ipa/meson.build b/include/ipa/meson.build
> index a0ce96ba96c3..695a4183a0e8 100644
> --- a/include/ipa/meson.build
> +++ b/include/ipa/meson.build
> @@ -1,4 +1,5 @@
>  libcamera_ipa_api = files([
> +    'ipa_controls.h',
>      'ipa_interface.h',
>      'ipa_module_info.h',
>  ])
> diff --git a/src/libcamera/ipa_controls.cpp b/src/libcamera/ipa_controls.cpp
> new file mode 100644
> index 000000000000..bbcc5301cd59
> --- /dev/null
> +++ b/src/libcamera/ipa_controls.cpp
> @@ -0,0 +1,187 @@
> +/* SPDX-License-Identifier: LGPL-2.1-or-later */
> +/*
> + * Copyright (C) 2019, Google Inc.
> + *
> + * ipa_controls.h - IPA control handling
> + */
> +
> +/**
> + * \file ipa_controls.h
> + * \brief Type definitions for serialized controls
> + *
> + * This file defines binary formats to store ControlList and ControlInfoMap
> + * instances in contiguous, self-contained memory areas called control packets.
> + * It describes the layout of the packets through a set of C structures. These
> + * formats shall be used when serializing ControlList and ControlInfoMap to
> + * transfer them through the IPA C interface and IPA IPC transports.
> + *
> + * A control packet contains a list of entries, each of them describing a single
> + * control range or control value. The packet starts with a fixed-size header
> + * described by the ipa_controls_header structure, followed by an array of
> + * fixed-size entries. Each entry is associated with data, stored either
> + * directly in the entry, or in a data section after the entries array.
> + *
> + * The following diagram describes the layout of the ControlList packet.
> + *
> + * ~~~~
> + *           +-------------------------+    .                      .
> + *  Header / | ipa_controls_header     |    |                      |
> + *         | |                         |    |                      |
> + *         \ |                         |    |                      |
> + *           +-------------------------+    |                      |
> + *         / | ipa_control_value_entry |    | hdr.data_offset      |
> + *         | | #0                      |    |                      |
> + * Control | +-------------------------+    |                      |
> + *   value | | ...                     |    |                      |
> + * entries | +-------------------------+    |                      |
> + *         | | ipa_control_value_entry |    |             hdr.size |
> + *         \ | #hdr.entries - 1        |    |                      |
> + *           +-------------------------+    |                      |
> + *           | empty space (optional)  |    |                      |
> + *           +-------------------------+ <--´  .                   |
> + *         / | ...                     |       | entry[n].offset   |
> + *    Data | | ...                     |       |                   |
> + * section | | value data for entry #n | <-----´                   |
> + *         \ | ...                     |                           |
> + *           +-------------------------+                           |
> + *           | empty space (optional)  |                           |
> + *           +-------------------------+ <-------------------------´
> + * ~~~~
> + *
> + * The packet header contains the size of the packet, the number of entries, and
> + * the offset from the beginning of the packet to the data section. The packet
> + * entries array immediately follows the header. The data section starts at the
> + * offset ipa_controls_header::data_offset from the beginning of the packed, and
> + * shall be aligned to a multiple of 8 bytes.
> + *
> + * Entries are described by the ipa_control_value_entry structure. They contain
> + * the numerical ID of the control, its type, and the number of control values.
> + * The control values are stored in the platform's native format.
> + *
> + * The control values are stored in the data section in the platform's native
> + * format. The ipa_control_value_entry::offset field stores the offset from the
> + * beginning of the data section to the values.
> + *
> + * All control values in the data section shall be stored in the same order as
> + * the controls in the entries array, shall be aligned to a multiple of 8 bytes,
> + * and shall be contiguous in memory.
> + *
> + * Empty spaces may be present between the end of the entries array and the
> + * data section, and after the data section. They shall be ignored when parsing
> + * the packet.
> + *
> + * The following diagram describes the layout of the ControlInfoMap packet.
> + *
> + * ~~~~
> + *           +-------------------------+    .                      .
> + *  Header / | ipa_controls_header     |    |                      |
> + *         | |                         |    |                      |
> + *         \ |                         |    |                      |
> + *           +-------------------------+    |                      |
> + *         / | ipa_control_range_entry |    | hdr.data_offset      |
> + *         | | #0                      |    |                      |
> + * Control | +-------------------------+    |                      |
> + *   range | | ...                     |    |                      |
> + * entries | +-------------------------+    |                      |
> + *         | | ipa_control_range_entry |    |             hdr.size |
> + *         \ | #hdr.entries - 1        |    |                      |
> + *           +-------------------------+    |                      |
> + *           | empty space (optional)  |    |                      |
> + *           +-------------------------+ <--´  .                   |
> + *         / | ...                     |       | entry[n].offset   |
> + *    Data | | ...                     |       |                   |
> + * section | | range data for entry #n | <-----´                   |
> + *         \ | ...                     |                           |
> + *           +-------------------------+                           |
> + *           | empty space (optional)  |                           |
> + *           +-------------------------+ <-------------------------´
> + * ~~~~
> + *
> + * The packet header is identical to the ControlList packet header.
> + *
> + * Entries are described by the ipa_control_range_entry structure. They contain
> + * the numerical ID and type of the control. The control range data is stored
> + * in the data section as described by the ipa_control_range_data structure.
> + * The ipa_control_range_entry::offset field stores the offset from the
> + * beginning of the data section to the range data.
> + *
> + * Range data in the data section shall be stored in the same order as the
> + * entries array, shall be aligned to a multiple of 8 bytes, and shall be
> + * contiguous in memory.
> + *
> + * As for the ControlList packet, empty spaces may be present between the end of
> + * the entries array and the data section, and after the data section. They
> + * shall be ignored when parsing the packet.
> + */
> +
> +/**
> + * \def IPA_CONTROLS_FORMAT_VERSION
> + * \brief The current control serialization format version
> + */
> +
> +/**
> + * \struct ipa_controls_header
> + * \brief Serialized control packet header
> + * \var ipa_controls_header::version
> + * Control packet format version number (shall be IPA_CONTROLS_FORMAT_VERSION)
> + * \var ipa_controls_header::handle
> + * For ControlInfoMap packets, this field contains a unique non-zero handle
> + * generated when the ControlInfoMap is serialized. For ControlList packets,
> + * this field contains the handle of the corresponding ControlInfoMap.
> + * \var ipa_controls_header::entries
> + * Number of entries in the packet
> + * \var ipa_controls_header::size
> + * The total packet size in bytes
> + * \var ipa_controls_header::data_offset
> + * Offset in bytes from the beginning of the packet of the data section start
> + * \var ipa_controls_header::reserved
> + * Reserved for future extensions
> + */
> +
> +/**
> + * \struct ipa_control_value_entry
> + * \brief Description of a serialized ControlValue entry
> + * \var ipa_control_value_entry::id
> + * The numerical ID of the control
> + * \var ipa_control_value_entry::type
> + * The type of the control (defined by enum ControlType)
> + * \var ipa_control_value_entry::count
> + * The number of control array entries for array controls (1 otherwise)
> + * \var ipa_control_value_entry::offset
> + * The offset in bytes from the beginning of the data section to the control
> + * value data (shall be a multiple of 8 bytes).
> + */
> +
> +/**
> + * \struct ipa_control_range_entry
> + * \brief Description of a serialized ControlRange entry
> + * \var ipa_control_range_entry::id
> + * The numerical ID of the control
> + * \var ipa_control_range_entry::type
> + * The type of the control (defined by enum ControlType)
> + * \var ipa_control_range_entry::offset
> + * The offset in bytes from the beginning of the data section to the control
> + * range data (shall be a multiple of 8 bytes)
> + * \var ipa_control_range_entry::padding
> + * Padding bytes (shall be set to 0)
> + */
> +
> +/**
> + * \union ipa_control_value_data
> + * \brief Serialized control value
> + * \var ipa_control_value_data::b
> + * Value for ControlTypeBool controls
> + * \var ipa_control_value_data::i32
> + * Value for ControlTypeInteger32 controls
> + * \var ipa_control_value_data::i64
> + * Value for ControlTypeInteger64 controls
> + */
> +
> +/**
> + * \struct ipa_control_range_data
> + * \brief Serialized control range
> + * \var ipa_control_range_data::min
> + * The control minimum value
> + * \var ipa_control_range_data::max
> + * The control maximum value
> + */
> diff --git a/src/libcamera/meson.build b/src/libcamera/meson.build
> index afbca76968f9..be0cd53f6f10 100644
> --- a/src/libcamera/meson.build
> +++ b/src/libcamera/meson.build
> @@ -14,6 +14,7 @@ libcamera_sources = files([
>      'event_notifier.cpp',
>      'formats.cpp',
>      'geometry.cpp',
> +    'ipa_controls.cpp',
>      'ipa_interface.cpp',
>      'ipa_manager.cpp',
>      'ipa_module.cpp',
> -- 
> Regards,
> 
> Laurent Pinchart
> 
> _______________________________________________
> libcamera-devel mailing list
> libcamera-devel at lists.libcamera.org
> https://lists.libcamera.org/listinfo/libcamera-devel

-- 
Regards,
Niklas Söderlund


More information about the libcamera-devel mailing list