[libcamera-devel] [PATCH v3 1/7] delayed_controls: Template the ControlRingBuffer class
Laurent Pinchart
laurent.pinchart at ideasonboard.com
Tue Oct 4 18:05:54 CEST 2022
Hi Naush,
Thank you for the patch.
On Mon, Sep 26, 2022 at 10:57:31AM +0100, Naushir Patuck via libcamera-devel wrote:
> Convert ControlRingBuffer to a templated class to allow arbitrary ring buffer
> array types to be defined. Rename ControlRingBuffer to RingBuffer to indicate
> this.
>
> Signed-off-by: Naushir Patuck <naush at raspberrypi.com>
> Reviewed-by: David Plowman <david.plowman at raspberrypi.com>
> Tested-by: David Plowman <david.plowman at raspberrypi.com>
This patch looks fine, so
Reviewed-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
I'll now look at how it's used :-)
> ---
> include/libcamera/internal/delayed_controls.h | 13 +++++++------
> 1 file changed, 7 insertions(+), 6 deletions(-)
>
> diff --git a/include/libcamera/internal/delayed_controls.h b/include/libcamera/internal/delayed_controls.h
> index aef37077103c..de8026e3e4f0 100644
> --- a/include/libcamera/internal/delayed_controls.h
> +++ b/include/libcamera/internal/delayed_controls.h
> @@ -53,17 +53,18 @@ private:
>
> /* \todo Make the listSize configurable at instance creation time. */
> static constexpr int listSize = 16;
> - class ControlRingBuffer : public std::array<Info, listSize>
> + template<typename T>
> + class RingBuffer : public std::array<T, listSize>
> {
> public:
> - Info &operator[](unsigned int index)
> + T &operator[](unsigned int index)
> {
> - return std::array<Info, listSize>::operator[](index % listSize);
> + return std::array<T, listSize>::operator[](index % listSize);
> }
>
> - const Info &operator[](unsigned int index) const
> + const T &operator[](unsigned int index) const
> {
> - return std::array<Info, listSize>::operator[](index % listSize);
> + return std::array<T, listSize>::operator[](index % listSize);
> }
> };
>
> @@ -75,7 +76,7 @@ private:
> uint32_t queueCount_;
> uint32_t writeCount_;
> /* \todo Evaluate if we should index on ControlId * or unsigned int */
> - std::unordered_map<const ControlId *, ControlRingBuffer> values_;
> + std::unordered_map<const ControlId *, RingBuffer<Info>> values_;
> };
>
> } /* namespace libcamera */
--
Regards,
Laurent Pinchart
More information about the libcamera-devel
mailing list