| DPDK
    20.11.10
    | 
Go to the source code of this file.
| Functions | |
| ssize_t | rte_ring_get_memsize_elem (unsigned int esize, unsigned int count) | 
| 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 int | 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 int | 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 int | 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 int | 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 int | 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.
| 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). | 
| 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 574 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 620 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 644 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 670 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 699 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 727 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 758 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 805 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 829 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 857 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 886 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 915 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 946 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 998 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 1027 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 1058 of file rte_ring_elem.h.
 1.8.13
 1.8.13