[RFC PATCH v1 3/8] utils: codegen: ipc: Add `deserializer()` function
Paul Elder
paul.elder at ideasonboard.com
Thu May 15 14:23:53 CEST 2025
Quoting Barnabás Pőcze (2025-05-15 14:00:07)
> Add `deserializer()` in `serializer.tmpl` to have a single function
> that generates all the necessary functions into the template specialization
> like `serializer()`. This also avoids the duplication of some
> conditional logic.
>
> Signed-off-by: Barnabás Pőcze <barnabas.pocze at ideasonboard.com>
Reviewed-by: Paul Elder <paul.elder at ideasonboard.com>
> ---
> .../libcamera_templates/core_ipa_serializer.h.tmpl | 7 +------
> .../module_ipa_serializer.h.tmpl | 7 +------
> .../generators/libcamera_templates/serializer.tmpl | 14 ++++++++++++++
> 3 files changed, 16 insertions(+), 12 deletions(-)
>
> diff --git a/utils/codegen/ipc/generators/libcamera_templates/core_ipa_serializer.h.tmpl b/utils/codegen/ipc/generators/libcamera_templates/core_ipa_serializer.h.tmpl
> index cbb35ef51..ac84963dc 100644
> --- a/utils/codegen/ipc/generators/libcamera_templates/core_ipa_serializer.h.tmpl
> +++ b/utils/codegen/ipc/generators/libcamera_templates/core_ipa_serializer.h.tmpl
> @@ -32,12 +32,7 @@ class IPADataSerializer<{{struct|name}}>
> {
> public:
> {{- serializer.serializer(struct)}}
> -{%- if struct|has_fd %}
> -{{serializer.deserializer_fd(struct)}}
> -{%- else %}
> -{{serializer.deserializer_no_fd(struct)}}
> -{{serializer.deserializer_fd_simple(struct)}}
> -{%- endif %}
> +{{- serializer.deserializer(struct)}}
> };
> {% endfor %}
>
> diff --git a/utils/codegen/ipc/generators/libcamera_templates/module_ipa_serializer.h.tmpl b/utils/codegen/ipc/generators/libcamera_templates/module_ipa_serializer.h.tmpl
> index f3b8e3b15..65a7dd11c 100644
> --- a/utils/codegen/ipc/generators/libcamera_templates/module_ipa_serializer.h.tmpl
> +++ b/utils/codegen/ipc/generators/libcamera_templates/module_ipa_serializer.h.tmpl
> @@ -33,12 +33,7 @@ class IPADataSerializer<{{struct|name_full}}>
> {
> public:
> {{- serializer.serializer(struct)}}
> -{%- if struct|has_fd %}
> -{{serializer.deserializer_fd(struct)}}
> -{%- else %}
> -{{serializer.deserializer_no_fd(struct)}}
> -{{serializer.deserializer_fd_simple(struct)}}
> -{%- endif %}
> +{{- serializer.deserializer(struct)}}
> };
> {% endfor %}
>
> diff --git a/utils/codegen/ipc/generators/libcamera_templates/serializer.tmpl b/utils/codegen/ipc/generators/libcamera_templates/serializer.tmpl
> index 114e349c9..d07836cc1 100644
> --- a/utils/codegen/ipc/generators/libcamera_templates/serializer.tmpl
> +++ b/utils/codegen/ipc/generators/libcamera_templates/serializer.tmpl
> @@ -317,3 +317,17 @@
> return ret;
> }
> {%- endmacro %}
> +
> +{#
> + # \brief Deserialize a struct
> + #
> + # Generate code for IPADataSerializer specialization, for deserializing \a struct.
> + #}
> +{%- macro deserializer(struct) %}
> +{%- if struct|has_fd %}
> +{{deserializer_fd(struct)}}
> +{%- else %}
> +{{deserializer_no_fd(struct)}}
> +{{deserializer_fd_simple(struct)}}
> +{%- endif %}
> +{%- endmacro %}
> --
> 2.49.0
>
More information about the libcamera-devel
mailing list