env: add single-producer, single-consumer ring type

This case will be used in incoming vhost patches.

Change-Id: I62d569c01e9b8bf25c9293dff827d1b4406cea04
Signed-off-by: Pawel Wodkowski <pawelx.wodkowski@intel.com>
Reviewed-on: https://review.gerrithub.io/362334
Reviewed-by: Tomasz Zawadzki <tomasz.zawadzki@intel.com>
Tested-by: SPDK Automated Test System <sys_sgsw@intel.com>
Reviewed-by: Daniel Verkamp <daniel.verkamp@intel.com>
Reviewed-by: Jim Harris <james.r.harris@intel.com>
Reviewed-by: Ben Walker <benjamin.walker@intel.com>
This commit is contained in:
Pawel Wodkowski 2017-05-24 14:34:12 +02:00 committed by Ben Walker
parent fadfd84920
commit 8557b1c2c5
2 changed files with 11 additions and 2 deletions

View File

@ -230,6 +230,7 @@ void spdk_delay_us(unsigned int us);
struct spdk_ring;
enum spdk_ring_type {
SPDK_RING_TYPE_SP_SC, /* Single-producer, single-consumer */
SPDK_RING_TYPE_MP_SC, /* Multi-producer, single-consumer */
};

View File

@ -264,15 +264,23 @@ spdk_ring_create(enum spdk_ring_type type, size_t count, size_t ele_size, int so
{
char ring_name[64];
static uint32_t ring_num = 0;
unsigned flags = 0;
if (type != SPDK_RING_TYPE_MP_SC) {
switch (type) {
case SPDK_RING_TYPE_SP_SC:
flags = RING_F_SP_ENQ | RING_F_SC_DEQ;
break;
case SPDK_RING_TYPE_MP_SC:
flags = RING_F_SC_DEQ;
break;
default:
return NULL;
}
snprintf(ring_name, sizeof(ring_name), "spdk_ring_%u",
__sync_fetch_and_add(&ring_num, 1));
return (struct spdk_ring *)rte_ring_create(ring_name, count, socket_id, RING_F_SC_DEQ);
return (struct spdk_ring *)rte_ring_create(ring_name, count, socket_id, flags);
}
void