numam-dpdk/app/test-bbdev/test_bbdev_vector.h
Amr Mokhtar f714a18885 app/testbbdev: add test application for bbdev
- full test suite for bbdev
- test App works seamlessly on all PMDs registered with bbdev
 framework
- a python script is provided to make our life easier
- supports execution of tests by parsing Test Vector files
- test Vectors can be added/deleted/modified with no need for
 re-compilation
- various tests can be executed:
 (a) Throughput test
 (b) Offload latency test
 (c) Operation latency test
 (d) Validation test
 (c) Sanity checks

Signed-off-by: Amr Mokhtar <amr.mokhtar@intel.com>
2018-01-19 01:44:25 +01:00

72 lines
1.8 KiB
C

/* SPDX-License-Identifier: BSD-3-Clause
* Copyright(c) 2017 Intel Corporation
*/
#ifndef TEST_BBDEV_VECTOR_H_
#define TEST_BBDEV_VECTOR_H_
#include <rte_bbdev_op.h>
/* Flags which are set when specific parameter is define in vector file */
enum {
TEST_BBDEV_VF_E = (1ULL << 0),
TEST_BBDEV_VF_EA = (1ULL << 1),
TEST_BBDEV_VF_EB = (1ULL << 2),
TEST_BBDEV_VF_K = (1ULL << 3),
TEST_BBDEV_VF_K_NEG = (1ULL << 4),
TEST_BBDEV_VF_K_POS = (1ULL << 5),
TEST_BBDEV_VF_C_NEG = (1ULL << 6),
TEST_BBDEV_VF_C = (1ULL << 7),
TEST_BBDEV_VF_CAB = (1ULL << 8),
TEST_BBDEV_VF_RV_INDEX = (1ULL << 9),
TEST_BBDEV_VF_ITER_MAX = (1ULL << 10),
TEST_BBDEV_VF_ITER_MIN = (1ULL << 11),
TEST_BBDEV_VF_EXPECTED_ITER_COUNT = (1ULL << 12),
TEST_BBDEV_VF_EXT_SCALE = (1ULL << 13),
TEST_BBDEV_VF_NUM_MAPS = (1ULL << 14),
TEST_BBDEV_VF_NCB = (1ULL << 15),
TEST_BBDEV_VF_NCB_NEG = (1ULL << 16),
TEST_BBDEV_VF_NCB_POS = (1ULL << 17),
TEST_BBDEV_VF_R = (1ULL << 18),
TEST_BBDEV_VF_CODE_BLOCK_MODE = (1ULL << 19),
TEST_BBDEV_VF_OP_FLAGS = (1ULL << 20),
TEST_BBDEV_VF_EXPECTED_STATUS = (1ULL << 21),
};
enum op_data_type {
DATA_INPUT = 0,
DATA_SOFT_OUTPUT,
DATA_HARD_OUTPUT,
DATA_NUM_TYPES,
};
struct op_data_buf {
uint32_t *addr;
uint32_t length;
};
struct op_data_entries {
struct op_data_buf segments[RTE_BBDEV_MAX_CODE_BLOCKS];
unsigned int nb_segments;
};
struct test_bbdev_vector {
enum rte_bbdev_op_type op_type;
int expected_status;
int mask;
union {
struct rte_bbdev_op_turbo_dec turbo_dec;
struct rte_bbdev_op_turbo_enc turbo_enc;
};
/* Additional storage for op data entries */
struct op_data_entries entries[DATA_NUM_TYPES];
};
/* fills test vector parameters based on test file */
int
test_bbdev_vector_read(const char *filename,
struct test_bbdev_vector *vector);
#endif /* TEST_BBDEV_VECTOR_H_ */