1*1cf65e43SKonstantin Ananyev /* SPDX-License-Identifier: BSD-3-Clause
2*1cf65e43SKonstantin Ananyev * Copyright(c) 2020 Intel Corporation
3*1cf65e43SKonstantin Ananyev */
4*1cf65e43SKonstantin Ananyev
5*1cf65e43SKonstantin Ananyev #include "test_ring_stress_impl.h"
6*1cf65e43SKonstantin Ananyev
7*1cf65e43SKonstantin Ananyev static inline uint32_t
_st_ring_dequeue_bulk(struct rte_ring * r,void ** obj,uint32_t n,uint32_t * avail)8*1cf65e43SKonstantin Ananyev _st_ring_dequeue_bulk(struct rte_ring *r, void **obj, uint32_t n,
9*1cf65e43SKonstantin Ananyev uint32_t *avail)
10*1cf65e43SKonstantin Ananyev {
11*1cf65e43SKonstantin Ananyev return rte_ring_mc_hts_dequeue_bulk(r, obj, n, avail);
12*1cf65e43SKonstantin Ananyev }
13*1cf65e43SKonstantin Ananyev
14*1cf65e43SKonstantin Ananyev static inline uint32_t
_st_ring_enqueue_bulk(struct rte_ring * r,void * const * obj,uint32_t n,uint32_t * free)15*1cf65e43SKonstantin Ananyev _st_ring_enqueue_bulk(struct rte_ring *r, void * const *obj, uint32_t n,
16*1cf65e43SKonstantin Ananyev uint32_t *free)
17*1cf65e43SKonstantin Ananyev {
18*1cf65e43SKonstantin Ananyev return rte_ring_mp_hts_enqueue_bulk(r, obj, n, free);
19*1cf65e43SKonstantin Ananyev }
20*1cf65e43SKonstantin Ananyev
21*1cf65e43SKonstantin Ananyev static int
_st_ring_init(struct rte_ring * r,const char * name,uint32_t num)22*1cf65e43SKonstantin Ananyev _st_ring_init(struct rte_ring *r, const char *name, uint32_t num)
23*1cf65e43SKonstantin Ananyev {
24*1cf65e43SKonstantin Ananyev return rte_ring_init(r, name, num,
25*1cf65e43SKonstantin Ananyev RING_F_MP_HTS_ENQ | RING_F_MC_HTS_DEQ);
26*1cf65e43SKonstantin Ananyev }
27*1cf65e43SKonstantin Ananyev
28*1cf65e43SKonstantin Ananyev const struct test test_ring_hts_stress = {
29*1cf65e43SKonstantin Ananyev .name = "MT_HTS",
30*1cf65e43SKonstantin Ananyev .nb_case = RTE_DIM(tests),
31*1cf65e43SKonstantin Ananyev .cases = tests,
32*1cf65e43SKonstantin Ananyev };
33