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 0706BA04DB; Sat, 17 Oct 2020 05:09:51 +0200 (CEST) Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id 4CF7AE2B9; Sat, 17 Oct 2020 05:07:58 +0200 (CEST) Received: from mailout1.w1.samsung.com (mailout1.w1.samsung.com [210.118.77.11]) by dpdk.org (Postfix) with ESMTP id EB466E2A9 for ; Sat, 17 Oct 2020 05:07:37 +0200 (CEST) Received: from eucas1p2.samsung.com (unknown [182.198.249.207]) by mailout1.w1.samsung.com (KnoxPortal) with ESMTP id 20201017030722euoutp01a0f050b9eb09c56990632f0d940d0faf~_qLvQ2TXM1627716277euoutp01W for ; Sat, 17 Oct 2020 03:07:22 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 mailout1.w1.samsung.com 20201017030722euoutp01a0f050b9eb09c56990632f0d940d0faf~_qLvQ2TXM1627716277euoutp01W DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=samsung.com; s=mail20170921; t=1602904042; bh=/u5EAfeiJ4p2Br7ASyxtneecnI0wj90it9BSaT4EZOE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=f5lKbw0D3eYs56e3Q5KC4jiNkQC9NhmDg0JyJCHxDgAB2Q76XxzljoylAHBSHSoFN faCpcPKWs1uRSJkSzgjPEyzoajzBf7Sfj0Zo8turIBe6Vso4icZq17rgMGbyoU8P6q pe9D+j13j5MKdEGq0MvUiLkvdG5VqS9LPVB91LMc= Received: from eusmges1new.samsung.com (unknown [203.254.199.242]) by eucas1p2.samsung.com (KnoxPortal) with ESMTP id 20201017030712eucas1p2eee90905a943ebe0e3d3f405737026f0~_qLmI-jFV2935829358eucas1p2r; Sat, 17 Oct 2020 03:07:12 +0000 (GMT) Received: from eucas1p1.samsung.com ( [182.198.249.206]) by eusmges1new.samsung.com (EUCPMTA) with SMTP id 97.E8.06456.0EF5A8F5; Sat, 17 Oct 2020 04:07:12 +0100 (BST) Received: from eusmtrp2.samsung.com (unknown [182.198.249.139]) by eucas1p1.samsung.com (KnoxPortal) with ESMTPA id 20201017030711eucas1p14855de461cd9d6a4fd3e4bac031b53e5~_qLlxt_RR0896808968eucas1p1r; Sat, 17 Oct 2020 03:07:11 +0000 (GMT) Received: from eusmgms1.samsung.com (unknown [182.198.249.179]) by eusmtrp2.samsung.com (KnoxPortal) with ESMTP id 20201017030711eusmtrp28a1358fec5ba86bb9aaac463d330f3a8~_qLlxOoD-2813028130eusmtrp2L; Sat, 17 Oct 2020 03:07:11 +0000 (GMT) X-AuditID: cbfec7f2-7efff70000001938-2a-5f8a5fe07073 Received: from eusmtip1.samsung.com ( [203.254.199.221]) by eusmgms1.samsung.com (EUCPMTA) with SMTP id 6A.99.06314.FDF5A8F5; Sat, 17 Oct 2020 04:07:11 +0100 (BST) Received: from localhost.localdomain (unknown [106.210.88.70]) by eusmtip1.samsung.com (KnoxPortal) with ESMTPA id 20201017030711eusmtip17c37a8e298927a8a3035ece16f2a83a5~_qLlO1MPo3071330713eusmtip1F; Sat, 17 Oct 2020 03:07:11 +0000 (GMT) From: Lukasz Wojciechowski To: David Hunt , Bruce Richardson Cc: dev@dpdk.org, l.wojciechow@partner.samsung.com, stable@dpdk.org Date: Sat, 17 Oct 2020 05:06:47 +0200 Message-Id: <20201017030701.16134-4-l.wojciechow@partner.samsung.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20201017030701.16134-1-l.wojciechow@partner.samsung.com> X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFnrMIsWRmVeSWpSXmKPExsWy7djPc7oP4rviDU5M4LC4screom/SRyaL d5+2M1k861nHaPGv4w+7A6vHrwVLWT0W73nJ5HHw3R6mAOYoLpuU1JzMstQifbsEroy/G2Yz FjxQqTh2dCFTA+M52S5GTg4JAROJx4tXMXcxcnEICaxglPh9Zw4LSEJI4AujxIoZuRD2Z0aJ G1vUYRqOz/sE1bCcUWLLrP8sEA5Q0ZErbxhBqtgEbCWOzPzKCmKLCIRJNDfvBSri4GAWcJZ4 8pUNJCws4CFxZfUWJpAwi4CqxP22EpAwr4CrxKx3p9ghdslLrN5wgBmkhFPATaLxuCvIJgmB 62wS/xZvZAeJSwi4SLy8wwJRLizx6vgWqFYZif875zNB1G9jlLj6+ycjhLOfUeJ67wqoKmuJ w/9+s0Gcpimxfpc+RNhR4kTLJTaI+XwSN94KgoSZgcxJ26YzQ4R5JTrahCCq9SSe9kxlhFn7 Z+0TqHM8JDZ0HWWHBM5VRon2WacYJzDKz0JYtoCRcRWjeGppcW56arFhXmq5XnFibnFpXrpe cn7uJkZg1J/+d/zTDsavl5IOMQpwMCrx8HIs7YwXYk0sK67MPcQowcGsJMLrdPZ0nBBvSmJl VWpRfnxRaU5q8SFGaQ4WJXFe40UvY4UE0hNLUrNTUwtSi2CyTBycUg2M07/83mR/NPricYkn CldvcT/Y82Ff45nsJR/47qs1LJkvPu39BoZloYt6g/mqNr0I6Koq05kSMmti5d9fEwKOXbQQ 7Tc2YXmmx3Zd9ZCi4Z0tnM5CJ8yTfn7XETSXmxEe3r7p4JTD55xOLDWyvHecrf3jhCUTww4V GryuuSb/S2hDSOjOA11qK5RYijMSDbWYi4oTAYzxltz2AgAA X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFjrKLMWRmVeSWpSXmKPExsVy+t/xu7r347viDWZN1be4screom/SRyaL d5+2M1k861nHaPGv4w+7A6vHrwVLWT0W73nJ5HHw3R6mAOYoPZui/NKSVIWM/OISW6VoQwsj PUNLCz0jE0s9Q2PzWCsjUyV9O5uU1JzMstQifbsEvYy/G2YzFjxQqTh2dCFTA+M52S5GTg4J AROJ4/M+MYPYQgJLGSWOfM/uYuQAistIfLgkAFEiLPHnWhdbFyMXUMlHRond13exgCTYBGwl jsz8ygpSLyIQJnFipT9ImFnAXWLL4qlgI4UFPCSurN7CBFLCIqAqcb+tBCTMK+AqMevdKXaI 8fISqzccYAYp4RRwk2g87gqxqZFR4uysdSwTGPkWMDKsYhRJLS3OTc8tNtQrTswtLs1L10vO z93ECAzCbcd+bt7BeGlj8CFGAQ5GJR7eDYs644VYE8uKK3MPMUpwMCuJ8DqdPR0nxJuSWFmV WpQfX1Sak1p8iNEU6KaJzFKiyfnACMkriTc0NTS3sDQ0NzY3NrNQEuftEDgYIySQnliSmp2a WpBaBNPHxMEp1cDYbWEy87tU3+r8boPGnW5rvrzhkRG8G1bBfMo5oO31FVvPbhcxa4b/HV/+ NPkaLVCMcs0Wlcq452P7o3DZbpeOM4vsp+4RiVHhcjnRcZTrztTnR5fJnBc+mFzzYomAmw1v Tt9ar0zHlFvbe1c/mcoc3LuL87La1y7Wm10z/727vrrnpoTPHX0lluKMREMt5qLiRADykp4Q WAIAAA== X-CMS-MailID: 20201017030711eucas1p14855de461cd9d6a4fd3e4bac031b53e5 X-Msg-Generator: CA Content-Type: text/plain; charset="utf-8" X-RootMTR: 20201017030711eucas1p14855de461cd9d6a4fd3e4bac031b53e5 X-EPHeader: CA CMS-TYPE: 201P X-CMS-RootMailID: 20201017030711eucas1p14855de461cd9d6a4fd3e4bac031b53e5 References: <20201010160508.19709-1-l.wojciechow@partner.samsung.com> <20201017030701.16134-1-l.wojciechow@partner.samsung.com> Subject: [dpdk-dev] [PATCH v8 03/17] distributor: do not use oldpkt when not needed 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_request_pkt and rte_distributor_get_pkt dereferenced oldpkt parameter when in RTE_DIST_ALG_SINGLE even if number of returned buffers from worker to distributor was 0. This patch passes NULL to the legacy API when number of returned buffers is 0. This allows passing NULL as oldpkt parameter. Distributor tests are also updated passing NULL as oldpkt and 0 as number of returned packets, where packets are not returned. 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 --- app/test/test_distributor.c | 28 +++++++++--------------- lib/librte_distributor/rte_distributor.c | 4 ++-- 2 files changed, 12 insertions(+), 20 deletions(-) diff --git a/app/test/test_distributor.c b/app/test/test_distributor.c index ba1f81cf8..52230d250 100644 --- a/app/test/test_distributor.c +++ b/app/test/test_distributor.c @@ -62,13 +62,10 @@ handle_work(void *arg) struct rte_mbuf *buf[8] __rte_cache_aligned; struct worker_params *wp = arg; struct rte_distributor *db = wp->dist; - unsigned int count = 0, num = 0; + unsigned int count = 0, num; unsigned int id = __atomic_fetch_add(&worker_idx, 1, __ATOMIC_RELAXED); - int i; - for (i = 0; i < 8; i++) - buf[i] = NULL; - num = rte_distributor_get_pkt(db, id, buf, buf, num); + num = rte_distributor_get_pkt(db, id, buf, NULL, 0); while (!quit) { __atomic_fetch_add(&worker_stats[id].handled_packets, num, __ATOMIC_RELAXED); @@ -272,19 +269,16 @@ handle_work_with_free_mbufs(void *arg) struct rte_distributor *d = wp->dist; unsigned int count = 0; unsigned int i; - unsigned int num = 0; + unsigned int num; unsigned int id = __atomic_fetch_add(&worker_idx, 1, __ATOMIC_RELAXED); - for (i = 0; i < 8; i++) - buf[i] = NULL; - num = rte_distributor_get_pkt(d, id, buf, buf, num); + num = rte_distributor_get_pkt(d, id, buf, NULL, 0); while (!quit) { worker_stats[id].handled_packets += num; count += num; for (i = 0; i < num; i++) rte_pktmbuf_free(buf[i]); - num = rte_distributor_get_pkt(d, - id, buf, buf, num); + num = rte_distributor_get_pkt(d, id, buf, NULL, 0); } worker_stats[id].handled_packets += num; count += num; @@ -342,14 +336,14 @@ handle_work_for_shutdown_test(void *arg) struct worker_params *wp = arg; struct rte_distributor *d = wp->dist; unsigned int count = 0; - unsigned int num = 0; + unsigned int num; unsigned int total = 0; unsigned int i; unsigned int returned = 0; const unsigned int id = __atomic_fetch_add(&worker_idx, 1, __ATOMIC_RELAXED); - num = rte_distributor_get_pkt(d, id, buf, buf, num); + num = rte_distributor_get_pkt(d, id, buf, NULL, 0); /* wait for quit single globally, or for worker zero, wait * for zero_quit */ @@ -358,8 +352,7 @@ handle_work_for_shutdown_test(void *arg) count += num; for (i = 0; i < num; i++) rte_pktmbuf_free(buf[i]); - num = rte_distributor_get_pkt(d, - id, buf, buf, num); + num = rte_distributor_get_pkt(d, id, buf, NULL, 0); total += num; } worker_stats[id].handled_packets += num; @@ -373,14 +366,13 @@ handle_work_for_shutdown_test(void *arg) while (zero_quit) usleep(100); - num = rte_distributor_get_pkt(d, - id, buf, buf, num); + num = rte_distributor_get_pkt(d, id, buf, NULL, 0); while (!quit) { worker_stats[id].handled_packets += num; count += num; rte_pktmbuf_free(pkt); - num = rte_distributor_get_pkt(d, id, buf, buf, num); + num = rte_distributor_get_pkt(d, id, buf, NULL, 0); } returned = rte_distributor_return_pkt(d, id, buf, num); diff --git a/lib/librte_distributor/rte_distributor.c b/lib/librte_distributor/rte_distributor.c index d6d4350a2..93c90cf54 100644 --- a/lib/librte_distributor/rte_distributor.c +++ b/lib/librte_distributor/rte_distributor.c @@ -42,7 +42,7 @@ rte_distributor_request_pkt(struct rte_distributor *d, if (unlikely(d->alg_type == RTE_DIST_ALG_SINGLE)) { rte_distributor_request_pkt_single(d->d_single, - worker_id, oldpkt[0]); + worker_id, count ? oldpkt[0] : NULL); return; } @@ -134,7 +134,7 @@ rte_distributor_get_pkt(struct rte_distributor *d, if (unlikely(d->alg_type == RTE_DIST_ALG_SINGLE)) { if (return_count <= 1) { pkts[0] = rte_distributor_get_pkt_single(d->d_single, - worker_id, oldpkt[0]); + worker_id, return_count ? oldpkt[0] : NULL); return (pkts[0]) ? 1 : 0; } else return -EINVAL; -- 2.17.1