From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from dpdk.org (dpdk.org [92.243.14.124]) by inbox.dpdk.org (Postfix) with ESMTP id E0A33A04BC; Sat, 10 Oct 2020 00:02:50 +0200 (CEST) Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id BF2FE1D5EA; Sat, 10 Oct 2020 00:02:49 +0200 (CEST) Received: from mailout2.w1.samsung.com (mailout2.w1.samsung.com [210.118.77.12]) by dpdk.org (Postfix) with ESMTP id C457C1D5C8 for ; Sat, 10 Oct 2020 00:02:46 +0200 (CEST) Received: from eucas1p1.samsung.com (unknown [182.198.249.206]) by mailout2.w1.samsung.com (KnoxPortal) with ESMTP id 20201009220236euoutp02aae7367abbeeff6d6350ff5af1817247~8cgpyOhXK2454124541euoutp02C for ; Fri, 9 Oct 2020 22:02:36 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 mailout2.w1.samsung.com 20201009220236euoutp02aae7367abbeeff6d6350ff5af1817247~8cgpyOhXK2454124541euoutp02C DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=samsung.com; s=mail20170921; t=1602280956; bh=yH3M1Cb4L5UauMPb4vqNmQJysLFgOKEd5bHi5VjtoSc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Ox8R0LYFjXuoyuV7eHZxDbL8d3/nRzOyFqTVnlRgFaYbAQ2WMWofDDJjs82ksx9t4 ShDyc3xvLRl1VLgP0bFmTpNDBHo032pkiuyKm8JDqkJ51tL0kbR4Qb4PNG+I4n7Kdq h1sFTXzTGSAZDf3sS+2qn1Pla8a9ROqN5gONSXFc= Received: from eusmges3new.samsung.com (unknown [203.254.199.245]) by eucas1p2.samsung.com (KnoxPortal) with ESMTP id 20201009220231eucas1p228d0dc392f16bee5cd170cfa5ac90400~8cgk_ZZX41995819958eucas1p2S; Fri, 9 Oct 2020 22:02:31 +0000 (GMT) Received: from eucas1p1.samsung.com ( [182.198.249.206]) by eusmges3new.samsung.com (EUCPMTA) with SMTP id 7D.E2.06318.7FDD08F5; Fri, 9 Oct 2020 23:02:31 +0100 (BST) Received: from eusmtrp2.samsung.com (unknown [182.198.249.139]) by eucas1p1.samsung.com (KnoxPortal) with ESMTPA id 20201009220229eucas1p17ad627f31005ed506c5422b93ad6d112~8cgjlWdP10450404504eucas1p1y; Fri, 9 Oct 2020 22:02:29 +0000 (GMT) Received: from eusmgms2.samsung.com (unknown [182.198.249.180]) by eusmtrp2.samsung.com (KnoxPortal) with ESMTP id 20201009220229eusmtrp29284b30d5953b910aa235f33ff39f20a~8cgjk02Gq1642116421eusmtrp2W; Fri, 9 Oct 2020 22:02:29 +0000 (GMT) X-AuditID: cbfec7f5-38bff700000018ae-95-5f80ddf7b097 Received: from eusmtip1.samsung.com ( [203.254.199.221]) by eusmgms2.samsung.com (EUCPMTA) with SMTP id 02.5F.06017.5FDD08F5; Fri, 9 Oct 2020 23:02:29 +0100 (BST) Received: from Padamandas.fritz.box (unknown [106.210.88.70]) by eusmtip1.samsung.com (KnoxPortal) with ESMTPA id 20201009220210eusmtip1850c0d5c6eb400f2bda759aed12f0c2b~8cgR6kEFs1334813348eusmtip1r; Fri, 9 Oct 2020 22:02:07 +0000 (GMT) From: Lukasz Wojciechowski To: David Hunt , Bruce Richardson Cc: dev@dpdk.org, l.wojciechow@partner.samsung.com, stable@dpdk.org Date: Sat, 10 Oct 2020 00:01:48 +0200 Message-Id: <20201009220202.20834-2-l.wojciechow@partner.samsung.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20201009220202.20834-1-l.wojciechow@partner.samsung.com> X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFnrOIsWRmVeSWpSXmKPExsWy7djPc7rf7zbEG0z8KmpxY5W9Rd+kj0wW 7z5tZ7J41rOO0eJfxx92B1aPXwuWsnos3vOSyePguz1MAcxRXDYpqTmZZalF+nYJXBkdD84x FpwWrXjwaRNzA+N6oS5GTg4JAROJxxN2snQxcnEICaxglLi26xIThPOFUeLLkRWsEM5nRok/ T5cAZTjAWu5OD4CIL2eU+DdpFzuE84lRYk7PSnaQuWwCthJHZn5lBbFFBMIkmpv3soA0Mws4 Szz5ygYSFhbwkTi26j0jiM0ioCqx5dsbFhCbV8BVYtGKDUwQ58lLrN5wgBnE5hRwk2jdtQzs VAmB62wS31csZoMocpG4+uAjK4QtLPHq+BZ2CFtG4v/O+UwQDdsYJa7+/skI4exnlLjeuwKq ylri8L/fbBDXaUqs36UPEXaUWDv1FNTHfBI33gqChJmBzEnbpjNDhHklOtqgwagn8bRnKiPM 2j9rn7BA2B4SresmQAPxKqPE+iPHmScwys9CWLaAkXEVo3hqaXFuemqxcV5quV5xYm5xaV66 XnJ+7iZGYPSf/nf86w7GfX+SDjEKcDAq8fA2JDfEC7EmlhVX5h5ilOBgVhLhdTp7Ok6INyWx siq1KD++qDQntfgQozQHi5I4r/Gil7FCAumJJanZqakFqUUwWSYOTqkGRqHFHS49TmfWtH80 70nriE9MjszLN9pVY9y93X5ysPKBefqWaXm5Ses/vWSS3++/z/34BM7Ow10HnUvzZFbaCmoY lnGvmX67zic1/+aDSR8O51eySNr80r3syRAkW/PwUPofsY//Zt/Vf+4vUeFpFxTwxW0Kl6Xb vuerDvySvbg0b0H/j3ITJZbijERDLeai4kQAx8kOfvoCAAA= X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFjrOLMWRmVeSWpSXmKPExsVy+t/xu7pf7zbEG7T+MLO4screom/SRyaL d5+2M1k861nHaPGv4w+7A6vHrwVLWT0W73nJ5HHw3R6mAOYoPZui/NKSVIWM/OISW6VoQwsj PUNLCz0jE0s9Q2PzWCsjUyV9O5uU1JzMstQifbsEvYyOB+cYC06LVjz4tIm5gXG9UBcjB4eE gInE3ekBXYxcHEICSxklHl/7wAYRl5H4cEmgi5ETyBSW+HOtiw2i5gOjxPO3fUwgCTYBW4kj M7+ygtSLCIRJnFjpDxJmFnCX2LJ4KjOILSzgI3Fs1XtGEJtFQFViy7c3LCA2r4CrxKIVG5gg 5stLrN5wAKyeU8BNonXXMhaIXY2MElsOvGSewMi3gJFhFaNIamlxbnpusZFecWJucWleul5y fu4mRmAgbjv2c8sOxq53wYcYBTgYlXh4NRIb4oVYE8uKK3MPMUpwMCuJ8DqdPR0nxJuSWFmV WpQfX1Sak1p8iNEU6KqJzFKiyfnAKMkriTc0NTS3sDQ0NzY3NrNQEuftEDgYIySQnliSmp2a WpBaBNPHxMEp1cBoeZRtafQOb8NJ6Zn7/nIJLipkni4VFmMh+Mf+T5fAZLu+y42JP7+uWM96 6se+B9ML1vec3hCiolZy7WtP8fapyas61gtM4k92YPzwTv85t33YCsnoQ2aJdTofFj1d1Vi7 9tjSnNVJxkXLw0uilNtn3PxoIBHP9iF+cpYnY5/b3ubYXZMnK5xWYinOSDTUYi4qTgQAJSAw 01oCAAA= X-CMS-MailID: 20201009220229eucas1p17ad627f31005ed506c5422b93ad6d112 X-Msg-Generator: CA Content-Type: text/plain; charset="utf-8" X-RootMTR: 20201009220229eucas1p17ad627f31005ed506c5422b93ad6d112 X-EPHeader: CA CMS-TYPE: 201P X-CMS-RootMailID: 20201009220229eucas1p17ad627f31005ed506c5422b93ad6d112 References: <20201008052323.11547-1-l.wojciechow@partner.samsung.com> <20201009220202.20834-1-l.wojciechow@partner.samsung.com> Subject: [dpdk-dev] [PATCH v6 01/15] distributor: fix missing handshake synchronization X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" rte_distributor_return_pkt function which is run on worker cores must wait for distributor core to clear handshake on retptr64 before using those buffers. While the handshake is set distributor core controls buffers and any operations on worker side might overwrite buffers which are unread yet. Same situation appears in the legacy single distributor. Function rte_distributor_return_pkt_single shouldn't modify the bufptr64 until handshake on it is cleared by distributor lcore. Fixes: 775003ad2f96 ("distributor: add new burst-capable library") Cc: david.hunt@intel.com Cc: stable@dpdk.org Signed-off-by: Lukasz Wojciechowski Acked-by: David Hunt --- lib/librte_distributor/rte_distributor.c | 14 ++++++++++++++ lib/librte_distributor/rte_distributor_single.c | 4 ++++ 2 files changed, 18 insertions(+) diff --git a/lib/librte_distributor/rte_distributor.c b/lib/librte_distributor/rte_distributor.c index 1c047f065..89493c331 100644 --- a/lib/librte_distributor/rte_distributor.c +++ b/lib/librte_distributor/rte_distributor.c @@ -160,6 +160,7 @@ rte_distributor_return_pkt(struct rte_distributor *d, { struct rte_distributor_buffer *buf = &d->bufs[worker_id]; unsigned int i; + volatile int64_t *retptr64; if (unlikely(d->alg_type == RTE_DIST_ALG_SINGLE)) { if (num == 1) @@ -169,6 +170,19 @@ rte_distributor_return_pkt(struct rte_distributor *d, return -EINVAL; } + retptr64 = &(buf->retptr64[0]); + /* Spin while handshake bits are set (scheduler clears it). + * Sync with worker on GET_BUF flag. + */ + while (unlikely(__atomic_load_n(retptr64, __ATOMIC_ACQUIRE) + & RTE_DISTRIB_GET_BUF)) { + rte_pause(); + uint64_t t = rte_rdtsc()+100; + + while (rte_rdtsc() < t) + rte_pause(); + } + /* Sync with distributor to acquire retptrs */ __atomic_thread_fence(__ATOMIC_ACQUIRE); for (i = 0; i < RTE_DIST_BURST_SIZE; i++) diff --git a/lib/librte_distributor/rte_distributor_single.c b/lib/librte_distributor/rte_distributor_single.c index abaf7730c..f4725b1d0 100644 --- a/lib/librte_distributor/rte_distributor_single.c +++ b/lib/librte_distributor/rte_distributor_single.c @@ -74,6 +74,10 @@ rte_distributor_return_pkt_single(struct rte_distributor_single *d, union rte_distributor_buffer_single *buf = &d->bufs[worker_id]; uint64_t req = (((int64_t)(uintptr_t)oldpkt) << RTE_DISTRIB_FLAG_BITS) | RTE_DISTRIB_RETURN_BUF; + while (unlikely(__atomic_load_n(&buf->bufptr64, __ATOMIC_RELAXED) + & RTE_DISTRIB_FLAGS_MASK)) + rte_pause(); + /* Sync with distributor on RETURN_BUF flag. */ __atomic_store_n(&(buf->bufptr64), req, __ATOMIC_RELEASE); return 0; -- 2.17.1