|
DPDK
20.02.1
|
#include <stdio.h>#include <stdint.h>#include <string.h>#include <sys/queue.h>#include <errno.h>#include <rte_common.h>#include <rte_config.h>#include <rte_memory.h>#include <rte_lcore.h>#include <rte_atomic.h>#include <rte_branch_prediction.h>#include <rte_memzone.h>#include <rte_pause.h>#include "rte_ring.h"#include "rte_ring_generic.h"Go to the source code of this file.
Functions | |
| __rte_experimental ssize_t | rte_ring_get_memsize_elem (unsigned int esize, unsigned int count) |
| __rte_experimental struct rte_ring * | rte_ring_create_elem (const char *name, unsigned int esize, unsigned int count, int socket_id, unsigned int flags) |
| static __rte_always_inline unsigned int | rte_ring_mp_enqueue_bulk_elem (struct rte_ring *r, const void *obj_table, unsigned int esize, unsigned int n, unsigned int *free_space) |
| static __rte_always_inline unsigned int | rte_ring_sp_enqueue_bulk_elem (struct rte_ring *r, const void *obj_table, unsigned int esize, unsigned int n, unsigned int *free_space) |
| static __rte_always_inline unsigned int | rte_ring_enqueue_bulk_elem (struct rte_ring *r, const void *obj_table, unsigned int esize, unsigned int n, unsigned int *free_space) |
| static __rte_always_inline int | rte_ring_mp_enqueue_elem (struct rte_ring *r, void *obj, unsigned int esize) |
| static __rte_always_inline int | rte_ring_sp_enqueue_elem (struct rte_ring *r, void *obj, unsigned int esize) |
| static __rte_always_inline int | rte_ring_enqueue_elem (struct rte_ring *r, void *obj, unsigned int esize) |
| static __rte_always_inline unsigned int | rte_ring_mc_dequeue_bulk_elem (struct rte_ring *r, void *obj_table, unsigned int esize, unsigned int n, unsigned int *available) |
| static __rte_always_inline unsigned int | rte_ring_sc_dequeue_bulk_elem (struct rte_ring *r, void *obj_table, unsigned int esize, unsigned int n, unsigned int *available) |
| static __rte_always_inline unsigned int | rte_ring_dequeue_bulk_elem (struct rte_ring *r, void *obj_table, unsigned int esize, unsigned int n, unsigned int *available) |
| static __rte_always_inline int | rte_ring_mc_dequeue_elem (struct rte_ring *r, void *obj_p, unsigned int esize) |
| static __rte_always_inline int | rte_ring_sc_dequeue_elem (struct rte_ring *r, void *obj_p, unsigned int esize) |
| static __rte_always_inline int | rte_ring_dequeue_elem (struct rte_ring *r, void *obj_p, unsigned int esize) |
| static __rte_always_inline unsigned | rte_ring_mp_enqueue_burst_elem (struct rte_ring *r, const void *obj_table, unsigned int esize, unsigned int n, unsigned int *free_space) |
| static __rte_always_inline unsigned | rte_ring_sp_enqueue_burst_elem (struct rte_ring *r, const void *obj_table, unsigned int esize, unsigned int n, unsigned int *free_space) |
| static __rte_always_inline unsigned | rte_ring_enqueue_burst_elem (struct rte_ring *r, const void *obj_table, unsigned int esize, unsigned int n, unsigned int *free_space) |
| static __rte_always_inline unsigned | rte_ring_mc_dequeue_burst_elem (struct rte_ring *r, void *obj_table, unsigned int esize, unsigned int n, unsigned int *available) |
| static __rte_always_inline unsigned | rte_ring_sc_dequeue_burst_elem (struct rte_ring *r, void *obj_table, unsigned int esize, unsigned int n, unsigned int *available) |
| static __rte_always_inline unsigned int | rte_ring_dequeue_burst_elem (struct rte_ring *r, void *obj_table, unsigned int esize, unsigned int n, unsigned int *available) |
RTE Ring with user defined element size
Definition in file rte_ring_elem.h.
| __rte_experimental ssize_t rte_ring_get_memsize_elem | ( | unsigned int | esize, |
| unsigned int | count | ||
| ) |
Calculate the memory size needed for a ring with given element size
This function returns the number of bytes needed for a ring, given the number of elements in it and the size of the element. This value is the sum of the size of the structure rte_ring and the size of the memory needed for storing the elements. The value is aligned to a cache line size.
| esize | The size of ring element, in bytes. It must be a multiple of 4. |
| count | The number of elements in the ring (must be a power of 2). |
| __rte_experimental struct rte_ring* rte_ring_create_elem | ( | const char * | name, |
| unsigned int | esize, | ||
| unsigned int | count, | ||
| int | socket_id, | ||
| unsigned int | flags | ||
| ) |
Create a new ring named name that stores elements with given size.
This function uses memzone_reserve() to allocate memory. Then it calls rte_ring_init() to initialize an empty ring.
The new ring size is set to count, which must be a power of two. Water marking is disabled by default. The real usable ring size is count-1 instead of count to differentiate a free ring from an empty ring.
The ring is added in RTE_TAILQ_RING list.
| name | The name of the ring. |
| esize | The size of ring element, in bytes. It must be a multiple of 4. |
| count | The number of elements in the ring (must be a power of 2). |
| socket_id | The socket_id argument is the socket identifier in case of NUMA. The value can be SOCKET_ID_ANY if there is no NUMA constraint for the reserved zone. |
| flags | An OR of the following:
|
|
static |
Enqueue several objects on the ring (multi-producers safe).
This function uses a "compare and set" instruction to move the producer index atomically.
| r | A pointer to the ring structure. |
| obj_table | A pointer to a table of objects. |
| esize | The size of ring element, in bytes. It must be a multiple of 4. This must be the same value used while creating the ring. Otherwise the results are undefined. |
| n | The number of objects to add in the ring from the obj_table. |
| free_space | if non-NULL, returns the amount of space in the ring after the enqueue operation has finished. |
Definition at line 509 of file rte_ring_elem.h.
|
static |
Enqueue several objects on a ring
| r | A pointer to the ring structure. |
| obj_table | A pointer to a table of objects. |
| esize | The size of ring element, in bytes. It must be a multiple of 4. This must be the same value used while creating the ring. Otherwise the results are undefined. |
| n | The number of objects to add in the ring from the obj_table. |
| free_space | if non-NULL, returns the amount of space in the ring after the enqueue operation has finished. |
Definition at line 538 of file rte_ring_elem.h.
|
static |
Enqueue several objects on a ring.
This function calls the multi-producer or the single-producer version depending on the default behavior that was specified at ring creation time (see flags).
| r | A pointer to the ring structure. |
| obj_table | A pointer to a table of objects. |
| esize | The size of ring element, in bytes. It must be a multiple of 4. This must be the same value used while creating the ring. Otherwise the results are undefined. |
| n | The number of objects to add in the ring from the obj_table. |
| free_space | if non-NULL, returns the amount of space in the ring after the enqueue operation has finished. |
Definition at line 569 of file rte_ring_elem.h.
|
static |
Enqueue one object on a ring (multi-producers safe).
This function uses a "compare and set" instruction to move the producer index atomically.
| r | A pointer to the ring structure. |
| obj | A pointer to the object to be added. |
| esize | The size of ring element, in bytes. It must be a multiple of 4. This must be the same value used while creating the ring. Otherwise the results are undefined. |
Definition at line 595 of file rte_ring_elem.h.
|
static |
Enqueue one object on a ring
| r | A pointer to the ring structure. |
| obj | A pointer to the object to be added. |
| esize | The size of ring element, in bytes. It must be a multiple of 4. This must be the same value used while creating the ring. Otherwise the results are undefined. |
Definition at line 619 of file rte_ring_elem.h.
|
static |
Enqueue one object on a ring.
This function calls the multi-producer or the single-producer version, depending on the default behaviour that was specified at ring creation time (see flags).
| r | A pointer to the ring structure. |
| obj | A pointer to the object to be added. |
| esize | The size of ring element, in bytes. It must be a multiple of 4. This must be the same value used while creating the ring. Otherwise the results are undefined. |
Definition at line 645 of file rte_ring_elem.h.
|
static |
Dequeue several objects from a ring (multi-consumers safe).
This function uses a "compare and set" instruction to move the consumer index atomically.
| r | A pointer to the ring structure. |
| obj_table | A pointer to a table of objects that will be filled. |
| esize | The size of ring element, in bytes. It must be a multiple of 4. This must be the same value used while creating the ring. Otherwise the results are undefined. |
| n | The number of objects to dequeue from the ring to the obj_table. |
| available | If non-NULL, returns the number of remaining ring entries after the dequeue has finished. |
Definition at line 674 of file rte_ring_elem.h.
|
static |
Dequeue several objects from a ring (NOT multi-consumers safe).
| r | A pointer to the ring structure. |
| obj_table | A pointer to a table of objects that will be filled. |
| esize | The size of ring element, in bytes. It must be a multiple of 4. This must be the same value used while creating the ring. Otherwise the results are undefined. |
| n | The number of objects to dequeue from the ring to the obj_table, must be strictly positive. |
| available | If non-NULL, returns the number of remaining ring entries after the dequeue has finished. |
Definition at line 702 of file rte_ring_elem.h.
|
static |
Dequeue several objects from a ring.
This function calls the multi-consumers or the single-consumer version, depending on the default behaviour that was specified at ring creation time (see flags).
| r | A pointer to the ring structure. |
| obj_table | A pointer to a table of objects that will be filled. |
| esize | The size of ring element, in bytes. It must be a multiple of 4. This must be the same value used while creating the ring. Otherwise the results are undefined. |
| n | The number of objects to dequeue from the ring to the obj_table. |
| available | If non-NULL, returns the number of remaining ring entries after the dequeue has finished. |
Definition at line 733 of file rte_ring_elem.h.
|
static |
Dequeue one object from a ring (multi-consumers safe).
This function uses a "compare and set" instruction to move the consumer index atomically.
| r | A pointer to the ring structure. |
| obj_p | A pointer to the object that will be filled. |
| esize | The size of ring element, in bytes. It must be a multiple of 4. This must be the same value used while creating the ring. Otherwise the results are undefined. |
Definition at line 760 of file rte_ring_elem.h.
|
static |
Dequeue one object from a ring (NOT multi-consumers safe).
| r | A pointer to the ring structure. |
| obj_p | A pointer to the object that will be filled. |
| esize | The size of ring element, in bytes. It must be a multiple of 4. This must be the same value used while creating the ring. Otherwise the results are undefined. |
Definition at line 784 of file rte_ring_elem.h.
|
static |
Dequeue one object from a ring.
This function calls the multi-consumers or the single-consumer version depending on the default behaviour that was specified at ring creation time (see flags).
| r | A pointer to the ring structure. |
| obj_p | A pointer to the object that will be filled. |
| esize | The size of ring element, in bytes. It must be a multiple of 4. This must be the same value used while creating the ring. Otherwise the results are undefined. |
Definition at line 812 of file rte_ring_elem.h.
|
static |
Enqueue several objects on the ring (multi-producers safe).
This function uses a "compare and set" instruction to move the producer index atomically.
| r | A pointer to the ring structure. |
| obj_table | A pointer to a table of objects. |
| esize | The size of ring element, in bytes. It must be a multiple of 4. This must be the same value used while creating the ring. Otherwise the results are undefined. |
| n | The number of objects to add in the ring from the obj_table. |
| free_space | if non-NULL, returns the amount of space in the ring after the enqueue operation has finished. |
Definition at line 841 of file rte_ring_elem.h.
|
static |
Enqueue several objects on a ring
| r | A pointer to the ring structure. |
| obj_table | A pointer to a table of objects. |
| esize | The size of ring element, in bytes. It must be a multiple of 4. This must be the same value used while creating the ring. Otherwise the results are undefined. |
| n | The number of objects to add in the ring from the obj_table. |
| free_space | if non-NULL, returns the amount of space in the ring after the enqueue operation has finished. |
Definition at line 870 of file rte_ring_elem.h.
|
static |
Enqueue several objects on a ring.
This function calls the multi-producer or the single-producer version depending on the default behavior that was specified at ring creation time (see flags).
| r | A pointer to the ring structure. |
| obj_table | A pointer to a table of objects. |
| esize | The size of ring element, in bytes. It must be a multiple of 4. This must be the same value used while creating the ring. Otherwise the results are undefined. |
| n | The number of objects to add in the ring from the obj_table. |
| free_space | if non-NULL, returns the amount of space in the ring after the enqueue operation has finished. |
Definition at line 901 of file rte_ring_elem.h.
|
static |
Dequeue several objects from a ring (multi-consumers safe). When the request objects are more than the available objects, only dequeue the actual number of objects
This function uses a "compare and set" instruction to move the consumer index atomically.
| r | A pointer to the ring structure. |
| obj_table | A pointer to a table of objects that will be filled. |
| esize | The size of ring element, in bytes. It must be a multiple of 4. This must be the same value used while creating the ring. Otherwise the results are undefined. |
| n | The number of objects to dequeue from the ring to the obj_table. |
| available | If non-NULL, returns the number of remaining ring entries after the dequeue has finished. |
Definition at line 933 of file rte_ring_elem.h.
|
static |
Dequeue several objects from a ring (NOT multi-consumers safe).When the request objects are more than the available objects, only dequeue the actual number of objects
| r | A pointer to the ring structure. |
| obj_table | A pointer to a table of objects that will be filled. |
| esize | The size of ring element, in bytes. It must be a multiple of 4. This must be the same value used while creating the ring. Otherwise the results are undefined. |
| n | The number of objects to dequeue from the ring to the obj_table. |
| available | If non-NULL, returns the number of remaining ring entries after the dequeue has finished. |
Definition at line 962 of file rte_ring_elem.h.
|
static |
Dequeue multiple objects from a ring up to a maximum number.
This function calls the multi-consumers or the single-consumer version, depending on the default behaviour that was specified at ring creation time (see flags).
| r | A pointer to the ring structure. |
| obj_table | A pointer to a table of objects that will be filled. |
| esize | The size of ring element, in bytes. It must be a multiple of 4. This must be the same value used while creating the ring. Otherwise the results are undefined. |
| n | The number of objects to dequeue from the ring to the obj_table. |
| available | If non-NULL, returns the number of remaining ring entries after the dequeue has finished. |
Definition at line 993 of file rte_ring_elem.h.
1.8.9.1