[PATCH v4 09/20] libcamera: converter: Add function to check if a stream was configured

Paul Elder paul.elder at ideasonboard.com
Tue Dec 17 04:43:32 CET 2024


On Mon, Dec 16, 2024 at 04:40:49PM +0100, Stefan Klug wrote:
> Add a isConfigured() function to be able to check if a given stream was
> configured in the converter. This is useful in pipelines to either query
> device or stream specific crop bounds depending on whether the stream is
> configured or not.
> 
> Signed-off-by: Stefan Klug <stefan.klug at ideasonboard.com>

Reviewed-by: Paul Elder <paul.elder at ideasonboard.com>

> 
> ---
> 
> Changes in v4:
> - Added this patch
> ---
>  include/libcamera/internal/converter.h                    | 1 +
>  include/libcamera/internal/converter/converter_v4l2_m2m.h | 1 +
>  src/libcamera/converter.cpp                               | 7 +++++++
>  src/libcamera/converter/converter_v4l2_m2m.cpp            | 8 ++++++++
>  4 files changed, 17 insertions(+)
> 
> diff --git a/include/libcamera/internal/converter.h b/include/libcamera/internal/converter.h
> index 04187a2a96e8..afea4624041b 100644
> --- a/include/libcamera/internal/converter.h
> +++ b/include/libcamera/internal/converter.h
> @@ -56,6 +56,7 @@ public:
>  
>  	virtual int configure(const StreamConfiguration &inputCfg,
>  			      const std::vector<std::reference_wrapper<StreamConfiguration>> &outputCfgs) = 0;
> +	virtual bool isConfigured(const Stream *stream) const = 0;
>  	virtual int exportBuffers(const Stream *stream, unsigned int count,
>  				  std::vector<std::unique_ptr<FrameBuffer>> *buffers) = 0;
>  
> diff --git a/include/libcamera/internal/converter/converter_v4l2_m2m.h b/include/libcamera/internal/converter/converter_v4l2_m2m.h
> index 402a803959b9..1ccbfc7c2d4e 100644
> --- a/include/libcamera/internal/converter/converter_v4l2_m2m.h
> +++ b/include/libcamera/internal/converter/converter_v4l2_m2m.h
> @@ -50,6 +50,7 @@ public:
>  	int configure(const StreamConfiguration &inputCfg,
>  		      const std::vector<std::reference_wrapper<StreamConfiguration>>
>  		      &outputCfg) override;
> +	bool isConfigured(const Stream *stream) const override;
>  	int exportBuffers(const Stream *stream, unsigned int count,
>  			  std::vector<std::unique_ptr<FrameBuffer>> *buffers) override;
>  
> diff --git a/src/libcamera/converter.cpp b/src/libcamera/converter.cpp
> index 73c02fdcf4bb..09ebf4f57d12 100644
> --- a/src/libcamera/converter.cpp
> +++ b/src/libcamera/converter.cpp
> @@ -126,6 +126,13 @@ Converter::~Converter()
>   * \return 0 on success or a negative error code otherwise
>   */
>  
> +/**
> + * \fn Converter::isConfigured()
> + * \brief Check if a given stream is configured
> + * \param[in] stream The output stream
> + * \return True if the \a stream is configured or false otherwise
> + */
> +
>  /**
>   * \fn Converter::exportBuffers()
>   * \brief Export buffers from the converter device
> diff --git a/src/libcamera/converter/converter_v4l2_m2m.cpp b/src/libcamera/converter/converter_v4l2_m2m.cpp
> index 342aa32dab52..83daca15b37e 100644
> --- a/src/libcamera/converter/converter_v4l2_m2m.cpp
> +++ b/src/libcamera/converter/converter_v4l2_m2m.cpp
> @@ -437,6 +437,14 @@ int V4L2M2MConverter::configure(const StreamConfiguration &inputCfg,
>  	return 0;
>  }
>  
> +/**
> + * \copydoc libcamera::Converter::isConfigured
> + */
> +bool V4L2M2MConverter::isConfigured(const Stream *stream) const
> +{
> +	return streams_.find(stream) != streams_.end();
> +}
> +
>  /**
>   * \copydoc libcamera::Converter::exportBuffers
>   */
> -- 
> 2.43.0
> 


More information about the libcamera-devel mailing list