diff options
author | Damjan Marion <damarion@cisco.com> | 2021-07-13 21:12:41 +0200 |
---|---|---|
committer | Florin Coras <florin.coras@gmail.com> | 2021-07-13 20:06:19 +0000 |
commit | d154a17989b1da7abbfdb87b98b90cc5f4d3295f (patch) | |
tree | 9353de897ec10d0afd3005dd2cf26e0b7ac512ef /src/vppinfra/test_vector_funcs_compress.c | |
parent | b7e4d4487c0fa02f3869d24799c6573452276396 (diff) |
vppinfra: put each vector function into own file
Type: refactor
Change-Id: I2dd9a18497992ac7e2686c14f5d17eccccda0cda
Signed-off-by: Damjan Marion <damarion@cisco.com>
Diffstat (limited to 'src/vppinfra/test_vector_funcs_compress.c')
-rw-r--r-- | src/vppinfra/test_vector_funcs_compress.c | 81 |
1 files changed, 0 insertions, 81 deletions
diff --git a/src/vppinfra/test_vector_funcs_compress.c b/src/vppinfra/test_vector_funcs_compress.c deleted file mode 100644 index c0815601e45..00000000000 --- a/src/vppinfra/test_vector_funcs_compress.c +++ /dev/null @@ -1,81 +0,0 @@ -/* SPDX-License-Identifier: Apache-2.0 - * Copyright(c) 2021 Cisco Systems, Inc. - */ - -#include <vppinfra/format.h> -#include <vppinfra/vector_funcs.h> -#include <vppinfra/test_vector_funcs.h> - -__clib_test_fn u32 -clib_compress_u32_wrapper (u32 *dst, u32 *src, u64 *mask, u32 n_elts) -{ - return clib_compress_u32 (dst, src, mask, n_elts); -} - -typedef struct -{ - u64 mask[10]; - u32 n_elts; -} compress_test_t; - -static compress_test_t tests[] = { - { .mask = { 1 }, .n_elts = 1 }, - { .mask = { 2 }, .n_elts = 2 }, - { .mask = { 3 }, .n_elts = 2 }, - { .mask = { 0, 1 }, .n_elts = 66 }, - { .mask = { 0, 2 }, .n_elts = 69 }, - { .mask = { 0, 3 }, .n_elts = 66 }, - { .mask = { ~0ULL, ~0ULL, ~0ULL, ~0ULL }, .n_elts = 62 }, - { .mask = { ~0ULL, ~0ULL, ~0ULL, ~0ULL }, .n_elts = 255 }, - { .mask = { ~0ULL, 1, 1, ~0ULL }, .n_elts = 256 }, -}; - -static clib_error_t * -test_clib_compress_u32 (clib_error_t *err) -{ - u32 src[513]; - u32 dst[513]; - u32 i, j; - - for (i = 0; i < ARRAY_LEN (src); i++) - src[i] = i; - - for (i = 0; i < ARRAY_LEN (tests); i++) - { - compress_test_t *t = tests + i; - u32 *dp = dst; - u32 r; - - for (j = 0; j < ARRAY_LEN (dst); j++) - dst[j] = 0xa5a5a5a5; - - r = clib_compress_u32_wrapper (dst, src, t->mask, t->n_elts); - - for (j = 0; j < t->n_elts; j++) - { - if ((t->mask[j >> 6] & (1ULL << (j & 0x3f))) == 0) - continue; - - if (dp[0] != src[j]) - return clib_error_return (err, - "wrong data in testcase %u at " - "(dst[%u] = 0x%x, src[%u] = 0x%x)", - i, dp - dst, dp[0], j, src[j]); - dp++; - } - - if (dst[dp - dst + 1] != 0xa5a5a5a5) - return clib_error_return (err, "buffer overrun in testcase %u", i); - - if (dp - dst != r) - return clib_error_return (err, "wrong number of elts in testcase %u", - i); - } - - return err; -} - -REGISTER_TEST (clib_compress_u32) = { - .name = "clib_compress_u32", - .fn = test_clib_compress_u32, -}; |