From patchwork Wed Jan 22 18:28:06 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Pavan Nikhilesh Bhagavatula X-Patchwork-Id: 65057 Return-Path: X-Original-To: patchwork@inbox.dpdk.org Delivered-To: patchwork@inbox.dpdk.org Received: from dpdk.org (dpdk.org [92.243.14.124]) by inbox.dpdk.org (Postfix) with ESMTP id 9EC37A0532; Wed, 22 Jan 2020 19:28:25 +0100 (CET) Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id 8EC7A2BBD; Wed, 22 Jan 2020 19:28:24 +0100 (CET) Received: from mx0b-0016f401.pphosted.com (mx0a-0016f401.pphosted.com [67.231.148.174]) by dpdk.org (Postfix) with ESMTP id 449AB2A62 for ; Wed, 22 Jan 2020 19:28:23 +0100 (CET) Received: from pps.filterd (m0045849.ppops.net [127.0.0.1]) by mx0a-0016f401.pphosted.com (8.16.0.42/8.16.0.42) with SMTP id 00MIKKYa014371; Wed, 22 Jan 2020 10:28:22 -0800 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=marvell.com; h=from : to : cc : subject : date : message-id : in-reply-to : references : mime-version : content-transfer-encoding : content-type; s=pfpt0818; bh=oFQvUQU1VrW2hnBMWSEsnsHAOjMpJP3mkyqlsKyU3AE=; b=DldP4+a2zYppwyCsvMLrMahBNXd9qH/qmfFoFduJS/+zZefBarNYszB9yzQY8DEWnq5L ewWV7g8PKoUx/6aVNrLQcRQSa/Lp8WWLK9AwvmdlUiASFx+4GcQYW+fC7ZroHkPGMQek 2WDxwfh0K07SWlpDMY1KigDhqZg2ajZFwKdeQu6knMG1nWcK3ZTEMz3uP0USIFNClm95 1b9qogA+jwWGWngAZTx/2D0danWBWD/a1mHfomLwupMRWQreNl9XtzuuIpLVtP9i+WEu sog7tnDNq20mLwjG3+2WA06U6jEer+BMfFSasqw3ViIQuDGrBqPvAlYbJ46tmbSOedF7 Kw== Received: from sc-exch01.marvell.com ([199.233.58.181]) by mx0a-0016f401.pphosted.com with ESMTP id 2xpm901xkb-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-SHA384 bits=256 verify=NOT); Wed, 22 Jan 2020 10:28:22 -0800 Received: from SC-EXCH03.marvell.com (10.93.176.83) by SC-EXCH01.marvell.com (10.93.176.81) with Microsoft SMTP Server (TLS) id 15.0.1497.2; Wed, 22 Jan 2020 10:28:20 -0800 Received: from maili.marvell.com (10.93.176.43) by SC-EXCH03.marvell.com (10.93.176.83) with Microsoft SMTP Server id 15.0.1497.2 via Frontend Transport; Wed, 22 Jan 2020 10:28:20 -0800 Received: from BG-LT7430.marvell.com (unknown [10.28.17.83]) by maili.marvell.com (Postfix) with ESMTP id 43E3A3F7040; Wed, 22 Jan 2020 10:28:19 -0800 (PST) From: To: , CC: , Pavan Nikhilesh Date: Wed, 22 Jan 2020 23:58:06 +0530 Message-ID: <20200122182817.1667-1-pbhagavatula@marvell.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200111134730.5329-1-pbhagavatula@marvell.com> References: <20200111134730.5329-1-pbhagavatula@marvell.com> MIME-Version: 1.0 X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.138, 18.0.572 definitions=2020-01-22_08:2020-01-22, 2020-01-22 signatures=0 Subject: [dpdk-dev] [PATCH v4 00/11] example/l3fwd: introduce event device support 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" From: Pavan Nikhilesh This patchset adds support for event mode in l3fwd. The poll mode is still the default mode of operation. The following new command line parameters are added: --mode: Dictates the mode of operation either poll or event. If unset then by default poll mode is used. --eventq_sched: Dictates event synchronization mode i.e. either ordered, atomic or parallel. --event-eth-rxqs: Number of ethernet RX queues per device. Based on event device capability the configuration is done as follows: - A single event device is enabled. - The number of event ports is equal to the number of worker cores enabled in the core mask. Additional event ports might be configured based on Rx/Tx adapter capability. - The number of event queues is equal to the number of ethernet ports. If Tx adapter doesn't have internal port capability then an additional single link event queue is used to enqueue events to Tx adapter. - Each event port is linked to all existing event queues. - Dedicated Rx/Tx adapters for each Ethernet port. v4 Changes: ---------- - Update documentation about --event-eth-rxqs. (Jerin) - Add validation for command line options that are specific to event/poll mode. - Fix event device service initialization. v3 Changes: ---------- - Unify argument parsing. - Segregate poll mode and event mode initialization. - Simplify event resource creation and accesses. - Integrate http://patches.dpdk.org/project/dpdk/list/?series=8002 series. - Reduce code duplication in lpm. v2 Changes: ---------- - Shorten the structure name `s/event_rsrc/evt_rsrc` `s/l2fwd_rsrc/rsrc`. - Use rte_panic instead of rte_exit. - Rebase on top of Tx adapter change http://patches.dpdk.org/patch/60971. - Add parallel mode support. - Fix missing eventdev args parsing. Pavan Nikhilesh (7): examples/l3fwd: add event device configuration examples/l3fwd: add event eth Rx/Tx adapter setup examples/l3fwd: add service core setup based on caps examples/l3fwd: add event lpm main loop examples/l3fwd: add event em main loop examples/l3fwd: add graceful teardown for eventdevice doc: update l3fwd user guide to support eventdev Sunil Kumar Kori (4): examples/l3fwd: add framework for event device examples/l3fwd: split pipelines based on capability examples/l3fwd: add ethdev setup based on eventdev examples/l3fwd: add event port and queue setup doc/guides/sample_app_ug/l3_forward.rst | 79 ++++- examples/l3fwd/Makefile | 3 +- examples/l3fwd/l3fwd.h | 30 ++ examples/l3fwd/l3fwd_em.c | 177 +++++++++++ examples/l3fwd/l3fwd_em.h | 159 +++++++--- examples/l3fwd/l3fwd_em_hlm.h | 131 ++++++++ examples/l3fwd/l3fwd_em_sequential.h | 26 ++ examples/l3fwd/l3fwd_event.c | 263 ++++++++++++++++ examples/l3fwd/l3fwd_event.h | 86 ++++++ examples/l3fwd/l3fwd_event_generic.c | 303 ++++++++++++++++++ examples/l3fwd/l3fwd_event_internal_port.c | 279 +++++++++++++++++ examples/l3fwd/l3fwd_lpm.c | 203 ++++++++++++ examples/l3fwd/main.c | 341 +++++++++++++++++---- examples/l3fwd/meson.build | 5 +- 14 files changed, 1970 insertions(+), 115 deletions(-) create mode 100644 examples/l3fwd/l3fwd_event.c create mode 100644 examples/l3fwd/l3fwd_event.h create mode 100644 examples/l3fwd/l3fwd_event_generic.c create mode 100644 examples/l3fwd/l3fwd_event_internal_port.c --- 2.17.1