From: Damjan Marion Date: Mon, 26 Oct 2020 10:27:13 +0000 (+0100) Subject: avf: use atomic store instead of barrier X-Git-Tag: v21.06-rc0~264 X-Git-Url: https://gerrit.fd.io/r/gitweb?a=commitdiff_plain;h=bcaa44ced6fe456835f3f73d184ab2345e39d367;p=vpp.git avf: use atomic store instead of barrier Type: improvement Change-Id: Ifea5f0c2fecb99fd320a2e1141f4b4f0d6a793ca Signed-off-by: Damjan Marion --- diff --git a/src/plugins/avf/input.c b/src/plugins/avf/input.c index 0ccf7721835..9d677ab96d5 100644 --- a/src/plugins/avf/input.c +++ b/src/plugins/avf/input.c @@ -125,8 +125,7 @@ avf_rxq_refill (vlib_main_t * vm, vlib_node_runtime_t * node, avf_rxq_t * rxq, n_alloc -= 8; } - CLIB_MEMORY_STORE_BARRIER (); - *(rxq->qrx_tail) = slot; + clib_atomic_store_rel_n (rxq->qrx_tail, slot); } diff --git a/src/plugins/avf/output.c b/src/plugins/avf/output.c index e5b53ba5457..de645319e73 100644 --- a/src/plugins/avf/output.c +++ b/src/plugins/avf/output.c @@ -257,8 +257,8 @@ avf_tx_enqueue (vlib_main_t * vm, vlib_node_runtime_t * node, avf_txq_t * txq, d[0].qword[1] |= AVF_TXD_CMD_RS; } - CLIB_MEMORY_BARRIER (); - *(txq->qtx_tail) = txq->next = next & mask; + txq->next = next & mask; + clib_atomic_store_rel_n (txq->qtx_tail, txq->next); txq->n_enqueued += n_desc; return n_packets - n_packets_left; }