From patchwork Sat Jan 22 17:02:35 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Naga Harish K, S V" X-Patchwork-Id: 106231 X-Patchwork-Delegate: jerinj@marvell.com Return-Path: X-Original-To: patchwork@inbox.dpdk.org Delivered-To: patchwork@inbox.dpdk.org Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id DFD8FA00C4; Sat, 22 Jan 2022 18:02:55 +0100 (CET) Received: from [217.70.189.124] (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 65F8D40141; Sat, 22 Jan 2022 18:02:55 +0100 (CET) Received: from mga11.intel.com (mga11.intel.com [192.55.52.93]) by mails.dpdk.org (Postfix) with ESMTP id B4C9C40040 for ; Sat, 22 Jan 2022 18:02:53 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1642870973; x=1674406973; h=from:to:cc:subject:date:message-id:mime-version: content-transfer-encoding; bh=pO8cEaZ8wy4JhtjQUOFk0kOPaYFl15gTgOO89FI55fA=; b=XhC2t2gGe+GzJsD1AzBl02tGZ92N+LHUI9onxCiy8oB6yqHxOeFUNHwT z6Yjm/MN3d0NIT8xTUWOEHV0sdgJV/iGdWEu/j+aF3+JASwyNHiuch702 758ANxqnXV/AzFzo87ynyVhbwLo8Ht23wF1vYdsCfW7x1TTfdfLKzMVsn 4aOTakl+VY4qMcrZ29p1xZ22yQfL3FgndxqeswMdinpnyvkr0C/6N8OY4 3zO+C2Yi26+TzKJEnBRVHqlRicgx5bVYjgQGUgaguAvNTRhpVaph8ebfU h+yjpUzpiZdkJv6TLktSghLz7KleRrF2QX3kUTH5YwHUtncfeoNXXaIBX w==; X-IronPort-AV: E=McAfee;i="6200,9189,10234"; a="243430287" X-IronPort-AV: E=Sophos;i="5.88,308,1635231600"; d="scan'208";a="243430287" Received: from orsmga008.jf.intel.com ([10.7.209.65]) by fmsmga102.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 22 Jan 2022 09:02:52 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.88,308,1635231600"; d="scan'208";a="533675556" Received: from txandevlnx322.an.intel.com ([10.123.117.44]) by orsmga008.jf.intel.com with ESMTP; 22 Jan 2022 09:02:51 -0800 From: Naga Harish K S V To: jerinjacobk@gmail.com, jay.jayatheerthan@intel.com Cc: dev@dpdk.org Subject: [PATCH v2] eventdev/rx_adapter: add event port get api Date: Sat, 22 Jan 2022 11:02:35 -0600 Message-Id: <20220122170235.875481-1-s.v.naga.harish.k@intel.com> X-Mailer: git-send-email 2.23.0 MIME-Version: 1.0 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 This patch introduces new api for retrieving event port id of eth rx adapter. Signed-off-by: Naga Harish K S V Acked-by: Jay Jayatheerthan --- doc/guides/rel_notes/release_22_03.rst | 2 ++ lib/eventdev/rte_event_eth_rx_adapter.c | 20 ++++++++++++++++++++ lib/eventdev/rte_event_eth_rx_adapter.h | 20 ++++++++++++++++++++ lib/eventdev/version.map | 3 +++ 4 files changed, 45 insertions(+) diff --git a/doc/guides/rel_notes/release_22_03.rst b/doc/guides/rel_notes/release_22_03.rst index 6d99d1eaa9..288d94c0e6 100644 --- a/doc/guides/rel_notes/release_22_03.rst +++ b/doc/guides/rel_notes/release_22_03.rst @@ -83,6 +83,8 @@ API Changes This section is a comment. Do not overwrite or remove it. Also, make sure to start the actual text at the margin. ======================================================= +* eventdev: Added new API ``rte_event_eth_rx_adapter_event_port_get``, + to retrieve event port id of eth rx adapter. ABI Changes diff --git a/lib/eventdev/rte_event_eth_rx_adapter.c b/lib/eventdev/rte_event_eth_rx_adapter.c index f946137b25..ae1e260c08 100644 --- a/lib/eventdev/rte_event_eth_rx_adapter.c +++ b/lib/eventdev/rte_event_eth_rx_adapter.c @@ -3123,6 +3123,26 @@ rte_event_eth_rx_adapter_service_id_get(uint8_t id, uint32_t *service_id) return rx_adapter->service_inited ? 0 : -ESRCH; } +int +rte_event_eth_rx_adapter_event_port_get(uint8_t id, uint8_t *event_port_id) +{ + struct event_eth_rx_adapter *rx_adapter; + + if (rxa_memzone_lookup()) + return -ENOMEM; + + RTE_EVENT_ETH_RX_ADAPTER_ID_VALID_OR_ERR_RET(id, -EINVAL); + + rx_adapter = rxa_id_to_adapter(id); + if (rx_adapter == NULL || event_port_id == NULL) + return -EINVAL; + + if (rx_adapter->service_inited) + *event_port_id = rx_adapter->event_port_id; + + return rx_adapter->service_inited ? 0 : -ESRCH; +} + int rte_event_eth_rx_adapter_cb_register(uint8_t id, uint16_t eth_dev_id, diff --git a/lib/eventdev/rte_event_eth_rx_adapter.h b/lib/eventdev/rte_event_eth_rx_adapter.h index 9546d792e9..3608a7b2cf 100644 --- a/lib/eventdev/rte_event_eth_rx_adapter.h +++ b/lib/eventdev/rte_event_eth_rx_adapter.h @@ -37,6 +37,7 @@ * - rte_event_eth_rx_adapter_queue_conf_get() * - rte_event_eth_rx_adapter_queue_stats_get() * - rte_event_eth_rx_adapter_queue_stats_reset() + * - rte_event_eth_rx_adapter_event_port_get() * * The application creates an ethernet to event adapter using * rte_event_eth_rx_adapter_create_ext() or rte_event_eth_rx_adapter_create() @@ -684,6 +685,25 @@ rte_event_eth_rx_adapter_queue_stats_reset(uint8_t id, uint16_t eth_dev_id, uint16_t rx_queue_id); +/** + * Retrieve the event port ID of an adapter. If the adapter doesn't use + * a rte_service function, this function returns -ESRCH. + * + * @param id + * Adapter identifier. + * + * @param [out] event_port_id + * A pointer to a uint8_t, to be filled in with the port id. + * + * @return + * - 0: Success + * - <0: Error code on failure, if the adapter doesn't use a rte_service + * function, this function returns -ESRCH. + */ +__rte_experimental +int +rte_event_eth_rx_adapter_event_port_get(uint8_t id, uint8_t *event_port_id); + #ifdef __cplusplus } #endif diff --git a/lib/eventdev/version.map b/lib/eventdev/version.map index ade1f1182e..cd5dada07f 100644 --- a/lib/eventdev/version.map +++ b/lib/eventdev/version.map @@ -105,6 +105,9 @@ EXPERIMENTAL { rte_event_eth_rx_adapter_queue_conf_get; rte_event_eth_rx_adapter_queue_stats_get; rte_event_eth_rx_adapter_queue_stats_reset; + + # added in 22.03 + rte_event_eth_rx_adapter_event_port_get; }; INTERNAL {