[PATCH 1/1] lib:tests: add math test suite

Anup Patel anup at brainfault.org
Mon Jul 22 21:50:18 PDT 2024


On Mon, Jul 1, 2024 at 8:00 AM <zhangdongdong at eswincomputing.com> wrote:
>
> From: Dongdong Zhang <zhangdongdong at eswincomputing.com>
>
> This patch introduces a new math test suite to the SBI unit
> tests. The changes include:
>
> * Updating lib/sbi/tests/objects.mk to include
>   math_test_suite and sbi_math_test.o.
> * Adding a new file lib/sbi/tests/sbi_math_test.c which
>   contains tests for log2roundup function using various cases.
>
> The addition of this test suite ensures that mathematical
> functions are verified and work as expected.
>
> Signed-off-by: Dongdong Zhang <zhangdongdong at eswincomputing.com>

Need a space between "lib:" and "tests:" in the patch subject. Otherwise,
looks good to me. I will take care of this at the time of merging this patch.

Reviewed-by: Anup Patel <anup at brainfault.org>

Applied this patch to the riscv/opensbi repo.

Thanks,
Anup

> ---
>  lib/sbi/tests/objects.mk      |  3 +++
>  lib/sbi/tests/sbi_math_test.c | 46 +++++++++++++++++++++++++++++++++++
>  2 files changed, 49 insertions(+)
>  create mode 100644 lib/sbi/tests/sbi_math_test.c
>
> diff --git a/lib/sbi/tests/objects.mk b/lib/sbi/tests/objects.mk
> index 8f27289..82b6061 100644
> --- a/lib/sbi/tests/objects.mk
> +++ b/lib/sbi/tests/objects.mk
> @@ -12,3 +12,6 @@ libsbi-objs-$(CONFIG_SBIUNIT) += tests/riscv_atomic_test.o
>
>  carray-sbi_unit_tests-$(CONFIG_SBIUNIT) += locks_test_suite
>  libsbi-objs-$(CONFIG_SBIUNIT) += tests/riscv_locks_test.o
> +
> +carray-sbi_unit_tests-$(CONFIG_SBIUNIT) += math_test_suite
> +libsbi-objs-$(CONFIG_SBIUNIT) += tests/sbi_math_test.o
> \ No newline at end of file
> diff --git a/lib/sbi/tests/sbi_math_test.c b/lib/sbi/tests/sbi_math_test.c
> new file mode 100644
> index 0000000..81ed832
> --- /dev/null
> +++ b/lib/sbi/tests/sbi_math_test.c
> @@ -0,0 +1,46 @@
> +/*
> + * SPDX-License-Identifier: BSD-2-Clause
> + *
> + * Copyright  2024  Beijing ESWIN Computing Technology Co., Ltd.
> + *
> + * Author: Dongdong Zhang <zhangdongdong at eswincomputing.com>
> + */
> +#include <sbi/sbi_math.h>
> +#include <sbi/sbi_unit_test.h>
> +
> +static void log2roundup_test(struct sbiunit_test_case *test)
> +{
> +    struct {
> +        unsigned long input;
> +        unsigned long expected;
> +    } cases[] = {
> +        {1, 0},
> +        {2, 1},
> +        {3, 2},
> +        {4, 2},
> +        {5, 3},
> +        {8, 3},
> +        {9, 4},
> +        {15, 4},
> +        {16, 4},
> +        {17, 5},
> +        {31, 5},
> +        {32, 5},
> +        {33, 6},
> +        {63, 6},
> +        {64, 6},
> +        {65, 7},
> +    };
> +
> +    for (int i = 0; i < sizeof(cases)/sizeof(cases[0]); i++) {
> +        unsigned long result = log2roundup(cases[i].input);
> +        SBIUNIT_EXPECT_EQ(test, result, cases[i].expected);
> +    }
> +}
> +
> +static struct sbiunit_test_case math_test_cases[] = {
> +    SBIUNIT_TEST_CASE(log2roundup_test),
> +    SBIUNIT_END_CASE,
> +};
> +
> +SBIUNIT_TEST_SUITE(math_test_suite, math_test_cases);
> --
> 2.17.1
>
>
> --
> opensbi mailing list
> opensbi at lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/opensbi



More information about the opensbi mailing list