From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by smtp.lore.kernel.org (Postfix) with ESMTP id 6CFF6CD98F2 for ; Sat, 20 Jun 2026 02:32:55 +0000 (UTC) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id DF34240E0F; Sat, 20 Jun 2026 04:32:00 +0200 (CEST) Received: from mail-yw1-f182.google.com (mail-yw1-f182.google.com [209.85.128.182]) by mails.dpdk.org (Postfix) with ESMTP id 3F2E340DD8 for ; Sat, 20 Jun 2026 04:31:57 +0200 (CEST) Received: by mail-yw1-f182.google.com with SMTP id 00721157ae682-7fd6b4d5d49so23044077b3.0 for ; Fri, 19 Jun 2026 19:31:57 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=networkplumber-org.20251104.gappssmtp.com; s=20251104; t=1781922716; x=1782527516; darn=dpdk.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=dgOfGdIrUWElVZ8RERrHIa5tu6DvybwadqOzpvd1HHM=; b=OSVUn8+AtZevLsoPWootPIaQfuV6aT8+KfU0yEkb6hPqKqAjZhHEPoximofjHDksDV k5oPV0tX6EbrU/0YHodFhtEjwLkWI59RCzzu4VY0lp7gQ4GcTsvyVIJY84tfrAcruMFK lR1EA6kNkUSFTwGDQRAD+tl6eZ7Hzg/o+QmfU3l/W+T5Bm+KDCDRkHBQHmwcK0iOLeUW WVdm4iid2Hi4c+fo+O+CLsR8vlh5W+egwgi3FkgWNNBv5Ewkl6hfRMn9va/aAux9ICbT Ujb1xQ+MTmcr5amf4CKGTwDN+NrHeYNHDY6NPHKeJ1q36ZRfRA3Ji2lSQUErZoW/GxXb 2mVw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1781922716; x=1782527516; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=dgOfGdIrUWElVZ8RERrHIa5tu6DvybwadqOzpvd1HHM=; b=hJ5bJYNGZIG2WAR+xFYgTRlWIc/rrhyHKpnef6fuH1r5hh3buKfCOUN6XbFl107P4c vfa85XKKtOFfzyQmW9w7aP8XcntgxYIGpbVdciFU4v2GSiSSVJwkJPG9M3/6+AOtj64F bvXBtAqkAOaNxWpOwsKypZVh9aJ56eqCHwRsknKXT9llAdS9MPThNCbCtmignsx6IlCj 4Zg9kITjSTlWzt8mVfzOhVFwtCMU1dkfyBNB50uZX77caFTLXfLxXwgZZ+IkcPczedxM hmcBWqEVLZVMQX2vOcJ376JcmjEcayM6d2zCmMSYo2XJMa1myrNR+8mlKxtA3WueTzYC bKTw== X-Gm-Message-State: AOJu0YxB9E4HFOAA422ROHrC9ulA/stFmTiV0agJGsr+OqAouEu+k8qq PxlLE/SBJGW0Q6u1pGajPDjt2jfKuqWRdqRma1b3AjUYnihGFNWAo2E5PDS+jZy7JTxj/JiYEXh fvEc4 X-Gm-Gg: AfdE7ckl+/ZqtTZwztAganSWFFlMxuDLxULegcVo/NdG4LEriJx1Rbec+tEAB8IlhdK s0yXoaEuf4NNZwKhEoInZaYRohnR9TrM3d+erFZLKtbodrvzHyYGQYG5S9gGoM29FINfYBgAYc0 UzIM9wWDhdMok04EIE559UYq3AKbTVpts2fDpsC57g1MnaiHWaTpomIRoVXcoRM90CR1p9EteGK MNC7TqXyYNpJI9ykRO6cUKrDdS1h6Ybjroofy9KyaUu3Nn0ZEJmiGOKE7ms/wIvphABv4GSPNhV eGlaWbmIHzi17D2fZte6v8Ifp1Zbs5VFar3+KihkUoYT0g1zkn7CweEERLij2NxGkdbUi3cLHc+ bzOEbPz+OYP1obRyoOuqX0wUC3EpiFhzEeGI86zCM4dT5ChfbKrSMYuXW72katD8niPk6wkQDE/ 5KAuO//aH21+9uXptJ2vAA+wWs5Pc2tYPbzxQCNJo7a8qHp2y5+/kd63sXWr5N7g== X-Received: by 2002:a05:690c:4483:b0:7eb:938:81bc with SMTP id 00721157ae682-80122ec0064mr53613017b3.13.1781922716438; Fri, 19 Jun 2026 19:31:56 -0700 (PDT) Received: from phoenix.lan (204-195-96-226.wavecable.com. [204.195.96.226]) by smtp.gmail.com with ESMTPSA id 00721157ae682-8025c96ffd5sm6045897b3.9.2026.06.19.19.31.55 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 19 Jun 2026 19:31:55 -0700 (PDT) From: Stephen Hemminger To: dev@dpdk.org Cc: Stephen Hemminger Subject: [PATCH v5 13/24] event/sw: convert from rte_atomic32 to stdatomic Date: Fri, 19 Jun 2026 19:28:38 -0700 Message-ID: <20260620023134.42877-14-stephen@networkplumber.org> X-Mailer: git-send-email 2.53.0 In-Reply-To: <20260620023134.42877-1-stephen@networkplumber.org> References: <20260620023134.42877-1-stephen@networkplumber.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Use stdatomic to keep track of inflights. Signed-off-by: Stephen Hemminger --- drivers/event/sw/sw_evdev.c | 8 +++++--- drivers/event/sw/sw_evdev.h | 4 ++-- drivers/event/sw/sw_evdev_worker.c | 16 +++++++++++----- 3 files changed, 18 insertions(+), 10 deletions(-) diff --git a/drivers/event/sw/sw_evdev.c b/drivers/event/sw/sw_evdev.c index 3ad82e94ac..a2f760a98d 100644 --- a/drivers/event/sw/sw_evdev.c +++ b/drivers/event/sw/sw_evdev.c @@ -153,7 +153,9 @@ sw_port_setup(struct rte_eventdev *dev, uint8_t port_id, * the sum to no leak credits */ int possible_inflights = p->inflight_credits + p->inflights; - rte_atomic32_sub(&sw->inflights, possible_inflights); + rte_atomic_fetch_sub_explicit(&sw->inflights, + possible_inflights, + rte_memory_order_release); } *p = (struct sw_port){0}; /* zero entire structure */ @@ -512,7 +514,7 @@ sw_dev_configure(const struct rte_eventdev *dev) sw->qid_count = conf->nb_event_queues; sw->port_count = conf->nb_event_ports; sw->nb_events_limit = conf->nb_events_limit; - rte_atomic32_set(&sw->inflights, 0); + sw->inflights = 0; /* Number of chunks sized for worst-case spread of events across IQs */ num_chunks = ((SW_INFLIGHT_EVENTS_TOTAL/SW_EVS_PER_Q_CHUNK)+1) + @@ -633,7 +635,7 @@ sw_dump(struct rte_eventdev *dev, FILE *f) fprintf(f, "\tsched cq/qid call: %"PRIu64"\n", sw->sched_cq_qid_called); fprintf(f, "\tsched no IQ enq: %"PRIu64"\n", sw->sched_no_iq_enqueues); fprintf(f, "\tsched no CQ enq: %"PRIu64"\n", sw->sched_no_cq_enqueues); - uint32_t inflights = rte_atomic32_read(&sw->inflights); + uint32_t inflights = rte_atomic_load_explicit(&sw->inflights, rte_memory_order_relaxed); uint32_t credits = sw->nb_events_limit - inflights; fprintf(f, "\tinflight %d, credits: %d\n", inflights, credits); diff --git a/drivers/event/sw/sw_evdev.h b/drivers/event/sw/sw_evdev.h index c159be21be..5e49b08030 100644 --- a/drivers/event/sw/sw_evdev.h +++ b/drivers/event/sw/sw_evdev.h @@ -8,7 +8,7 @@ #include "sw_evdev_log.h" #include #include -#include +#include #define SW_DEFAULT_CREDIT_QUANTA 32 #define SW_DEFAULT_SCHED_QUANTA 128 @@ -233,7 +233,7 @@ struct sw_evdev { /* Contains all ports - load balanced and directed */ alignas(RTE_CACHE_LINE_SIZE) struct sw_port ports[SW_PORTS_MAX]; - alignas(RTE_CACHE_LINE_SIZE) rte_atomic32_t inflights; + alignas(RTE_CACHE_LINE_SIZE) RTE_ATOMIC(uint32_t) inflights; /* * max events in this instance. Cached here for performance. diff --git a/drivers/event/sw/sw_evdev_worker.c b/drivers/event/sw/sw_evdev_worker.c index 4215726513..0755def367 100644 --- a/drivers/event/sw/sw_evdev_worker.c +++ b/drivers/event/sw/sw_evdev_worker.c @@ -56,7 +56,7 @@ sw_event_enqueue_burst(void *port, const struct rte_event ev[], uint16_t num) uint8_t new_ops[PORT_ENQUEUE_MAX_BURST_SIZE]; struct sw_port *p = port; struct sw_evdev *sw = (void *)p->sw; - uint32_t sw_inflights = rte_atomic32_read(&sw->inflights); + uint32_t sw_inflights = rte_atomic_load_explicit(&sw->inflights, rte_memory_order_relaxed); uint32_t credit_update_quanta = sw->credit_update_quanta; int new = 0; @@ -74,8 +74,10 @@ sw_event_enqueue_burst(void *port, const struct rte_event ev[], uint16_t num) if (sw_inflights + credit_update_quanta > sw->nb_events_limit) return 0; - rte_atomic32_add(&sw->inflights, credit_update_quanta); - p->inflight_credits += (credit_update_quanta); + rte_atomic_fetch_add_explicit(&sw->inflights, + credit_update_quanta, + rte_memory_order_acquire); + p->inflight_credits += credit_update_quanta; /* If there are fewer inflight credits than new events, limit * the number of enqueued events. @@ -124,7 +126,9 @@ sw_event_enqueue_burst(void *port, const struct rte_event ev[], uint16_t num) /* Replenish credits if enough releases are performed */ if (p->inflight_credits >= credit_update_quanta * 2) { - rte_atomic32_sub(&sw->inflights, credit_update_quanta); + rte_atomic_fetch_sub_explicit(&sw->inflights, + credit_update_quanta, + rte_memory_order_release); p->inflight_credits -= credit_update_quanta; } @@ -150,7 +154,9 @@ sw_event_dequeue_burst(void *port, struct rte_event *ev, uint16_t num, /* Replenish credits if enough releases are performed */ if (p->inflight_credits >= credit_update_quanta * 2) { - rte_atomic32_sub(&sw->inflights, credit_update_quanta); + rte_atomic_fetch_sub_explicit(&sw->inflights, + credit_update_quanta, + rte_memory_order_release); p->inflight_credits -= credit_update_quanta; } } -- 2.53.0