From patchwork Mon Oct 16 21:44:34 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Nipun Gupta X-Patchwork-Id: 30442 Return-Path: X-Original-To: patchwork@dpdk.org Delivered-To: patchwork@dpdk.org Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id 9BDC81B77E; Mon, 16 Oct 2017 17:29:35 +0200 (CEST) Received: from NAM02-BL2-obe.outbound.protection.outlook.com (mail-bl2nam02on0054.outbound.protection.outlook.com [104.47.38.54]) by dpdk.org (Postfix) with ESMTP id 666641B77B for ; Mon, 16 Oct 2017 17:29:32 +0200 (CEST) Received: from MWHPR03CA0010.namprd03.prod.outlook.com (10.175.133.148) by BN3PR03MB2353.namprd03.prod.outlook.com (10.166.74.148) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256) id 15.20.77.7; Mon, 16 Oct 2017 15:29:31 +0000 Received: from BY2FFO11OLC008.protection.gbl (2a01:111:f400:7c0c::194) by MWHPR03CA0010.outlook.office365.com (2603:10b6:300:117::20) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256) id 15.20.77.7 via Frontend Transport; Mon, 16 Oct 2017 15:29:31 +0000 Authentication-Results: spf=fail (sender IP is 192.88.158.2) smtp.mailfrom=nxp.com; NXP1.onmicrosoft.com; dkim=none (message not signed) header.d=none;NXP1.onmicrosoft.com; dmarc=fail action=none header.from=nxp.com; Received-SPF: Fail (protection.outlook.com: domain of nxp.com does not designate 192.88.158.2 as permitted sender) receiver=protection.outlook.com; client-ip=192.88.158.2; helo=az84smr01.freescale.net; Received: from az84smr01.freescale.net (192.88.158.2) by BY2FFO11OLC008.mail.protection.outlook.com (10.1.14.255) with Microsoft SMTP Server (version=TLS1_0, cipher=TLS_RSA_WITH_AES_256_CBC_SHA) id 15.20.77.10 via Frontend Transport; Mon, 16 Oct 2017 15:29:30 +0000 Received: from b27504-OptiPlex-790.ap.freescale.net (b27504-OptiPlex-790.ap.freescale.net [10.232.132.60]) by az84smr01.freescale.net (8.14.3/8.14.0) with ESMTP id v9GFTHP9021125; Mon, 16 Oct 2017 08:29:28 -0700 From: Nipun Gupta To: CC: , , , Nipun Gupta Date: Tue, 17 Oct 2017 03:14:34 +0530 Message-ID: <1508190275-32305-3-git-send-email-nipun.gupta@nxp.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1508190275-32305-1-git-send-email-nipun.gupta@nxp.com> References: <1507657887-11366-1-git-send-email-nipun.gupta@nxp.com> <1508190275-32305-1-git-send-email-nipun.gupta@nxp.com> X-EOPAttributedMessage: 0 X-Matching-Connectors: 131526413708831932; (91ab9b29-cfa4-454e-5278-08d120cd25b8); () X-Forefront-Antispam-Report: CIP:192.88.158.2; IPV:NLI; CTRY:US; EFV:NLI; SFV:NSPM; SFS:(10009020)(6009001)(336005)(39860400002)(346002)(39380400002)(376002)(2980300002)(1109001)(1110001)(339900001)(189002)(199003)(69596002)(8656003)(54906003)(104016004)(498600001)(48376002)(50466002)(16586007)(316002)(5660300001)(86362001)(575784001)(77096006)(5890100001)(68736007)(85426001)(4326008)(81156014)(2950100002)(6916009)(36756003)(81166006)(50226002)(97736004)(8676002)(106466001)(105606002)(47776003)(305945005)(189998001)(53936002)(5003940100001)(6666003)(50986999)(33646002)(8936002)(2906002)(356003)(76176999)(2351001); DIR:OUT; SFP:1101; SCL:1; SRVR:BN3PR03MB2353; H:az84smr01.freescale.net; FPR:; SPF:Fail; PTR:InfoDomainNonexistent; MX:1; A:1; LANG:en; X-Microsoft-Exchange-Diagnostics: 1; BY2FFO11OLC008; 1:MMZWAk9vHSyoPHieJ5ur5wS4xIC6FMpEmm2evsZulJNVBMk9S3YhxoSii/753XrcH+WsNwkPcB3SicYDEgJvGqub3TmNIid7RQuDqC4KL/VavOMEqgzXhggHp2nwo/y9 MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: ec5711c5-17fe-40eb-2cbc-08d514aab229 X-Microsoft-Antispam: UriScan:; BCL:0; PCL:0; RULEID:(22001)(2017052603199)(201703131430075)(201703131517081); SRVR:BN3PR03MB2353; X-Microsoft-Exchange-Diagnostics: 1; BN3PR03MB2353; 3:Qc+JmDhVO/I22Q2E94GzJu0lEHl3J1iSFXgU3evPvr9NtcT14O/PJ5dYKmQ5MkLLhB1E2Ds74Z8gNPOYzgr0wF5dfyvGA08JlciBnncIKCo2kXYdJZ5NSfBF79Vk0+FzMsQiyiMO/i8e0iTxIWFrgN4Lscm7gTaC2gGn4ovoOgpBucJoqTSZXf7ehMg0qKC5nwPgU2DvKk6+TUTSGg6+Y/qxRDzNGbGKz9qAhzgaSq3T+oQ2vu5uRRJN5Q6GLItYaeb/qi4dwARogYTIirE9b57NZVBFcQErR8b9uUhQHf4xwbJ9/Z/uLmyy05KHiY+BPLQhwTTEUv2T/ybJ6yFFv3Sq1UOUtAoqgHoKpN0Uum8=; 25:eTgv8lQB3S7qDXXZqNMt2dUtcxfzuG4CV+8TL+zTY0znVn065mLtkUa0+sHSyR5nkLzaFATvO7iexv3gluwq2XgsCuwuVlc3EaTraPm6akIYX51rwddR8CPa/HVqYBXzc7U0zu5chxFGm2ICy4OYLLJMI6rpogp2JReCbIj5neU/snrmPW3QKBlzTH2n3p2terwyFUDAx+ugUdlssmDviXufD7MILlLsiX7zC8sJaLNr2ivl2cQ5xWs8+pBtNDwP/zyZCkIgO4B9j7wsRCJ9K+U5r1B1vyO415sOulG3BBnzMnvEIJzQ0fXe8xPRDIjC38ujJ42HY2lizpSbppB38Q== X-MS-TrafficTypeDiagnostic: BN3PR03MB2353: X-Microsoft-Exchange-Diagnostics: 1; BN3PR03MB2353; 31:kMPEkYH1Zsy+wrdCxz4o/ZsqMKcRFNppJFgrqQ8swSp0Fl1Rl6vxGRi3LPLgG74mfPU0sUp3218W3IScIw+RFBAJPgo2CVKmWmo5Jb6SuxS7kblKLkeUggF+50eLh+qp9emAsj9a4p9yANs1eQlRAyvCyLvZujCGfIuPqB1r6ZixhqwqfLNGVv7VwHCZ7SKzZoErIwXb9YxNu3ipoqewHwbIX/Hf+lfxwJSt7Jj3mXY=; 4:2JStFUieh0TKwR39CgrLfGuZf3fZTC8Jk5SPOc2WavhGkKdjBEJ9JPmSFVMgNA2FFkYd7NYAJcuwCgSzs395cFyn9l3F93Sn4SFetaSpnoagRq3Kr4TBhOt+2GapSHfrHs8Ew2SmCDUKoRoUqluH6XONp6FLhYNaG58SP1BvHCxakvKVbuotT9uVk0r1av7vmH9pfy+sHMaKWE4YQtWf/kpYMaD0BhNjSUQK8F/Rbxn95k2L1kX9liRx/bBn7qFmmLVjc6WZN67DxwEStFc5iYexv7DeIK42D1ptj6ufpBAF96wJ5O2GJipK0rh5JP2bflyZ7a6hnllNt/g6lBfiiimvCozhauX0r9BNw/henbMWuOvoAI6qLIx9SofTHhfU X-Exchange-Antispam-Report-Test: UriScan:(185117386973197)(275809806118684)(228905959029699); X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(100000700101)(100105000095)(100000701101)(100105300095)(100000702101)(100105100095)(6095135)(2401047)(8121501046)(5005006)(10201501046)(3002001)(93006095)(93001095)(100000703101)(100105400095)(6055026)(6096035)(20161123565025)(201703131430075)(201703131433075)(201703131448075)(201703161259150)(201703151042153)(20161123556025)(20161123561025)(20161123559100)(20161123563025)(201708071742011)(100000704101)(100105200095)(100000705101)(100105500095); SRVR:BN3PR03MB2353; BCL:0; PCL:0; RULEID:(100000800101)(100110000095)(100000801101)(100110300095)(100000802101)(100110100095)(100000803101)(100110400095)(400006)(100000804101)(100110200095)(100000805101)(100110500095); SRVR:BN3PR03MB2353; X-Forefront-PRVS: 0462918D61 X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; BN3PR03MB2353; 23:kkPysmUdWMWshTSaBJ9OvuozsvjdaVal/6TmJ/YV2?= pfyKqXDqGjwMJ5Wbtj0p2UWjEQIzh+crXYEy/AzW2JY0J1prd9GYbMmVgfE0SxUM2AqoJTBEvO4GLA7xxeHm3AtOLkwWkCSdxVmZJCRbdKWnrUNFJ0VueKcFwPa56oVhquxOo5jDhWa6Fbyl5jPSTk93FDnEB/j+oYgaX6ZwJX6s0KtwX0pHcL3n8vUzBUQs+AN9NdOQpdCjE4viUK2aVS7YuzavR4V9iAwLVf3F6xobK+K1LFhG30yYDWZq0yYLLCkwy47mrSF+/ks2DMFyl8dEwcRX29hdsOXXaBXE8ZKMM34Uf65B8iDCfaXyFSRKb8LBGrh6X0zP8Pq66HlywhyBbKUpio0EZjiDIP2C2eNPI4uWbdo7Tpqq60HIRwPWAjHQNuSBGGux6j5hXKG3j4QVUApLj3lk3/dx7I8TQdx4bmFeDkUq3KY/6sMI7laGYyBZz2tLsd/eAd/0FNB9pUZt6kkQKv89TlZ1Ycrb7T7KkNEohnOyAcueIStZ6lCwegMNRVvLPNR7u1XaWA6gyRg+KR9l3qsWw8VEmSRpCh2CAT5BXk+i4Eh5aXY6TwKPfAUgnyvT8CgqTOtT0Z/8UldRdVImQ2avyawq4onj0VEm2jUODI4i0VZdaeNLYiZR63sLjM8QQYGPOEtUDv0MLlVYuthqBXGcXOSQwyDgtmOEXAjuuiSLWz/93z2VlZNmUmFRxr1hmrxHOiuhpTUZP3Etm9n2xfRhBsm4OJm3rwizlVkn4pr6mbsvu2SKC5O4uc4uBCITJAE0WKDFvxqRP7qFmEOw8MNGFxUNtEVc/70G6gq0XyR0uyR18gQzROvDZSA1ZRX4ci8JDsEd0iVLmZKVmCdX+AgPBhjay2gpmPhvRlfqJO4RvpQ0GxvadON6RiiZii6yDXm/tlBO20zkv/+iiUZ3SYxEtoyXLvC4TC0aT5IEADDbhO5zzxnNIc9o0Xkd7MAqxzotelmvYf+hoXjA/oRtLZnAOinLE6HhtFT0iZTChsCM2LDkhkK95evf5I5rCfmwLwuZ15uVoACQMeCTbsy53/H8X0JxO4tUmddY1WYf0Lq8+kCrrtjI3RJZlo0E8vjmO+6dttihRGJA76l5VW5IfYQCeO/2/ra4X8jBvORqIrkBa2de9RiTUSzQjhpqCaEGA5FYzl08uT/4xunHdDUP6hI4ph6zPru6HMl6g== X-Microsoft-Exchange-Diagnostics: 1; BN3PR03MB2353; 6:QRPwV9smCm67MRrChz/PYfoO2voTfIO5SQQ68IoNKMoIDwMKQVMuhWlMppoyP2PAiRKYIfDBACWDKExzqukuJddqpT5DPDNVUpymJsHLqTyheMuZ50HGnDfsJK4noi3o0fB7GvQK+zgwDaojov9nhYJq9FsP3XHDYMmG+STLvFk/LlMh5pcQ1c6dj1IxDaaQI9fyyCXcT8MlhJLT7vt4/kq6AxqynnvmLumsTlsl3LJmVOodNKwoHDD3q15mdHmZ7vI0Ww8QGw+iayC23Xp/Ojfnufnen9QiScenkh0AL7bzPSL5TU5dbC9kpMSxIpABdA0plYXuHMNgvygY9+veQw==; 5:WXQBsTBJA99bLxeIKc6ClMgcXmGMOxcJd6HxwA5Xn5KpU7L898pogwFRaI9/QOg63Nj5BNkk1PxXGoWge04TrOTKHsJEIge699i5K0sEK2BvQEpm/Vftr07I7hcl9p9m1AHr1ht28i/Ec+VQeISc5g==; 24:aans9EbE3lFzIy7jslAS5FeZ/YUcJgGX4smtPWywgXiVa2ibEWLPIzgDDo+MtAV1FFUEmdfCNXpaH8tzNkALYq+pA5FyL6tqgkuZrdWpZ5U=; 7:saxx8vVoetMsZ6Vlfv8+IAkgkPWA3KnP+rxCXTQg0vgjLlLeE0Jxq6wYl2ZMd/EfuTuBvCn3y+l8EyZoseA/8PafIAuSpB9FnxGTY/LKJ6qxX3hUM+y0871+B30HX7ICuKMogxRZpaGZloFx2ZdRM3tu79/XvNZv7QkdHS7aUz+Gw0BCpyv1KUS5tbPWNq7OeFasOYpoQlTCCkFGZHlUvAEOYIU/pfKeiGgKdCzuXzc= SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-MS-Exchange-CrossTenant-OriginalArrivalTime: 16 Oct 2017 15:29:30.7583 (UTC) X-MS-Exchange-CrossTenant-Id: 5afe0b00-7697-4969-b663-5eab37d5f47e X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=5afe0b00-7697-4969-b663-5eab37d5f47e; Ip=[192.88.158.2]; Helo=[az84smr01.freescale.net] X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: BN3PR03MB2353 Subject: [dpdk-dev] [PATCH v3 3/4] event/dpaa2: support event eth adapter 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" Signed-off-by: Nipun Gupta Reviewed-by: Nikhil Rao Acked-by: Hemant Agrawal --- Changes in v3: Fix shared library build Changes in v2: Support rx_queue_id = -1 in eth adapter queue and and del (Nikhil) Remove duplicate returns (Nikhil) drivers/Makefile | 2 +- drivers/event/Makefile | 4 +- drivers/event/dpaa2/Makefile | 2 + drivers/event/dpaa2/dpaa2_eventdev.c | 151 ++++++++++++++++++++++++++++++++++- drivers/event/dpaa2/dpaa2_eventdev.h | 8 ++ 5 files changed, 163 insertions(+), 4 deletions(-) diff --git a/drivers/Makefile b/drivers/Makefile index 0467250..db0cd76 100644 --- a/drivers/Makefile +++ b/drivers/Makefile @@ -39,6 +39,6 @@ DEPDIRS-net := bus mempool DIRS-$(CONFIG_RTE_LIBRTE_CRYPTODEV) += crypto DEPDIRS-crypto := bus mempool DIRS-$(CONFIG_RTE_LIBRTE_EVENTDEV) += event -DEPDIRS-event := bus mempool +DEPDIRS-event := bus mempool net include $(RTE_SDK)/mk/rte.subdir.mk diff --git a/drivers/event/Makefile b/drivers/event/Makefile index d09be74..e119d60 100644 --- a/drivers/event/Makefile +++ b/drivers/event/Makefile @@ -31,7 +31,7 @@ include $(RTE_SDK)/mk/rte.vars.mk -core-libs := librte_eal librte_eventdev +core-libs := librte_eal librte_ether librte_eventdev DIRS-$(CONFIG_RTE_LIBRTE_PMD_SKELETON_EVENTDEV) += skeleton DEPDIRS-skeleton = $(core-libs) @@ -40,6 +40,6 @@ DEPDIRS-sw = $(core-libs) librte_kvargs librte_ring DIRS-$(CONFIG_RTE_LIBRTE_PMD_OCTEONTX_SSOVF) += octeontx DEPDIRS-octeontx = $(core-libs) librte_mempool_octeontx DIRS-$(CONFIG_RTE_LIBRTE_PMD_DPAA2_EVENTDEV) += dpaa2 -DEPDIRS-dpaa2 = $(core-libs) librte_bus_fslmc +DEPDIRS-dpaa2 = $(core-libs) librte_bus_fslmc librte_pmd_dpaa2 include $(RTE_SDK)/mk/rte.subdir.mk diff --git a/drivers/event/dpaa2/Makefile b/drivers/event/dpaa2/Makefile index 3497d09..2d1d7c4 100644 --- a/drivers/event/dpaa2/Makefile +++ b/drivers/event/dpaa2/Makefile @@ -45,6 +45,8 @@ CFLAGS += -I$(RTE_SDK)/drivers/bus/fslmc/portal CFLAGS += -I$(RTE_SDK)/drivers/mempool/dpaa2 CFLAGS += -I$(RTE_SDK)/drivers/event/dpaa2 CFLAGS += -I$(RTE_SDK)/lib/librte_eal/linuxapp/eal +CFLAGS += -I$(RTE_SDK)/drivers/net/dpaa2 +CFLAGS += -I$(RTE_SDK)/drivers/net/dpaa2/mc # versioning export map EXPORT_MAP := rte_pmd_dpaa2_event_version.map diff --git a/drivers/event/dpaa2/dpaa2_eventdev.c b/drivers/event/dpaa2/dpaa2_eventdev.c index 8a6a3e3..ee3a164 100644 --- a/drivers/event/dpaa2/dpaa2_eventdev.c +++ b/drivers/event/dpaa2/dpaa2_eventdev.c @@ -53,11 +53,14 @@ #include #include #include +#include +#include #include #include #include #include +#include #include "dpaa2_eventdev.h" #include #include @@ -557,6 +560,147 @@ static void dpaa2_eventdev_process_atomic(struct qbman_swp *swp, RTE_SET_USED(f); } +static int +dpaa2_eventdev_eth_caps_get(const struct rte_eventdev *dev, + const struct rte_eth_dev *eth_dev, + uint32_t *caps) +{ + const char *ethdev_driver = eth_dev->device->driver->name; + + PMD_DRV_FUNC_TRACE(); + + RTE_SET_USED(dev); + + if (!strcmp(ethdev_driver, "net_dpaa2")) + *caps = RTE_EVENT_ETH_RX_ADAPTER_DPAA2_CAP; + else + *caps = RTE_EVENT_ETH_RX_ADAPTER_SW_CAP; + + return 0; +} + +static int +dpaa2_eventdev_eth_queue_add_all(const struct rte_eventdev *dev, + const struct rte_eth_dev *eth_dev, + const struct rte_event_eth_rx_adapter_queue_conf *queue_conf) +{ + struct dpaa2_eventdev *priv = dev->data->dev_private; + uint8_t ev_qid = queue_conf->ev.queue_id; + uint16_t dpcon_id = priv->evq_info[ev_qid].dpcon->dpcon_id; + int i, ret; + + PMD_DRV_FUNC_TRACE(); + + for (i = 0; i < eth_dev->data->nb_rx_queues; i++) { + ret = dpaa2_eth_eventq_attach(eth_dev, i, + dpcon_id, queue_conf); + if (ret) { + PMD_DRV_ERR("dpaa2_eth_eventq_attach failed: ret %d\n", + ret); + goto fail; + } + } + return 0; +fail: + for (i = (i - 1); i >= 0 ; i--) + dpaa2_eth_eventq_detach(eth_dev, i); + + return ret; +} + +static int +dpaa2_eventdev_eth_queue_add(const struct rte_eventdev *dev, + const struct rte_eth_dev *eth_dev, + int32_t rx_queue_id, + const struct rte_event_eth_rx_adapter_queue_conf *queue_conf) +{ + struct dpaa2_eventdev *priv = dev->data->dev_private; + uint8_t ev_qid = queue_conf->ev.queue_id; + uint16_t dpcon_id = priv->evq_info[ev_qid].dpcon->dpcon_id; + int ret; + + PMD_DRV_FUNC_TRACE(); + + if (rx_queue_id == -1) + return dpaa2_eventdev_eth_queue_add_all(dev, + eth_dev, queue_conf); + + ret = dpaa2_eth_eventq_attach(eth_dev, rx_queue_id, + dpcon_id, queue_conf); + if (ret) { + PMD_DRV_ERR("dpaa2_eth_eventq_attach failed: ret: %d\n", ret); + return ret; + } + return 0; +} + +static int +dpaa2_eventdev_eth_queue_del_all(const struct rte_eventdev *dev, + const struct rte_eth_dev *eth_dev) +{ + int i, ret; + + PMD_DRV_FUNC_TRACE(); + + RTE_SET_USED(dev); + + for (i = 0; i < eth_dev->data->nb_rx_queues; i++) { + ret = dpaa2_eth_eventq_detach(eth_dev, i); + if (ret) { + PMD_DRV_ERR("dpaa2_eth_eventq_detach failed: ret %d\n", + ret); + return ret; + } + } + + return 0; +} + +static int +dpaa2_eventdev_eth_queue_del(const struct rte_eventdev *dev, + const struct rte_eth_dev *eth_dev, + int32_t rx_queue_id) +{ + int ret; + + PMD_DRV_FUNC_TRACE(); + + if (rx_queue_id == -1) + return dpaa2_eventdev_eth_queue_del_all(dev, eth_dev); + + ret = dpaa2_eth_eventq_detach(eth_dev, rx_queue_id); + if (ret) { + PMD_DRV_ERR("dpaa2_eth_eventq_detach failed: ret: %d\n", ret); + return ret; + } + + return 0; +} + +static int +dpaa2_eventdev_eth_start(const struct rte_eventdev *dev, + const struct rte_eth_dev *eth_dev) +{ + PMD_DRV_FUNC_TRACE(); + + RTE_SET_USED(dev); + RTE_SET_USED(eth_dev); + + return 0; +} + +static int +dpaa2_eventdev_eth_stop(const struct rte_eventdev *dev, + const struct rte_eth_dev *eth_dev) +{ + PMD_DRV_FUNC_TRACE(); + + RTE_SET_USED(dev); + RTE_SET_USED(eth_dev); + + return 0; +} + static const struct rte_eventdev_ops dpaa2_eventdev_ops = { .dev_infos_get = dpaa2_eventdev_info_get, .dev_configure = dpaa2_eventdev_configure, @@ -572,7 +716,12 @@ static void dpaa2_eventdev_process_atomic(struct qbman_swp *swp, .port_link = dpaa2_eventdev_port_link, .port_unlink = dpaa2_eventdev_port_unlink, .timeout_ticks = dpaa2_eventdev_timeout_ticks, - .dump = dpaa2_eventdev_dump + .dump = dpaa2_eventdev_dump, + .eth_rx_adapter_caps_get = dpaa2_eventdev_eth_caps_get, + .eth_rx_adapter_queue_add = dpaa2_eventdev_eth_queue_add, + .eth_rx_adapter_queue_del = dpaa2_eventdev_eth_queue_del, + .eth_rx_adapter_start = dpaa2_eventdev_eth_start, + .eth_rx_adapter_stop = dpaa2_eventdev_eth_stop, }; static int diff --git a/drivers/event/dpaa2/dpaa2_eventdev.h b/drivers/event/dpaa2/dpaa2_eventdev.h index f79f78a..ae8e07e 100644 --- a/drivers/event/dpaa2/dpaa2_eventdev.h +++ b/drivers/event/dpaa2/dpaa2_eventdev.h @@ -74,6 +74,14 @@ enum { DPAA2_EVENT_DPCI_MAX_QUEUES }; +#define RTE_EVENT_ETH_RX_ADAPTER_DPAA2_CAP \ + (RTE_EVENT_ETH_RX_ADAPTER_CAP_INTERNAL_PORT | \ + RTE_EVENT_ETH_RX_ADAPTER_CAP_MULTI_EVENTQ | \ + RTE_EVENT_ETH_RX_ADAPTER_CAP_OVERRIDE_FLOW_ID) +/**< Ethernet Rx adapter cap to return If the packet transfers from + * the ethdev to eventdev with DPAA2 devices. + */ + struct dpaa2_dpcon_dev { TAILQ_ENTRY(dpaa2_dpcon_dev) next; struct fsl_mc_io dpcon;