Hi Honnappa,
 
> Hi Konstantin,
>       I like the way the tests are organized and it looks good.
> 
> I am just wondering about the way it is being tested here. The intent to 
> write the test cases the way they are currently is to mimic how the
> APIs would be used mostly. IMO, the APIs would be used with a constant value 
> for element size so that the compiler will throw away the
> unwanted code (in the functions where the actual copy is being done).
> 
> With your method here, it looks to me like all the branches in the copy 
> functions are kept and the branch decisions are done at run time.
> Is  my understanding correct?

You mean branching on esize[] values?
Actually from what I've seen that happens for both cases:
before and after the patch (gcc 7.3 -O3).

Main intention in my changes was to avoid using 
test_ring_enqueue/test_ring_dequeue,
as it seems too many branches here and it takes compiler a lot of effort to 
resolve all
of them at compile time.
So I replaced it with  array of function pointers (test_enqdeq_impl[]) and 
iterating over it.
That way compiler knows straightway which function to use.
 
> Can you please check this? https://patches.dpdk.org/patch/69567/

As I can see your approach reduces number of test-cases by factor of 5:
now each of test_ring_burst_bulk_tests[1-4] is executed only with just
one esize value, correct?
In term of compilation speed - it helps.
On my box with (gcc 7.3 -O3)  compiling test_ring.c takes:
orig code:                             ~100s
with 69567 (your patch):  < 20s
with 69559 (my patch):    < 10s

Konstantin
 
> 
> > -----Original Message-----
> > From: Konstantin Ananyev <konstantin.anan...@intel.com>
> > Sent: Wednesday, April 29, 2020 12:57 PM
> > To: dev@dpdk.org
> > Cc: acon...@redhat.com; Honnappa Nagarahalli
> > <honnappa.nagaraha...@arm.com>; Konstantin Ananyev
> > <konstantin.anan...@intel.com>
> > Subject: [PATCH] test/ring: code rework to reduce compilation time
> >
> > Rework test code to reduce code complexity for the compiler and bring down
> > compilation time and memory consumption.
> >
> > Signed-off-by: Konstantin Ananyev <konstantin.anan...@intel.com>
> > ---
> >  app/test/test_ring.c | 373 +++++++++++++++++++++++++++++--------------
> >  1 file changed, 249 insertions(+), 124 deletions(-)
> >
> > diff --git a/app/test/test_ring.c b/app/test/test_ring.c index
> > e21557cd9..0ae97d341 100644
> > --- a/app/test/test_ring.c
> > +++ b/app/test/test_ring.c
> > @@ -58,6 +58,181 @@
> >
> >  static const int esize[] = {-1, 4, 8, 16, 20};
> >
> > +static const struct {
> > +   const char *desc;
> > +   uint32_t api_type;
> > +   uint32_t create_flags;
> > +   struct {
> > +           unsigned int (*flegacy)(struct rte_ring *r,
> > +                   void * const *obj_table, unsigned int n,
> > +                   unsigned int *free_space);
> > +           unsigned int (*felem)(struct rte_ring *r, const void *obj_table,
> > +                   unsigned int esize, unsigned int n,
> > +                   unsigned int *free_space);
> > +   } enq;
> > +   struct {
> > +           unsigned int (*flegacy)(struct rte_ring *r,
> > +                   void **obj_table, unsigned int n,
> > +                   unsigned int *available);
> > +           unsigned int (*felem)(struct rte_ring *r, void *obj_table,
> > +                   unsigned int esize, unsigned int n,
> > +                   unsigned int *available);
> > +   } deq;
> > +} test_enqdeq_impl[] = {
> > +   {
> > +           .desc = "MP/MC sync mode",
> Details about the tests are already printed by the function 
> 'test_ring_print_test_string'. This string should be 'Test standard ring'.
> 
> > +           .api_type = TEST_RING_ELEM_BULK |
> > TEST_RING_THREAD_DEF,
> > +           .create_flags = 0,
> > +           .enq = {
> > +                   .flegacy = rte_ring_enqueue_bulk,
> > +                   .felem = rte_ring_enqueue_bulk_elem,
> > +           },
> > +           .deq = {
> > +                   .flegacy = rte_ring_dequeue_bulk,
> > +                   .felem = rte_ring_dequeue_bulk_elem,
> > +           },
> > +   },
> > +   {
> > +           .desc = "SP/SC sync mode",
> > +           .api_type = TEST_RING_ELEM_BULK |
> > TEST_RING_THREAD_SPSC,
> > +           .create_flags = RING_F_SP_ENQ | RING_F_SC_DEQ,
> > +           .enq = {
> > +                   .flegacy = rte_ring_sp_enqueue_bulk,
> > +                   .felem = rte_ring_sp_enqueue_bulk_elem,
> > +           },
> > +           .deq = {
> > +                   .flegacy = rte_ring_sc_dequeue_bulk,
> > +                   .felem = rte_ring_sc_dequeue_bulk_elem,
> > +           },
> > +   },
> > +   {
> > +           .desc = "MP/MC sync mode",
> > +           .api_type = TEST_RING_ELEM_BULK |
> > TEST_RING_THREAD_MPMC,
> > +           .create_flags = 0,
> > +           .enq = {
> > +                   .flegacy = rte_ring_mp_enqueue_bulk,
> > +                   .felem = rte_ring_mp_enqueue_bulk_elem,
> > +           },
> > +           .deq = {
> > +                   .flegacy = rte_ring_mc_dequeue_bulk,
> > +                   .felem = rte_ring_mc_dequeue_bulk_elem,
> > +           },
> > +   },
> > +   {
> > +           .desc = "MP_RTS/MC_RTS sync mode",
> > +           .api_type = TEST_RING_ELEM_BULK |
> > TEST_RING_THREAD_DEF,
> > +           .create_flags = RING_F_MP_RTS_ENQ |
> > RING_F_MC_RTS_DEQ,
> > +           .enq = {
> > +                   .flegacy = rte_ring_enqueue_bulk,
> > +                   .felem = rte_ring_enqueue_bulk_elem,
> > +           },
> > +           .deq = {
> > +                   .flegacy = rte_ring_dequeue_bulk,
> > +                   .felem = rte_ring_dequeue_bulk_elem,
> > +           },
> > +   },
> > +   {
> > +           .desc = "MP_HTS/MC_HTS sync mode",
> > +           .api_type = TEST_RING_ELEM_BULK |
> > TEST_RING_THREAD_DEF,
> > +           .create_flags = RING_F_MP_HTS_ENQ |
> > RING_F_MC_HTS_DEQ,
> > +           .enq = {
> > +                   .flegacy = rte_ring_enqueue_bulk,
> > +                   .felem = rte_ring_enqueue_bulk_elem,
> > +           },
> > +           .deq = {
> > +                   .flegacy = rte_ring_dequeue_bulk,
> > +                   .felem = rte_ring_dequeue_bulk_elem,
> > +           },
> > +   },
> > +   {
> > +           .desc = "MP/MC sync mode",
> > +           .api_type = TEST_RING_ELEM_BURST |
> > TEST_RING_THREAD_DEF,
> > +           .create_flags = 0,
> > +           .enq = {
> > +                   .flegacy = rte_ring_enqueue_burst,
> > +                   .felem = rte_ring_enqueue_burst_elem,
> > +           },
> > +           .deq = {
> > +                   .flegacy = rte_ring_dequeue_burst,
> > +                   .felem = rte_ring_dequeue_burst_elem,
> > +           },
> > +   },
> > +   {
> > +           .desc = "SP/SC sync mode",
> > +           .api_type = TEST_RING_ELEM_BURST |
> > TEST_RING_THREAD_SPSC,
> > +           .create_flags = RING_F_SP_ENQ | RING_F_SC_DEQ,
> > +           .enq = {
> > +                   .flegacy = rte_ring_sp_enqueue_burst,
> > +                   .felem = rte_ring_sp_enqueue_burst_elem,
> > +           },
> > +           .deq = {
> > +                   .flegacy = rte_ring_sc_dequeue_burst,
> > +                   .felem = rte_ring_sc_dequeue_burst_elem,
> > +           },
> > +   },
> > +   {
> > +           .desc = "MP/MC sync mode",
> > +           .api_type = TEST_RING_ELEM_BURST |
> > TEST_RING_THREAD_MPMC,
> > +           .create_flags = 0,
> > +           .enq = {
> > +                   .flegacy = rte_ring_mp_enqueue_burst,
> > +                   .felem = rte_ring_mp_enqueue_burst_elem,
> > +           },
> > +           .deq = {
> > +                   .flegacy = rte_ring_mc_dequeue_burst,
> > +                   .felem = rte_ring_mc_dequeue_burst_elem,
> > +           },
> > +   },
> > +   {
> > +           .desc = "MP_RTS/MC_RTS sync mode",
> > +           .api_type = TEST_RING_ELEM_BURST |
> > TEST_RING_THREAD_DEF,
> > +           .create_flags = RING_F_MP_RTS_ENQ |
> > RING_F_MC_RTS_DEQ,
> > +           .enq = {
> > +                   .flegacy = rte_ring_enqueue_burst,
> > +                   .felem = rte_ring_enqueue_burst_elem,
> > +           },
> > +           .deq = {
> > +                   .flegacy = rte_ring_dequeue_burst,
> > +                   .felem = rte_ring_dequeue_burst_elem,
> > +           },
> > +   },
> > +   {
> > +           .desc = "MP_HTS/MC_HTS sync mode",
> > +           .api_type = TEST_RING_ELEM_BURST |
> > TEST_RING_THREAD_DEF,
> > +           .create_flags = RING_F_MP_HTS_ENQ |
> > RING_F_MC_HTS_DEQ,
> > +           .enq = {
> > +                   .flegacy = rte_ring_enqueue_burst,
> > +                   .felem = rte_ring_enqueue_burst_elem,
> > +           },
> > +           .deq = {
> > +                   .flegacy = rte_ring_dequeue_burst,
> > +                   .felem = rte_ring_dequeue_burst_elem,
> > +           },
> > +   },
> > +};
> > +
> > +static unsigned int
> > +test_ring_enq_impl(struct rte_ring *r, void **obj, int esize, unsigned int 
> > n,
> > +   unsigned int test_idx)
> > +{
> > +   if (esize == -1)
> > +           return test_enqdeq_impl[test_idx].enq.flegacy(r, obj, n, NULL);
> > +   else
> > +           return test_enqdeq_impl[test_idx].enq.felem(r, obj, esize, n,
> > +                   NULL);
> > +}
> > +
> > +static unsigned int
> > +test_ring_deq_impl(struct rte_ring *r, void **obj, int esize, unsigned int 
> > n,
> > +   unsigned int test_idx)
> > +{
> > +   if (esize == -1)
> > +           return test_enqdeq_impl[test_idx].deq.flegacy(r, obj, n, NULL);
> > +   else
> > +           return test_enqdeq_impl[test_idx].deq.felem(r, obj, esize, n,
> > +                   NULL);
> > +}
> > +
> >  static void**
> >  test_ring_inc_ptr(void **obj, int esize, unsigned int n)  { @@ -203,8 
> > +378,7
> > @@ test_ring_negative_tests(void)
> >   * Random number of elements are enqueued and dequeued.
> >   */
> >  static int
> > -test_ring_burst_bulk_tests1(unsigned int api_type, unsigned int 
> > create_flags,
> > -   const char *tname)
> > +test_ring_burst_bulk_tests1(unsigned int test_idx)
> >  {
> >     struct rte_ring *r;
> >     void **src = NULL, **cur_src = NULL, **dst = NULL, **cur_dst = NULL;
> > @@ -214,11 +388,13 @@ test_ring_burst_bulk_tests1(unsigned int api_type,
> > unsigned int create_flags,
> >     const unsigned int rsz = RING_SIZE - 1;
> >
> >     for (i = 0; i < RTE_DIM(esize); i++) {
> > -           test_ring_print_test_string(tname, api_type, esize[i]);
> > +           test_ring_print_test_string(test_enqdeq_impl[test_idx].desc,
> > +                   test_enqdeq_impl[test_idx].api_type, esize[i]);
> >
> >             /* Create the ring */
> >             r = test_ring_create("test_ring_burst_bulk_tests", esize[i],
> > -                                   RING_SIZE, SOCKET_ID_ANY,
> > create_flags);
> > +                           RING_SIZE, SOCKET_ID_ANY,
> > +                           test_enqdeq_impl[test_idx].create_flags);
> >
> >             /* alloc dummy object pointers */
> >             src = test_ring_calloc(RING_SIZE * 2, esize[i]); @@ -240,17
> > +416,17 @@ test_ring_burst_bulk_tests1(unsigned int api_type, unsigned int
> > create_flags,
> >                     rand = RTE_MAX(rte_rand() % RING_SIZE, 1UL);
> >                     printf("%s: iteration %u, random shift: %u;\n",
> >                         __func__, i, rand);
> > -                   ret = test_ring_enqueue(r, cur_src, esize[i], rand,
> > -                                                   api_type);
> > +                   ret = test_ring_enq_impl(r, cur_src, esize[i], rand,
> > +                                                   test_idx);
> >                     TEST_RING_VERIFY(ret != 0);
> >
> > -                   ret = test_ring_dequeue(r, cur_dst, esize[i], rand,
> > -                                                   api_type);
> > +                   ret = test_ring_deq_impl(r, cur_dst, esize[i], rand,
> > +                                                   test_idx);
> >                     TEST_RING_VERIFY(ret == rand);
> >
> >                     /* fill the ring */
> > -                   ret = test_ring_enqueue(r, cur_src, esize[i], rsz,
> > -                                                   api_type);
> > +                   ret = test_ring_enq_impl(r, cur_src, esize[i], rsz,
> > +                                                   test_idx);
> >                     TEST_RING_VERIFY(ret != 0);
> >
> >                     TEST_RING_VERIFY(rte_ring_free_count(r) == 0); @@
> > -259,8 +435,8 @@ test_ring_burst_bulk_tests1(unsigned int api_type,
> > unsigned int create_flags,
> >                     TEST_RING_VERIFY(rte_ring_empty(r) == 0);
> >
> >                     /* empty the ring */
> > -                   ret = test_ring_dequeue(r, cur_dst, esize[i], rsz,
> > -                                                   api_type);
> > +                   ret = test_ring_deq_impl(r, cur_dst, esize[i], rsz,
> > +                                                   test_idx);
> >                     TEST_RING_VERIFY(ret == (int)rsz);
> >                     TEST_RING_VERIFY(rsz == rte_ring_free_count(r));
> >                     TEST_RING_VERIFY(rte_ring_count(r) == 0); @@ -
> > 294,8 +470,7 @@ test_ring_burst_bulk_tests1(unsigned int api_type,
> > unsigned int create_flags,
> >   * dequeued data.
> >   */
> >  static int
> > -test_ring_burst_bulk_tests2(unsigned int api_type, unsigned int 
> > create_flags,
> > -   const char *tname)
> > +test_ring_burst_bulk_tests2(unsigned int test_idx)
> >  {
> >     struct rte_ring *r;
> >     void **src = NULL, **cur_src = NULL, **dst = NULL, **cur_dst = NULL;
> > @@ -303,11 +478,13 @@ test_ring_burst_bulk_tests2(unsigned int api_type,
> > unsigned int create_flags,
> >     unsigned int i;
> >
> >     for (i = 0; i < RTE_DIM(esize); i++) {
> > -           test_ring_print_test_string(tname, api_type, esize[i]);
> > +           test_ring_print_test_string(test_enqdeq_impl[test_idx].desc,
> > +                   test_enqdeq_impl[test_idx].api_type, esize[i]);
> >
> >             /* Create the ring */
> >             r = test_ring_create("test_ring_burst_bulk_tests", esize[i],
> > -                                   RING_SIZE, SOCKET_ID_ANY,
> > create_flags);
> > +                           RING_SIZE, SOCKET_ID_ANY,
> > +                           test_enqdeq_impl[test_idx].create_flags);
> >
> >             /* alloc dummy object pointers */
> >             src = test_ring_calloc(RING_SIZE * 2, esize[i]); @@ -323,39
> > +500,39 @@ test_ring_burst_bulk_tests2(unsigned int api_type, unsigned int
> > create_flags,
> >             cur_dst = dst;
> >
> >             printf("enqueue 1 obj\n");
> > -           ret = test_ring_enqueue(r, cur_src, esize[i], 1, api_type);
> > +           ret = test_ring_enq_impl(r, cur_src, esize[i], 1, test_idx);
> >             if (ret != 1)
> >                     goto fail;
> >             cur_src = test_ring_inc_ptr(cur_src, esize[i], 1);
> >
> >             printf("enqueue 2 objs\n");
> > -           ret = test_ring_enqueue(r, cur_src, esize[i], 2, api_type);
> > +           ret = test_ring_enq_impl(r, cur_src, esize[i], 2, test_idx);
> >             if (ret != 2)
> >                     goto fail;
> >             cur_src = test_ring_inc_ptr(cur_src, esize[i], 2);
> >
> >             printf("enqueue MAX_BULK objs\n");
> > -           ret = test_ring_enqueue(r, cur_src, esize[i], MAX_BULK,
> > -                                           api_type);
> > +           ret = test_ring_enq_impl(r, cur_src, esize[i], MAX_BULK,
> > +                                           test_idx);
> >             if (ret != MAX_BULK)
> >                     goto fail;
> >             cur_src = test_ring_inc_ptr(cur_src, esize[i], MAX_BULK);
> >
> >             printf("dequeue 1 obj\n");
> > -           ret = test_ring_dequeue(r, cur_dst, esize[i], 1, api_type);
> > +           ret = test_ring_deq_impl(r, cur_dst, esize[i], 1, test_idx);
> >             if (ret != 1)
> >                     goto fail;
> >             cur_dst = test_ring_inc_ptr(cur_dst, esize[i], 1);
> >
> >             printf("dequeue 2 objs\n");
> > -           ret = test_ring_dequeue(r, cur_dst, esize[i], 2, api_type);
> > +           ret = test_ring_deq_impl(r, cur_dst, esize[i], 2, test_idx);
> >             if (ret != 2)
> >                     goto fail;
> >             cur_dst = test_ring_inc_ptr(cur_dst, esize[i], 2);
> >
> >             printf("dequeue MAX_BULK objs\n");
> > -           ret = test_ring_dequeue(r, cur_dst, esize[i], MAX_BULK,
> > -                                           api_type);
> > +           ret = test_ring_deq_impl(r, cur_dst, esize[i], MAX_BULK,
> > +                                           test_idx);
> >             if (ret != MAX_BULK)
> >                     goto fail;
> >             cur_dst = test_ring_inc_ptr(cur_dst, esize[i], MAX_BULK); @@
> > -390,8 +567,7 @@ test_ring_burst_bulk_tests2(unsigned int api_type,
> > unsigned int create_flags,
> >   * Enqueue and dequeue to cover the entire ring length.
> >   */
> >  static int
> > -test_ring_burst_bulk_tests3(unsigned int api_type, unsigned int 
> > create_flags,
> > -   const char *tname)
> > +test_ring_burst_bulk_tests3(unsigned int test_idx)
> >  {
> >     struct rte_ring *r;
> >     void **src = NULL, **cur_src = NULL, **dst = NULL, **cur_dst = NULL;
> > @@ -399,11 +575,13 @@ test_ring_burst_bulk_tests3(unsigned int api_type,
> > unsigned int create_flags,
> >     unsigned int i, j;
> >
> >     for (i = 0; i < RTE_DIM(esize); i++) {
> > -           test_ring_print_test_string(tname, api_type, esize[i]);
> > +           test_ring_print_test_string(test_enqdeq_impl[test_idx].desc,
> > +                   test_enqdeq_impl[test_idx].api_type, esize[i]);
> >
> >             /* Create the ring */
> >             r = test_ring_create("test_ring_burst_bulk_tests", esize[i],
> > -                                   RING_SIZE, SOCKET_ID_ANY,
> > create_flags);
> > +                           RING_SIZE, SOCKET_ID_ANY,
> > +                           test_enqdeq_impl[test_idx].create_flags);
> >
> >             /* alloc dummy object pointers */
> >             src = test_ring_calloc(RING_SIZE * 2, esize[i]); @@ -420,15
> > +598,15 @@ test_ring_burst_bulk_tests3(unsigned int api_type, unsigned int
> > create_flags,
> >
> >             printf("fill and empty the ring\n");
> >             for (j = 0; j < RING_SIZE / MAX_BULK; j++) {
> > -                   ret = test_ring_enqueue(r, cur_src, esize[i],
> > MAX_BULK,
> > -                                                   api_type);
> > +                   ret = test_ring_enq_impl(r, cur_src, esize[i],
> > MAX_BULK,
> > +                                                   test_idx);
> >                     if (ret != MAX_BULK)
> >                             goto fail;
> >                     cur_src = test_ring_inc_ptr(cur_src, esize[i],
> >                                                             MAX_BULK);
> >
> > -                   ret = test_ring_dequeue(r, cur_dst, esize[i],
> > MAX_BULK,
> > -                                                   api_type);
> > +                   ret = test_ring_deq_impl(r, cur_dst, esize[i],
> > MAX_BULK,
> > +                                                   test_idx);
> >                     if (ret != MAX_BULK)
> >                             goto fail;
> >                     cur_dst = test_ring_inc_ptr(cur_dst, esize[i], @@ -
> > 465,21 +643,24 @@ test_ring_burst_bulk_tests3(unsigned int api_type,
> > unsigned int create_flags,
> >   * Enqueue till the ring is full and dequeue till the ring becomes empty.
> >   */
> >  static int
> > -test_ring_burst_bulk_tests4(unsigned int api_type, unsigned int 
> > create_flags,
> > -   const char *tname)
> > +test_ring_burst_bulk_tests4(unsigned int test_idx)
> >  {
> >     struct rte_ring *r;
> >     void **src = NULL, **cur_src = NULL, **dst = NULL, **cur_dst = NULL;
> >     int ret;
> >     unsigned int i, j;
> > -   unsigned int num_elems;
> > +   unsigned int api_type, num_elems;
> > +
> > +   api_type = test_enqdeq_impl[test_idx].api_type;
> >
> >     for (i = 0; i < RTE_DIM(esize); i++) {
> > -           test_ring_print_test_string(tname, api_type, esize[i]);
> > +           test_ring_print_test_string(test_enqdeq_impl[test_idx].desc,
> > +                   test_enqdeq_impl[test_idx].api_type, esize[i]);
> >
> >             /* Create the ring */
> >             r = test_ring_create("test_ring_burst_bulk_tests", esize[i],
> > -                                   RING_SIZE, SOCKET_ID_ANY,
> > create_flags);
> > +                           RING_SIZE, SOCKET_ID_ANY,
> > +                           test_enqdeq_impl[test_idx].create_flags);
> >
> >             /* alloc dummy object pointers */
> >             src = test_ring_calloc(RING_SIZE * 2, esize[i]); @@ -496,8
> > +677,8 @@ test_ring_burst_bulk_tests4(unsigned int api_type, unsigned int
> > create_flags,
> >
> >             printf("Test enqueue without enough memory space\n");
> >             for (j = 0; j < (RING_SIZE/MAX_BULK - 1); j++) {
> > -                   ret = test_ring_enqueue(r, cur_src, esize[i],
> > MAX_BULK,
> > -                                                   api_type);
> > +                   ret = test_ring_enq_impl(r, cur_src, esize[i],
> > MAX_BULK,
> > +                                                   test_idx);
> >                     if (ret != MAX_BULK)
> >                             goto fail;
> >                     cur_src = test_ring_inc_ptr(cur_src, esize[i], @@ -
> > 505,7 +686,7 @@ test_ring_burst_bulk_tests4(unsigned int api_type,
> > unsigned int create_flags,
> >             }
> >
> >             printf("Enqueue 2 objects, free entries = MAX_BULK - 2\n");
> > -           ret = test_ring_enqueue(r, cur_src, esize[i], 2, api_type);
> > +           ret = test_ring_enq_impl(r, cur_src, esize[i], 2, test_idx);
> >             if (ret != 2)
> >                     goto fail;
> >             cur_src = test_ring_inc_ptr(cur_src, esize[i], 2); @@ -517,8
> > +698,8 @@ test_ring_burst_bulk_tests4(unsigned int api_type, unsigned int
> > create_flags,
> >             else
> >                     num_elems = MAX_BULK;
> >             /* Always one free entry left */
> > -           ret = test_ring_enqueue(r, cur_src, esize[i], num_elems,
> > -                                           api_type);
> > +           ret = test_ring_enq_impl(r, cur_src, esize[i], num_elems,
> > +                                           test_idx);
> >             if (ret != MAX_BULK - 3)
> >                     goto fail;
> >             cur_src = test_ring_inc_ptr(cur_src, esize[i], MAX_BULK - 3);
> > @@ -528,15 +709,15 @@ test_ring_burst_bulk_tests4(unsigned int api_type,
> > unsigned int create_flags,
> >                     goto fail;
> >
> >             printf("Test enqueue for a full entry\n");
> > -           ret = test_ring_enqueue(r, cur_src, esize[i], MAX_BULK,
> > -                                           api_type);
> > +           ret = test_ring_enq_impl(r, cur_src, esize[i], MAX_BULK,
> > +                                           test_idx);
> >             if (ret != 0)
> >                     goto fail;
> >
> >             printf("Test dequeue without enough objects\n");
> >             for (j = 0; j < RING_SIZE / MAX_BULK - 1; j++) {
> > -                   ret = test_ring_dequeue(r, cur_dst, esize[i],
> > MAX_BULK,
> > -                                                   api_type);
> > +                   ret = test_ring_deq_impl(r, cur_dst, esize[i],
> > MAX_BULK,
> > +                                                   test_idx);
> >                     if (ret != MAX_BULK)
> >                             goto fail;
> >                     cur_dst = test_ring_inc_ptr(cur_dst, esize[i], @@ -
> > 544,7 +725,7 @@ test_ring_burst_bulk_tests4(unsigned int api_type,
> > unsigned int create_flags,
> >             }
> >
> >             /* Available memory space for the exact MAX_BULK entries
> > */
> > -           ret = test_ring_dequeue(r, cur_dst, esize[i], 2, api_type);
> > +           ret = test_ring_deq_impl(r, cur_dst, esize[i], 2, test_idx);
> >             if (ret != 2)
> >                     goto fail;
> >             cur_dst = test_ring_inc_ptr(cur_dst, esize[i], 2); @@ -554,8
> > +735,8 @@ test_ring_burst_bulk_tests4(unsigned int api_type, unsigned int
> > create_flags,
> >                     num_elems = MAX_BULK - 3;
> >             else
> >                     num_elems = MAX_BULK;
> > -           ret = test_ring_dequeue(r, cur_dst, esize[i], num_elems,
> > -                                           api_type);
> > +           ret = test_ring_deq_impl(r, cur_dst, esize[i], num_elems,
> > +                                           test_idx);
> >             if (ret != MAX_BULK - 3)
> >                     goto fail;
> >             cur_dst = test_ring_inc_ptr(cur_dst, esize[i], MAX_BULK - 3);
> > @@ -816,22 +997,7 @@ static int
> >  test_ring(void)
> >  {
> >     int32_t rc;
> > -   unsigned int i, j;
> > -   const char *tname;
> > -
> > -   static const struct {
> > -           uint32_t create_flags;
> > -           const char *name;
> > -   } test_sync_modes[] = {
> > -           {
> > -                   RING_F_MP_RTS_ENQ | RING_F_MC_RTS_DEQ,
> > -                   "Test MT_RTS ring",
> > -           },
> > -           {
> > -                   RING_F_MP_HTS_ENQ | RING_F_MC_HTS_DEQ,
> > -                   "Test MT_HTS ring",
> > -           },
> > -   };
> > +   unsigned int i;
> >
> >     /* Negative test cases */
> >     if (test_ring_negative_tests() < 0)
> > @@ -848,65 +1014,24 @@ test_ring(void)
> >      * The test cases are split into smaller test cases to
> >      * help clang compile faster.
> >      */
> > -   tname = "Test standard ring";
> > -
> > -   for (j = TEST_RING_ELEM_BULK; j <= TEST_RING_ELEM_BURST; j <<= 1)
> > -           for (i = TEST_RING_THREAD_DEF;
> > -                                   i <= TEST_RING_THREAD_MPMC; i
> > <<= 1)
> > -                   if (test_ring_burst_bulk_tests1(i | j, 0, tname) < 0)
> > -                           goto test_fail;
> > -
> > -   for (j = TEST_RING_ELEM_BULK; j <= TEST_RING_ELEM_BURST; j <<= 1)
> > -           for (i = TEST_RING_THREAD_DEF;
> > -                                   i <= TEST_RING_THREAD_MPMC; i
> > <<= 1)
> > -                   if (test_ring_burst_bulk_tests2(i | j, 0, tname) < 0)
> > -                           goto test_fail;
> > -
> > -   for (j = TEST_RING_ELEM_BULK; j <= TEST_RING_ELEM_BURST; j <<= 1)
> > -           for (i = TEST_RING_THREAD_DEF;
> > -                                   i <= TEST_RING_THREAD_MPMC; i
> > <<= 1)
> > -                   if (test_ring_burst_bulk_tests3(i | j, 0, tname) < 0)
> > -                           goto test_fail;
> > -
> > -   for (j = TEST_RING_ELEM_BULK; j <= TEST_RING_ELEM_BURST; j <<= 1)
> > -           for (i = TEST_RING_THREAD_DEF;
> > -                                   i <= TEST_RING_THREAD_MPMC; i
> > <<= 1)
> > -                   if (test_ring_burst_bulk_tests4(i | j, 0, tname) < 0)
> > -                           goto test_fail;
> > -
> > -   /* Burst and bulk operations with MT_RTS and MT_HTS sync modes
> > */
> > -   for (i = 0; i != RTE_DIM(test_sync_modes); i++) {
> > -           for (j = TEST_RING_ELEM_BULK; j <= TEST_RING_ELEM_BURST;
> > -                           j <<= 1) {
> > -
> > -                   rc = test_ring_burst_bulk_tests1(
> > -                           TEST_RING_THREAD_DEF | j,
> > -                           test_sync_modes[i].create_flags,
> > -                           test_sync_modes[i].name);
> > -                   if (rc < 0)
> > -                           goto test_fail;
> > -
> > -                   rc = test_ring_burst_bulk_tests2(
> > -                           TEST_RING_THREAD_DEF | j,
> > -                           test_sync_modes[i].create_flags,
> > -                           test_sync_modes[i].name);
> > -                   if (rc < 0)
> > -                           goto test_fail;
> > -
> > -                   rc = test_ring_burst_bulk_tests3(
> > -                           TEST_RING_THREAD_DEF | j,
> > -                           test_sync_modes[i].create_flags,
> > -                           test_sync_modes[i].name);
> > -                   if (rc < 0)
> > -                           goto test_fail;
> > -
> > -                   rc = test_ring_burst_bulk_tests3(
> > -                           TEST_RING_THREAD_DEF | j,
> > -                           test_sync_modes[i].create_flags,
> > -                           test_sync_modes[i].name);
> > -                   if (rc < 0)
> > -                           goto test_fail;
> > -           }
> > +   for (i = 0; i != RTE_DIM(test_enqdeq_impl); i++) {
> > +
> > +
> > +           rc = test_ring_burst_bulk_tests1(i);
> > +           if (rc < 0)
> > +                   goto test_fail;
> > +
> > +           rc = test_ring_burst_bulk_tests2(i);
> > +           if (rc < 0)
> > +                   goto test_fail;
> > +
> > +           rc = test_ring_burst_bulk_tests3(i);
> > +           if (rc < 0)
> > +                   goto test_fail;
> > +
> > +           rc = test_ring_burst_bulk_tests4(i);
> > +           if (rc < 0)
> > +                   goto test_fail;
> >     }
> >
> >     /* dump the ring status */
> > --
> > 2.17.1

Reply via email to