[libcamera-devel] [PATCH v4 02/19] libcamera: utils: Add alignUp and alignDown functions
Niklas Söderlund
niklas.soderlund at ragnatech.se
Tue Jul 21 13:46:07 CEST 2020
Hi Jacopo,
Thanks for your work.
On 2020-07-20 12:47:19 +0200, Jacopo Mondi wrote:
> Add to libcamera utils library two functions to round up or down a
> value to an alignment and add a test in test/utils.cpp for the two
> new functions.
>
> Reviewed-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
> Signed-off-by: Jacopo Mondi <jacopo at jmondi.org>
Reviewed-by: Niklas Söderlund <niklas.soderlund at ragnatech.se>
> ---
> include/libcamera/internal/utils.h | 10 ++++++++++
> src/libcamera/utils.cpp | 16 ++++++++++++++++
> test/utils.cpp | 11 +++++++++++
> 3 files changed, 37 insertions(+)
>
> diff --git a/include/libcamera/internal/utils.h b/include/libcamera/internal/utils.h
> index 8d026cc6c0fe..45cd6f120c51 100644
> --- a/include/libcamera/internal/utils.h
> +++ b/include/libcamera/internal/utils.h
> @@ -200,6 +200,16 @@ details::StringSplitter split(const std::string &str, const std::string &delim);
> std::string libcameraBuildPath();
> std::string libcameraSourcePath();
>
> +constexpr unsigned int alignDown(unsigned int value, unsigned int alignment)
> +{
> + return value / alignment * alignment;
> +}
> +
> +constexpr unsigned int alignUp(unsigned int value, unsigned int alignment)
> +{
> + return (value + alignment - 1) / alignment * alignment;
> +}
> +
> } /* namespace utils */
>
> } /* namespace libcamera */
> diff --git a/src/libcamera/utils.cpp b/src/libcamera/utils.cpp
> index 0567328fe31b..615df46ac142 100644
> --- a/src/libcamera/utils.cpp
> +++ b/src/libcamera/utils.cpp
> @@ -444,6 +444,22 @@ std::string libcameraSourcePath()
> return path + "/";
> }
>
> +/**
> + * \fn alignDown(unsigned int value, unsigned int alignment)
> + * \brief Align \a value down to \a alignment
> + * \param[in] value The value to align
> + * \param[in] alignment The alignment
> + * \return The value rounded down to the nearest multiple of \a alignment
> + */
> +
> +/**
> + * \fn alignUp(unsigned int value, unsigned int alignment)
> + * \brief Align \a value up to \a alignment
> + * \param[in] value The value to align
> + * \param[in] alignment The alignment
> + * \return The value rounded up to the nearest multiple of \a alignment
> + */
> +
> } /* namespace utils */
>
> } /* namespace libcamera */
> diff --git a/test/utils.cpp b/test/utils.cpp
> index f482e6a1d829..08f293898fd9 100644
> --- a/test/utils.cpp
> +++ b/test/utils.cpp
> @@ -166,6 +166,17 @@ protected:
> return TestFail;
> }
>
> + /* utils::alignUp() and utils::alignDown() tests. */
> + if (utils::alignDown(6, 3) != 6 || utils::alignDown(7, 3) != 6) {
> + cerr << "utils::alignDown test failed" << endl;
> + return TestFail;
> + }
> +
> + if (utils::alignUp(6, 3) != 6 || utils::alignUp(7, 3) != 9) {
> + cerr << "utils::alignUp test failed" << endl;
> + return TestFail;
> + }
> +
> return TestPass;
> }
> };
> --
> 2.27.0
>
> _______________________________________________
> 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