Hi, I'm seeing compile error. Isn't it due to this patch?
$ gcc --version gcc (GCC) 4.8.5 20150623 (Red Hat 4.8.5-28) [1484/1523] Compiling C object 'app/test/app@test@@dpdk-test@exe/test_compressdev.c.o'. FAILED: app/test/app@test@@dpdk-test@exe/test_compressdev.c.o cc -Iapp/test/app@test@@dpdk-test@exe -Iapp/test -I../app/test -Ilib/librte_acl -I../lib/librte_acl -I. -I../ -Iconfig -I../config -Ilib/librte_eal/common/include -I../lib/librte_eal/common/include -I../lib/librte_eal/linux/eal/include -Ilib/librte_eal/common -I../lib/librte_eal/common -Ilib/librte_eal/common/include/arch/x86 -I../lib/librte_eal/common/include/arch/x86 -Ilib/librte_eal -I../lib/librte_eal -Ilib/librte_kvargs -I../lib/librte_kvargs -Ilib/librte_bitratestats -I../lib/librte_bitratestats -Ilib/librte_ethdev -I../lib/librte_ethdev -Ilib/librte_net -I../lib/librte_net -Ilib/librte_mbuf-I../lib/librte_mbuf -Ilib/librte_mempool -I../lib/librte_mempool -Ilib/librte_ring -I../lib/librte_ring -Ilib/librte_cmdline -I../lib/librte_cmdline -Ilib/librte_meter -I../lib/librte_meter -Ilib/librte_metrics -I../lib/librte_metrics -Ilib/librte_bpf -I../lib/librte_bpf -Ilib/librte_cfgfile -I../lib/librte_cfgfile -Ilib/librte_cryptodev -I../lib/librte_cryptodev -Ilib/librte_distributor -I../lib/librte_distributor -Ilib/librte_efd -I../lib/librte_efd -Ilib/librte_hash -I../lib/librte_hash -Ilib/librte_eventdev -I../lib/librte_eventdev -Ilib/librte_timer -I../lib/librte_timer -Ilib/librte_flow_classify -I../lib/librte_flow_classify -Ilib/librte_table -I../lib/librte_table -Ilib/librte_port -I../lib/librte_port -Ilib/librte_sched -I../lib/librte_sched -Ilib/librte_ip_frag -I../lib/librte_ip_frag -Ilib/librte_kni -I../lib/librte_kni -Ilib/librte_pci -I../lib/librte_pci -Ilib/librte_lpm -I../lib/librte_lpm -Ilib/librte_ipsec -I../lib/librte_ipsec -Ilib/librte_security -I../lib/librte_security -Ilib/librte_latencystats -I../lib/librte_latencystats -Ilib/librte_member -I../lib/librte_member -Ilib/librte_pipeline -I../lib/librte_pipeline -Ilib/librte_reorder -I../lib/librte_reorder -Ilib/librte_stack -I../lib/librte_stack -Ilib/librte_pdump -I../lib/librte_pdump -Idrivers/net/i40e -I../drivers/net/i40e -Idrivers/net/i40e/base -I../drivers/net/i40e/base -Idrivers/bus/pci -I../drivers/bus/pci -I../drivers/bus/pci/linux -Idrivers/bus/vdev -I../drivers/bus/vdev -Idrivers/net/ixgbe -I../drivers/net/ixgbe -Idrivers/net/ixgbe/base -I../drivers/net/ixgbe/base-Idrivers/net/bonding -I../drivers/net/bonding -Idrivers/net/ring -I../drivers/net/ring -Ilib/librte_power -I../lib/librte_power -Ilib/librte_compressdev -I../lib/librte_compressdev -pipe -D_FILE_OFFSET_BITS=64 -Wall -Winvalid-pch -O3 -include rte_config.h -Wsign-compare -Wcast-qual -march=native -D_GNU_SOURCE -DALLOW_EXPERIMENTAL_API -MD -MQ 'app/test/app@test@@dpdk-test@exe/test_compressdev.c.o' -MF 'app/test/app@test@@dpdk-test@exe/test_compressdev.c.o.d' -o 'app/test/app@test@@dpdk-test@exe/test_compressdev.c.o' -c ../app/test/test_compressdev.c ../app/test/test_compressdev.c: In function ‘test_compressdev_deflate_stateless_dynamic_big’: ../app/test/test_compressdev.c:1992:16: error: conflicting types for ‘i’ for (uint32_t i = 0; i < BIG_DATA_TEST_SIZE - 1; ++i) ^ ../app/test/test_compressdev.c:1949:11: note: previous definition of ‘i’ was here uint16_t i = 0; ^ ../app/test/test_compressdev.c:1992:2: error: ‘for’ loop initial declarations are only allowed in C99 mode for (uint32_t i = 0; i < BIG_DATA_TEST_SIZE - 1; ++i) ^ ../app/test/test_compressdev.c:1992:2: note: use option -std=c99 or -std=gnu99 to compile your code ../app/test/test_compressdev.c:1996:19: warning: assignment from incompatible pointer type [enabled by default] int_data.buf_idx = &i; ^ [1501/1523] Generating igb_uio with a custom command. make: Entering directory `/usr/src/kernels/3.10.0-862.el7.x86_64' CC [M] /auto/mtiswgwork/yskoh/git/mellanox/dpdk.org-2/build/kernel/linux/igb_uio/igb_uio.o Building modules, stage 2. MODPOST 1 modules make[1]: Warning: File `/auto/mtiswgwork/yskoh/git/mellanox/dpdk.org-2/build/kernel/linux/igb_uio/igb_uio.mod.c' has modification time 0.0096 s in the future CC /auto/mtiswgwork/yskoh/git/mellanox/dpdk.org-2/build/kernel/linux/igb_uio/igb_uio.mod.o LD [M] /auto/mtiswgwork/yskoh/git/mellanox/dpdk.org-2/build/kernel/linux/igb_uio/igb_uio.ko make[1]: warning: Clock skew detected. Your build may be incomplete. make: Leaving directory `/usr/src/kernels/3.10.0-862.el7.x86_64' Thanks, Yongseok > On Apr 2, 2019, at 5:22 AM, Cel, TomaszX <tomaszx....@intel.com> wrote: > > Hi Tomasz, > >> -----Original Message----- >> From: Cel, TomaszX >> Sent: Tuesday, April 2, 2019 1:17 PM >> To: dev@dpdk.org; Trahe, Fiona <fiona.tr...@intel.com>; Jozwiak, TomaszX >> <tomaszx.jozw...@intel.com>; Cel, TomaszX <tomaszx....@intel.com> >> Subject: [PATCH v2 1/1] test/compress: add max mbuf size test case >> >> From: Tomasz Jozwiak <tomaszx.jozw...@intel.com> >> >> This patch adds new test case in which max. size of chain mbufs has been >> used to compress random data dynamically. >> >> Signed-off-by: Tomasz Jozwiak <tomaszx.jozw...@intel.com> >> --- >> app/test/test_compressdev.c | 158 >> ++++++++++++++++++++++++++++++++++++++------ >> 1 file changed, 136 insertions(+), 22 deletions(-) >> >> diff --git a/app/test/test_compressdev.c b/app/test/test_compressdev.c >> index 13cf26c..f59b3d2 100644 >> --- a/app/test/test_compressdev.c >> +++ b/app/test/test_compressdev.c >> @@ -1,10 +1,10 @@ >> /* SPDX-License-Identifier: BSD-3-Clause >> - * Copyright(c) 2018 Intel Corporation >> + * Copyright(c) 2018 - 2019 Intel Corporation >> */ >> #include <string.h> >> #include <zlib.h> >> #include <math.h> >> -#include <unistd.h> >> +#include <stdlib.h> >> >> #include <rte_cycles.h> >> #include <rte_malloc.h> >> @@ -45,6 +45,11 @@ >> >> #define OUT_OF_SPACE_BUF 1 >> >> +#define MAX_MBUF_SEGMENT_SIZE 65535 >> +#define MAX_DATA_MBUF_SIZE (MAX_MBUF_SEGMENT_SIZE - >> +RTE_PKTMBUF_HEADROOM) #define NUM_BIG_MBUFS 4 #define >> +BIG_DATA_TEST_SIZE (MAX_DATA_MBUF_SIZE * NUM_BIG_MBUFS / 2) >> + >> const char * >> huffman_type_strings[] = { >> [RTE_COMP_HUFFMAN_DEFAULT] = "PMD default", >> @@ -73,6 +78,7 @@ struct priv_op_data { >> struct comp_testsuite_params { >> struct rte_mempool *large_mbuf_pool; >> struct rte_mempool *small_mbuf_pool; >> + struct rte_mempool *big_mbuf_pool; >> struct rte_mempool *op_pool; >> struct rte_comp_xform *def_comp_xform; >> struct rte_comp_xform *def_decomp_xform; @@ -92,6 +98,7 @@ >> struct test_data_params { >> enum varied_buff buff_type; >> enum zlib_direction zlib_dir; >> unsigned int out_of_space; >> + unsigned int big_data; >> }; >> >> static struct comp_testsuite_params testsuite_params = { 0 }; @@ -105,11 >> +112,14 @@ testsuite_teardown(void) >> RTE_LOG(ERR, USER1, "Large mbuf pool still has unfreed >> bufs\n"); >> if (rte_mempool_in_use_count(ts_params->small_mbuf_pool)) >> RTE_LOG(ERR, USER1, "Small mbuf pool still has unfreed >> bufs\n"); >> + if (rte_mempool_in_use_count(ts_params->big_mbuf_pool)) >> + RTE_LOG(ERR, USER1, "Big mbuf pool still has unfreed >> bufs\n"); >> if (rte_mempool_in_use_count(ts_params->op_pool)) >> RTE_LOG(ERR, USER1, "op pool still has unfreed ops\n"); >> >> rte_mempool_free(ts_params->large_mbuf_pool); >> rte_mempool_free(ts_params->small_mbuf_pool); >> + rte_mempool_free(ts_params->big_mbuf_pool); >> rte_mempool_free(ts_params->op_pool); >> rte_free(ts_params->def_comp_xform); >> rte_free(ts_params->def_decomp_xform); >> @@ -162,6 +172,17 @@ testsuite_setup(void) >> goto exit; >> } >> >> + /* Create mempool with big buffers for SGL testing */ >> + ts_params->big_mbuf_pool = >> rte_pktmbuf_pool_create("big_mbuf_pool", >> + NUM_BIG_MBUFS + 1, >> + CACHE_SIZE, 0, >> + MAX_MBUF_SEGMENT_SIZE, >> + rte_socket_id()); >> + if (ts_params->big_mbuf_pool == NULL) { >> + RTE_LOG(ERR, USER1, "Big mbuf pool could not be >> created\n"); >> + goto exit; >> + } >> + >> ts_params->op_pool = rte_comp_op_pool_create("op_pool", >> NUM_OPS, >> 0, sizeof(struct priv_op_data), >> rte_socket_id()); >> @@ -598,10 +619,11 @@ prepare_sgl_bufs(const char *test_buf, struct >> rte_mbuf *head_buf, >> uint32_t total_data_size, >> struct rte_mempool *small_mbuf_pool, >> struct rte_mempool *large_mbuf_pool, >> - uint8_t limit_segs_in_sgl) >> + uint8_t limit_segs_in_sgl, >> + uint16_t seg_size) >> { >> uint32_t remaining_data = total_data_size; >> - uint16_t num_remaining_segs = DIV_CEIL(remaining_data, >> SMALL_SEG_SIZE); >> + uint16_t num_remaining_segs = DIV_CEIL(remaining_data, >> seg_size); >> struct rte_mempool *pool; >> struct rte_mbuf *next_seg; >> uint32_t data_size; >> @@ -617,10 +639,10 @@ prepare_sgl_bufs(const char *test_buf, struct >> rte_mbuf *head_buf, >> * Allocate data in the first segment (header) and >> * copy data if test buffer is provided >> */ >> - if (remaining_data < SMALL_SEG_SIZE) >> + if (remaining_data < seg_size) >> data_size = remaining_data; >> else >> - data_size = SMALL_SEG_SIZE; >> + data_size = seg_size; >> buf_ptr = rte_pktmbuf_append(head_buf, data_size); >> if (buf_ptr == NULL) { >> RTE_LOG(ERR, USER1, >> @@ -644,13 +666,13 @@ prepare_sgl_bufs(const char *test_buf, struct >> rte_mbuf *head_buf, >> >> if (i == (num_remaining_segs - 1)) { >> /* last segment */ >> - if (remaining_data > SMALL_SEG_SIZE) >> + if (remaining_data > seg_size) >> pool = large_mbuf_pool; >> else >> pool = small_mbuf_pool; >> data_size = remaining_data; >> } else { >> - data_size = SMALL_SEG_SIZE; >> + data_size = seg_size; >> pool = small_mbuf_pool; >> } >> >> @@ -704,6 +726,7 @@ test_deflate_comp_decomp(const struct >> interim_data_params *int_data, >> enum rte_comp_op_type state = test_data->state; >> unsigned int buff_type = test_data->buff_type; >> unsigned int out_of_space = test_data->out_of_space; >> + unsigned int big_data = test_data->big_data; >> enum zlib_direction zlib_dir = test_data->zlib_dir; >> int ret_status = -1; >> int ret; >> @@ -738,7 +761,9 @@ test_deflate_comp_decomp(const struct >> interim_data_params *int_data, >> memset(ops_processed, 0, sizeof(struct rte_comp_op *) * >> num_bufs); >> memset(priv_xforms, 0, sizeof(void *) * num_bufs); >> >> - if (buff_type == SGL_BOTH) >> + if (big_data) >> + buf_pool = ts_params->big_mbuf_pool; >> + else if (buff_type == SGL_BOTH) >> buf_pool = ts_params->small_mbuf_pool; >> else >> buf_pool = ts_params->large_mbuf_pool; @@ -757,10 >> +782,11 @@ test_deflate_comp_decomp(const struct interim_data_params >> *int_data, >> for (i = 0; i < num_bufs; i++) { >> data_size = strlen(test_bufs[i]) + 1; >> if (prepare_sgl_bufs(test_bufs[i], uncomp_bufs[i], >> - data_size, >> - ts_params->small_mbuf_pool, >> - ts_params->large_mbuf_pool, >> - MAX_SEGS) < 0) >> + data_size, >> + big_data ? buf_pool : ts_params- >>> small_mbuf_pool, >> + big_data ? buf_pool : ts_params- >>> large_mbuf_pool, >> + big_data ? 0 : MAX_SEGS, >> + big_data ? MAX_DATA_MBUF_SIZE : >> SMALL_SEG_SIZE) < 0) >> goto exit; >> } >> } else { >> @@ -789,10 +815,12 @@ test_deflate_comp_decomp(const struct >> interim_data_params *int_data, >> COMPRESS_BUF_SIZE_RATIO); >> >> if (prepare_sgl_bufs(NULL, comp_bufs[i], >> - data_size, >> - ts_params->small_mbuf_pool, >> - ts_params->large_mbuf_pool, >> - MAX_SEGS) < 0) >> + data_size, >> + big_data ? buf_pool : ts_params- >>> small_mbuf_pool, >> + big_data ? buf_pool : ts_params- >>> large_mbuf_pool, >> + big_data ? 0 : MAX_SEGS, >> + big_data ? MAX_DATA_MBUF_SIZE : >> SMALL_SEG_SIZE) >> + < 0) >> goto exit; >> } >> >> @@ -1017,10 +1045,12 @@ test_deflate_comp_decomp(const struct >> interim_data_params *int_data, >> strlen(test_bufs[priv_data->orig_idx]) + 1; >> >> if (prepare_sgl_bufs(NULL, uncomp_bufs[i], >> - data_size, >> - ts_params->small_mbuf_pool, >> - ts_params->large_mbuf_pool, >> - MAX_SEGS) < 0) >> + data_size, >> + big_data ? buf_pool : ts_params- >>> small_mbuf_pool, >> + big_data ? buf_pool : ts_params- >>> large_mbuf_pool, >> + big_data ? 0 : MAX_SEGS, >> + big_data ? MAX_DATA_MBUF_SIZE : >> SMALL_SEG_SIZE) >> + < 0) >> goto exit; >> } >> >> @@ -1320,6 +1350,7 @@ test_compressdev_deflate_stateless_fixed(void) >> RTE_COMP_OP_STATELESS, >> LB_BOTH, >> ZLIB_DECOMPRESS, >> + 0, >> 0 >> }; >> >> @@ -1390,6 +1421,7 @@ >> test_compressdev_deflate_stateless_dynamic(void) >> RTE_COMP_OP_STATELESS, >> LB_BOTH, >> ZLIB_DECOMPRESS, >> + 0, >> 0 >> }; >> >> @@ -1443,6 +1475,7 @@ >> test_compressdev_deflate_stateless_multi_op(void) >> RTE_COMP_OP_STATELESS, >> LB_BOTH, >> ZLIB_DECOMPRESS, >> + 0, >> 0 >> }; >> >> @@ -1492,6 +1525,7 @@ >> test_compressdev_deflate_stateless_multi_level(void) >> RTE_COMP_OP_STATELESS, >> LB_BOTH, >> ZLIB_DECOMPRESS, >> + 0, >> 0 >> }; >> >> @@ -1581,6 +1615,7 @@ >> test_compressdev_deflate_stateless_multi_xform(void) >> RTE_COMP_OP_STATELESS, >> LB_BOTH, >> ZLIB_DECOMPRESS, >> + 0, >> 0 >> }; >> >> @@ -1626,6 +1661,7 @@ test_compressdev_deflate_stateless_sgl(void) >> RTE_COMP_OP_STATELESS, >> SGL_BOTH, >> ZLIB_DECOMPRESS, >> + 0, >> 0 >> }; >> >> @@ -1733,6 +1769,7 @@ >> test_compressdev_deflate_stateless_checksum(void) >> RTE_COMP_OP_STATELESS, >> LB_BOTH, >> ZLIB_DECOMPRESS, >> + 0, >> 0 >> }; >> >> @@ -1863,7 +1900,8 @@ test_compressdev_out_of_space_buffer(void) >> RTE_COMP_OP_STATELESS, >> LB_BOTH, >> ZLIB_DECOMPRESS, >> - 1 >> + 1, >> + 0 >> }; >> /* Compress with compressdev, decompress with Zlib */ >> test_data.zlib_dir = ZLIB_DECOMPRESS; >> @@ -1904,6 +1942,80 @@ test_compressdev_out_of_space_buffer(void) >> return ret; >> } >> >> +static int >> +test_compressdev_deflate_stateless_dynamic_big(void) >> +{ >> + struct comp_testsuite_params *ts_params = &testsuite_params; >> + uint16_t i = 0; >> + int ret = TEST_SUCCESS; >> + const struct rte_compressdev_capabilities *capab; >> + char *test_buffer = NULL; >> + >> + capab = rte_compressdev_capability_get(0, >> RTE_COMP_ALGO_DEFLATE); >> + TEST_ASSERT(capab != NULL, "Failed to retrieve device capabilities"); >> + >> + if ((capab->comp_feature_flags & >> RTE_COMP_FF_HUFFMAN_DYNAMIC) == 0) >> + return -ENOTSUP; >> + >> + if ((capab->comp_feature_flags & >> RTE_COMP_FF_OOP_SGL_IN_SGL_OUT) == 0) >> + return -ENOTSUP; >> + >> + test_buffer = rte_malloc(NULL, BIG_DATA_TEST_SIZE, 0); >> + if (test_buffer == NULL) { >> + RTE_LOG(ERR, USER1, >> + "Can't allocate buffer for big-data\n"); >> + return TEST_FAILED; >> + } >> + >> + struct interim_data_params int_data = { >> + (const char * const *)&test_buffer, >> + 1, >> + NULL, >> + &ts_params->def_comp_xform, >> + &ts_params->def_decomp_xform, >> + 1 >> + }; >> + >> + struct test_data_params test_data = { >> + RTE_COMP_OP_STATELESS, >> + SGL_BOTH, >> + ZLIB_DECOMPRESS, >> + 0, >> + 1 >> + }; >> + >> + ts_params->def_comp_xform->compress.deflate.huffman = >> + >> RTE_COMP_HUFFMAN_DYNAMIC; >> + >> + /* fill the buffer with data based on rand. data */ >> + srand(BIG_DATA_TEST_SIZE); >> + for (uint32_t i = 0; i < BIG_DATA_TEST_SIZE - 1; ++i) >> + test_buffer[i] = (uint8_t)(rand() % ((uint8_t)-1)) | 1; >> + >> + test_buffer[BIG_DATA_TEST_SIZE-1] = 0; >> + int_data.buf_idx = &i; >> + >> + /* Compress with compressdev, decompress with Zlib */ >> + test_data.zlib_dir = ZLIB_DECOMPRESS; >> + if (test_deflate_comp_decomp(&int_data, &test_data) < 0) { >> + ret = TEST_FAILED; >> + goto end; >> + } >> + >> + /* Compress with Zlib, decompress with compressdev */ >> + test_data.zlib_dir = ZLIB_COMPRESS; >> + if (test_deflate_comp_decomp(&int_data, &test_data) < 0) { >> + ret = TEST_FAILED; >> + goto end; >> + } >> + >> +end: >> + ts_params->def_comp_xform->compress.deflate.huffman = >> + >> RTE_COMP_HUFFMAN_DEFAULT; >> + rte_free(test_buffer); >> + return ret; >> +} >> + >> >> static struct unit_test_suite compressdev_testsuite = { >> .suite_name = "compressdev unit test suite", @@ -1917,6 +2029,8 >> @@ static struct unit_test_suite compressdev_testsuite = { >> TEST_CASE_ST(generic_ut_setup, generic_ut_teardown, >> test_compressdev_deflate_stateless_dynamic), >> TEST_CASE_ST(generic_ut_setup, generic_ut_teardown, >> + test_compressdev_deflate_stateless_dynamic_big), >> + TEST_CASE_ST(generic_ut_setup, generic_ut_teardown, >> test_compressdev_deflate_stateless_multi_op), >> TEST_CASE_ST(generic_ut_setup, generic_ut_teardown, >> test_compressdev_deflate_stateless_multi_level), >> -- >> 2.7.4 > > Acked-by: Tomasz Cel <tomaszx....@intel.com> >